re PR c++/46670 (ICE in dependent_type_p, at cp/pt.c:17553)
authorJason Merrill <jason@redhat.com>
Fri, 17 Dec 2010 17:47:27 +0000 (12:47 -0500)
committerJason Merrill <jason@gcc.gnu.org>
Fri, 17 Dec 2010 17:47:27 +0000 (12:47 -0500)
PR c++/46670
* pt.c (value_dependent_expression_p) [ARRAY_REF]: Handle
properly.

From-SVN: r167993

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

index 0d46bcca404dd5e4a97b87fe98882bae270ddb2c..b2a958742d083a0557d9a00741e0b8392f719be5 100644 (file)
@@ -1,3 +1,9 @@
+2010-12-17  Jason Merrill  <jason@redhat.com>
+
+       PR c++/46670
+       * pt.c (value_dependent_expression_p) [ARRAY_REF]: Handle
+       properly.
+
 2010-12-15  Nathan Froyd  <froydnj@codesourcery.com>
 
        PR c++/39859
index a696d3bd8e3065d413571010b33249d470060d25..49016b3542fe3b97a5807a769c60547a23f7fdcf 100644 (file)
@@ -18108,6 +18108,10 @@ value_dependent_expression_p (tree expression)
       return ((value_dependent_expression_p (TREE_OPERAND (expression, 0)))
              || (value_dependent_expression_p (TREE_OPERAND (expression, 2))));
 
+    case ARRAY_REF:
+      return ((value_dependent_expression_p (TREE_OPERAND (expression, 0)))
+             || (value_dependent_expression_p (TREE_OPERAND (expression, 1))));
+
     case ADDR_EXPR:
       {
        tree op = TREE_OPERAND (expression, 0);
index 209174b724024e7e4f75a45dc8da96e5940d2898..fe5581e113870016d95d084744bf4466824c3445 100644 (file)
@@ -1,3 +1,8 @@
+2010-12-17  Jason Merrill  <jason@redhat.com>
+
+       PR c++/46670
+       * g++.dg/cpp0x/constexpr-null1.C: New.
+
 2010-12-17  Bernd Schmidt  <bernds@codesourcery.com>
 
        * gcc.c-torture/compile/20101217-1.c: New test.
diff --git a/gcc/testsuite/g++.dg/constexpr-null1.C b/gcc/testsuite/g++.dg/constexpr-null1.C
new file mode 100644 (file)
index 0000000..44cf9a0
--- /dev/null
@@ -0,0 +1,11 @@
+// PR c++/46670
+// { dg-options -std=c++0x }
+
+extern unsigned char __TBB_ReverseByte(unsigned char src);
+extern unsigned char *reversed;
+template<typename T> T __TBB_ReverseBits(T src)
+{
+  unsigned char *original = (unsigned char *) &src;
+  for( int i = sizeof(T)-1; i--; )
+    reversed[i] = __TBB_ReverseByte( original[sizeof(T)-i-1] );
+}