Data D: {{ $data.d.value }}
All Data: {{ $data }}
-i18n hello: {{ i18n "hello" . }}
+i18n hello1: {{ i18n "hello1" . }}
i18n theme: {{ i18n "theme" . }}
i18n theme2: {{ i18n "theme2" . }}
`)
b.WithSourceFile("themes/d/data/d.toml", `value="Hugo Rodks!"`)
// i18n files
- b.WithSourceFile("i18n/en.toml", i18nContent("hello", "Project"))
- b.WithSourceFile("themes/c/en.toml", i18nContent("hello", "Theme C"))
- b.WithSourceFile("themes/c/i18n/en.toml", i18nContent("theme", "Theme C"))
+ b.WithSourceFile("i18n/en.toml", i18nContent("hello1", "Project"))
+ b.WithSourceFile("themes/c/i18n/en.toml", `
+[hello1]
+other="Theme C Hello"
+[theme]
+other="Theme C"
+`)
b.WithSourceFile("themes/d/i18n/en.toml", i18nContent("theme", "Theme D"))
b.WithSourceFile("themes/d/i18n/en.toml", i18nContent("theme2", "Theme2 D"))
// i18n
b.AssertFileContent("public/index.html",
- "i18n hello: Project",
+ "i18n hello1: Project",
"i18n theme: Theme C",
"i18n theme2: Theme2 D",
)
}
var newLangs []string
- for _, dir := range d.BaseFs.I18n.Dirs {
+ // The source dirs are ordered so the most important comes first. Since this is a
+ // last key win situation, we have to reverse the iteration order.
+ dirs := d.BaseFs.I18n.Dirs
+ for i := len(dirs) - 1; i >= 0; i-- {
+ dir := dirs[i]
src := spec.NewFilesystemFromFileMetaInfo(dir)
files, err := src.Files()
language.RegisterPluralSpec(newLangs, en)
}
- // The source files are ordered so the most important comes first. Since this is a
- // last key win situation, we have to reverse the iteration order.
- for i := len(files) - 1; i >= 0; i-- {
- if err := addTranslationFile(i18nBundle, files[i]); err != nil {
+ for _, file := range files {
+ if err := addTranslationFile(i18nBundle, file); err != nil {
return err
}
}