Fix page names that contain dot
authorPrashant Karmakar <webster15july@gmail.com>
Tue, 1 Nov 2016 13:18:24 +0000 (18:48 +0530)
committerBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Tue, 1 Nov 2016 13:18:24 +0000 (14:18 +0100)
changes:
    - in hugolib/page.go, `func permalink` and `func TargetPath`
      Fixed the attempt to *replace* the extension of something
      that was *already* a basename.
    - in source/file.go, `func NewFile`
      added check for allowed languages before translating filename

Fixes #2555

hugolib/page.go
source/file.go

index 111cb52bd635a2337000fcb8eb0e894cc5e0b3f5..79889cd3f4c4c72575da001ac95626810ae85856 100644 (file)
@@ -586,7 +586,7 @@ func (p *Page) permalink() (*url.URL, error) {
                        permalink = helpers.URLPrep(viper.GetBool("uglyURLs"), path.Join(dir, p.Slug+"."+p.Extension()))
                } else {
                        t := p.Source.TranslationBaseName()
-                       permalink = helpers.URLPrep(viper.GetBool("uglyURLs"), path.Join(dir, helpers.ReplaceExtension(strings.TrimSpace(t), p.Extension())))
+                       permalink = helpers.URLPrep(viper.GetBool("uglyURLs"), path.Join(dir, (strings.TrimSpace(t)+"."+p.Extension())))
                }
        }
 
@@ -1163,7 +1163,7 @@ func (p *Page) TargetPath() (outfile string) {
                outfile = strings.TrimSpace(p.Slug) + "." + p.Extension()
        } else {
                // Fall back to filename
-               outfile = helpers.ReplaceExtension(p.Source.TranslationBaseName(), p.Extension())
+               outfile = (p.Source.TranslationBaseName() + "." + p.Extension())
        }
 
        return p.addLangFilepathPrefix(filepath.Join(strings.ToLower(
index 7e3e7d7c4cdbc8cb355fb3fcc4ae94bdc562a029..c309bbd03026aac57f5b67b3930fca281cd9bdae 100644 (file)
@@ -126,11 +126,14 @@ func NewFile(relpath string) *File {
        f.ext = strings.TrimPrefix(filepath.Ext(f.LogicalName()), ".")
        f.baseName = helpers.Filename(f.LogicalName())
 
-       f.lang = strings.TrimPrefix(filepath.Ext(f.baseName), ".")
-       if f.lang == "" {
+       lang := strings.TrimPrefix(filepath.Ext(f.baseName), ".")
+       if _, ok := viper.GetStringMap("languages")[lang]; lang == "" || !ok {
                f.lang = viper.GetString("defaultContentLanguage")
+               f.translationBaseName = f.baseName
+       } else {
+               f.lang = lang
+               f.translationBaseName = helpers.Filename(f.baseName)
        }
-       f.translationBaseName = helpers.Filename(f.baseName)
 
        f.section = helpers.GuessSection(f.Dir())
        f.uniqueID = helpers.Md5String(f.LogicalName())