From eb3aed18821146725128821988ecf5f468c6e43f Mon Sep 17 00:00:00 2001 From: Michael Sauter Date: Fri, 3 Nov 2023 08:46:44 +0100 Subject: [PATCH] Add keys helper --- build/docs/render.adoc | 1 + cmd/render/template_funcs.go | 9 +++++++++ 2 files changed, 10 insertions(+) diff --git a/build/docs/render.adoc b/build/docs/render.adoc index 64ae861..f785751 100644 --- a/build/docs/render.adoc +++ b/build/docs/render.adoc @@ -16,5 +16,6 @@ The Go template has access to the following helper functions: * `toYAML`. Turns the given object into a YAML string. * `parseTime`. Parses a string using the specified layout into a `time.Time`. This function is just a wrapper around link:https://pkg.go.dev/time#Parse[time.Parse], see its documentation for details how to specify various layouts. Once parsed, the time can be formatted with `{{$t.Format ""}}` as per link:https://pkg.go.dev/time#Time.Format[time.Format]. * `toSentence`. Turns a slice into a string enumerating its items. The words are connected with commas, except for the last two words, which are connected with "and". +* `keys`. Returns a slice of all keys of given map. After the Go template has been rendered, link:https://github.com/asciidoctor/asciidoctor-pdf[asciidoctor-pdf] is used to turn each rendered asciidoc file into a PDF file. The resulting files are placed into the directory specified by `output-dir` (defaulting to `.ods/artifacts/org.opendevstack.pipeline.adoc.pdf` so that created PDFs are preserved as artifacts in Nexus). Theming is possible by specifying the `pdf-theme` parameter as explained in the link:https://docs.asciidoctor.org/pdf-converter/latest/theme/apply-theme/#theme-and-font-directories[Theme and font directories] documentation. diff --git a/cmd/render/template_funcs.go b/cmd/render/template_funcs.go index 1c378d3..2dbd7ed 100644 --- a/cmd/render/template_funcs.go +++ b/cmd/render/template_funcs.go @@ -13,6 +13,7 @@ var templateFuncs = template.FuncMap{ "toYAML": toYAML, "parseTime": parseTime, "toSentence": toSentence, + "keys": keys, } // fromMultiYAML turns a string of multiple YAML documents @@ -55,3 +56,11 @@ func toSentence(items []string) string { return strings.Join(items[0:len(items)-1], ", ") + " and " + items[len(items)-1] } } + +// keys returns a slice of all keys in map m. +func keys(m map[string]any) (keys []string) { + for k, _ := range m { + keys = append(keys, k) + } + return +}