re PR c++/51150 ([C++11][4.6/4.7 Regression] ICE when result of -> initializes const...
authorPaolo Carlini <paolo@gcc.gnu.org>
Fri, 18 Nov 2011 15:31:38 +0000 (15:31 +0000)
committerPaolo Carlini <paolo@gcc.gnu.org>
Fri, 18 Nov 2011 15:31:38 +0000 (15:31 +0000)
/cp
2011-11-18  Paolo Carlini  <paolo.carlini@oracle.com>

PR c++/51150
* pt.c (tsubst_copy_and_build): Handle FIX_TRUNC_EXPR.

/testsuite
2011-11-18  Paolo Carlini  <paolo.carlini@oracle.com>

PR c++/51150
* g++.dg/cpp0x/pr51150.C: New.

From-SVN: r181478

gcc/cp/ChangeLog
gcc/cp/pt.c
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/cpp0x/pr51150.C [new file with mode: 0644]

index 26d3c293da30430e125abbad5af38d61cff008b9..c1d347d02bdf7202ea643e815382ea4acb56dc33 100644 (file)
@@ -1,3 +1,8 @@
+2011-11-18  Paolo Carlini  <paolo.carlini@oracle.com>
+
+       PR c++/51150
+       * pt.c (tsubst_copy_and_build): Handle FIX_TRUNC_EXPR.
+
 2011-11-18  Dodji Seketeli  <dodji@redhat.com>
 
        PR c++/51191
index 78e263f9e95bb22e2370afb97e9f9f8f369f008f..987b70b7ba498442cab1b225d470975ebcf7fe3a 100644 (file)
@@ -13387,6 +13387,10 @@ tsubst_copy_and_build (tree t,
       return build_x_unary_op (TREE_CODE (t), RECUR (TREE_OPERAND (t, 0)),
                                complain);
 
+    case FIX_TRUNC_EXPR:
+      return cp_build_unary_op (FIX_TRUNC_EXPR, RECUR (TREE_OPERAND (t, 0)),
+                               0, complain);
+
     case ADDR_EXPR:
       op1 = TREE_OPERAND (t, 0);
       if (TREE_CODE (op1) == LABEL_DECL)
index 1edc46c4e19f2b7b4ef96caa5bef9c24abc4a7bd..b22ebc6c861d34e90dd005a5c6f50abdde9fb5dc 100644 (file)
@@ -1,3 +1,8 @@
+2011-11-18  Paolo Carlini  <paolo.carlini@oracle.com>
+
+       PR c++/51150
+       * g++.dg/cpp0x/pr51150.C: New.
+
 2011-11-18  Martin Jambor  <mjambor@suse.cz>
 
        PR tree-optimization/50605
@@ -16,7 +21,7 @@
 
 2011-11-17  Andrew MacLeod  <amacleod@redhat.com>
 
-       * gcc.dg/atomic-generic-aux.c (__atomic_compare_exchange): Fail if 
+       * gcc.dg/atomic-generic-aux.c (__atomic_compare_exchange): Fail if
        memory model parameters don't match expected values.
        * gcc.dg/atomic-generic.c: Pass specific memory model parameters to
        __atomic_compare_exchange.
diff --git a/gcc/testsuite/g++.dg/cpp0x/pr51150.C b/gcc/testsuite/g++.dg/cpp0x/pr51150.C
new file mode 100644 (file)
index 0000000..37eb166
--- /dev/null
@@ -0,0 +1,20 @@
+// PR c++/51150
+// { dg-options "-std=c++0x" }
+
+struct Clock {
+  double Now();
+};
+template <class T> void Foo(Clock* clock) {
+  const int now = clock->Now();
+}
+
+template void Foo<float>(Clock*);
+
+template <class T> void Boo(int val) {
+  const int now1 = (double)(val);
+  const int now2 = const_cast<double>(val); // { dg-error "invalid" }
+  const int now3 = static_cast<double>(val);
+  const int now4 = reinterpret_cast<double>(val); // { dg-error "invalid" }
+}
+
+template void Boo<float>(int);