typeck.c (build_array_ref): Push the array reference inside COMPOUND_EXPR and COND_EXPR.
authorRichard Henderson <rth@redhat.com>
Tue, 10 Apr 2001 16:49:29 +0000 (09:49 -0700)
committerRichard Henderson <rth@gcc.gnu.org>
Tue, 10 Apr 2001 16:49:29 +0000 (09:49 -0700)
        * typeck.c (build_array_ref): Push the array reference inside
        COMPOUND_EXPR and COND_EXPR.

From-SVN: r41223

gcc/cp/ChangeLog
gcc/cp/typeck.c

index 2f3c032dd282724160519ed5bad42705c9c08463..1b0c470aba7ef4a2c7c63574bf80eba8f68d0d50 100644 (file)
@@ -1,3 +1,8 @@
+2001-04-10  Richard Henderson  <rth@redhat.com>
+
+       * typeck.c (build_array_ref): Push the array reference inside
+       COMPOUND_EXPR and COND_EXPR.
+
 2001-04-05  Mark Mitchell  <mark@codesourcery.com>
 
        * cp-tree.h (DECL_THIS_INLINE): Rename to DECL_DECLARED_INLINE_P.
index 673e7c345540e71de64ab453c335572277576445..139290bb166179d2114afbe02517f09562a64682 100644 (file)
@@ -2433,6 +2433,27 @@ build_array_ref (array, idx)
       || TREE_TYPE (idx) == error_mark_node)
     return error_mark_node;
 
+  /* If ARRAY is a COMPOUND_EXPR or COND_EXPR, move our reference
+     inside it.  */
+  switch (TREE_CODE (array))
+    {
+    case COMPOUND_EXPR:
+      {
+       tree value = build_array_ref (TREE_OPERAND (array, 1), idx);
+       return build (COMPOUND_EXPR, TREE_TYPE (value),
+                     TREE_OPERAND (array, 0), value);
+      }
+
+    case COND_EXPR:
+      return build_conditional_expr
+       (TREE_OPERAND (array, 0),
+        build_array_ref (TREE_OPERAND (array, 1), idx),
+        build_array_ref (TREE_OPERAND (array, 2), idx));
+
+    default:
+      break;
+    }
+
   if (TREE_CODE (TREE_TYPE (array)) == ARRAY_TYPE
       && TREE_CODE (array) != INDIRECT_REF)
     {
@@ -2469,6 +2490,7 @@ build_array_ref (array, idx)
          if (mark_addressable (array) == 0)
            return error_mark_node;
        }
+
       /* An array that is indexed by a constant value which is not within
         the array bounds cannot be stored in a register either; because we
         would get a crash in store_bit_field/extract_bit_field when trying