aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGeoffrey Keating <geoffk@apple.com>2002-11-27 01:59:43 +0000
committerGeoffrey Keating <geoffk@gcc.gnu.org>2002-11-27 01:59:43 +0000
commita16f235752abdce78d8e5f608762a207f4973f13 (patch)
treedb5500814feb0e745c846f219176878af5153a6e
parent0ef08cc42e3010f897e2ba1b71d78c47356ed13a (diff)
downloadgcc-a16f235752abdce78d8e5f608762a207f4973f13.zip
gcc-a16f235752abdce78d8e5f608762a207f4973f13.tar.gz
gcc-a16f235752abdce78d8e5f608762a207f4973f13.tar.bz2
Index: cp/ChangeLog
2002-11-26 Geoffrey Keating <geoffk@apple.com> * decl.c (check_initializer): Don't error on initialisation of a scalar with a brace-enclosed expression. Index: testsuite/ChangeLog 2002-11-26 Geoffrey Keating <geoffk@apple.com> * g++.dg/init/brace2.C: New test. * g++.old-deja/g++.mike/p9129.C: Correct. From-SVN: r59553
-rw-r--r--gcc/cp/ChangeLog5
-rw-r--r--gcc/cp/decl.c14
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/g++.dg/init/brace2.C8
-rw-r--r--gcc/testsuite/g++.old-deja/g++.mike/p9129.C2
5 files changed, 32 insertions, 2 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog
index bd596d5..42ae0dd 100644
--- a/gcc/cp/ChangeLog
+++ b/gcc/cp/ChangeLog
@@ -1,3 +1,8 @@
+2002-11-26 Geoffrey Keating <geoffk@apple.com>
+
+ * decl.c (check_initializer): Don't error on initialisation of
+ a scalar with a brace-enclosed expression.
+
2002-11-26 Nathan Sidwell <nathan@codesourcery.com>
* cp-tree.h (DECL_LANG_FLAG_4): Document more uses.
diff --git a/gcc/cp/decl.c b/gcc/cp/decl.c
index 9ee0556..5a30e5b 100644
--- a/gcc/cp/decl.c
+++ b/gcc/cp/decl.c
@@ -8017,7 +8017,19 @@ check_initializer (tree decl, tree init, int flags)
else if (init)
{
if (TREE_CODE (init) == CONSTRUCTOR && TREE_HAS_CONSTRUCTOR (init))
- init = reshape_init (type, &init);
+ {
+ /* [dcl.init] paragraph 13,
+ If T is a scalar type, then a declaration of the form
+ T x = { a };
+ is equivalent to
+ T x = a;
+
+ reshape_init will complain about the extra braces,
+ and doesn't do anything useful in the case where TYPE is
+ scalar, so just don't call it. */
+ if (CP_AGGREGATE_TYPE_P (type))
+ init = reshape_init (type, &init);
+ }
/* If DECL has an array type without a specific bound, deduce the
array size from the initializer. */
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 86d7df3..d9a69fc 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2002-11-26 Geoffrey Keating <geoffk@apple.com>
+
+ * g++.dg/init/brace2.C: New test.
+ * g++.old-deja/g++.mike/p9129.C: Correct.
+
2002-11-26 Mark Mitchell <mark@codesourcery.com>
* g++.dg/abi/empty10.C: Don't run on non-x86 targets.
diff --git a/gcc/testsuite/g++.dg/init/brace2.C b/gcc/testsuite/g++.dg/init/brace2.C
new file mode 100644
index 0000000..488d916
--- /dev/null
+++ b/gcc/testsuite/g++.dg/init/brace2.C
@@ -0,0 +1,8 @@
+// { dg-do compile }
+// [dcl.init] paragraph 13.
+int x = { 2 };
+const char * y = { "hello" };
+int a = 2;
+int b = { 2,3 }; // { dg-error "requires one element" }
+int c = { { 2 } } ; // { dg-error "braces around scalar initializer" }
+
diff --git a/gcc/testsuite/g++.old-deja/g++.mike/p9129.C b/gcc/testsuite/g++.old-deja/g++.mike/p9129.C
index a986104..c8d5485 100644
--- a/gcc/testsuite/g++.old-deja/g++.mike/p9129.C
+++ b/gcc/testsuite/g++.old-deja/g++.mike/p9129.C
@@ -7,6 +7,6 @@ public:
int DoSomething();
};
-int (Foo::*pA)() = { &Foo::DoSomething }; // ERROR -
+int (Foo::*pA)() = { &Foo::DoSomething };
int (Foo::*X[1])(int) = { { &Foo::DoSomething } }; // ERROR -
int (Foo::*Y[])(int) = { { &Foo::DoSomething, &Foo::DoSomething, 0 } }; // ERROR -