hugolib: Must recreate Paginator on live-reload
authorBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Wed, 12 Apr 2017 16:11:37 +0000 (18:11 +0200)
committerBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Wed, 12 Apr 2017 19:15:51 +0000 (21:15 +0200)
The structure may potentially have changed, and then it fails.

Fixes #3315

hugolib/page_output.go
hugolib/site_render.go

index 88e865c97c534b3085fa76f30a10f742aa9512ed..ea23dc2031f038f32e31f73a42b80df2e074c598 100644 (file)
@@ -78,13 +78,17 @@ func newPageOutput(p *Page, createCopy bool, f output.Format) (*PageOutput, erro
 
 // copy creates a copy of this PageOutput with the lazy sync.Once vars reset
 // so they will be evaluated again, for word count calculations etc.
-func (p *PageOutput) copy() *PageOutput {
-       c, err := newPageOutput(p.Page, true, p.outputFormat)
+func (p *PageOutput) copyWithFormat(f output.Format) (*PageOutput, error) {
+       c, err := newPageOutput(p.Page, true, f)
        if err != nil {
-               panic(err)
+               return nil, err
        }
        c.paginator = p.paginator
-       return c
+       return c, nil
+}
+
+func (p *PageOutput) copy() (*PageOutput, error) {
+       return p.copyWithFormat(p.outputFormat)
 }
 
 func (p *PageOutput) layouts(layouts ...string) ([]string, error) {
@@ -142,6 +146,9 @@ func (p *Page) Render(layout ...string) template.HTML {
        }
 
        p.pageOutputInit.Do(func() {
+               if p.mainPageOutput != nil {
+                       return
+               }
                // If Render is called in a range loop, the page output isn't available.
                // So, create one.
                outFormat := p.outputFormats[0]
index 17a14bd103ae265da9528dd947ce4fc11f2e802a..d5b16975dcbb34ef1872425d31be70546cf401d4 100644 (file)
@@ -75,14 +75,10 @@ func pageRenderer(s *Site, pages <-chan *Page, results chan<- error, wg *sync.Wa
                        )
 
                        if i == 0 {
-                               page.pageOutputInit.Do(func() {
-                                       var po *PageOutput
-                                       po, err = newPageOutput(page, false, outFormat)
-                                       page.mainPageOutput = po
-                               })
-                               pageOutput = page.mainPageOutput
+                               pageOutput, err = newPageOutput(page, false, outFormat)
+                               page.mainPageOutput = pageOutput
                        } else {
-                               pageOutput, err = newPageOutput(page, true, outFormat)
+                               pageOutput, err = page.mainPageOutput.copyWithFormat(outFormat)
                        }
 
                        if err != nil {
@@ -159,7 +155,10 @@ func (s *Site) renderPaginator(p *PageOutput) error {
                                continue
                        }
 
-                       pagerNode := p.copy()
+                       pagerNode, err := p.copy()
+                       if err != nil {
+                               return err
+                       }
 
                        pagerNode.paginator = pager
                        if pager.TotalPages() > 0 {