tpl: Pull in Go 1.18 patch that fixes the "no space in {{ continue }} and {{ break...
authorBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Wed, 16 Mar 2022 12:11:29 +0000 (13:11 +0100)
committerBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Wed, 16 Mar 2022 12:14:23 +0000 (13:14 +0100)
scripts/fork_go_templates/main.go
tpl/internal/go_templates/htmltemplate/escape.go
tpl/internal/go_templates/texttemplate/parse/parse.go
tpl/internal/go_templates/texttemplate/parse/parse_test.go
tpl/tplimpl/integration_test.go

index 4ffba018fe84541e5199c5d626bec2d446d04eac..9296b7bdd7985194aeabd43433901f86c54b74c0 100644 (file)
@@ -17,7 +17,7 @@ import (
 )
 
 func main() {
-       // The current is built with Go tag go1.18 4aa1efed4853ea067d665a952eee77c52faac774
+       // The current is built with 41a82aa9c3 text/template/parse: allow space after continue or break
        fmt.Println("Forking ...")
        defer fmt.Println("Done ...")
 
index 5382c42886a2a77ef502b7f54e10108a8a9caaaa..488894416e801b69968f97fbd29aad9463465513 100644 (file)
@@ -45,7 +45,7 @@ func escapeTemplate(tmpl *Template, node parse.Node, name string) error {
 }
 
 // evalArgs formats the list of arguments into a string. It is equivalent to
-// fmt.Sprint(args...), except that it deferences all pointers.
+// fmt.Sprint(args...), except that it dereferences all pointers.
 func evalArgs(args ...any) string {
        // Optimization for simple common case of a single string argument.
        if len(args) == 1 {
@@ -691,7 +691,7 @@ func (e *escaper) escapeTemplateBody(c context, t *template.Template) (context,
                return c.eq(c1)
        }
        // We need to assume an output context so that recursive template calls
-       // take the fast path out of escapeTree instead of infinitely recursing.
+       // take the fast path out of escapeTree instead of infinitely recurring.
        // Naively assuming that the input context is the same as the output
        // works >90% of the time.
        e.output[t.Name()] = c
index b0cbe9dfc8b0c7097097fb5e414cec75977f58ac..ce548b08865d893308249ccade5a3da2496312e5 100644 (file)
@@ -415,8 +415,8 @@ func (t *Tree) action() (n Node) {
 //     {{break}}
 // Break keyword is past.
 func (t *Tree) breakControl(pos Pos, line int) Node {
-       if token := t.next(); token.typ != itemRightDelim {
-               t.unexpected(token, "in {{break}}")
+       if token := t.nextNonSpace(); token.typ != itemRightDelim {
+               t.unexpected(token, "{{break}}")
        }
        if t.rangeDepth == 0 {
                t.errorf("{{break}} outside {{range}}")
@@ -428,8 +428,8 @@ func (t *Tree) breakControl(pos Pos, line int) Node {
 //     {{continue}}
 // Continue keyword is past.
 func (t *Tree) continueControl(pos Pos, line int) Node {
-       if token := t.next(); token.typ != itemRightDelim {
-               t.unexpected(token, "in {{continue}}")
+       if token := t.nextNonSpace(); token.typ != itemRightDelim {
+               t.unexpected(token, "{{continue}}")
        }
        if t.rangeDepth == 0 {
                t.errorf("{{continue}} outside {{range}}")
index b0e75afa9872c275985b6bdf36b260fa929f1537..52bd6aca276e32991a9109ef46f6cdc3c88700a2 100644 (file)
@@ -263,6 +263,10 @@ var parseTests = []parseTest{
        {"newline in pipeline", "{{\n\"x\"\n|\nprintf\n}}", noError, `{{"x" | printf}}`},
        {"newline in comment", "{{/*\nhello\n*/}}", noError, ""},
        {"newline in comment", "{{-\n/*\nhello\n*/\n-}}", noError, ""},
+       {"spaces around continue", "{{range .SI}}{{.}}{{ continue }}{{end}}", noError,
+               `{{range .SI}}{{.}}{{continue}}{{end}}`},
+       {"spaces around break", "{{range .SI}}{{.}}{{ break }}{{end}}", noError,
+               `{{range .SI}}{{.}}{{break}}{{end}}`},
 
        // Errors.
        {"unclosed action", "hello{{range", hasError, ""},
index 18cebc7d1350691c42416d4ee19d8d82a5b843a7..49722c5c1dde27f02fb9559c71b19e72cfa30770 100644 (file)
@@ -75,9 +75,10 @@ title: "P1"
 -- layouts/partials/counter.html --
 {{ if .Scratch.Get "counter" }}{{ .Scratch.Add "counter" 1 }}{{ else }}{{ .Scratch.Set "counter" 1 }}{{ end }}{{ return true }}
 -- layouts/_default/single.html --
-{{/* Note no spaces in {{continue}} or {{break}}, see https://github.com/golang/go/issues/51670 */}}
 continue:{{ range seq 5 }}{{ if eq . 2 }}{{continue}}{{ end }}{{ . }}{{ end }}:END:
 break:{{ range seq 5 }}{{ if eq . 2 }}{{break}}{{ end }}{{ . }}{{ end }}:END:
+continue2:{{ range seq 5 }}{{ if eq . 2 }}{{ continue }}{{ end }}{{ . }}{{ end }}:END:
+break2:{{ range seq 5 }}{{ if eq . 2 }}{{ break }}{{ end }}{{ . }}{{ end }}:END:
 
 counter1: {{ partial "counter.html" . }}/{{ .Scratch.Get "counter" }}
 and1: {{ if (and false (partial "counter.html" .)) }}true{{ else }}false{{ end }}
@@ -103,6 +104,8 @@ counter2: {{ .Scratch.Get "counter" }}
        b.AssertFileContent("public/p1/index.html", `
 continue:1345:END:
 break:1:END:
+continue2:1345:END:
+break2:1:END:
 counter1: true/1
 and1: false
 or1: true