Skip to content

Commit

Permalink
Fix broken shortcodes for Ace and Amber
Browse files Browse the repository at this point in the history
Fixes #4051
  • Loading branch information
bep committed Nov 18, 2017
1 parent b3daa1f commit 503ca6d
Show file tree
Hide file tree
Showing 3 changed files with 56 additions and 14 deletions.
33 changes: 23 additions & 10 deletions hugolib/template_engines_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,7 @@ func TestAllTemplateEngines(t *testing.T) {
amberFixer := func(s string) string {
fixed := strings.Replace(s, "{{ .Title", "{{ Title", -1)
fixed = strings.Replace(fixed, ".Content", "Content", -1)
fixed = strings.Replace(fixed, ".IsNamedParams", "IsNamedParams", -1)
fixed = strings.Replace(fixed, "{{", "#{", -1)
fixed = strings.Replace(fixed, "}}", "}", -1)
fixed = strings.Replace(fixed, `title "hello world"`, `title("hello world")`, -1)
Expand All @@ -47,8 +48,10 @@ func TestAllTemplateEngines(t *testing.T) {
{"html", noOp},
{"ace", noOp},
} {
doTestTemplateEngine(t, config.suffix, config.templateFixer)

t.Run(config.suffix,
func(t *testing.T) {
doTestTemplateEngine(t, config.suffix, config.templateFixer)
})
}

}
Expand All @@ -57,13 +60,6 @@ func doTestTemplateEngine(t *testing.T, suffix string, templateFixer func(s stri

cfg, fs := newTestCfg()

writeSource(t, fs, filepath.Join("content", "p.md"), `
---
title: My Title
---
My Content
`)

t.Log("Testing", suffix)

templTemplate := `
Expand All @@ -75,13 +71,29 @@ p
br
| {{ title "hello world" }}
`

templShortcodeTemplate := `
p
|
| Shortcode: {{ .IsNamedParams }}
`

templ := templateFixer(templTemplate)
shortcodeTempl := templateFixer(templShortcodeTemplate)

writeSource(t, fs, filepath.Join("content", "p.md"), `
---
title: My Title
---
My Content
t.Log(templ)
Shortcode: {{< myShort >}}
`)

writeSource(t, fs, filepath.Join("layouts", "_default", fmt.Sprintf("single.%s", suffix)), templ)
writeSource(t, fs, filepath.Join("layouts", "shortcodes", fmt.Sprintf("myShort.%s", suffix)), shortcodeTempl)

s := buildSingleSite(t, deps.DepsCfg{Fs: fs, Cfg: cfg}, BuildCfg{})
th := testHelper{s.Cfg, s.Fs, t}
Expand All @@ -90,6 +102,7 @@ p
"Page Title: My Title",
"My Content",
"Hello World",
"Shortcode: false",
)

}
20 changes: 18 additions & 2 deletions tpl/tplimpl/ace.go
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@
package tplimpl

import (
"html/template"
"path/filepath"

"strings"
Expand All @@ -24,7 +25,8 @@ import (
func (t *templateHandler) addAceTemplate(name, basePath, innerPath string, baseContent, innerContent []byte) error {
t.checkState()
var base, inner *ace.File
name = name[:len(name)-len(filepath.Ext(innerPath))] + ".html"
withoutExt := name[:len(name)-len(filepath.Ext(innerPath))]
name = withoutExt + ".html"

// Fixes issue #1178
basePath = strings.Replace(basePath, "\\", "/", -1)
Expand All @@ -37,15 +39,29 @@ func (t *templateHandler) addAceTemplate(name, basePath, innerPath string, baseC
base = ace.NewFile(innerPath, innerContent)
inner = ace.NewFile("", []byte{})
}

parsed, err := ace.ParseSource(ace.NewSource(base, inner, []*ace.File{}), nil)
if err != nil {
t.errors = append(t.errors, &templateErr{name: name, err: err})
return err
}

templ, err := ace.CompileResultWithTemplate(t.html.t.New(name), parsed, nil)
if err != nil {
t.errors = append(t.errors, &templateErr{name: name, err: err})
return err
}
return applyTemplateTransformersToHMLTTemplate(templ)

if err := applyTemplateTransformersToHMLTTemplate(templ); err != nil {
return err
}

if strings.Contains(name, "shortcodes") {
// We need to keep track of one ot the output format's shortcode template
// without knowing the rendering context.
clone := template.Must(templ.Clone())
t.html.t.AddParseTree(withoutExt, clone.Tree)
}

return nil
}
17 changes: 15 additions & 2 deletions tpl/tplimpl/template.go
Original file line number Diff line number Diff line change
Expand Up @@ -622,7 +622,8 @@ func (t *templateHandler) addTemplateFile(name, baseTemplatePath, path string) e
switch ext {
case ".amber":
// Only HTML support for Amber
templateName := strings.TrimSuffix(name, filepath.Ext(name)) + ".html"
withoutExt := strings.TrimSuffix(name, filepath.Ext(name))
templateName := withoutExt + ".html"
b, err := afero.ReadFile(t.Fs.Source, path)

if err != nil {
Expand All @@ -636,7 +637,19 @@ func (t *templateHandler) addTemplateFile(name, baseTemplatePath, path string) e
return err
}

return applyTemplateTransformersToHMLTTemplate(templ)
if err := applyTemplateTransformersToHMLTTemplate(templ); err != nil {
return err
}

if strings.Contains(templateName, "shortcodes") {
// We need to keep track of one ot the output format's shortcode template
// without knowing the rendering context.
clone := template.Must(templ.Clone())
t.html.t.AddParseTree(withoutExt, clone.Tree)
}

return nil

case ".ace":
// Only HTML support for Ace
var innerContent, baseContent []byte
Expand Down

0 comments on commit 503ca6d

Please sign in to comment.