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 {
|
||||
k := key.AsString()
|
||||
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 {
|
||||
vals[key.AsString()] = val
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if !known {
|
||||
return cty.DynamicVal, diags
|
||||
|
@ -529,6 +529,17 @@ upper(
|
||||
}),
|
||||
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...]`,
|
||||
nil,
|
||||
|
Loading…
Reference in New Issue
Block a user