* cp-tree.def (CTOR_COMPLETE): New tree node.
authormmitchel <mmitchel@138bc75d-0d04-0410-961f-82ee72b054a4>
Tue, 23 Nov 1999 07:31:07 +0000 (07:31 +0000)
committermmitchel <mmitchel@138bc75d-0d04-0410-961f-82ee72b054a4>
Tue, 23 Nov 1999 07:31:07 +0000 (07:31 +0000)
(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.

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

gcc/cp/ChangeLog
gcc/cp/cp-tree.def
gcc/cp/ir.texi
gcc/cp/semantics.c
gcc/testsuite/g++.old-deja/g++.eh/cleanup2.C

index d214aaa..b5fdd4c 100644 (file)
@@ -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.
index de874cb..59b14fd 100644 (file)
@@ -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.  */
index b31fd1d..09ae98d 100644 (file)
@@ -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.
 
index 37510e5..7a030e6 100644 (file)
@@ -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;
index 08b3c5d..b9ed9a5 100644 (file)
@@ -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;