|
|
|
@ -74,18 +74,20 @@ type staticConfig struct {
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func ParseHCL(dt []byte, fn string) (*Config, error) {
|
|
|
|
|
var file *hcl.File
|
|
|
|
|
var diags hcl.Diagnostics
|
|
|
|
|
|
|
|
|
|
// Decode user defined functions.
|
|
|
|
|
// Decode user defined functions, first parsing as hcl and falling back to
|
|
|
|
|
// json, returning errors based on the file suffix.
|
|
|
|
|
file, hcldiags := hclsyntax.ParseConfig(dt, fn, hcl.Pos{Line: 1, Column: 1})
|
|
|
|
|
if hcldiags.HasErrors() {
|
|
|
|
|
var jsondiags hcl.Diagnostics
|
|
|
|
|
file, jsondiags = json.Parse(dt, fn)
|
|
|
|
|
if jsondiags.HasErrors() {
|
|
|
|
|
fnl := strings.ToLower(fn)
|
|
|
|
|
if strings.HasSuffix(fnl, ".json") {
|
|
|
|
|
file, diags = json.Parse(dt, fn)
|
|
|
|
|
return nil, jsondiags
|
|
|
|
|
} else {
|
|
|
|
|
file, diags = hclsyntax.ParseConfig(dt, fn, hcl.Pos{Line: 1, Column: 1})
|
|
|
|
|
return nil, hcldiags
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
if diags.HasErrors() {
|
|
|
|
|
return nil, diags
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
userFunctions, _, diags := userfunc.DecodeUserFunctions(file.Body, "function", func() *hcl.EvalContext {
|
|
|
|
|