mirror of
				https://github.com/gohugoio/hugo.git
				synced 2024-05-11 05:54:58 +00:00 
			
		
		
		
	Revert "Improve .Content vs shortcodes"
This reverts commit e590cc26eb.
			
			
This commit is contained in:
		| @@ -559,83 +559,38 @@ func (h *HugoSites) setupTranslations() { | ||||
| 	} | ||||
| } | ||||
|  | ||||
| type pagesRenderPreparer struct { | ||||
| 	numWorkers int | ||||
| 	s          *Site | ||||
| 	cfg        *BuildCfg | ||||
| 	wg         *sync.WaitGroup | ||||
| 	pages      chan *Page | ||||
| } | ||||
|  | ||||
| func newStartedRenderPreparator(s *Site, cfg *BuildCfg) *pagesRenderPreparer { | ||||
| 	numWorkers := getGoMaxProcs() * 4 | ||||
| 	pp := &pagesRenderPreparer{ | ||||
| 		s:          s, | ||||
| 		cfg:        cfg, | ||||
| 		numWorkers: numWorkers, | ||||
| 		wg:         &sync.WaitGroup{}, | ||||
| 		pages:      make(chan *Page), | ||||
| 	} | ||||
|  | ||||
| 	pp.start() | ||||
| 	return pp | ||||
| } | ||||
|  | ||||
| func (pp *pagesRenderPreparer) start() { | ||||
| 	for i := 0; i < pp.numWorkers; i++ { | ||||
| 		pp.wg.Add(1) | ||||
| 		go func() { | ||||
| 			defer pp.wg.Done() | ||||
| 			for p := range pp.pages { | ||||
| 				if err := p.prepareForRender(pp.cfg); err != nil { | ||||
| 					pp.s.Log.ERROR.Printf("Failed to prepare page %q for render: %s", p.BaseFileName(), err) | ||||
|  | ||||
| 				} | ||||
| 			} | ||||
| 		}() | ||||
| 	} | ||||
| } | ||||
|  | ||||
| func (pp *pagesRenderPreparer) add(p *Page) { | ||||
| 	pp.pages <- p | ||||
| } | ||||
|  | ||||
| func (pp *pagesRenderPreparer) done() { | ||||
| 	close(pp.pages) | ||||
| 	pp.wg.Wait() | ||||
| } | ||||
|  | ||||
| func (s *Site) preparePagesForRender(cfg *BuildCfg) { | ||||
|  | ||||
| 	// For the content from other pages in shortcodes there are some chicken and | ||||
| 	// egg dependencies that is hard to get around. But we can improve on this | ||||
| 	// by preparing the pages in a certain order. | ||||
| 	// So the headless pages goes first. These are typically collection of | ||||
| 	// pages and images etc. used by others. | ||||
| 	batch := newStartedRenderPreparator(s, cfg) | ||||
| 	for _, p := range s.headlessPages { | ||||
| 		batch.add(p) | ||||
| 	pageChan := make(chan *Page) | ||||
| 	wg := &sync.WaitGroup{} | ||||
|  | ||||
| 	numWorkers := getGoMaxProcs() * 4 | ||||
|  | ||||
| 	for i := 0; i < numWorkers; i++ { | ||||
| 		wg.Add(1) | ||||
| 		go func(pages <-chan *Page, wg *sync.WaitGroup) { | ||||
| 			defer wg.Done() | ||||
| 			for p := range pages { | ||||
| 				if err := p.prepareForRender(cfg); err != nil { | ||||
| 					s.Log.ERROR.Printf("Failed to prepare page %q for render: %s", p.BaseFileName(), err) | ||||
|  | ||||
| 				} | ||||
| 			} | ||||
| 		}(pageChan, wg) | ||||
| 	} | ||||
|  | ||||
| 	batch.done() | ||||
|  | ||||
| 	// Then the rest in the following order: | ||||
| 	order := []bundleDirType{bundleLeaf, bundleNot, bundleBranch} | ||||
|  | ||||
| 	for _, tp := range order { | ||||
| 		batch = newStartedRenderPreparator(s, cfg) | ||||
| 	for _, p := range s.Pages { | ||||
| 			// sanity check | ||||
| 			if p.bundleType < 0 || p.bundleType > bundleBranch { | ||||
| 				panic("unknown bundle type") | ||||
| 		pageChan <- p | ||||
| 	} | ||||
| 			if p.bundleType == tp { | ||||
| 				batch.add(p) | ||||
| 			} | ||||
| 		} | ||||
| 		batch.done() | ||||
|  | ||||
| 	for _, p := range s.headlessPages { | ||||
| 		pageChan <- p | ||||
| 	} | ||||
|  | ||||
| 	close(pageChan) | ||||
|  | ||||
| 	wg.Wait() | ||||
|  | ||||
| } | ||||
|  | ||||
| // Pages returns all pages for all sites. | ||||
|   | ||||
| @@ -224,7 +224,6 @@ func (h *HugoSites) render(config *BuildCfg) error { | ||||
| 		s.initRenderFormats() | ||||
| 		for i, rf := range s.renderFormats { | ||||
| 			s.rc = &siteRenderingContext{Format: rf} | ||||
|  | ||||
| 			s.preparePagesForRender(config) | ||||
|  | ||||
| 			if !config.SkipRender { | ||||
|   | ||||
| @@ -243,8 +243,6 @@ type Page struct { | ||||
| 	// 3. But you can get it via .Site.GetPage | ||||
| 	headless bool | ||||
|  | ||||
| 	bundleType bundleDirType | ||||
|  | ||||
| 	layoutDescriptor output.LayoutDescriptor | ||||
|  | ||||
| 	scratch *Scratch | ||||
|   | ||||
| @@ -218,8 +218,6 @@ func (c *contentHandlers) parsePage(h contentHandler) contentHandler { | ||||
| 		ctx.currentPage = p | ||||
|  | ||||
| 		if ctx.bundle != nil { | ||||
| 			p.bundleType = ctx.bundle.tp | ||||
|  | ||||
| 			// Add the bundled files | ||||
| 			for _, fi := range ctx.bundle.resources { | ||||
| 				childCtx := ctx.childCtx(fi) | ||||
|   | ||||
| @@ -1865,7 +1865,6 @@ func getGoMaxProcs() int { | ||||
|  | ||||
| func (s *Site) newNodePage(typ string, sections ...string) *Page { | ||||
| 	p := &Page{ | ||||
| 		bundleType: bundleBranch, | ||||
| 		language: s.Language, | ||||
| 		pageInit: &pageInit{}, | ||||
| 		Kind:     typ, | ||||
|   | ||||
		Reference in New Issue
	
	Block a user