Commit aca8071f authored by Rob Pike's avatar Rob Pike

text/template: evaluate function fields

Just an oversight they didn't work and easy to address.

Fixes #3025.

R=golang-dev, dsymonds
CC=golang-dev
https://golang.org/cl/5656059
parent 9a445600
...@@ -419,10 +419,14 @@ func (s *state) evalField(dot reflect.Value, fieldName string, args []parse.Node ...@@ -419,10 +419,14 @@ func (s *state) evalField(dot reflect.Value, fieldName string, args []parse.Node
tField, ok := receiver.Type().FieldByName(fieldName) tField, ok := receiver.Type().FieldByName(fieldName)
if ok { if ok {
field := receiver.FieldByIndex(tField.Index) field := receiver.FieldByIndex(tField.Index)
if tField.PkgPath == "" { // field is exported
// If it's a function, we must call it.
if field.Type().Kind() == reflect.Func {
return s.evalCall(dot, field, fieldName, args, final)
}
if hasArgs { if hasArgs {
s.errorf("%s is not a method but has arguments", fieldName) s.errorf("%s is not a method or function but has arguments", fieldName)
} }
if tField.PkgPath == "" { // field is exported
return field return field
} }
} }
......
...@@ -59,6 +59,8 @@ type T struct { ...@@ -59,6 +59,8 @@ type T struct {
PI *int PI *int
PSI *[]int PSI *[]int
NIL *int NIL *int
// Function (not method)
Func func(...string) string
// Template to test evaluation of templates. // Template to test evaluation of templates.
Tmpl *Template Tmpl *Template
} }
...@@ -118,6 +120,7 @@ var tVal = &T{ ...@@ -118,6 +120,7 @@ var tVal = &T{
Err: errors.New("erroozle"), Err: errors.New("erroozle"),
PI: newInt(23), PI: newInt(23),
PSI: newIntSlice(21, 22, 23), PSI: newIntSlice(21, 22, 23),
Func: func(s ...string) string { return fmt.Sprint("<", strings.Join(s, "+"), ">") },
Tmpl: Must(New("x").Parse("test template")), // "x" is the value of .X Tmpl: Must(New("x").Parse("test template")), // "x" is the value of .X
} }
...@@ -297,8 +300,13 @@ var execTests = []execTest{ ...@@ -297,8 +300,13 @@ var execTests = []execTest{
"{{with $x := .}}{{with .SI}}{{$.GetU.TrueFalse $.True}}{{end}}{{end}}", "{{with $x := .}}{{with .SI}}{{$.GetU.TrueFalse $.True}}{{end}}{{end}}",
"true", tVal, true}, "true", tVal, true},
// Function call
{".Func", "-{{.Func}}-", "-<>-", tVal, true},
{".Func2", "-{{.Func `he` `llo`}}-", "-<he+llo>-", tVal, true},
// Pipelines. // Pipelines.
{"pipeline", "-{{.Method0 | .Method2 .U16}}-", "-Method2: 16 M0-", tVal, true}, {"pipeline", "-{{.Method0 | .Method2 .U16}}-", "-Method2: 16 M0-", tVal, true},
{"pipeline func", "-{{.Func `llo` | .Func `he` }}-", "-<he+<llo>>-", tVal, true},
// If. // If.
{"if true", "{{if true}}TRUE{{end}}", "TRUE", tVal, true}, {"if true", "{{if true}}TRUE{{end}}", "TRUE", tVal, true},
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment