diff options
author | Bjørn Erik Pedersen <[email protected]> | 2017-05-30 19:07:01 +0300 |
---|---|---|
committer | Bjørn Erik Pedersen <[email protected]> | 2017-05-30 19:29:55 +0300 |
commit | 4aff2b6e7409a308f30cff1825fec02991e0d56a (patch) | |
tree | 85a04d45a7d008ca56b89e0015be99946a644bed /source | |
parent | 2342df4d2dcc2f253865e317c1026c5cb673fa54 (diff) | |
download | hugo-4aff2b6e7409a308f30cff1825fec02991e0d56a.tar.gz hugo-4aff2b6e7409a308f30cff1825fec02991e0d56a.zip |
source: Cache language config
```
benchmark old ns/op new ns/op delta
BenchmarkSiteBuilding/frontmatter=YAML|num_root_sections=1|num_pages=5000|tags_per_page=0|shortcodes=false|render=false-4 552742744 501838152 -9.21%
benchmark old allocs new allocs delta
BenchmarkSiteBuilding/frontmatter=YAML|num_root_sections=1|num_pages=5000|tags_per_page=0|shortcodes=false|render=false-4 3047393 2957378 -2.95%
benchmark old bytes new bytes delta
BenchmarkSiteBuilding/frontmatter=YAML|num_root_sections=1|num_pages=5000|tags_per_page=0|shortcodes=false|render=false-4 356533864 354291924 -0.63%
```
Diffstat (limited to 'source')
-rw-r--r-- | source/file.go | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/source/file.go b/source/file.go index 1dff9ac0b..13352429e 100644 --- a/source/file.go +++ b/source/file.go @@ -27,10 +27,15 @@ import ( type SourceSpec struct { Cfg config.Provider Fs *hugofs.Fs + + languages map[string]interface{} + defaultContentLanguage string } func NewSourceSpec(cfg config.Provider, fs *hugofs.Fs) SourceSpec { - return SourceSpec{Cfg: cfg, Fs: fs} + defaultLang := cfg.GetString("defaultContentLanguage") + languages := cfg.GetStringMap("languages") + return SourceSpec{Cfg: cfg, Fs: fs, languages: languages, defaultContentLanguage: defaultLang} } // File represents a source content file. @@ -139,8 +144,8 @@ func (sp SourceSpec) NewFile(relpath string) *File { f.baseName = helpers.Filename(f.LogicalName()) lang := strings.TrimPrefix(filepath.Ext(f.baseName), ".") - if _, ok := sp.Cfg.GetStringMap("languages")[lang]; lang == "" || !ok { - f.lang = sp.Cfg.GetString("defaultContentLanguage") + if _, ok := sp.languages[lang]; lang == "" || !ok { + f.lang = sp.defaultContentLanguage f.translationBaseName = f.baseName } else { f.lang = lang |