forked from OSchip/llvm-project
Improve the diagnostics generated for switch statements missing expressions
- Move the diagnostic to the case statement instead of at the end of the switch - Add a fix-it hint as to how to fix the compilation error llvm-svn: 132903
This commit is contained in:
parent
ff455bbc3c
commit
0ac67fa22f
|
@ -502,6 +502,7 @@ StmtResult Parser::ParseCaseStatement(ParsedAttributes &attrs, bool MissingCase,
|
||||||
StmtTy *DeepestParsedCaseStmt = 0;
|
StmtTy *DeepestParsedCaseStmt = 0;
|
||||||
|
|
||||||
// While we have case statements, eat and stack them.
|
// While we have case statements, eat and stack them.
|
||||||
|
SourceLocation ColonLoc;
|
||||||
do {
|
do {
|
||||||
SourceLocation CaseLoc = MissingCase ? Expr.get()->getExprLoc() :
|
SourceLocation CaseLoc = MissingCase ? Expr.get()->getExprLoc() :
|
||||||
ConsumeToken(); // eat the 'case'.
|
ConsumeToken(); // eat the 'case'.
|
||||||
|
@ -539,7 +540,6 @@ StmtResult Parser::ParseCaseStatement(ParsedAttributes &attrs, bool MissingCase,
|
||||||
|
|
||||||
ColonProtection.restore();
|
ColonProtection.restore();
|
||||||
|
|
||||||
SourceLocation ColonLoc;
|
|
||||||
if (Tok.is(tok::colon)) {
|
if (Tok.is(tok::colon)) {
|
||||||
ColonLoc = ConsumeToken();
|
ColonLoc = ConsumeToken();
|
||||||
|
|
||||||
|
@ -589,8 +589,9 @@ StmtResult Parser::ParseCaseStatement(ParsedAttributes &attrs, bool MissingCase,
|
||||||
} else {
|
} else {
|
||||||
// Nicely diagnose the common error "switch (X) { case 4: }", which is
|
// Nicely diagnose the common error "switch (X) { case 4: }", which is
|
||||||
// not valid.
|
// not valid.
|
||||||
// FIXME: add insertion hint.
|
SourceLocation ExpectedLoc = PP.getLocForEndOfToken(ColonLoc);
|
||||||
Diag(Tok, diag::err_label_end_of_compound_statement);
|
Diag(ExpectedLoc, diag::err_label_end_of_compound_statement)
|
||||||
|
<< FixItHint::CreateInsertion(ExpectedLoc, ";");
|
||||||
SubStmt = true;
|
SubStmt = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -634,7 +635,9 @@ StmtResult Parser::ParseDefaultStatement(ParsedAttributes &attrs) {
|
||||||
|
|
||||||
// Diagnose the common error "switch (X) {... default: }", which is not valid.
|
// Diagnose the common error "switch (X) {... default: }", which is not valid.
|
||||||
if (Tok.is(tok::r_brace)) {
|
if (Tok.is(tok::r_brace)) {
|
||||||
Diag(Tok, diag::err_label_end_of_compound_statement);
|
SourceLocation ExpectedLoc = PP.getLocForEndOfToken(ColonLoc);
|
||||||
|
Diag(ExpectedLoc, diag::err_label_end_of_compound_statement)
|
||||||
|
<< FixItHint::CreateInsertion(ExpectedLoc, ";");
|
||||||
return StmtError();
|
return StmtError();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -156,3 +156,17 @@ void test12(int x) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void missing_statement_case(int x) {
|
||||||
|
switch (x) {
|
||||||
|
case 1:
|
||||||
|
case 0: // expected-error {{label at end of compound statement: expected statement}}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void missing_statement_default(int x) {
|
||||||
|
switch (x) {
|
||||||
|
case 0:
|
||||||
|
default: // expected-error {{label at end of compound statement: expected statement}}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue