re PR c/12446 (ICE in emit_move_insn on complicated array reference)
authorEric Botcazou <ebotcazou@libertysurf.fr>
Sat, 4 Oct 2003 18:02:32 +0000 (20:02 +0200)
committerEric Botcazou <ebotcazou@gcc.gnu.org>
Sat, 4 Oct 2003 18:02:32 +0000 (18:02 +0000)
PR c/12446
* c-typeck.c (convert_for_assignment): Issue an error for
array to pointer assignment after default conversion.
(digest_init): Likewise.

From-SVN: r72096

gcc/ChangeLog
gcc/c-typeck.c
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.dg/c90-array-lval-6.c [new file with mode: 0644]
gcc/testsuite/gcc.dg/c99-array-lval-6.c [new file with mode: 0644]

index c0786895aaee134e5de257ed96363d8f57799d48..b1724000cff6937df510520927866a31da4cb336 100644 (file)
@@ -1,3 +1,10 @@
+2003-10-04  Eric Botcazou  <ebotcazou@libertysurf.fr>
+
+       PR c/12446
+       * c-typeck.c (convert_for_assignment): Issue an error for
+       array to pointer assignment after default conversion.
+       (digest_init): Likewise.
+
 2003-10-04  Fariborz Jahanian  <fjahanian@apple.com>
 
        * c-decl.c (duplicate_decls): retain DECL_COMMON of old declaration
index 59110c829c529d02faf435e08015de315004a9ca..eaad4fe9698c8970f0a2e293bb1dccf9b88f7c7c 100644 (file)
@@ -3556,6 +3556,11 @@ convert_for_assignment (tree type, tree rhs, const char *errtype,
                             errtype, funname, parmnum);
       return convert (type, rhs);
     }
+  else if (codel == POINTER_TYPE && coder == ARRAY_TYPE)
+    {
+      error ("invalid use of non-lvalue array");
+      return error_mark_node;
+    }
   else if (codel == POINTER_TYPE && coder == INTEGER_TYPE)
     {
       /* An explicit constant 0 can convert to a pointer,
@@ -4052,8 +4057,16 @@ digest_init (tree type, tree init, int require_constant)
                            TREE_TYPE (type), COMPARE_STRICT))))
     {
       if (code == POINTER_TYPE)
-       inside_init = default_function_array_conversion (inside_init);
-      
+       {
+         inside_init = default_function_array_conversion (inside_init);
+
+         if (TREE_CODE (TREE_TYPE (inside_init)) == ARRAY_TYPE)
+           {
+             error_init ("invalid use of non-lvalue array");
+             return error_mark_node;
+           }
+        }
+
       if (code == VECTOR_TYPE)
        /* Although the types are compatible, we may require a
           conversion.  */
index 66151d408aefe8b91ed28ef4fd670583941df1c8..6361f9e33c266abf5f512d983bbae5ccaf6f5bb3 100644 (file)
@@ -1,3 +1,8 @@
+2003-10-04  Eric Botcazou  <ebotcazou@libertysurf.fr>
+
+       * gcc.dg/c90-array-lval-6.c: New test.
+       * gcc.dg/c99-array-lval-6.c: New test.
+
 2003-10-03  Alexander Malmberg  <alexander@malmberg.org>
            Ziemowit Laski  <zlaski@apple.com>
 
diff --git a/gcc/testsuite/gcc.dg/c90-array-lval-6.c b/gcc/testsuite/gcc.dg/c90-array-lval-6.c
new file mode 100644 (file)
index 0000000..f42ef52
--- /dev/null
@@ -0,0 +1,16 @@
+/* PR c/12446 */
+/* Origin: Keith Thompson <kst@cts.com> */
+
+/* { dg-do compile } */
+/* { dg-options "-std=iso9899:1990 -pedantic-errors" } */
+
+
+struct s { char c[1]; };
+
+extern struct s foo(void);
+
+void bar(void)
+{
+  char *ptr = foo().c; /* { dg-bogus "warning" "warning in place of error" } */
+}
+/* { dg-error "non-lvalue" "array not decaying to lvalue" { target *-*-* } 14 } */
diff --git a/gcc/testsuite/gcc.dg/c99-array-lval-6.c b/gcc/testsuite/gcc.dg/c99-array-lval-6.c
new file mode 100644 (file)
index 0000000..426b3c7
--- /dev/null
@@ -0,0 +1,15 @@
+/* PR c/12446 */
+/* Origin: Keith Thompson <kst@cts.com> */
+
+/* { dg-do compile } */
+/* { dg-options "-std=iso9899:1999 -pedantic-errors" } */
+
+
+struct s { char c[1]; };
+
+extern struct s foo(void);
+
+void bar(void)
+{
+  char *ptr = foo().c; /* { dg-bogus "non-lvalue" "array not decaying to lvalue" } */
+}