From: Chris Lattner Date: Thu, 28 May 2009 05:39:39 +0000 (+0000) Subject: fix the "pasting formed 'a]', an invalid preprocessing token" X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=3c17b8a4306b84c05454168128bc705b33a79ca3;p=clang fix the "pasting formed 'a]', an invalid preprocessing token" diagnostic to include the full instantiation location for the invalid paste. For: #define foo(a, b) a ## b #define bar(x) foo(x, ]) bar(a) bar(zdy) Instead of: t.c:3:22: error: pasting formed 'a]', an invalid preprocessing token #define foo(a, b) a ## b ^ t.c:3:22: error: pasting formed 'zdy]', an invalid preprocessing token we now produce: t.c:7:1: error: pasting formed 'a]', an invalid preprocessing token bar(a) ^ t.c:4:16: note: instantiated from: #define bar(x) foo(x, ]) ^ t.c:3:22: note: instantiated from: #define foo(a, b) a ## b ^ t.c:8:1: error: pasting formed 'zdy]', an invalid preprocessing token bar(zdy) ^ t.c:4:16: note: instantiated from: #define bar(x) foo(x, ]) ^ t.c:3:22: note: instantiated from: #define foo(a, b) a ## b ^ git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@72519 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Lex/TokenLexer.cpp b/lib/Lex/TokenLexer.cpp index 318c57cc5f..f9f93867c8 100644 --- a/lib/Lex/TokenLexer.cpp +++ b/lib/Lex/TokenLexer.cpp @@ -471,9 +471,16 @@ bool TokenLexer::PasteTokens(Token &Tok) { } // Do not emit the warning when preprocessing assembler code. - if (!PP.getLangOptions().AsmPreprocessor) - PP.Diag(PasteOpLoc, diag::err_pp_bad_paste) + if (!PP.getLangOptions().AsmPreprocessor) { + // Explicitly convert the token location to have proper instantiation + // information so that the user knows where it came from. + SourceManager &SM = PP.getSourceManager(); + SourceLocation Loc = + SM.createInstantiationLoc(PasteOpLoc, InstantiateLocStart, + InstantiateLocEnd, 2); + PP.Diag(Loc, diag::err_pp_bad_paste) << std::string(Buffer.begin(), Buffer.end()); + } // Do not consume the RHS. --CurToken;