forked from OSchip/llvm-project
Fix crash-on-invalid, improve error recovery, and test coverage for missing colon after access specifiers in C++
llvm-svn: 141852
This commit is contained in:
parent
d3043965b9
commit
eba32c2229
|
@ -2135,12 +2135,23 @@ void Parser::ParseCXXMemberSpecification(SourceLocation RecordLoc,
|
|||
// Current token is a C++ access specifier.
|
||||
CurAS = AS;
|
||||
SourceLocation ASLoc = Tok.getLocation();
|
||||
unsigned TokLength = Tok.getLength();
|
||||
ConsumeToken();
|
||||
if (Tok.is(tok::colon))
|
||||
Actions.ActOnAccessSpecifier(AS, ASLoc, Tok.getLocation());
|
||||
else
|
||||
Diag(Tok, diag::err_expected_colon);
|
||||
ConsumeToken();
|
||||
SourceLocation EndLoc;
|
||||
if (Tok.is(tok::colon)) {
|
||||
EndLoc = Tok.getLocation();
|
||||
ConsumeToken();
|
||||
} else if (Tok.is(tok::semi)) {
|
||||
EndLoc = Tok.getLocation();
|
||||
ConsumeToken();
|
||||
Diag(EndLoc, diag::err_expected_colon)
|
||||
<< FixItHint::CreateReplacement(EndLoc, ":");
|
||||
} else {
|
||||
EndLoc = ASLoc.getLocWithOffset(TokLength);
|
||||
Diag(EndLoc, diag::err_expected_colon)
|
||||
<< FixItHint::CreateInsertion(EndLoc, ":");
|
||||
}
|
||||
Actions.ActOnAccessSpecifier(AS, ASLoc, EndLoc);
|
||||
continue;
|
||||
}
|
||||
|
||||
|
|
|
@ -40,3 +40,20 @@ typedef union {
|
|||
} y;
|
||||
} bug3177;
|
||||
|
||||
// check that we don't consume the token after the access specifier
|
||||
// when it's not a colon
|
||||
class D {
|
||||
public // expected-error{{expected ':'}}
|
||||
int i;
|
||||
};
|
||||
|
||||
// consume the token after the access specifier if it's a semicolon
|
||||
// that was meant to be a colon
|
||||
class E {
|
||||
public; // expected-error{{expected ':'}}
|
||||
int i;
|
||||
};
|
||||
|
||||
// PR11109 must appear at the end of the source file
|
||||
class pr11109r3 { // expected-note{{to match this '{'}}
|
||||
public // expected-error{{expected ':'}} expected-error{{expected '}'}} expected-error{{expected ';' after class}}
|
||||
|
|
Loading…
Reference in New Issue