2017-09-11 23:56:31 +00:00
|
|
|
// Package userfunc implements a HCL extension that allows user-defined
|
|
|
|
// functions in HCL configuration.
|
2017-07-26 01:34:56 +00:00
|
|
|
//
|
|
|
|
// Using this extension requires some integration effort on the part of the
|
2017-09-11 23:56:31 +00:00
|
|
|
// calling application, to pass any declared functions into a HCL evaluation
|
2017-07-26 01:34:56 +00:00
|
|
|
// context after processing.
|
|
|
|
//
|
|
|
|
// The function declaration syntax looks like this:
|
|
|
|
//
|
|
|
|
// function "foo" {
|
|
|
|
// params = ["name"]
|
|
|
|
// result = "Hello, ${name}!"
|
|
|
|
// }
|
|
|
|
//
|
|
|
|
// When a user-defined function is called, the expression given for the "result"
|
|
|
|
// attribute is evaluated in an isolated evaluation context that defines variables
|
|
|
|
// named after the given parameter names.
|
|
|
|
//
|
|
|
|
// The block name "function" may be overridden by the calling application, if
|
|
|
|
// that default name conflicts with an existing block or attribute name in
|
|
|
|
// the application.
|
|
|
|
package userfunc
|