summaryrefslogtreecommitdiffstats
path: root/clang
diff options
context:
space:
mode:
authorDouglas Gregor <dgregor@apple.com>2013-01-30 23:10:17 +0000
committerDouglas Gregor <dgregor@apple.com>2013-01-30 23:10:17 +0000
commit1a347f76c2d93a8d92cf8031c802d876d72cb637 (patch)
tree3bdd3e53aec367217e241b9197ace7edc87b2fc1 /clang
parentd219675c2a8d5acc0bb77752cf242a7af0f97fe0 (diff)
downloadbcm5719-llvm-1a347f76c2d93a8d92cf8031c802d876d72cb637.tar.gz
bcm5719-llvm-1a347f76c2d93a8d92cf8031c802d876d72cb637.zip
Reinstate r173952, this time limiting it to exactly the form
#define X X for which there is no point warning, ever. llvm-svn: 173991
Diffstat (limited to 'clang')
-rw-r--r--clang/lib/Lex/PPMacroExpansion.cpp5
-rw-r--r--clang/test/Headers/stdbool.cpp5
-rw-r--r--clang/test/Preprocessor/warn-disabled-macro-expansion.c6
3 files changed, 14 insertions, 2 deletions
diff --git a/clang/lib/Lex/PPMacroExpansion.cpp b/clang/lib/Lex/PPMacroExpansion.cpp
index 63791448858..bda31ed294a 100644
--- a/clang/lib/Lex/PPMacroExpansion.cpp
+++ b/clang/lib/Lex/PPMacroExpansion.cpp
@@ -459,7 +459,10 @@ bool Preprocessor::HandleMacroExpandedIdentifier(Token &Identifier,
if (MacroInfo *NewMI = getMacroInfo(NewII))
if (!NewMI->isEnabled() || NewMI == MI) {
Identifier.setFlag(Token::DisableExpand);
- Diag(Identifier, diag::pp_disabled_macro_expansion);
+ // Don't warn for "#define X X" like "#define bool bool" from
+ // stdbool.h.
+ if (NewMI != MI || MI->isFunctionLike())
+ Diag(Identifier, diag::pp_disabled_macro_expansion);
}
}
diff --git a/clang/test/Headers/stdbool.cpp b/clang/test/Headers/stdbool.cpp
index a252cca1a6a..7c927db441b 100644
--- a/clang/test/Headers/stdbool.cpp
+++ b/clang/test/Headers/stdbool.cpp
@@ -1,5 +1,6 @@
// RUN: %clang_cc1 -E -dM %s | FileCheck --check-prefix=CHECK-GNU-COMPAT %s
// RUN: %clang_cc1 -std=c++98 -E -dM %s | FileCheck --check-prefix=CHECK-CONFORMING %s
+// RUN: %clang_cc1 -fsyntax-only -std=gnu++98 -verify -Weverything %s
#include <stdbool.h>
#define zzz
@@ -12,3 +13,7 @@
// CHECK-CONFORMING: #define __CHAR_BIT__
// CHECK-CONFORMING-NOT: #define false false
// CHECK-CONFORMING: #define zzz
+
+zzz
+// expected-no-diagnostics
+extern bool x;
diff --git a/clang/test/Preprocessor/warn-disabled-macro-expansion.c b/clang/test/Preprocessor/warn-disabled-macro-expansion.c
index b01b63f6b3f..21a3b7e4f14 100644
--- a/clang/test/Preprocessor/warn-disabled-macro-expansion.c
+++ b/clang/test/Preprocessor/warn-disabled-macro-expansion.c
@@ -14,9 +14,10 @@
#define c(x) x(0)
+#define y(x) y
#define z(x) (z)(x)
-p // expected-warning {{recursive macro}}
+p // no warning
a // expected-warning {{recursive macro}}
@@ -28,4 +29,7 @@ h(0) // expected-warning {{recursive macro}}
c(c) // expected-warning {{recursive macro}}
+y(5) // expected-warning {{recursive macro}}
+
z(z) // ok
+
OpenPOWER on IntegriCloud