diff options
author | Richard Henderson <rth@redhat.com> | 2004-06-24 16:12:30 -0700 |
---|---|---|
committer | Richard Henderson <rth@gcc.gnu.org> | 2004-06-24 16:12:30 -0700 |
commit | 506e2710352a43151c4d5df8673606a9bf395885 (patch) | |
tree | 1fab0ddb0ef43b779ede7dfbfbd2254c84c942e4 /gcc/objc | |
parent | 6e6e49b10f94aaf10b6e9224e07130ab2d818f14 (diff) | |
download | gcc-506e2710352a43151c4d5df8673606a9bf395885.zip gcc-506e2710352a43151c4d5df8673606a9bf395885.tar.gz gcc-506e2710352a43151c4d5df8673606a9bf395885.tar.bz2 |
c-decl.c (c_in_iteration_stmt, [...]): Remove.
* c-decl.c (c_in_iteration_stmt, c_in_case_stmt): Remove.
(c_break_label, c_cont_label): New.
(start_function): Update initializations.
(c_push_function_context): Update saves.
(c_pop_function_context): Update restores.
* c-parse.in: Update expected conflicts.
(stmt_count, compstmt_count): Remove. Remove all updates.
(if_prefix, simple_if, do_stmt_start): Remove.
(lineno_labeled_stmt): Remove.
(lineno_labels): New.
(c99_block_lineno_labeled_stmt): Use it.
(lineno_stmt, lineno_label): Don't clear EXPR_LOCUS before calling
annotate_with_locus.
(select_or_iter_stmt): Replace by ...
(condition, if_statement_1, if_statement_2, if_statement,
start_break, start_continue, while_statement, do_statement,
for_cond_expr, for_incr_expr, for_statement, switch_statement): New.
(stmt): Split out ...
(stmt_nocomp): ... this. Use c_finish_bc_stmt, c_finish_goto_label,
c_finish_goto_ptr.
* c-semantics.c (add_stmt): Don't add line numbers to labels.
* c-tree.h: Update prototypes.
(struct language_function): Remove x_in_iteration_stmt, x_in_case_stmt;
add x_break_label, x_cont_label, x_switch_stack.
(c_switch_stack): Declare.
* c-typeck.c (c_finish_goto_label, c_finish_goto_ptr): New.
(c_finish_return): Return the statement.
(c_switch_stack): Rename from switch_stack; export.
(if_elt, if_stack, if_stack_space, if_stack_pointer): Remove.
(c_begin_if_stmt, c_finish_if_cond, c_finish_then, c_begin_else,
c_finish_else): Remove.
(c_finish_if_stmt): Rewrite to perform the entire operation.
(c_begin_while_stmt, c_finish_while_stmt_cond, c_finish_while_stmt,
c_begin_for_stmt, c_finish_for_stmt_init, c_finish_for_stmt_cond,
c_finish_for_stmt_incr, c_finish_for_stmt): Remove.
(c_finish_loop): New.
(c_finish_bc_stmt): New.
(c_finish_expr_stmt): Return the statement. Split out...
(c_process_expr_stmt): ... this. Don't add locus to error marks.
* gimplify.c (gimplify_cond_expr): Accept NULL type statements.
* tree-gimple.c (is_gimple_stmt): Likewise.
* tree-pretty-print.c (dump_generic_node <COND_EXPR>): Likewise.
(print_struct_decl): Delete empty compound statement.
* objc/objc-act.c (objc_build_throw_stmt): Return the statement.
* objc/objc-act.h: Update decl.
From-SVN: r83620
Diffstat (limited to 'gcc/objc')
-rw-r--r-- | gcc/objc/objc-act.c | 14 | ||||
-rw-r--r-- | gcc/objc/objc-act.h | 2 |
2 files changed, 8 insertions, 8 deletions
diff --git a/gcc/objc/objc-act.c b/gcc/objc/objc-act.c index 39e6f76..2ecd030 100644 --- a/gcc/objc/objc-act.c +++ b/gcc/objc/objc-act.c @@ -3188,10 +3188,12 @@ objc_finish_try_stmt (void) free (c); } -void +tree objc_build_throw_stmt (tree throw_expr) { - tree func_params; + tree args; + + objc_init_exceptions (); if (throw_expr == NULL) { @@ -3201,7 +3203,7 @@ objc_build_throw_stmt (tree throw_expr) || cur_try_context->current_catch == NULL) { error ("%<@throw%> (rethrow) used outside of a @catch block"); - return; + return NULL_TREE; } /* Otherwise the object is still sitting in the EXC_PTR_EXPR @@ -3211,10 +3213,8 @@ objc_build_throw_stmt (tree throw_expr) /* A throw is just a call to the runtime throw function with the object as a parameter. */ - func_params = tree_cons (NULL, throw_expr, NULL); - add_stmt (build_function_call (objc_exception_throw_decl, func_params)); - - objc_init_exceptions (); + args = tree_cons (NULL, throw_expr, NULL); + return add_stmt (build_function_call (objc_exception_throw_decl, args)); } void diff --git a/gcc/objc/objc-act.h b/gcc/objc/objc-act.h index ab2ea08..2472bfe 100644 --- a/gcc/objc/objc-act.h +++ b/gcc/objc/objc-act.h @@ -39,7 +39,7 @@ void finish_method_def (void); tree start_protocol (enum tree_code, tree, tree); void finish_protocol (tree); -void objc_build_throw_stmt (tree); +tree objc_build_throw_stmt (tree); void objc_begin_try_stmt (location_t, tree); void objc_begin_catch_clause (tree); void objc_finish_catch_clause (void); |