Skip to content

Commit

Permalink
Add additional template functions
Browse files Browse the repository at this point in the history
Adds templat functions which:
- to exec an inline template
- indent a template
- remove n continuous empty lines from a template

An example would be a template like:
```
{{define "my-template"}}new template

content

with empty lines

to
remove
{{end}}
Some other template content and add the rendered from my-template
{{$var := execTempl "my-template" . | removeNewLines 1}}
{{$var}}
```

Co-authored-by: auniyal61

Signed-off-by: Martin Schuppert <[email protected]>
  • Loading branch information
stuggi committed Oct 14, 2024
1 parent 66e6544 commit 494a53f
Show file tree
Hide file tree
Showing 4 changed files with 374 additions and 7 deletions.
6 changes: 5 additions & 1 deletion .pre-commit-config.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -40,4 +40,8 @@ repos:
exclude: ^vendor
- id: no-commit-to-branch
- id: trailing-whitespace
exclude: ^vendor
exclude: |
(?x)(
^vendor|
^modules/common/util/template_util_test.go
)
98 changes: 92 additions & 6 deletions modules/common/util/template_util.go
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@ limitations under the License.
package util

import (
"bufio"
"bytes"
"fmt"
"os"
Expand Down Expand Up @@ -138,6 +139,82 @@ func ExecuteTemplate(templateFile string, data interface{}) (string, error) {
return renderedTemplate, nil
}

// template functions
var tmpl *template.Template

// template function which allows to execute a template from within
// a template file.
// name - name of the template as defined with with `{{define "some-template"}}your template{{end}}
// data - data to pass into to render the template for all can use `.`
func execTempl(name string, data interface{}) (string, error) {
buf := &bytes.Buffer{}
err := tmpl.ExecuteTemplate(buf, name, data)
return buf.String(), err
}

// template function to indent the template with n tabs
func indent(n int, in string) string {
var out string
s := bufio.NewScanner(bytes.NewReader([]byte(in)))
for s.Scan() {
line := strings.TrimSpace(s.Text())
for i := 0; i < n; i++ {
line = "\t" + line
}
out += line + "\n"
}
return out
}

// template function to remove empty lines if there are > n continuous empty lines
func removeNewLines(n int, in string) string {
var out string
s := bufio.NewScanner(bytes.NewReader([]byte(in)))

// Variable to keep track of consecutive empty lines
emptyLineCount := 0
for s.Scan() {
line := s.Text()

if strings.TrimSpace(line) == "" {
emptyLineCount++
// If we have already seen more then n empty lines, skip this one
if emptyLineCount > n {
continue
}
} else {
// Reset the empty line counter when we encounter a non-empty line
emptyLineCount = 0
}

out += line + "\n"
}
return out
}

// This function removes extra space and new-lines from conf data.
func removeNewLinesInSections(in string) string {
var out string
s := bufio.NewScanner(bytes.NewReader([]byte(in)))

for s.Scan() {
line := strings.TrimSpace(s.Text())

if line != "" {
if strings.HasPrefix(line, "[") && strings.HasSuffix(line, "]") {
// new section-header
if len(out) > 0 {
out += "\n"
}
}

out += line + "\n"
}
}

return out
}

// template function to increment an int
func add(x, y int) int {
return x + y
Expand All @@ -153,11 +230,16 @@ func lower(s string) string {
func ExecuteTemplateData(templateData string, data interface{}) (string, error) {

var buff bytes.Buffer
var err error
funcs := template.FuncMap{
"add": add,
"lower": lower,
"add": add,
"execTempl": execTempl,
"indent": indent,
"lower": lower,
"removeNewLines": removeNewLines,
"removeNewLinesInSections": removeNewLinesInSections,
}
tmpl, err := template.New("tmp").Option("missingkey=error").Funcs(funcs).Parse(templateData)
tmpl, err = template.New("tmp").Option("missingkey=error").Funcs(funcs).Parse(templateData)
if err != nil {
return "", err
}
Expand Down Expand Up @@ -193,10 +275,14 @@ func ExecuteTemplateFile(filename string, data interface{}) (string, error) {
file := string(b)
var buff bytes.Buffer
funcs := template.FuncMap{
"add": add,
"lower": lower,
"add": add,
"execTempl": execTempl,
"indent": indent,
"lower": lower,
"removeNewLines": removeNewLines,
"removeNewLinesInSections": removeNewLinesInSections,
}
tmpl, err := template.New("tmp").Option("missingkey=error").Funcs(funcs).Parse(file)
tmpl, err = template.New("tmp").Option("missingkey=error").Funcs(funcs).Parse(file)
if err != nil {
return "", err
}
Expand Down
Loading

0 comments on commit 494a53f

Please sign in to comment.