Browse Source

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

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@156647 91177308-0d34-0410-b5e6-96231b3b80d8

Argyrios Kyrtzidis 13 years ago
parent
commit
df8755884e
3 changed files with 24 additions and 5 deletions
  1. 2 2
      lib/AST/Expr.cpp
  2. 4 3
      lib/StaticAnalyzer/Core/HTMLDiagnostics.cpp
  3. 18 0
      test/PCH/format-strings.c

+ 2 - 2
lib/AST/Expr.cpp

@@ -708,8 +708,8 @@ getLocationOfByte(unsigned ByteNo, const SourceManager &SM,
     LangOpts.Trigraphs = true;
     LangOpts.Trigraphs = true;
     
     
     // Create a lexer starting at the beginning of this token.
     // 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;
     Token TheTok;
     TheLexer.LexFromRawLexer(TheTok);
     TheLexer.LexFromRawLexer(TheTok);
     
     

+ 4 - 3
lib/StaticAnalyzer/Core/HTMLDiagnostics.cpp

@@ -441,9 +441,10 @@ void HTMLDiagnostics::HandlePiece(Rewriter& R, FileID BugFileID,
       FullSourceLoc L = MP->getLocation().asLocation().getExpansionLoc();
       FullSourceLoc L = MP->getLocation().asLocation().getExpansionLoc();
       assert(L.isFileID());
       assert(L.isFileID());
       StringRef BufferInfo = L.getBufferData();
       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;
       Token TheTok;
       rawLexer.LexFromRawLexer(TheTok);
       rawLexer.LexFromRawLexer(TheTok);

+ 18 - 0
test/PCH/format-strings.c

@@ -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