create: Preserve shortcodes in archetype templates
authorBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Fri, 23 Jun 2017 07:29:59 +0000 (09:29 +0200)
committerBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Fri, 23 Jun 2017 07:59:06 +0000 (09:59 +0200)
Fixes #3623

create/content_template_handler.go
create/content_test.go

index fbe062cba3d48d1e172476f62b08cf55a09277eb..0be495d150965e53cfdc800fc319808a9b13b2c7 100644 (file)
@@ -16,6 +16,7 @@ package create
 import (
        "bytes"
        "fmt"
+       "strings"
        "time"
 
        "github.com/gohugoio/hugo/helpers"
@@ -57,6 +58,20 @@ draft: true
 `
 )
 
+var (
+       archetypeShortcodeReplacementsPre = strings.NewReplacer(
+               "{{<", "{x{<",
+               "{{%", "{x{%",
+               ">}}", ">}x}",
+               "%}}", "%}x}")
+
+       archetypeShortcodeReplacementsPost = strings.NewReplacer(
+               "{x{<", "{{<",
+               "{x{%", "{{%",
+               ">}x}", ">}}",
+               "%}x}", "%}}")
+)
+
 func executeArcheTypeAsTemplate(s *hugolib.Site, kind, targetPath, archetypeFilename string) ([]byte, error) {
 
        var (
@@ -86,6 +101,10 @@ func executeArcheTypeAsTemplate(s *hugolib.Site, kind, targetPath, archetypeFile
 
        }
 
+       // The archetype template may contain shortcodes, and these does not play well
+       // with the Go templates. Need to set some temporary delimiters.
+       archetypeTemplate = []byte(archetypeShortcodeReplacementsPre.Replace(string(archetypeTemplate)))
+
        // Reuse the Hugo template setup to get the template funcs properly set up.
        templateHandler := s.Deps.Tmpl.(tpl.TemplateHandler)
        templateName := "_text/" + helpers.Filename(archetypeFilename)
@@ -100,7 +119,7 @@ func executeArcheTypeAsTemplate(s *hugolib.Site, kind, targetPath, archetypeFile
                return nil, fmt.Errorf("Failed to process archetype file %q: %s", archetypeFilename, err)
        }
 
-       archetypeContent = buff.Bytes()
+       archetypeContent = []byte(archetypeShortcodeReplacementsPost.Replace(buff.String()))
 
        if !bytes.Contains(archetypeContent, []byte("date")) || !bytes.Contains(archetypeContent, []byte("title")) {
                // TODO(bep) remove some time in the future.
index bd7c34a1d88c7714e16b5069d11bad716c2d0b1e..9147591648ae730d937c8101a64c9207bc5e8d56 100644 (file)
@@ -49,6 +49,11 @@ func TestNewContent(t *testing.T) {
                {"stump", "stump/sample-2.md", []string{`title: "Sample 2"`}},      // no archetype file
                {"", "sample-3.md", []string{`title: "Sample 3"`}},                 // no archetype
                {"product", "product/sample-4.md", []string{`title = "SAMPLE-4"`}}, // empty archetype front matter
+               {"shortcodes", "shortcodes/go.md", []string{
+                       `title = "GO"`,
+                       "{{< myshortcode >}}",
+                       "{{% myshortcode %}}",
+                       "{{</* comment */>}}\n{{%/* comment */%}}"}}, // shortcodes
        }
 
        for _, c := range cases {
@@ -126,6 +131,24 @@ title = "{{ .BaseFileName  | upper }}"
                        path:    filepath.Join("archetypes", "emptydate.md"),
                        content: "+++\ndate =\"\"\ntitle = \"Empty Date Arch title\"\ntest = \"test1\"\n+++\n",
                },
+               // #3623x
+               {
+                       path: filepath.Join("archetypes", "shortcodes.md"),
+                       content: `+++
+title = "{{ .BaseFileName  | upper }}"
++++
+
+{{< myshortcode >}}
+
+Some text.
+
+{{% myshortcode %}}
+{{</* comment */>}}
+{{%/* comment */%}}
+
+
+`,
+               },
        } {
                f, err := fs.Source.Create(v.path)
                if err != nil {