summaryrefslogtreecommitdiffstats
path: root/clang/lib/AST/Expr.cpp
diff options
context:
space:
mode:
authorDaniel Marjamaki <daniel.marjamaki@evidente.se>2017-09-29 09:44:41 +0000
committerDaniel Marjamaki <daniel.marjamaki@evidente.se>2017-09-29 09:44:41 +0000
commit817a3bfcdd0bbac8d74fdfdb83a08484d8f63a30 (patch)
tree0bd66b37648b18350a93eb4e6c5700e9e8956fdb /clang/lib/AST/Expr.cpp
parent19fc4d941f85481b8aba33021d6df55c6db98fe7 (diff)
downloadbcm5719-llvm-817a3bfcdd0bbac8d74fdfdb83a08484d8f63a30.tar.gz
bcm5719-llvm-817a3bfcdd0bbac8d74fdfdb83a08484d8f63a30.zip
[Sema] Suppress warnings for C's zero initializer
Patch by S. Gilles! Differential Revision: https://reviews.llvm.org/D28148 llvm-svn: 314499
Diffstat (limited to 'clang/lib/AST/Expr.cpp')
-rw-r--r--clang/lib/AST/Expr.cpp11
1 files changed, 11 insertions, 0 deletions
diff --git a/clang/lib/AST/Expr.cpp b/clang/lib/AST/Expr.cpp
index aab89d392dc..9181176bbd9 100644
--- a/clang/lib/AST/Expr.cpp
+++ b/clang/lib/AST/Expr.cpp
@@ -1951,6 +1951,17 @@ bool InitListExpr::isTransparent() const {
getInit(0)->getType().getCanonicalType();
}
+bool InitListExpr::isIdiomaticZeroInitializer(const LangOptions &LangOpts) const {
+ assert(isSyntacticForm() && "only test syntactic form as zero initializer");
+
+ if (LangOpts.CPlusPlus || getNumInits() != 1) {
+ return false;
+ }
+
+ const IntegerLiteral *Lit = dyn_cast<IntegerLiteral>(getInit(0));
+ return Lit && Lit->getValue() == 0;
+}
+
SourceLocation InitListExpr::getLocStart() const {
if (InitListExpr *SyntacticForm = getSyntacticForm())
return SyntacticForm->getLocStart();
OpenPOWER on IntegriCloud