summaryrefslogtreecommitdiffstats
path: root/clang
diff options
context:
space:
mode:
authorSteve Naroff <snaroff@apple.com>2008-09-02 18:50:17 +0000
committerSteve Naroff <snaroff@apple.com>2008-09-02 18:50:17 +0000
commitc84e8b779ed816bbaecc8c82fd60d157dbfbab71 (patch)
tree4d23ea84a983156ae238d0449e334624fe64f2d4 /clang
parent9989ddeb15f5ea25a25a46ff24dfd7e231f3c818 (diff)
downloadbcm5719-llvm-c84e8b779ed816bbaecc8c82fd60d157dbfbab71.tar.gz
bcm5719-llvm-c84e8b779ed816bbaecc8c82fd60d157dbfbab71.zip
- Implement __block.
- Replace FIXME in Preprocessor::HandleIdentifier() with a check that avoids diagnosing extension tokens that originate from macro definitions. llvm-svn: 55639
Diffstat (limited to 'clang')
-rw-r--r--clang/lib/Lex/Preprocessor.cpp13
-rw-r--r--clang/test/Preprocessor/extension-warning.c10
2 files changed, 20 insertions, 3 deletions
diff --git a/clang/lib/Lex/Preprocessor.cpp b/clang/lib/Lex/Preprocessor.cpp
index 18b106ad841..50fafdc73b8 100644
--- a/clang/lib/Lex/Preprocessor.cpp
+++ b/clang/lib/Lex/Preprocessor.cpp
@@ -476,6 +476,14 @@ static void InitializePredefinedMacros(Preprocessor &PP,
DefineBuiltinMacro(Buf, "__int64=long long");
DefineBuiltinMacro(Buf, "__declspec(X)=");
}
+ // Directly modeled after the attribute-based implementation in GCC.
+ if (PP.getLangOptions().Blocks)
+ DefineBuiltinMacro(Buf, "__block=__attribute__((__blocks__(byref)))");
+ else
+ // This allows "__block int unusedVar;" even when blocks are disabled.
+ // This is modeled after GCC's handling of __strong/__weak.
+ DefineBuiltinMacro(Buf, "__block=");
+
// FIXME: Should emit a #line directive here.
}
@@ -594,8 +602,7 @@ void Preprocessor::HandleIdentifier(Token &Identifier) {
Identifier.setKind(II.getTokenID());
// If this is an extension token, diagnose its use.
- // FIXME: tried (unsuccesfully) to shut this up when compiling with gnu99
- // For now, I'm just commenting it out (while I work on attributes).
- if (II.isExtensionToken() && Features.C99)
+ // We avoid diagnosing tokens that originate from macro definitions.
+ if (II.isExtensionToken() && Features.C99 && !DisableMacroExpansion)
Diag(Identifier, diag::ext_token_used);
}
diff --git a/clang/test/Preprocessor/extension-warning.c b/clang/test/Preprocessor/extension-warning.c
new file mode 100644
index 00000000000..c325c2fcf23
--- /dev/null
+++ b/clang/test/Preprocessor/extension-warning.c
@@ -0,0 +1,10 @@
+// RUN: clang -fsyntax-only -verify -pedantic %s
+
+// The preprocessor shouldn't warn about extensions within macro bodies that
+// aren't expanded.
+#define __block __attribute__((__blocks__(byref)))
+
+// This warning is entirely valid.
+__block int x; // expected-warning{{extension used}}
+
+void whatever() {}
OpenPOWER on IntegriCloud