aboutsummaryrefslogtreecommitdiff
path: root/src/text
diff options
context:
space:
mode:
authorIan Lance Taylor <iant@golang.org>2021-09-17 12:27:23 -0700
committerIan Lance Taylor <iant@golang.org>2021-09-20 23:00:47 +0000
commitba1c52d7d77724de4407572bd02421c36df3d78a (patch)
treeb05a31e2c061e069d2516beaf9920d3e81449c4d /src/text
parent6e81f78c0f1653ea140e6c8d008700ddad1fa0a5 (diff)
downloadgo-ba1c52d7d77724de4407572bd02421c36df3d78a.tar.gz
go-ba1c52d7d77724de4407572bd02421c36df3d78a.zip
text/template: initialize template before locking it
For #39807 Fixes #48436 Change-Id: I75f82fd8738dd2f11f0c69b1230e1be1abc36024 Reviewed-on: https://go-review.googlesource.com/c/go/+/350730 Trust: Ian Lance Taylor <iant@golang.org> Trust: Daniel Martí <mvdan@mvdan.cc> Run-TryBot: Ian Lance Taylor <iant@golang.org> TryBot-Result: Go Bot <gobot@golang.org> Reviewed-by: Daniel Martí <mvdan@mvdan.cc>
Diffstat (limited to 'src/text')
-rw-r--r--src/text/template/multi_test.go10
-rw-r--r--src/text/template/template.go2
2 files changed, 11 insertions, 1 deletions
diff --git a/src/text/template/multi_test.go b/src/text/template/multi_test.go
index b543ab5c47..6b81ffe7ac 100644
--- a/src/text/template/multi_test.go
+++ b/src/text/template/multi_test.go
@@ -452,3 +452,13 @@ func TestIssue19294(t *testing.T) {
}
}
}
+
+// Issue 48436
+func TestAddToZeroTemplate(t *testing.T) {
+ tree, err := parse.Parse("c", cloneText3, "", "", nil, builtins())
+ if err != nil {
+ t.Fatal(err)
+ }
+ var tmpl Template
+ tmpl.AddParseTree("x", tree["c"])
+}
diff --git a/src/text/template/template.go b/src/text/template/template.go
index fd74d45e9b..776be9cd07 100644
--- a/src/text/template/template.go
+++ b/src/text/template/template.go
@@ -127,9 +127,9 @@ func (t *Template) copy(c *common) *Template {
// its definition. If it has been defined and already has that name, the existing
// definition is replaced; otherwise a new template is created, defined, and returned.
func (t *Template) AddParseTree(name string, tree *parse.Tree) (*Template, error) {
+ t.init()
t.muTmpl.Lock()
defer t.muTmpl.Unlock()
- t.init()
nt := t
if name != t.name {
nt = t.New(name)