summaryrefslogtreecommitdiffstats
path: root/hugolib
diff options
context:
space:
mode:
authorBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>2019-04-22 09:13:47 +0200
committerBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>2019-04-22 13:22:01 +0200
commit0775c98e6c5b700e46adaaf190fc3f693a6ab002 (patch)
treeb2162c568fc2afd528792a5e28064f7d9c6caa0a /hugolib
parent1477fb33c938107601ffcbc7d3051378cf608443 (diff)
hugolib: No links for bundled pages
This fixes a bug introduced in Hugo 0.55. Fixes #5882
Diffstat (limited to 'hugolib')
-rw-r--r--hugolib/page__meta.go3
-rw-r--r--hugolib/page__new.go4
-rw-r--r--hugolib/page__paths.go4
-rw-r--r--hugolib/pagebundler_handlers.go2
-rw-r--r--hugolib/pagebundler_test.go22
5 files changed, 26 insertions, 9 deletions
diff --git a/hugolib/page__meta.go b/hugolib/page__meta.go
index 64c72b895..d14b9d724 100644
--- a/hugolib/page__meta.go
+++ b/hugolib/page__meta.go
@@ -98,6 +98,9 @@ type pageMeta struct {
// 3. But you can get it via .Site.GetPage
headless bool
+ // Set if this page is bundled inside another.
+ bundled bool
+
// A key that maps to translation(s) of this page. This value is fetched
// from the page front matter.
translationKey string
diff --git a/hugolib/page__new.go b/hugolib/page__new.go
index c703867f1..64c84b0f8 100644
--- a/hugolib/page__new.go
+++ b/hugolib/page__new.go
@@ -166,14 +166,14 @@ func newPageStandalone(m *pageMeta, f output.Format) (*pageState, error) {
}
-func newPageWithContent(f *fileInfo, s *Site, content resource.OpenReadSeekCloser) (*pageState, error) {
+func newPageWithContent(f *fileInfo, s *Site, bundled bool, content resource.OpenReadSeekCloser) (*pageState, error) {
sections := s.sectionsFromFile(f)
kind := s.kindFromFileInfoOrSections(f, sections)
if kind == page.KindTaxonomy {
s.PathSpec.MakePathsSanitized(sections)
}
- metaProvider := &pageMeta{kind: kind, sections: sections, s: s, f: f}
+ metaProvider := &pageMeta{kind: kind, sections: sections, bundled: bundled, s: s, f: f}
ps, err := newPageBase(metaProvider)
if err != nil {
diff --git a/hugolib/page__paths.go b/hugolib/page__paths.go
index 8bc7a7535..adbdb4668 100644
--- a/hugolib/page__paths.go
+++ b/hugolib/page__paths.go
@@ -52,7 +52,9 @@ func newPagePaths(
var relPermalink, permalink string
- if !pm.headless {
+ // If a page is headless or bundled in another, it will not get published
+ // on its own and it will have no links.
+ if !pm.headless && !pm.bundled {
relPermalink = paths.RelPermalink(s.PathSpec)
permalink = paths.PermalinkForOutputFormat(s.PathSpec, f)
}
diff --git a/hugolib/pagebundler_handlers.go b/hugolib/pagebundler_handlers.go
index c217b5e09..e745a04f2 100644
--- a/hugolib/pagebundler_handlers.go
+++ b/hugolib/pagebundler_handlers.go
@@ -197,7 +197,7 @@ func (c *contentHandlers) parsePage(h contentHandler) contentHandler {
return f, nil
}
- ps, err := newPageWithContent(fi, c.s, content)
+ ps, err := newPageWithContent(fi, c.s, ctx.parentPage != nil, content)
if err != nil {
return handlerResult{err: err}
}
diff --git a/hugolib/pagebundler_test.go b/hugolib/pagebundler_test.go
index 06bd64154..64c1529d8 100644
--- a/hugolib/pagebundler_test.go
+++ b/hugolib/pagebundler_test.go
@@ -237,10 +237,17 @@ func TestPageBundlerSiteRegular(t *testing.T) {
"Short Thumb Width: 56",
"1: Image Title: Sunset Galore 1",
"1: Image Params: map[myparam:My Sunny Param]",
+ relPermalinker("1: Image RelPermalink: %s/2017/pageslug/sunset1.jpg"),
"2: Image Title: Sunset Galore 2",
"2: Image Params: map[myparam:My Sunny Param]",
"1: Image myParam: Lower: My Sunny Param Caps: My Sunny Param",
+ "0: Page Title: Bundle Galore",
)
+
+ // https://github.com/gohugoio/hugo/issues/5882
+ th.assertFileContent(
+ filepath.FromSlash("/work/public/2017/pageslug.html"), "0: Page RelPermalink: |")
+
th.assertFileContent(filepath.FromSlash("/work/public/cpath/2017/pageslug.html"), "TheContent")
// 은행
@@ -642,11 +649,16 @@ Thumb Name: {{ $thumb.Name }}
Thumb Title: {{ $thumb.Title }}
Thumb RelPermalink: {{ $thumb.RelPermalink }}
{{ end }}
-{{ range $i, $e := .Resources.ByType "image" }}
-{{ $i }}: Image Title: {{ .Title }}
-{{ $i }}: Image Name: {{ .Name }}
-{{ $i }}: Image Params: {{ printf "%v" .Params }}
-{{ $i }}: Image myParam: Lower: {{ .Params.myparam }} Caps: {{ .Params.MYPARAM }}
+{{ $types := slice "image" "page" }}
+{{ range $types }}
+{{ $typeTitle := . | title }}
+{{ range $i, $e := $.Resources.ByType . }}
+{{ $i }}: {{ $typeTitle }} Title: {{ .Title }}
+{{ $i }}: {{ $typeTitle }} Name: {{ .Name }}
+{{ $i }}: {{ $typeTitle }} RelPermalink: {{ .RelPermalink }}|
+{{ $i }}: {{ $typeTitle }} Params: {{ printf "%v" .Params }}
+{{ $i }}: {{ $typeTitle }} myParam: Lower: {{ .Params.myparam }} Caps: {{ .Params.MYPARAM }}
+{{ end }}
{{ end }}
`