forked from OSchip/llvm-project
fix rdar://6757323, where an escaped newline in a // comment
was causing the char after the newline to get eaten. llvm-svn: 68430
This commit is contained in:
parent
fff33a3cdf
commit
ecdaf40c9e
|
@ -848,6 +848,14 @@ bool Lexer::SkipBCPLComment(Token &Result, const char *CurPtr) {
|
|||
LexingRawMode = true;
|
||||
C = getAndAdvanceChar(CurPtr, Result);
|
||||
LexingRawMode = OldRawMode;
|
||||
|
||||
// If the char that we finally got was a \n, then we must have had something
|
||||
// like \<newline><newline>. We don't want to have consumed the second
|
||||
// newline, we want CurPtr, to end up pointing to it down below.
|
||||
if (C == '\n' || C == '\r') {
|
||||
--CurPtr;
|
||||
C = 'x'; // doesn't matter what this is.
|
||||
}
|
||||
|
||||
// If we read multiple characters, and one of those characters was a \r or
|
||||
// \n, then we had an escaped newline within the comment. Emit diagnostic
|
||||
|
|
|
@ -0,0 +1,6 @@
|
|||
// RUN: clang -fsyntax-only %s
|
||||
// rdar://6757323
|
||||
// foo \
|
||||
|
||||
#define blork 32
|
||||
|
Loading…
Reference in New Issue