internal/parser/hcl.go (61 lines of code) (raw):

package parser import ( "github.com/hashicorp/hcl/v2" "github.com/hashicorp/hcl/v2/hclsyntax" "github.com/zclconf/go-cty/cty" ) func ToLiteral(expression hclsyntax.Expression) *string { value, dialog := expression.Value(&hcl.EvalContext{}) if dialog != nil && dialog.HasErrors() { return nil } if value.Type() == cty.String && !value.IsNull() && value.IsKnown() { v := value.AsString() return &v } return nil } func ToLiteralBoolean(expression hclsyntax.Expression) *bool { value, dialog := expression.Value(&hcl.EvalContext{}) if dialog != nil && dialog.HasErrors() { return nil } if value.Type() == cty.Bool && !value.IsNull() && value.IsKnown() { v := value.True() return &v } return nil } func BlockAtPos(body *hclsyntax.Body, pos hcl.Pos) *hclsyntax.Block { for _, b := range body.Blocks { if ContainsPos(b.Range(), pos) { return b } } return nil } func AttributeAtPos(block *hclsyntax.Block, pos hcl.Pos) *hclsyntax.Attribute { if block == nil { return nil } for _, attr := range block.Body.Attributes { if ContainsPos(attr.SrcRange, pos) { return attr } if ContainsPos(attr.Expr.Range(), pos) { return attr } } return nil } func AttributeWithName(block *hclsyntax.Block, name string) *hclsyntax.Attribute { if block == nil { return nil } for _, attr := range block.Body.Attributes { if attr.Name == name { return attr } } return nil }