]> granicus.if.org Git - clang/commitdiff
properly form a full token for # before calling HandleDirective.
authorChris Lattner <sabre@nondot.org>
Wed, 18 Mar 2009 20:58:27 +0000 (20:58 +0000)
committerChris Lattner <sabre@nondot.org>
Wed, 18 Mar 2009 20:58:27 +0000 (20:58 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@67235 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Lex/Lexer.cpp

index c68d21c7e79aa10594f59155af11a213d99b55ee..0478eebb62376b8d6a1448621d4b338fb213d8c0 100644 (file)
@@ -1595,15 +1595,13 @@ LexNextToken:
         if (!isLexingRawMode())
           Diag(BufferPtr, diag::charize_microsoft_ext);
         Kind = tok::hashat;
-      } else {
-        Kind = tok::hash;       // '%:' -> '#'
-        
+      } else {                                         // '%:' -> '#'
         // We parsed a # character.  If this occurs at the start of the line,
         // it's actually the start of a preprocessing directive.  Callback to
         // the preprocessor to handle it.
         // FIXME: -fpreprocessed mode??
         if (Result.isAtStartOfLine() && !LexingRawMode) {
-          BufferPtr = CurPtr;
+          FormTokenWithChars(Result, CurPtr, tok::hash);
           PP->HandleDirective(Result);
           
           // As an optimization, if the preprocessor didn't switch lexers, tail
@@ -1621,6 +1619,8 @@ LexNextToken:
           
           return PP->Lex(Result);
         }
+        
+        Kind = tok::hash;
       }
     } else {
       Kind = tok::percent;
@@ -1727,13 +1727,12 @@ LexNextToken:
         Diag(BufferPtr, diag::charize_microsoft_ext);
       CurPtr = ConsumeChar(CurPtr, SizeTmp, Result);
     } else {
-      Kind = tok::hash;
       // We parsed a # character.  If this occurs at the start of the line,
       // it's actually the start of a preprocessing directive.  Callback to
       // the preprocessor to handle it.
       // FIXME: -fpreprocessed mode??
       if (Result.isAtStartOfLine() && !LexingRawMode) {
-        BufferPtr = CurPtr;
+        FormTokenWithChars(Result, CurPtr, tok::hash);
         PP->HandleDirective(Result);
         
         // As an optimization, if the preprocessor didn't switch lexers, tail
@@ -1750,6 +1749,8 @@ LexNextToken:
         }
         return PP->Lex(Result);
       }
+      
+      Kind = tok::hash;
     }
     break;