hclsyntax: If nested block doesn't parse, produce empty body

Our usual rule for parse errors is to return a valid-but-incomplete object
along with error diagnostics. This was violating that rule by returning
a nil child body, which callers do not expect to deal with.

Instead, we'll return an *empty* body, so that callers who use the partial
result for careful analyses can still process the block header, without
needing to guard against the body being nil.
This commit is contained in:
Martin Atkins 2018-10-01 14:06:26 -07:00
parent cce5ae6cc5
commit 3e4b7e0eb2

View File

@ -273,7 +273,10 @@ Token:
return &Block{ return &Block{
Type: blockType, Type: blockType,
Labels: labels, Labels: labels,
Body: nil, Body: &Body{
SrcRange: ident.Range,
EndRange: ident.Range,
},
TypeRange: ident.Range, TypeRange: ident.Range,
LabelRanges: labelRanges, LabelRanges: labelRanges,