/cp
authorpaolo <paolo@138bc75d-0d04-0410-961f-82ee72b054a4>
Tue, 8 Sep 2009 22:00:42 +0000 (22:00 +0000)
committerpaolo <paolo@138bc75d-0d04-0410-961f-82ee72b054a4>
Tue, 8 Sep 2009 22:00:42 +0000 (22:00 +0000)
2009-09-08  Paolo Carlini  <paolo.carlini@oracle.com>

PR c++/39923
* decl.c (build_init_list_var_init): Check return value of
perform_implicit_conversion.

/testsuite
2009-09-08  Paolo Carlini  <paolo.carlini@oracle.com>

PR c++/39923
* g++.dg/cpp0x/initlist24.C: New.

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

gcc/cp/ChangeLog
gcc/cp/decl.c
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/cpp0x/initlist24.C [new file with mode: 0644]

index 4244976..3656dba 100644 (file)
@@ -1,3 +1,9 @@
+2009-09-08  Paolo Carlini  <paolo.carlini@oracle.com>
+
+       PR c++/39923
+       * decl.c (build_init_list_var_init): Check return value of
+       perform_implicit_conversion.
+
 2009-09-03  Jason Merrill  <jason@redhat.com>
 
        * class.c (currently_open_class): Make sure we're dealing with the
index 99ae9f1..0cfcb4f 100644 (file)
@@ -4415,6 +4415,9 @@ build_init_list_var_init (tree decl, tree type, tree init, tree *cleanup)
 {
   tree aggr_init, array, arrtype;
   init = perform_implicit_conversion (type, init, tf_warning_or_error);
+  if (error_operand_p (init))
+    return error_mark_node;
+
   aggr_init = TARGET_EXPR_INITIAL (init);
   init = build2 (INIT_EXPR, type, decl, init);
 
index f265406..045c207 100644 (file)
@@ -1,3 +1,8 @@
+2009-09-08  Paolo Carlini  <paolo.carlini@oracle.com>
+
+       PR c++/39923
+       * g++.dg/cpp0x/initlist24.C: New.
+
 2009-09-08  Ozkan Sezer  <sezeroz@gmail.com>
 
        * gcc.dg/large-size-array-2.c: Fix target requirement.
diff --git a/gcc/testsuite/g++.dg/cpp0x/initlist24.C b/gcc/testsuite/g++.dg/cpp0x/initlist24.C
new file mode 100644 (file)
index 0000000..33e97c7
--- /dev/null
@@ -0,0 +1,9 @@
+// PR c++/39923
+// { dg-options "-std=c++0x" }
+
+#include <initializer_list>
+
+void test3()
+{
+  std::initializer_list<int> list{move}; // { dg-error "not declared|could not convert" }
+}