summaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
Diffstat (limited to 'gcc')
-rw-r--r--gcc/cp/ChangeLog9
-rw-r--r--gcc/cp/call.c3
-rw-r--r--gcc/cp/decl.c1
-rw-r--r--gcc/cp/init.c4
-rw-r--r--gcc/testsuite/ChangeLog6
-rw-r--r--gcc/testsuite/g++.dg/cpp0x/initlist35.C24
-rw-r--r--gcc/testsuite/g++.dg/init/brace6.C4
7 files changed, 46 insertions, 5 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog
index b0454e67070..2a3a8a06fcf 100644
--- a/gcc/cp/ChangeLog
+++ b/gcc/cp/ChangeLog
@@ -1,3 +1,12 @@
+2010-05-24 Jason Merrill <jason@redhat.com>
+
+ PR c++/41510
+ * decl.c (check_initializer): Don't wrap an init-list in a
+ TREE_LIST.
+ * init.c (build_aggr_init): Don't assume copy-initialization if
+ init has CONSTRUCTOR_IS_DIRECT_INIT.
+ * call.c (build_new_method_call): Sanity check.
+
2010-05-24 Nathan Froyd <froydnj@codesourcery.com>
* rtti.c (tinfo_base_init): Use build_constructor instead of
diff --git a/gcc/cp/call.c b/gcc/cp/call.c
index 3cb30a5d8ee..890ab885f88 100644
--- a/gcc/cp/call.c
+++ b/gcc/cp/call.c
@@ -6350,7 +6350,8 @@ build_new_method_call (tree instance, tree fns, VEC(tree,gc) **args,
&& BRACE_ENCLOSED_INITIALIZER_P (VEC_index (tree, *args, 0))
&& CONSTRUCTOR_IS_DIRECT_INIT (VEC_index (tree, *args, 0)))
{
- gcc_assert (VEC_length (tree, *args) == 1);
+ gcc_assert (VEC_length (tree, *args) == 1
+ && !(flags & LOOKUP_ONLYCONVERTING));
list = VEC_index (tree, *args, 0);
if (TYPE_HAS_LIST_CTOR (basetype))
diff --git a/gcc/cp/decl.c b/gcc/cp/decl.c
index 95ae8ebbe0f..5420f71ecdf 100644
--- a/gcc/cp/decl.c
+++ b/gcc/cp/decl.c
@@ -5278,7 +5278,6 @@ check_initializer (tree decl, tree init, int flags, tree *cleanup)
error ("in C++98 %qD must be initialized by constructor, "
"not by %<{...}%>",
decl);
- init = build_tree_list (NULL_TREE, init);
}
else if (TREE_CODE (type) == VECTOR_TYPE && TYPE_VECTOR_OPAQUE (type))
{
diff --git a/gcc/cp/init.c b/gcc/cp/init.c
index 1fb5eb0d069..bf80c096d7e 100644
--- a/gcc/cp/init.c
+++ b/gcc/cp/init.c
@@ -1240,7 +1240,9 @@ build_aggr_init (tree exp, tree init, int flags, tsubst_flags_t complain)
TREE_READONLY (exp) = 0;
TREE_THIS_VOLATILE (exp) = 0;
- if (init && TREE_CODE (init) != TREE_LIST)
+ if (init && TREE_CODE (init) != TREE_LIST
+ && !(BRACE_ENCLOSED_INITIALIZER_P (init)
+ && CONSTRUCTOR_IS_DIRECT_INIT (init)))
flags |= LOOKUP_ONLYCONVERTING;
if (TREE_CODE (type) == ARRAY_TYPE)
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index a0b34c9454d..eb1361dd7f0 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,9 @@
+2010-05-24 Jason Merrill <jason@redhat.com>
+
+ PR c++/41510
+ * g++.dg/cpp0x/initlist35.C: New.
+ * g++.dg/init/brace6.C: Adjust.
+
2010-05-24 Paul Brook <paul@codesourcery.com>
* gcc.target/arm/frame-pointer-1.c: New test.
diff --git a/gcc/testsuite/g++.dg/cpp0x/initlist35.C b/gcc/testsuite/g++.dg/cpp0x/initlist35.C
new file mode 100644
index 00000000000..e5b7cb4bd52
--- /dev/null
+++ b/gcc/testsuite/g++.dg/cpp0x/initlist35.C
@@ -0,0 +1,24 @@
+// PR c++/41510
+// { dg-options "-std=c++0x" }
+
+struct B
+{
+ B(int, int);
+};
+struct A
+{
+ A(int, int);
+ A(const B&);
+};
+
+void f()
+{
+ A a = { 1, 2 };
+};
+
+template <class T> void g()
+{
+ A a = { 1, 2 };
+};
+
+template void g<int>();
diff --git a/gcc/testsuite/g++.dg/init/brace6.C b/gcc/testsuite/g++.dg/init/brace6.C
index bff89daa2f2..96b35b0d711 100644
--- a/gcc/testsuite/g++.dg/init/brace6.C
+++ b/gcc/testsuite/g++.dg/init/brace6.C
@@ -6,7 +6,7 @@ struct A {
};
struct B {
- B(const B&); // { dg-message "candidate" }
+ B(const B&);
int b;
};
@@ -19,7 +19,7 @@ int main()
int i = { 1 };
int j = { 1, 2 }; /* { dg-error "requires one element" } */
A a = { 6 }; /* { dg-error "initialize" } */
- B b = { 6 }; /* { dg-error "initialize" } */
+ B b = { 6 }; /* { dg-error "" } */
C c = { 6 }; /* { dg-error "too many initializers" } */
D d = { 6 };
}