aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRichard Smith <richard-llvm@metafoo.co.uk>2012-01-31 01:47:46 +0000
committerRichard Smith <richard-llvm@metafoo.co.uk>2012-01-31 01:47:46 +0000
commit395f1c08ff720be7df6535a86df14b6d36a2d57a (patch)
tree1494d753d6bcbcb74253dd5be3ddd1bda31c3388
parent339b9072e26a2a0fe796dc69c4d28d964d0ec86d (diff)
constexpr: remove integral conversion overflow checking introduced in r149286.
As Eli points out, this is implementation-defined, and the way we define it makes this fine. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@149327 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--lib/AST/ExprConstant.cpp7
-rw-r--r--test/CXX/expr/expr.const/p2-0x.cpp4
2 files changed, 2 insertions, 9 deletions
diff --git a/lib/AST/ExprConstant.cpp b/lib/AST/ExprConstant.cpp
index d2d651c97f..50e96bdd4b 100644
--- a/lib/AST/ExprConstant.cpp
+++ b/lib/AST/ExprConstant.cpp
@@ -1094,13 +1094,6 @@ static APSInt HandleIntToIntCast(EvalInfo &Info, const Expr *E,
// Figure out if this is a truncate, extend or noop cast.
// If the input is signed, do a sign extend, noop, or truncate.
Result = Result.extOrTrunc(DestWidth);
-
- // Check whether we overflowed. If so, fold the cast anyway.
- if (DestType->isSignedIntegerOrEnumerationType() &&
- ((Result.isNegative() && Value.isUnsigned()) ||
- Result.extOrTrunc(Value.getBitWidth()) != Value))
- (void)HandleOverflow(Info, E, Value, DestType);
-
Result.setIsUnsigned(DestType->isUnsignedIntegerOrEnumerationType());
return Result;
}
diff --git a/test/CXX/expr/expr.const/p2-0x.cpp b/test/CXX/expr/expr.const/p2-0x.cpp
index 4b425da73c..5659273129 100644
--- a/test/CXX/expr/expr.const/p2-0x.cpp
+++ b/test/CXX/expr/expr.const/p2-0x.cpp
@@ -118,8 +118,8 @@ namespace UndefinedBehavior {
void f(int n) {
switch (n) {
case (int)4.4e9: // expected-error {{constant expression}} expected-note {{value 4.4E+9 is outside the range of representable values of type 'int'}}
- case (int)10000000000ll: // expected-error {{constant expression}} expected-note {{value 10000000000 is outside the range of representable values of type 'int'}} expected-note {{here}}
- case (int)0x80000000u: // expected-error {{constant expression}} expected-note {{value 2147483648 is outside the range of representable values of type 'int'}}
+ case (int)0x80000000u: // ok
+ case (int)10000000000ll: // expected-note {{here}}
case (unsigned int)10000000000ll: // expected-error {{duplicate case value}}
case (int)(unsigned)(long long)4.4e9: // ok
case (int)(float)1e300: // expected-error {{constant expression}} expected-note {{value 1.0E+300 is outside the range of representable values of type 'float'}}