Improve markup determination logic
authorVas Sudanagunta <vas@commonkarma.org>
Sat, 5 May 2018 00:17:16 +0000 (20:17 -0400)
committerBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Sat, 12 May 2018 18:16:26 +0000 (20:16 +0200)
Sets Page.markup earlier (as early as possible, when the page is
loaded). Sets it once and only once, removing many redundant calls
to determineMarkupType().

This kills a sleeping bug that was avoided by the parts of the
code depending on this value making those redundant calls.

hugolib/page.go
hugolib/shortcode.go

index 6e0f2b86f37544b4eb15c3ce83d5321778c0dc27..e79b063cca18888ea6d1f115e526990035ce92a5 100644 (file)
@@ -728,8 +728,7 @@ func replaceDivider(content, from, to []byte) ([]byte, bool) {
 // rendering engines.
 func (p *Page) replaceDivider(content []byte) []byte {
        summaryDivider := helpers.SummaryDivider
-       // TODO(bep) handle better.
-       if p.Ext() == "org" || p.Markup == "org" {
+       if p.Markup == "org" {
                summaryDivider = []byte("# more")
        }
 
@@ -863,7 +862,7 @@ func (p *Page) setAutoSummary() error {
 
 func (p *Page) renderContent(content []byte) []byte {
        return p.s.ContentSpec.RenderBytes(&helpers.RenderingContext{
-               Content: content, RenderTOC: true, PageFmt: p.determineMarkupType(),
+               Content: content, RenderTOC: true, PageFmt: p.Markup,
                Cfg:        p.Language(),
                DocumentID: p.UniqueID(), DocumentName: p.Path(),
                Config: p.getRenderingConfig()})
@@ -1486,6 +1485,13 @@ func (p *Page) update(frontmatter map[string]interface{}) error {
                }
        }
 
+       // Try markup explicitly set in the frontmatter
+       p.Markup = helpers.GuessType(p.Markup)
+       if p.Markup == "unknown" {
+               // Fall back to file extension (might also return "unknown")
+               p.Markup = helpers.GuessType(p.Source.Ext())
+       }
+
        if draft != nil && published != nil {
                p.Draft = *draft
                p.s.Log.ERROR.Printf("page %s has both draft and published settings in its frontmatter. Using draft.", p.File.Path())
@@ -1725,17 +1731,6 @@ func (p *Page) shouldRenderTo(f output.Format) bool {
        return found
 }
 
-func (p *Page) determineMarkupType() string {
-       // Try markup explicitly set in the frontmatter
-       p.Markup = helpers.GuessType(p.Markup)
-       if p.Markup == "unknown" {
-               // Fall back to file extension (might also return "unknown")
-               p.Markup = helpers.GuessType(p.Source.Ext())
-       }
-
-       return p.Markup
-}
-
 func (p *Page) parse(reader io.Reader) error {
        psr, err := parser.ReadFrom(reader)
        if err != nil {
index 8afbfb6452e48d1ad386b3840bfc88a122139d93..b82c1b6c2115381bd92650084676c758cddd817c 100644 (file)
@@ -314,7 +314,8 @@ func renderShortcode(
 
                if sc.doMarkup {
                        newInner := p.s.ContentSpec.RenderBytes(&helpers.RenderingContext{
-                               Content: []byte(inner), PageFmt: p.determineMarkupType(),
+                               Content:      []byte(inner),
+                               PageFmt:      p.Markup,
                                Cfg:          p.Language(),
                                DocumentID:   p.UniqueID(),
                                DocumentName: p.Path(),
@@ -333,7 +334,7 @@ func renderShortcode(
                        //     substitutions in <div>HUGOSHORTCODE-1</div> which prevents the
                        //     generation, but means that you can’t use shortcodes inside of
                        //     markdown structures itself (e.g., `[foo]({{% ref foo.md %}})`).
-                       switch p.determineMarkupType() {
+                       switch p.Markup {
                        case "unknown", "markdown":
                                if match, _ := regexp.MatchString(innerNewlineRegexp, inner); !match {
                                        cleaner, err := regexp.Compile(innerCleanupRegexp)