OSDN Git Service

* call.c (null_ptr_cst_p): Add explicit TREE_CONSTANT_OVERFLOW check.
authorsayle <sayle@138bc75d-0d04-0410-961f-82ee72b054a4>
Thu, 6 Apr 2006 16:47:40 +0000 (16:47 +0000)
committersayle <sayle@138bc75d-0d04-0410-961f-82ee72b054a4>
Thu, 6 Apr 2006 16:47:40 +0000 (16:47 +0000)
* g++.dg/conversion/nullptr1.C: New test case.
* g++.dg/conversion/nullptr2.C: Likewise.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@112734 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/cp/ChangeLog
gcc/cp/call.c
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/conversion/nullptr1.C [new file with mode: 0644]
gcc/testsuite/g++.dg/conversion/nullptr2.C [new file with mode: 0644]

index 96191a2..266e347 100644 (file)
@@ -1,3 +1,7 @@
+2006-04-06  Roger Sayle  <roger@eyesopen.com>
+
+       * call.c (null_ptr_cst_p): Add explicit TREE_CONSTANT_OVERFLOW check.
+
 2006-04-05  Jason Merrill  <jason@redhat.com>
 
        * name-lookup.c (push_namespace_with_attribs): Temporarily disable
index 268573d..0413a98 100644 (file)
@@ -427,7 +427,9 @@ null_ptr_cst_p (tree t)
      (_expr.const_) rvalue of integer type that evaluates to zero.  */
   t = integral_constant_value (t);
   if (t == null_node
-      || (CP_INTEGRAL_TYPE_P (TREE_TYPE (t)) && integer_zerop (t)))
+      || (CP_INTEGRAL_TYPE_P (TREE_TYPE (t))
+         && integer_zerop (t)
+         && !TREE_CONSTANT_OVERFLOW (t)))
     return true;
   return false;
 }
index a9fa5b0..814f957 100644 (file)
@@ -1,3 +1,8 @@
+2006-04-06  Roger Sayle  <roger@eyesopen.com>
+
+       * g++.dg/conversion/nullptr1.C: New test case.
+       * g++.dg/conversion/nullptr2.C: Likewise.
+
 2006-04-05  Roger Sayle  <roger@eyesopen.com>
 
        * gfortran.dg/dependency_18.f90: New test case.
diff --git a/gcc/testsuite/g++.dg/conversion/nullptr1.C b/gcc/testsuite/g++.dg/conversion/nullptr1.C
new file mode 100644 (file)
index 0000000..6230a29
--- /dev/null
@@ -0,0 +1,10 @@
+/* Test for overflow in NULL pointer constant.  */
+/* { dg-do compile } */
+
+#include <limits.h>
+
+void *p = 0;
+
+void *q = 0 * (INT_MAX + 1);  // { dg-error "invalid conversion" }
+
+
diff --git a/gcc/testsuite/g++.dg/conversion/nullptr2.C b/gcc/testsuite/g++.dg/conversion/nullptr2.C
new file mode 100644 (file)
index 0000000..74ceff4
--- /dev/null
@@ -0,0 +1,10 @@
+/* Test for enumeration as NULL pointer constant.  */
+/* PR c++/14644 */
+/* { dg-do compile } */
+
+enum { NULL = 0 };
+
+void *p = 0;
+
+void *q = NULL;  // { dg-error "cannot convert" }
+