forked from OSchip/llvm-project
The Lexer constructor expects a source location at the start of the
file buffer, not at the start of lexing. Fixes assertion hit in format diagnostics. rdar://11418366 llvm-svn: 156647
This commit is contained in:
parent
aa9cb9df59
commit
45f5118248
|
@ -708,8 +708,8 @@ getLocationOfByte(unsigned ByteNo, const SourceManager &SM,
|
|||
LangOpts.Trigraphs = true;
|
||||
|
||||
// Create a lexer starting at the beginning of this token.
|
||||
Lexer TheLexer(StrTokSpellingLoc, Features, Buffer.begin(), StrData,
|
||||
Buffer.end());
|
||||
Lexer TheLexer(SM.getLocForStartOfFile(LocInfo.first), Features,
|
||||
Buffer.begin(), StrData, Buffer.end());
|
||||
Token TheTok;
|
||||
TheLexer.LexFromRawLexer(TheTok);
|
||||
|
||||
|
|
|
@ -441,9 +441,10 @@ void HTMLDiagnostics::HandlePiece(Rewriter& R, FileID BugFileID,
|
|||
FullSourceLoc L = MP->getLocation().asLocation().getExpansionLoc();
|
||||
assert(L.isFileID());
|
||||
StringRef BufferInfo = L.getBufferData();
|
||||
const char* MacroName = L.getDecomposedLoc().second + BufferInfo.data();
|
||||
Lexer rawLexer(L, PP.getLangOpts(), BufferInfo.begin(),
|
||||
MacroName, BufferInfo.end());
|
||||
std::pair<FileID, unsigned> LocInfo = L.getDecomposedLoc();
|
||||
const char* MacroName = LocInfo.second + BufferInfo.data();
|
||||
Lexer rawLexer(SM.getLocForStartOfFile(LocInfo.first), PP.getLangOpts(),
|
||||
BufferInfo.begin(), MacroName, BufferInfo.end());
|
||||
|
||||
Token TheTok;
|
||||
rawLexer.LexFromRawLexer(TheTok);
|
||||
|
|
|
@ -0,0 +1,18 @@
|
|||
// RUN: %clang_cc1 -D FOOBAR="\"\"" %s -emit-pch -o %t.pch
|
||||
// RUN: %clang_cc1 -D FOOBAR="\"\"" %s -include-pch %t.pch
|
||||
|
||||
// rdar://11418366
|
||||
|
||||
#ifndef HEADER
|
||||
#define HEADER
|
||||
|
||||
extern int printf(const char *restrict, ...);
|
||||
#define LOG printf(FOOBAR "%f", __LINE__)
|
||||
|
||||
#else
|
||||
|
||||
void foo() {
|
||||
LOG;
|
||||
}
|
||||
|
||||
#endif
|
Loading…
Reference in New Issue