shithub: hugo

Download patch

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",