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
This commit is contained in:
parent
4e32293ce6
commit
083eb5756f
@ -1,5 +1,12 @@
|
||||
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.h (current_function_name_declared): Tweak documentation.
|
||||
(lang_decl_flags): Add pretty_function_p, adjust dummy.
|
||||
|
@ -237,6 +237,9 @@ DEFTREECODE (ASM_STMT, "asm_stmt", 'e', 5)
|
||||
run if an exception is thrown before the end of the enclosing
|
||||
function. */
|
||||
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
|
||||
constructed. If, after this point, the CLEANUP_DECL goes out of
|
||||
scope, the CLEANUP_EXPR must be run. */
|
||||
|
@ -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
|
||||
fields.
|
||||
|
||||
@item CTOR_COMPLETE
|
||||
|
||||
Used to mark the end of the main body of a constructor.
|
||||
|
||||
@item DECL_STMT
|
||||
|
||||
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.
|
||||
|
||||
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
|
||||
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
|
||||
executed in the reverse order in which they appear.
|
||||
|
||||
|
@ -2268,6 +2268,11 @@ expand_stmt (t)
|
||||
finish_expr_stmt (EXPR_STMT_EXPR (t));
|
||||
break;
|
||||
|
||||
case CTOR_COMPLETE:
|
||||
/* All subobjects have been fully constructed at this point. */
|
||||
end_protect_partials ();
|
||||
break;
|
||||
|
||||
case DECL_STMT:
|
||||
{
|
||||
tree decl;
|
||||
|
@ -4,8 +4,6 @@
|
||||
// make sure we don't call base dtors, if we failed to call the
|
||||
// base ctor due to exception throwing
|
||||
|
||||
// execution test - XFAIL *-*-*
|
||||
|
||||
#include <stdio.h>
|
||||
|
||||
static bool bad = false;
|
||||
|
Loading…
Reference in New Issue
Block a user