[cfe-commits] r60333 - in /cfe/trunk: include/clang/AST/Expr.h lib/AST/Expr.cpp lib/Sema/Sema.h lib/Sema/SemaExpr.cpp
Anders Carlsson
andersca at mac.com
Sun Nov 30 22:28:23 PST 2008
Author: andersca
Date: Mon Dec 1 00:28:23 2008
New Revision: 60333
URL: http://llvm.org/viewvc/llvm-project?rev=60333&view=rev
Log:
Revert change that made isNullPointerConstant start emitting warnings. We don't want that :)
Modified:
cfe/trunk/include/clang/AST/Expr.h
cfe/trunk/lib/AST/Expr.cpp
cfe/trunk/lib/Sema/Sema.h
cfe/trunk/lib/Sema/SemaExpr.cpp
Modified: cfe/trunk/include/clang/AST/Expr.h
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/include/clang/AST/Expr.h?rev=60333&r1=60332&r2=60333&view=diff
==============================================================================
--- cfe/trunk/include/clang/AST/Expr.h (original)
+++ cfe/trunk/include/clang/AST/Expr.h Mon Dec 1 00:28:23 2008
@@ -181,7 +181,6 @@
/// isNullPointerConstant - C99 6.3.2.3p3 - Return true if this is either an
/// integer constant expression with the value zero, or if this is one that is
/// cast to void*.
- bool isNullPointerConstant(EvalResult &Result, ASTContext &Ctx) const;
bool isNullPointerConstant(ASTContext &Ctx) const;
/// hasGlobalStorage - Return true if this expression has static storage
Modified: cfe/trunk/lib/AST/Expr.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/AST/Expr.cpp?rev=60333&r1=60332&r2=60333&view=diff
==============================================================================
--- cfe/trunk/lib/AST/Expr.cpp (original)
+++ cfe/trunk/lib/AST/Expr.cpp Mon Dec 1 00:28:23 2008
@@ -1009,12 +1009,6 @@
/// cast to void*.
bool Expr::isNullPointerConstant(ASTContext &Ctx) const
{
- EvalResult EvalResult;
-
- return isNullPointerConstant(EvalResult, Ctx);
-}
-
-bool Expr::isNullPointerConstant(EvalResult &Result, ASTContext &Ctx) const {
// Strip off a cast to void*, if it exists. Except in C++.
if (const ExplicitCastExpr *CE = dyn_cast<ExplicitCastExpr>(this)) {
if (!Ctx.getLangOptions().CPlusPlus) {
@@ -1024,20 +1018,20 @@
if (Pointee.getCVRQualifiers() == 0 &&
Pointee->isVoidType() && // to void*
CE->getSubExpr()->getType()->isIntegerType()) // from int.
- return CE->getSubExpr()->isNullPointerConstant(Result, Ctx);
+ return CE->getSubExpr()->isNullPointerConstant(Ctx);
}
}
} else if (const ImplicitCastExpr *ICE = dyn_cast<ImplicitCastExpr>(this)) {
// Ignore the ImplicitCastExpr type entirely.
- return ICE->getSubExpr()->isNullPointerConstant(Result, Ctx);
+ return ICE->getSubExpr()->isNullPointerConstant(Ctx);
} else if (const ParenExpr *PE = dyn_cast<ParenExpr>(this)) {
// Accept ((void*)0) as a null pointer constant, as many other
// implementations do.
- return PE->getSubExpr()->isNullPointerConstant(Result, Ctx);
+ return PE->getSubExpr()->isNullPointerConstant(Ctx);
} else if (const CXXDefaultArgExpr *DefaultArg
= dyn_cast<CXXDefaultArgExpr>(this)) {
// See through default argument expressions
- return DefaultArg->getExpr()->isNullPointerConstant(Result, Ctx);
+ return DefaultArg->getExpr()->isNullPointerConstant(Ctx);
} else if (isa<GNUNullExpr>(this)) {
// The GNU __null extension is always a null pointer constant.
return true;
@@ -1049,8 +1043,12 @@
// If we have an integer constant expression, we need to *evaluate* it and
// test for the value 0.
+ // FIXME: We should probably return false if we're compiling in strict mode
+ // and Diag is not null (this indicates that the value was foldable but not
+ // an ICE.
+ EvalResult Result;
return Evaluate(Result, Ctx) && !Result.HasSideEffects &&
- Result.Val.isInt() && Result.Val.getInt() == 0;
+ Result.Val.isInt() && Result.Val.getInt() == 0;
}
/// isBitField - Return true if this expression is a bit-field.
Modified: cfe/trunk/lib/Sema/Sema.h
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Sema/Sema.h?rev=60333&r1=60332&r2=60333&view=diff
==============================================================================
--- cfe/trunk/lib/Sema/Sema.h (original)
+++ cfe/trunk/lib/Sema/Sema.h Mon Dec 1 00:28:23 2008
@@ -1352,8 +1352,6 @@
/// Can optionally return the value of the expression.
bool VerifyIntegerConstantExpression(const Expr*E, llvm::APSInt *Result = 0);
- bool isNullPointerConstant(const Expr *E);
-
//===--------------------------------------------------------------------===//
// Extra semantic analysis beyond the C type system
private:
Modified: cfe/trunk/lib/Sema/SemaExpr.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Sema/SemaExpr.cpp?rev=60333&r1=60332&r2=60333&view=diff
==============================================================================
--- cfe/trunk/lib/Sema/SemaExpr.cpp (original)
+++ cfe/trunk/lib/Sema/SemaExpr.cpp Mon Dec 1 00:28:23 2008
@@ -1582,13 +1582,13 @@
// the type of the other operand."
if ((lexT->isPointerType() || lexT->isBlockPointerType() ||
Context.isObjCObjectPointerType(lexT)) &&
- isNullPointerConstant(rex)) {
+ rex->isNullPointerConstant(Context)) {
ImpCastExprToType(rex, lexT); // promote the null to a pointer.
return lexT;
}
if ((rexT->isPointerType() || rexT->isBlockPointerType() ||
Context.isObjCObjectPointerType(rexT)) &&
- isNullPointerConstant(lex)) {
+ lex->isNullPointerConstant(Context)) {
ImpCastExprToType(lex, rexT); // promote the null to a pointer.
return rexT;
}
@@ -3706,23 +3706,3 @@
*Result = EvalResult.Val.getInt();
return false;
}
-
-bool Sema::isNullPointerConstant(const Expr *E)
-{
- Expr::EvalResult EvalResult;
-
- if (!E->isNullPointerConstant(EvalResult, Context))
- return false;
-
- if (EvalResult.Diag) {
- Diag(E->getExprLoc(), diag::ext_null_pointer_expr_not_ice) <<
- E->getSourceRange();
-
- // Print the reason it's not a constant.
- if (Diags.getDiagnosticLevel(diag::ext_null_pointer_expr_not_ice) !=
- Diagnostic::Ignored)
- Diag(EvalResult.DiagLoc, EvalResult.Diag);
- }
-
- return true;
-}
More information about the cfe-commits
mailing list