]> granicus.if.org Git - clang/commitdiff
Make sure an invalid concatentaion doesn't insert whitespace before
authorEli Friedman <eli.friedman@gmail.com>
Sun, 24 May 2009 19:25:46 +0000 (19:25 +0000)
committerEli Friedman <eli.friedman@gmail.com>
Sun, 24 May 2009 19:25:46 +0000 (19:25 +0000)
the RHS.  Fixes assembler-with-cpp issue reported on cfe-dev.

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

lib/Lex/TokenLexer.cpp
test/Preprocessor/assembler-with-cpp.c

index f1af42aea5172512d4e9677bdb2e497ae06c64bb..65d083dffdca0cfc727028dadd0c646d2ac0832f 100644 (file)
@@ -223,7 +223,11 @@ void TokenLexer::ExpandFunctionArguments() {
       // If the next token was supposed to get leading whitespace, ensure it has
       // it now.
       if (CurTok.hasLeadingSpace() || NextTokGetsSpace) {
-        ResultToks[ResultToks.size()-NumToks].setFlag(Token::LeadingSpace);
+        // Exception: the RHS of a paste doesn't get whitespace. This allows
+        // constructs like conacatenating a period and an identifer to work
+        // correctly in assembler-with-cpp.
+        if (!PasteBefore)
+          ResultToks[ResultToks.size()-NumToks].setFlag(Token::LeadingSpace);
         NextTokGetsSpace = false;
       }
       continue;
index 885e67b98c8fdd172cf2c216ec76f62b300a2669..bb1688057855dcc74606e02f533b9945c38765ba 100644 (file)
@@ -63,4 +63,9 @@ T7(foo)
 // RUN: grep 'T6 #nostring' %t &&
 // RUN: grep 'T7 "foo"' %t &&
 
+// Concatenation with period doesn't leave a space
+// RUN: grep '.T8' %t &&
+#define T8(A,B) A ## B
+T8(.,T8)
+
 // RUN: true