diff options
author | Steve Naroff <snaroff@apple.com> | 2008-09-02 18:50:17 +0000 |
---|---|---|
committer | Steve Naroff <snaroff@apple.com> | 2008-09-02 18:50:17 +0000 |
commit | c84e8b779ed816bbaecc8c82fd60d157dbfbab71 (patch) | |
tree | 4d23ea84a983156ae238d0449e334624fe64f2d4 /clang | |
parent | 9989ddeb15f5ea25a25a46ff24dfd7e231f3c818 (diff) | |
download | bcm5719-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.cpp | 13 | ||||
-rw-r--r-- | clang/test/Preprocessor/extension-warning.c | 10 |
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() {} |