diff options
author | Daniel Marjamaki <daniel.marjamaki@evidente.se> | 2017-09-29 09:44:41 +0000 |
---|---|---|
committer | Daniel Marjamaki <daniel.marjamaki@evidente.se> | 2017-09-29 09:44:41 +0000 |
commit | 817a3bfcdd0bbac8d74fdfdb83a08484d8f63a30 (patch) | |
tree | 0bd66b37648b18350a93eb4e6c5700e9e8956fdb /clang/lib/AST/Expr.cpp | |
parent | 19fc4d941f85481b8aba33021d6df55c6db98fe7 (diff) | |
download | bcm5719-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.cpp | 11 |
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(); |