ref: 0483299bc06a742d40528e0d675e42e149910853
parent: 27b62a546cd5c49df7424caeabe4af35ddd3bd90
author: Cameron Moore <[email protected]>
date: Thu Dec 20 21:42:37 EST 2018
hugolib: Improve logic of output path trimming Fixes #4666
--- a/hugolib/page_paths.go
+++ b/hugolib/page_paths.go
@@ -310,7 +310,7 @@
}
// For /index.json etc. we must use the full path.
- if strings.HasSuffix(f.BaseFilename(), "html") {
+ if f.MediaType.FullSuffix() == ".html" && filepath.Base(tp) == "index.html" {
tp = strings.TrimSuffix(tp, f.BaseFilename())
}
--- a/hugolib/page_permalink_test.go
+++ b/hugolib/page_permalink_test.go
@@ -55,6 +55,8 @@
{"x/y/z/boofar.md", "http://barnew/boo/", "booslug", "", false, false, "http://barnew/boo/x/y/z/booslug/", "/boo/x/y/z/booslug/"},
{"x/y/z/boofar.md", "http://barnew/boo/", "booslug", "", true, true, "http://barnew/boo/x/y/z/booslug.html", "/x/y/z/booslug.html"},
{"x/y/z/boofar.md", "http://barnew/boo", "booslug", "", true, true, "http://barnew/boo/x/y/z/booslug.html", "/x/y/z/booslug.html"},
+ // Issue #4666
+ {"x/y/z/boo-makeindex.md", "http://barnew/boo", "", "", true, true, "http://barnew/boo/x/y/z/boo-makeindex.html", "/x/y/z/boo-makeindex.html"},
// test URL overrides
{"x/y/z/boofar.md", "", "", "/z/y/q/", false, false, "/z/y/q/", "/z/y/q/"},