Fix crash on end-of-file after \ in a char literal, fixes PR14369.

This makes LexCharConstant() look more like LexStringLiteral(), which doesn't
have this bug. Add tests for eof after \ for several other cases.

llvm-svn: 168269
This commit is contained in:
Nico Weber 2012-11-17 20:25:54 +00:00
parent d41d094244
commit 4e270380c1
4 changed files with 32 additions and 6 deletions

View File

@ -1823,16 +1823,18 @@ void Lexer::LexCharConstant(Token &Result, const char *CurPtr,
while (C != '\'') { while (C != '\'') {
// Skip escaped characters. // Skip escaped characters.
if (C == '\\') { if (C == '\\')
// Skip the escaped character. C = getAndAdvanceChar(CurPtr, Result);
getAndAdvanceChar(CurPtr, Result);
} else if (C == '\n' || C == '\r' || // Newline. if (C == '\n' || C == '\r' || // Newline.
(C == 0 && CurPtr-1 == BufferEnd)) { // End of file. (C == 0 && CurPtr-1 == BufferEnd)) { // End of file.
if (!isLexingRawMode() && !LangOpts.AsmPreprocessor) if (!isLexingRawMode() && !LangOpts.AsmPreprocessor)
Diag(BufferPtr, diag::ext_unterminated_char); Diag(BufferPtr, diag::ext_unterminated_char);
FormTokenWithChars(Result, CurPtr-1, tok::unknown); FormTokenWithChars(Result, CurPtr-1, tok::unknown);
return; return;
} else if (C == 0) { }
if (C == 0) {
if (isCodeCompletionPoint(CurPtr-1)) { if (isCodeCompletionPoint(CurPtr-1)) {
PP->CodeCompleteNaturalLanguage(); PP->CodeCompleteNaturalLanguage();
FormTokenWithChars(Result, CurPtr-1, tok::unknown); FormTokenWithChars(Result, CurPtr-1, tok::unknown);

View File

@ -0,0 +1,8 @@
// RUN: %clang_cc1 %s -verify -fsyntax-only
// vim: set binary noeol:
// This file intentionally ends without a \n on the last line. Make sure your
// editor doesn't add one.
// expected-warning@+1{{missing terminating ' character}} expected-error@+1{{expected expression}} expected-error@+1{{expected ';'}}
char c = '\

View File

@ -0,0 +1,8 @@
// RUN: %clang_cc1 %s -verify -fsyntax-only
// vim: set binary noeol:
// This file intentionally ends without a \n on the last line. Make sure your
// editor doesn't add one.
// expected-error@+1{{expected expression}} expected-error@+1{{expected ';'}}
char c = \

View File

@ -0,0 +1,8 @@
// RUN: %clang_cc1 %s -verify -fsyntax-only
// vim: set binary noeol:
// This file intentionally ends without a \n on the last line. Make sure your
// editor doesn't add one.
// expected-warning@+1{{missing terminating '"' character}} expected-error@+1{{expected expression}} expected-error@+1{{expected ';'}}
char c = "\