Commit 083eb575 by Mark Mitchell Committed by Mark Mitchell

cp-tree.def (CTOR_COMPLETE): New tree node.

	* cp-tree.def (CTOR_COMPLETE): New tree node.
	(finish_constructor_body): Add it, to mark the end of the
	constructor.
	(finish_function): Don't call end_protect_partials here.
	* ir.texi (CTOR_COMPLETE): Document it.
	* semantics.c (expand_stmt): Handle it.

From-SVN: r30630
parent 4e32293c
1999-11-22 Mark Mitchell <mark@codesourcery.com> 1999-11-22 Mark Mitchell <mark@codesourcery.com>
* cp-tree.def (CTOR_COMPLETE): New tree node.
(finish_constructor_body): Add it, to mark the end of the
constructor.
(finish_function): Don't call end_protect_partials here.
* ir.texi (CTOR_COMPLETE): Document it.
* semantics.c (expand_stmt): Handle it.
* cp-tree.def (FUNCTION_NAME): New tree node. * cp-tree.def (FUNCTION_NAME): New tree node.
* cp-tree.h (current_function_name_declared): Tweak documentation. * cp-tree.h (current_function_name_declared): Tweak documentation.
(lang_decl_flags): Add pretty_function_p, adjust dummy. (lang_decl_flags): Add pretty_function_p, adjust dummy.
......
...@@ -237,6 +237,9 @@ DEFTREECODE (ASM_STMT, "asm_stmt", 'e', 5) ...@@ -237,6 +237,9 @@ DEFTREECODE (ASM_STMT, "asm_stmt", 'e', 5)
run if an exception is thrown before the end of the enclosing run if an exception is thrown before the end of the enclosing
function. */ function. */
DEFTREECODE (SUBOBJECT, "subobject", 'e', 1) DEFTREECODE (SUBOBJECT, "subobject", 'e', 1)
/* A CTOR_COMPLETE statements marks the end of the main body of the
constructor, not including any function try blocks. */
DEFTREECODE (CTOR_COMPLETE, "ctor_complete", 'e', 0)
/* A CLEANUP_STMT marks the point at which a declaration is fully /* A CLEANUP_STMT marks the point at which a declaration is fully
constructed. If, after this point, the CLEANUP_DECL goes out of constructed. If, after this point, the CLEANUP_DECL goes out of
scope, the CLEANUP_EXPR must be run. */ scope, the CLEANUP_EXPR must be run. */
......
...@@ -1274,6 +1274,10 @@ following the @code{TREE_CHAIN} link from one substatement to the next. ...@@ -1274,6 +1274,10 @@ following the @code{TREE_CHAIN} link from one substatement to the next.
Used to represent a @code{continue} statement. There are no additional Used to represent a @code{continue} statement. There are no additional
fields. fields.
@item CTOR_COMPLETE
Used to mark the end of the main body of a constructor.
@item DECL_STMT @item DECL_STMT
Used to represent a local declaration. The @code{DECL_STMT_DECL} macro Used to represent a local declaration. The @code{DECL_STMT_DECL} macro
...@@ -1383,7 +1387,7 @@ equalit) to @code{CATCH_ALL_TYPE} if this handler is for all types. ...@@ -1383,7 +1387,7 @@ equalit) to @code{CATCH_ALL_TYPE} if this handler is for all types.
In a constructor, these nodes are used to mark the point at which a In a constructor, these nodes are used to mark the point at which a
subobject of @code{this} is fully constructed. If, after this point, an subobject of @code{this} is fully constructed. If, after this point, an
exception is thrown before the constructor finishes executing, the exception is thrown before a CTOR_COMPLETE statement is encountered, the
@code{SUBOBJECT_CLEANUP} must be executed. The cleanups must be @code{SUBOBJECT_CLEANUP} must be executed. The cleanups must be
executed in the reverse order in which they appear. executed in the reverse order in which they appear.
......
...@@ -2268,6 +2268,11 @@ expand_stmt (t) ...@@ -2268,6 +2268,11 @@ expand_stmt (t)
finish_expr_stmt (EXPR_STMT_EXPR (t)); finish_expr_stmt (EXPR_STMT_EXPR (t));
break; break;
case CTOR_COMPLETE:
/* All subobjects have been fully constructed at this point. */
end_protect_partials ();
break;
case DECL_STMT: case DECL_STMT:
{ {
tree decl; tree decl;
......
...@@ -4,8 +4,6 @@ ...@@ -4,8 +4,6 @@
// make sure we don't call base dtors, if we failed to call the // make sure we don't call base dtors, if we failed to call the
// base ctor due to exception throwing // base ctor due to exception throwing
// execution test - XFAIL *-*-*
#include <stdio.h> #include <stdio.h>
static bool bad = false; static bool bad = false;
......
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