hclparser: strip out blocks for json files

Body.JustAttributes cannot distinguish between blocks and attributes for
JSON files, so the variable block could be included in the list of
attributes returned.

This patch ensures that JSON and HCL files behave the same way by
removing all known block types first, from the provided config schema
and then from a generated definitions schema.

Fixes #1051

Signed-off-by: Justin Chadwell <me@jedevc.com>
pull/1080/head
Justin Chadwell 3 years ago
parent 6a702ebe5b
commit 03885ec9f1

@ -745,3 +745,13 @@ target "two" {
require.Equal(t, c.Targets[1].Name, "two") require.Equal(t, c.Targets[1].Name, "two")
require.Equal(t, map[string]string{"b": "pre-jkl"}, c.Targets[1].Args) require.Equal(t, map[string]string{"b": "pre-jkl"}, c.Targets[1].Args)
} }
func TestEmptyVariableJSON(t *testing.T) {
dt := []byte(`{
"variable": {
"VAR": {}
}
}`)
_, err := ParseFile(dt, "docker-bake.json")
require.NoError(t, err)
}

@ -256,6 +256,7 @@ func Parse(b hcl.Body, opt Opt, val interface{}) hcl.Diagnostics {
if err := gohcl.DecodeBody(b, nil, &defs); err != nil { if err := gohcl.DecodeBody(b, nil, &defs); err != nil {
return err return err
} }
defsSchema, _ := gohcl.ImpliedBodySchema(defs)
if opt.LookupVar == nil { if opt.LookupVar == nil {
opt.LookupVar = func(string) (string, bool) { opt.LookupVar = func(string) (string, bool) {
@ -300,6 +301,16 @@ func Parse(b hcl.Body, opt Opt, val interface{}) hcl.Diagnostics {
p.funcs[v.Name] = v p.funcs[v.Name] = v
} }
content, b, diags := b.PartialContent(schema)
if diags.HasErrors() {
return diags
}
_, b, diags = b.PartialContent(defsSchema)
if diags.HasErrors() {
return diags
}
attrs, diags := b.JustAttributes() attrs, diags := b.JustAttributes()
if diags.HasErrors() { if diags.HasErrors() {
if d := removeAttributesDiags(diags, reserved, p.vars); len(d) > 0 { if d := removeAttributesDiags(diags, reserved, p.vars); len(d) > 0 {
@ -371,11 +382,6 @@ func Parse(b hcl.Body, opt Opt, val interface{}) hcl.Diagnostics {
} }
} }
content, _, diags := b.PartialContent(schema)
if diags.HasErrors() {
return diags
}
for _, a := range content.Attributes { for _, a := range content.Attributes {
return hcl.Diagnostics{ return hcl.Diagnostics{
&hcl.Diagnostic{ &hcl.Diagnostic{

Loading…
Cancel
Save