ref: 196a9df585c4744e3280f37c1c24e469fce14b8c
parent: 9b6e61464b09ffe3423fb8d7c72bddb7a9ed5b98
author: Bjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
date: Sun Jan 5 07:56:41 EST 2020
hugolib: Fix relative .Page.GetPage from bundle Fixes #6705
--- a/hugolib/hugo_modules_test.go
+++ b/hugolib/hugo_modules_test.go
@@ -585,9 +585,19 @@
{{ $mypage := .Site.GetPage "/blog/mypage.md" }}
{{ with $mypage }}MYPAGE: {{ .Title }}|Path: {{ path.Join .File.Path }}|FilePath: {{ path.Join .File.FileInfo.Meta.PathFile }}|{{ end }}
+`, "_default/_markup/render-link.html", `
+{{ $link := .Destination }}
+{{ $isRemote := strings.HasPrefix $link "http" }}
+{{- if not $isRemote -}}
+{{ $url := urls.Parse .Destination }}
+{{ $fragment := "" }}
+{{- with $url.Fragment }}{{ $fragment = printf "#%s" . }}{{ end -}}
+{{- with .Page.GetPage $url.Path }}{{ $link = printf "%s%s" .Permalink $fragment }}{{ end }}{{ end -}}
+<a href="{{ $link | safeURL }}"{{ with .Title}} title="{{ . }}"{{ end }}{{ if $isRemote }} target="_blank"{{ end }}>{{ .Text | safeHTML }}</a>
`)
os.Mkdir(filepath.Join(workingDir, "mycontent"), 0777)
+ os.Mkdir(filepath.Join(workingDir, "mycontent", "mybundle"), 0777)
b.WithSourceFile("README.md", `---
title: "Readme Title"
@@ -600,6 +610,23 @@
title: "My Page"
---
+
+* [Relative Link From Page](mybundle)
+* [Relative Link From Page, filename](mybundle/index.md)
+* [Link using original path](/mycontent/mybundle/index.md)
+
+
+`, filepath.Join("mycontent", "mybundle", "index.md"), `
+---
+title: "My Bundle"
+---
+
+* [Dot Relative Link From Bundle](../mypage.md)
+* [Link using original path](/mycontent/mypage.md)
+* [Link to Home](/)
+* [Link to Home, README.md](/README.md)
+* [Link to Home, _index.md](/_index.md)
+
`)
b.Build(BuildCfg{})
@@ -610,8 +637,20 @@
Readme Content.
MYPAGE: My Page|Path: blog/mypage.md|FilePath: mycontent/mypage.md|
`)
- b.AssertFileContent("public/blog/mypage/index.html", "Single: My Page")
+ b.AssertFileContent("public/blog/mypage/index.html", `
+<a href="https://example.com/blog/mybundle/">Relative Link From Page</a>
+<a href="https://example.com/blog/mybundle/">Relative Link From Page, filename</a>
+<a href="https://example.com/blog/mybundle/">Link using original path</a>
+`)
+ b.AssertFileContent("public/blog/mybundle/index.html", `
+<a href="https://example.com/blog/mypage/">Dot Relative Link From Bundle</a>
+<a href="https://example.com/blog/mypage/">Link using original path</a>
+<a href="https://example.com/">Link to Home</a>
+<a href="https://example.com/">Link to Home, README.md</a>
+<a href="https://example.com/">Link to Home, _index.md</a>
+`)
+
b.EditFiles("README.md", `---
title: "Readme Edit"
---
@@ -622,6 +661,7 @@
b.AssertFileContent("public/index.html", `
Readme Edit
`)
+
}
// https://github.com/gohugoio/hugo/issues/6299
--- a/hugolib/page.go
+++ b/hugolib/page.go
@@ -954,7 +954,7 @@
path := meta.PathFile()
if path != "" {
- ref := "/" + path
+ ref := "/" + filepath.ToSlash(path)
if ref != refs[0] {
refs = append(refs, ref)
}
--- a/hugolib/pagecollections.go
+++ b/hugolib/pagecollections.go
@@ -267,7 +267,14 @@
} else if context != nil {
// Try the page-relative path.
- ppath := path.Join("/", strings.ToLower(context.SectionsPath()), ref)
+ var dir string
+ if !context.File().IsZero() {
+ dir = filepath.ToSlash(context.File().Dir())
+ } else {
+ dir = context.SectionsPath()
+ }
+ ppath := path.Join("/", strings.ToLower(dir), ref)
+
p, err := c.getFromCache(ppath)
if err == nil && p != nil {
return p, nil
--- a/hugolib/testhelpers_test.go
+++ b/hugolib/testhelpers_test.go
@@ -466,6 +466,7 @@
for _, dir := range []string{
"content/sect",
"layouts/_default",
+ "layouts/_default/_markup",
"layouts/partials",
"layouts/shortcodes",
"data",