OSDN Git Service

PR c++/13081
authormmitchel <mmitchel@138bc75d-0d04-0410-961f-82ee72b054a4>
Mon, 29 Dec 2003 02:42:17 +0000 (02:42 +0000)
committermmitchel <mmitchel@138bc75d-0d04-0410-961f-82ee72b054a4>
Mon, 29 Dec 2003 02:42:17 +0000 (02:42 +0000)
* decl.c (duplicate_decls): Preserve inline-ness when redeclaring
a function template.

PR c++/12613
* decl.c (reshape_init): Reject GNU colon-style designated
initializers in arrays.

PR c++/13081
* g++.dg/opt/inline6.C: New test.

PR c++/12613
* g++.dg/parse/error9.C: New test.

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

gcc/cp/ChangeLog
gcc/cp/decl.c
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/opt/inline6.C [new file with mode: 0644]
gcc/testsuite/g++.dg/parse/error9.C [new file with mode: 0644]

index 3f85d7b..62e395a 100644 (file)
@@ -1,5 +1,13 @@
 2003-12-28  Mark Mitchell  <mark@codesourcery.com>
 
+       PR c++/13081
+       * decl.c (duplicate_decls): Preserve inline-ness when redeclaring
+       a function template.
+
+       PR c++/12613
+       * decl.c (reshape_init): Reject GNU colon-style designated
+       initializers in arrays.
+
        PR c++/13009
        * call.c (build_special_member_call): Do not assume that we have a
        pointer to the complete object in an assignment operator.
index 0c0803b..80041cb 100644 (file)
@@ -1594,6 +1594,14 @@ duplicate_decls (tree newdecl, tree olddecl)
            = DECL_SOURCE_LOCATION (newdecl);
        }
 
+      if (DECL_FUNCTION_TEMPLATE_P (newdecl))
+       {
+         DECL_INLINE (DECL_TEMPLATE_RESULT (olddecl)) 
+           |= DECL_INLINE (DECL_TEMPLATE_RESULT (newdecl));
+         DECL_DECLARED_INLINE_P (DECL_TEMPLATE_RESULT (olddecl))
+           |= DECL_DECLARED_INLINE_P (DECL_TEMPLATE_RESULT (newdecl));
+       }
+
       return olddecl;
     }
 
@@ -4342,7 +4350,17 @@ reshape_init (tree type, tree *initp)
              TREE_CHAIN (element_init) = CONSTRUCTOR_ELTS (new_init);
              CONSTRUCTOR_ELTS (new_init) = element_init;
              if (TREE_PURPOSE (element_init))
-               index = TREE_PURPOSE (element_init);
+               {
+                 tree next_index = TREE_PURPOSE (element_init);
+                 if (TREE_CODE (next_index) == IDENTIFIER_NODE)
+                   {
+                     error ("name `%D' used in a GNU-style designated "
+                            "initializer for an array", next_index);
+                     TREE_PURPOSE (element_init) = NULL_TREE;
+                   }
+                 else
+                   index = next_index;
+               }
            }
        }
       else
index 465b7a9..bfca531 100644 (file)
@@ -1,5 +1,11 @@
 2003-12-28  Mark Mitchell  <mark@codesourcery.com>
 
+       PR c++/13081
+       * g++.dg/opt/inline6.C: New test.
+
+       PR c++/12613
+       * g++.dg/parse/error9.C: New test.
+
        * gcc.dg/const-elim-1.c: XFAIL on arm-*-*.
 
 2003-12-28  Mark Mitchell  <mark@codesourcery.com>
diff --git a/gcc/testsuite/g++.dg/opt/inline6.C b/gcc/testsuite/g++.dg/opt/inline6.C
new file mode 100644 (file)
index 0000000..2187221
--- /dev/null
@@ -0,0 +1,14 @@
+// PR c++/13081
+// { dg-options "-O2" }
+// { dg-final { scan-assembler-not "foo" } }
+
+template<typename T> T foo(T);
+template<typename T> inline T foo(T t)
+{
+  return t;
+}
+
+void bar (long& l) {
+  l = foo(l);
+}
diff --git a/gcc/testsuite/g++.dg/parse/error9.C b/gcc/testsuite/g++.dg/parse/error9.C
new file mode 100644 (file)
index 0000000..aa9109f
--- /dev/null
@@ -0,0 +1,5 @@
+// PR c++/12613
+// { dg-options "" }
+
+enum { FOO = 1, BAR = 2 };
+int a[] = { FOO: 1, BAR: 2 }; // { dg-error "" }