hugolib: Revise paginator alias path handling
authorBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Sat, 25 Mar 2017 18:21:19 +0000 (19:21 +0100)
committerBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Mon, 27 Mar 2017 13:43:56 +0000 (15:43 +0200)
helpers/path.go
hugolib/site_render.go

index 14d98e2c08260ebfe0bca98285c0b7ce9a3442b0..554e9977d60686f4d9d55ad4d4bcc02a5e6e568e 100644 (file)
@@ -358,23 +358,6 @@ func GetRelativePath(path, base string) (final string, err error) {
        return name, nil
 }
 
-// PaginateAliasPath creates a path used to access the aliases in the paginator.
-func (p *PathSpec) PaginateAliasPath(base string, page int) string {
-       paginatePath := p.paginatePath
-       uglify := p.uglyURLs
-       var pth string
-       if base != "" {
-               pth = filepath.FromSlash(fmt.Sprintf("/%s/%s/%d", base, paginatePath, page))
-       } else {
-               pth = filepath.FromSlash(fmt.Sprintf("/%s/%d", paginatePath, page))
-       }
-       if uglify {
-               pth += ".html"
-       }
-
-       return pth
-}
-
 // GuessSection returns the section given a source path.
 // A section is the part between the root slash and the second slash
 // or before the first slash.
index be512fe48eea53799b06f4a16642d286080f70a8..fdac0348901e31c738fe339f53fe17031f5341d8 100644 (file)
@@ -122,12 +122,15 @@ func (s *Site) renderPaginator(p *PageOutput) error {
                paginatePath := s.Cfg.GetString("paginatePath")
 
                // write alias for page 1
-               // TODO(bep) ml all of these n.addLang ... fix.
-               //TODO(bep) output fix
+               addend := fmt.Sprintf("/%s/%d", paginatePath, 1)
+               target, err := p.createTargetPath(p.outputFormat, addend)
+               if err != nil {
+                       return err
+               }
 
-               aliasPath := p.addLangPathPrefix(s.PathSpec.PaginateAliasPath(path.Join(p.sections...), 1))
-               link := p.Permalink()
-               s.writeDestAlias(aliasPath, link, nil)
+               // TODO(bep) output do better
+               link := newOutputFormat(p.Page, p.outputFormat).Permalink()
+               s.writeDestAlias(target, link, nil)
 
                pagers := p.paginator.Pagers()