Files
terraform-docs/format/asciidoc_document.go
Khosrow Moossavi 465dd14cff Make terraform.Module available in content
Add one extra special variable the `content`:

- `{{ .Module }}`

As opposed to the other variables, which are generated sections based on
a selected formatter, the `{{ .Module }}` variable is just a `struct`
representing a Terraform module.

It can be used to build highly complex and highly customized content:

```yaml
content: |-
  ## Resources

  {{ range .Module.Resources }}
  - {{ .GetMode }}.{{ .Spec }} ({{ .Position.Filename }}#{{ .Position.Line }})
  {{- end }}
```

Signed-off-by: Khosrow Moossavi <khos2ow@gmail.com>
2021-10-04 20:01:44 -04:00

93 lines
2.1 KiB
Go

/*
Copyright 2021 The terraform-docs Authors.
Licensed under the MIT license (the "License"); you may not
use this file except in compliance with the License.
You may obtain a copy of the License at the LICENSE file in
the root directory of this source tree.
*/
package format
import (
"embed"
gotemplate "text/template"
"github.com/terraform-docs/terraform-docs/print"
"github.com/terraform-docs/terraform-docs/template"
"github.com/terraform-docs/terraform-docs/terraform"
)
//go:embed templates/asciidoc_document*.tmpl
var asciidocsDocumentFS embed.FS
// asciidocDocument represents AsciiDoc Document format.
type asciidocDocument struct {
*generator
config *print.Config
template *template.Template
}
// NewAsciidocDocument returns new instance of Asciidoc Document.
func NewAsciidocDocument(config *print.Config) Type {
items := readTemplateItems(asciidocsDocumentFS, "asciidoc_document")
config.Settings.Escape = false
tt := template.New(config, items...)
tt.CustomFunc(gotemplate.FuncMap{
"type": func(t string) string {
result, extraline := PrintFencedAsciidocCodeBlock(t, "hcl")
if !extraline {
result += "\n"
}
return result
},
"value": func(v string) string {
if v == "n/a" {
return v
}
result, extraline := PrintFencedAsciidocCodeBlock(v, "json")
if !extraline {
result += "\n"
}
return result
},
"isRequired": func() bool {
return config.Settings.Required
},
})
return &asciidocDocument{
generator: newGenerator(config, true),
config: config,
template: tt,
}
}
// Generate a Terraform module as AsciiDoc document.
func (d *asciidocDocument) Generate(module *terraform.Module) error {
err := d.generator.forEach(func(name string) (string, error) {
rendered, err := d.template.Render(name, module)
if err != nil {
return "", err
}
return sanitize(rendered), nil
})
d.generator.funcs(withModule(module))
return err
}
func init() {
register(map[string]initializerFn{
"asciidoc document": NewAsciidocDocument,
"asciidoc doc": NewAsciidocDocument,
"adoc document": NewAsciidocDocument,
"adoc doc": NewAsciidocDocument,
})
}