zclsyntax: disallow dupe keys in "for" when grouping not enabled
This commit is contained in:
parent
2506450b6e
commit
1ef7d6f6de
@ -801,10 +801,24 @@ func (e *ForExpr) Value(ctx *zcl.EvalContext) (cty.Value, zcl.Diagnostics) {
|
|||||||
if e.Group {
|
if e.Group {
|
||||||
k := key.AsString()
|
k := key.AsString()
|
||||||
groupVals[k] = append(groupVals[k], val)
|
groupVals[k] = append(groupVals[k], val)
|
||||||
|
} else {
|
||||||
|
k := key.AsString()
|
||||||
|
if _, exists := vals[k]; exists {
|
||||||
|
diags = append(diags, &zcl.Diagnostic{
|
||||||
|
Severity: zcl.DiagError,
|
||||||
|
Summary: "Duplicate object key",
|
||||||
|
Detail: fmt.Sprintf(
|
||||||
|
"Two different items produced the key %q in this for expression. If duplicates are expected, use the ellipsis (...) after the value expression to enable grouping by key.",
|
||||||
|
k,
|
||||||
|
),
|
||||||
|
Subject: e.KeyExpr.Range().Ptr(),
|
||||||
|
Context: &e.SrcRange,
|
||||||
|
})
|
||||||
} else {
|
} else {
|
||||||
vals[key.AsString()] = val
|
vals[key.AsString()] = val
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if !known {
|
if !known {
|
||||||
return cty.DynamicVal, diags
|
return cty.DynamicVal, diags
|
||||||
|
@ -529,6 +529,17 @@ upper(
|
|||||||
}),
|
}),
|
||||||
0,
|
0,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
`{for i, v in ["a", "b", "c", "b", "d"]: v => i}`,
|
||||||
|
nil,
|
||||||
|
cty.ObjectVal(map[string]cty.Value{
|
||||||
|
"a": cty.NumberIntVal(0),
|
||||||
|
"b": cty.NumberIntVal(1),
|
||||||
|
"c": cty.NumberIntVal(2),
|
||||||
|
"d": cty.NumberIntVal(4),
|
||||||
|
}),
|
||||||
|
1, // duplicate key "b"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
`[for v in {hello: "world"}: v...]`,
|
`[for v in {hello: "world"}: v...]`,
|
||||||
nil,
|
nil,
|
||||||
|
Loading…
Reference in New Issue
Block a user