Commit 3b616f08 by Paolo Carlini

re PR c++/55323 (ICE in expand_aggr_init_1, at cp/init.c:1718)

/cp
2012-11-14  Paolo Carlini  <paolo.carlini@oracle.com>

	PR c++/55323
	* init.c (emit_mem_initializers): Skip arguments == error_mark_node.

/testsuite
2012-11-14  Paolo Carlini  <paolo.carlini@oracle.com>

	PR c++/55323
	* g++.dg/cpp0x/vt-55323.C: New.

From-SVN: r193505
parent 7628dc54
2012-11-14 Paolo Carlini <paolo.carlini@oracle.com>
PR c++/55323
* init.c (emit_mem_initializers): Skip arguments == error_mark_node.
2012-11-14 Fabien Chêne <fabien@gcc.gnu.org> 2012-11-14 Fabien Chêne <fabien@gcc.gnu.org>
PR c++/11750 PR c++/11750
......
...@@ -1047,12 +1047,17 @@ emit_mem_initializers (tree mem_inits) ...@@ -1047,12 +1047,17 @@ emit_mem_initializers (tree mem_inits)
in_base_initializer = 1; in_base_initializer = 1;
/* Initialize base classes. */ /* Initialize base classes. */
while (mem_inits for (; (mem_inits
&& TREE_CODE (TREE_PURPOSE (mem_inits)) != FIELD_DECL) && TREE_CODE (TREE_PURPOSE (mem_inits)) != FIELD_DECL);
mem_inits = TREE_CHAIN (mem_inits))
{ {
tree subobject = TREE_PURPOSE (mem_inits); tree subobject = TREE_PURPOSE (mem_inits);
tree arguments = TREE_VALUE (mem_inits); tree arguments = TREE_VALUE (mem_inits);
/* We already have issued an error message. */
if (arguments == error_mark_node)
continue;
if (arguments == NULL_TREE) if (arguments == NULL_TREE)
{ {
/* If these initializations are taking place in a copy constructor, /* If these initializations are taking place in a copy constructor,
...@@ -1085,8 +1090,6 @@ emit_mem_initializers (tree mem_inits) ...@@ -1085,8 +1090,6 @@ emit_mem_initializers (tree mem_inits)
tf_warning_or_error); tf_warning_or_error);
expand_cleanup_for_base (subobject, NULL_TREE); expand_cleanup_for_base (subobject, NULL_TREE);
} }
mem_inits = TREE_CHAIN (mem_inits);
} }
in_base_initializer = 0; in_base_initializer = 0;
......
2012-11-14 Fabien Chêne <fabien@gcc.gnu.org> 2012-11-14 Paolo Carlini <paolo.carlini@oracle.com>
PR c++/11750 PR c++/55323
* call.c (build_new_method_call_1): Check that the instance type * g++.dg/cpp0x/vt-55323.C: New.
and the function context are the same before setting the flag
LOOKUP_NONVIRTUAL.
2012-11-13 Sriraman Tallam <tmsriram@google.com> 2012-11-13 Sriraman Tallam <tmsriram@google.com>
* testsuite/g++.dg/mv4.C: Add require ifunc. Change error message. * g++.dg/mv4.C: Add require ifunc. Change error message.
* testsuite/g++.dg/mv5.C: Add require ifunc. * g++.dg/mv5.C: Add require ifunc.
* testsuite/g++.dg/mv6.C: Add require ifunc. * g++.dg/mv6.C: Add require ifunc.
2012-11-13 Martin Jambor <mjambor@suse.cz> 2012-11-13 Martin Jambor <mjambor@suse.cz>
......
// { dg-options "-std=c++11" }
struct foo {
foo(int a, float b);
};
struct bar : foo {
template<typename... Args>
bar(Args&&... args) : foo(2, args){} // { dg-error "parameter packs" }
};
bar b(2,1.);
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment