forked from OSchip/llvm-project
improve comments, build array and array range designator nodes,
fix an obscure memory leak. llvm-svn: 58213
This commit is contained in:
parent
7243245a58
commit
8aafd35c79
|
@ -104,11 +104,18 @@ ParseInitializerWithPotentialDesignator(InitListDesignations &Designations,
|
||||||
// We must have either an array designator now or an objc message send.
|
// We must have either an array designator now or an objc message send.
|
||||||
assert(Tok.is(tok::l_square) && "Unexpected token!");
|
assert(Tok.is(tok::l_square) && "Unexpected token!");
|
||||||
|
|
||||||
|
// Handle the two forms of array designator:
|
||||||
// array-designator: '[' constant-expression ']'
|
// array-designator: '[' constant-expression ']'
|
||||||
// array-designator: '[' constant-expression '...' constant-expression ']'
|
// array-designator: '[' constant-expression '...' constant-expression ']'
|
||||||
// When designation is empty, this can be '[' objc-message-expr ']'. Note
|
//
|
||||||
// that we also have the case of [4][foo bar], which is the gnu designator
|
// Also, we have to handle the case where the expression after the
|
||||||
// extension + objc message send.
|
// designator an an objc message send: '[' objc-message-expr ']'.
|
||||||
|
// Interesting cases are:
|
||||||
|
// [foo bar] -> objc message send
|
||||||
|
// [foo] -> array designator
|
||||||
|
// [foo ... bar] -> array designator
|
||||||
|
// [4][foo bar] -> obsolete GNU designation with objc message send.
|
||||||
|
//
|
||||||
SourceLocation StartLoc = ConsumeBracket();
|
SourceLocation StartLoc = ConsumeBracket();
|
||||||
|
|
||||||
// If Objective-C is enabled and this is a typename or other identifier
|
// If Objective-C is enabled and this is a typename or other identifier
|
||||||
|
@ -141,16 +148,25 @@ ParseInitializerWithPotentialDesignator(InitListDesignations &Designations,
|
||||||
return ParseAssignmentExprWithObjCMessageExprStart(StartLoc, 0,Idx.Val);
|
return ParseAssignmentExprWithObjCMessageExprStart(StartLoc, 0,Idx.Val);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Create designation if we haven't already.
|
||||||
|
if (Desig == 0)
|
||||||
|
Desig = &Designations.CreateDesignation(InitNum);
|
||||||
|
|
||||||
|
// If this is a normal array designator, remember it.
|
||||||
|
if (Tok.isNot(tok::ellipsis)) {
|
||||||
|
Desig->AddDesignator(Designator::getArray(Idx.Val));
|
||||||
|
} else {
|
||||||
// Handle the gnu array range extension.
|
// Handle the gnu array range extension.
|
||||||
if (Tok.is(tok::ellipsis)) {
|
|
||||||
Diag(Tok, diag::ext_gnu_array_range);
|
Diag(Tok, diag::ext_gnu_array_range);
|
||||||
ConsumeToken();
|
ConsumeToken();
|
||||||
|
|
||||||
ExprResult RHS = ParseConstantExpression();
|
ExprResult RHS = ParseConstantExpression();
|
||||||
if (RHS.isInvalid) {
|
if (RHS.isInvalid) {
|
||||||
|
Actions.DeleteExpr(Idx.Val);
|
||||||
SkipUntil(tok::r_square);
|
SkipUntil(tok::r_square);
|
||||||
return RHS;
|
return RHS;
|
||||||
}
|
}
|
||||||
|
Desig->AddDesignator(Designator::getArrayRange(Idx.Val, RHS.Val));
|
||||||
}
|
}
|
||||||
|
|
||||||
MatchRHSPunctuation(tok::r_square, StartLoc);
|
MatchRHSPunctuation(tok::r_square, StartLoc);
|
||||||
|
|
Loading…
Reference in New Issue