zclsyntax: disallow dupe keys in "for" when grouping not enabled

This commit is contained in:
Martin Atkins 2017-06-18 08:49:52 -07:00
parent 2506450b6e
commit 1ef7d6f6de
2 changed files with 26 additions and 1 deletions

View File

@ -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

View File

@ -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,