Stop dividing templates up, and execute by name

- This allows us to use templates defined from anywhere in other
  templates.
This commit is contained in:
Aaron L 2016-07-16 23:55:15 -07:00
parent 7545343e0d
commit e08eacad05
5 changed files with 95 additions and 40 deletions

View file

@ -73,7 +73,7 @@ type executeTemplateData struct {
state *State
data *templateData
templates templateList
templates *templateList
importSet imports
importNamedSet map[string]imports
@ -94,14 +94,14 @@ func executeTemplates(e executeTemplateData) error {
imps.standard = e.importSet.standard
imps.thirdParty = e.importSet.thirdParty
for _, template := range e.templates {
for _, tplName := range e.templates.Templates() {
if e.combineImportsOnType {
imps = combineTypeImports(imps, importsBasedOnType, e.data.Table.Columns)
}
resp, err := executeTemplate(template, e.data)
resp, err := executeTemplate(e.templates.Template, tplName, e.data)
if err != nil {
return fmt.Errorf("Error generating template %s: %s", template.Name(), err)
return fmt.Errorf("Error generating template %s: %s", tplName, err)
}
out = append(out, resp)
}
@ -122,13 +122,13 @@ func executeSingletonTemplates(e executeTemplateData) error {
rgxRemove := regexp.MustCompile(`[0-9]+_`)
for _, template := range e.templates {
resp, err := executeTemplate(template, e.data)
for _, tplName := range e.templates.Templates() {
resp, err := executeTemplate(e.templates.Template, tplName, e.data)
if err != nil {
return fmt.Errorf("Error generating template %s: %s", template.Name(), err)
return fmt.Errorf("Error generating template %s: %s", tplName, err)
}
fName := template.Name()
fName := tplName
ext := filepath.Ext(fName)
fName = rgxRemove.ReplaceAllString(fName[:len(fName)-len(ext)], "")
@ -163,7 +163,7 @@ func generateTestMainOutput(state *State, data *templateData) error {
imps.standard = defaultTestMainImports[state.Config.DriverName].standard
imps.thirdParty = defaultTestMainImports[state.Config.DriverName].thirdParty
resp, err := executeTemplate(state.TestMainTemplate, data)
resp, err := executeTemplate(state.TestMainTemplate, state.TestMainTemplate.Name(), data)
if err != nil {
return err
}
@ -213,9 +213,9 @@ var rgxSyntaxError = regexp.MustCompile(`(\d+):\d+: `)
// executeTemplate takes a template and returns the output of the template
// execution.
func executeTemplate(t *template.Template, data *templateData) ([]byte, error) {
func executeTemplate(t *template.Template, name string, data *templateData) ([]byte, error) {
var buf bytes.Buffer
if err := t.Execute(&buf, data); err != nil {
if err := t.ExecuteTemplate(&buf, name, data); err != nil {
return nil, errors.Wrap(err, "failed to execute template")
}

View file

@ -30,10 +30,10 @@ type State struct {
Driver bdb.Interface
Tables []bdb.Table
Templates templateList
TestTemplates templateList
SingletonTemplates templateList
SingletonTestTemplates templateList
Templates *templateList
TestTemplates *templateList
SingletonTemplates *templateList
SingletonTestTemplates *templateList
TestMainTemplate *template.Template
}

View file

@ -96,7 +96,7 @@ func TestTemplates(t *testing.T) {
t.Fatalf("Unable to initialize templates: %s", err)
}
if len(state.Templates) == 0 {
if len(state.Templates.Templates()) == 0 {
t.Errorf("Templates is empty.")
}
@ -105,7 +105,7 @@ func TestTemplates(t *testing.T) {
t.Fatalf("Unable to initialize singleton templates: %s", err)
}
if len(state.SingletonTemplates) == 0 {
if len(state.SingletonTemplates.Templates()) == 0 {
t.Errorf("SingletonTemplates is empty.")
}
@ -114,7 +114,7 @@ func TestTemplates(t *testing.T) {
t.Fatalf("Unable to initialize templates: %s", err)
}
if len(state.Templates) == 0 {
if len(state.Templates.Templates()) == 0 {
t.Errorf("Templates is empty.")
}
@ -128,7 +128,7 @@ func TestTemplates(t *testing.T) {
t.Fatalf("Unable to initialize single test templates: %s", err)
}
if len(state.SingletonTestTemplates) == 0 {
if len(state.SingletonTestTemplates.Templates()) == 0 {
t.Errorf("SingleTestTemplates is empty.")
}

View file

@ -22,23 +22,27 @@ type templateData struct {
StringFuncs map[string]func(string) string
}
type templateList []*template.Template
type templateList struct {
*template.Template
}
func (t templateList) Len() int {
type templateNameList []string
func (t templateNameList) Len() int {
return len(t)
}
func (t templateList) Swap(k, j int) {
func (t templateNameList) Swap(k, j int) {
t[k], t[j] = t[j], t[k]
}
func (t templateList) Less(k, j int) bool {
func (t templateNameList) Less(k, j int) bool {
// Make sure "struct" goes to the front
if t[k].Name() == "struct.tpl" {
if t[k] == "struct.tpl" {
return true
}
res := strings.Compare(t[k].Name(), t[j].Name())
res := strings.Compare(t[k], t[j])
if res <= 0 {
return true
}
@ -46,8 +50,28 @@ func (t templateList) Less(k, j int) bool {
return false
}
// Templates returns the name of all the templates defined in the template list
func (t templateList) Templates() []string {
tplList := t.Template.Templates()
if len(tplList) == 0 {
return nil
}
ret := make([]string, 0, len(tplList))
for _, tpl := range tplList {
if name := tpl.Name(); strings.HasSuffix(name, ".tpl") {
ret = append(ret, name)
}
}
sort.Sort(templateNameList(ret))
return ret
}
// loadTemplates loads all of the template files in the specified directory.
func loadTemplates(dir string) (templateList, error) {
func loadTemplates(dir string) (*templateList, error) {
wd, err := os.Getwd()
if err != nil {
return nil, err
@ -60,10 +84,7 @@ func loadTemplates(dir string) (templateList, error) {
return nil, err
}
templates := templateList(tpl.Templates())
sort.Sort(templates)
return templates, err
return &templateList{Template: tpl}, err
}
// loadTemplate loads a single template file.

View file

@ -6,19 +6,21 @@ import (
"text/template"
)
func TestTemplateListSort(t *testing.T) {
templs := templateList{
template.New("bob.tpl"),
template.New("all.tpl"),
template.New("struct.tpl"),
template.New("ttt.tpl"),
func TestTemplateNameListSort(t *testing.T) {
t.Parallel()
templs := templateNameList{
"bob.tpl",
"all.tpl",
"struct.tpl",
"ttt.tpl",
}
expected := []string{"bob.tpl", "all.tpl", "struct.tpl", "ttt.tpl"}
for i, v := range templs {
if v.Name() != expected[i] {
t.Errorf("Order mismatch, expected: %s, got: %s", expected[i], v.Name())
if v != expected[i] {
t.Errorf("Order mismatch, expected: %s, got: %s", expected[i], v)
}
}
@ -27,8 +29,40 @@ func TestTemplateListSort(t *testing.T) {
sort.Sort(templs)
for i, v := range templs {
if v.Name() != expected[i] {
t.Errorf("Order mismatch, expected: %s, got: %s", expected[i], v.Name())
if v != expected[i] {
t.Errorf("Order mismatch, expected: %s, got: %s", expected[i], v)
}
}
}
func TestTemplateList_Templates(t *testing.T) {
t.Parallel()
tpl := template.New("")
tpl.New("wat.tpl").Parse("hello")
tpl.New("que.tpl").Parse("there")
tpl.New("not").Parse("hello")
tplList := templateList{tpl}
foundWat, foundQue, foundNot := false, false, false
for _, n := range tplList.Templates() {
switch n {
case "wat.tpl":
foundWat = true
case "que.tpl":
foundQue = true
case "not":
foundNot = true
}
}
if !foundWat {
t.Error("want wat")
}
if !foundQue {
t.Error("want que")
}
if foundNot {
t.Error("don't want not")
}
}