Signed-off-by: Jose E. Marchesi <jemarch@gnu.org>
gcc/algol68/ChangeLog
* a68-low-holes.cc (a68_wrap_formal_proc_hole): The wrapper is not
a top-level function.
* a68-low-units.cc (a68_lower_formal_hole): Reorder code and
remove spurious comment.
gcc/testsuite/ChangeLog
* algol68/compile/formal-hole-1.a68: New test.
}
DECL_ARGUMENTS (wrapper) = nreverse (DECL_ARGUMENTS (wrapper));
- a68_push_function_range (wrapper, wrapper_ret_type, true /* top_level */);
+ a68_push_function_range (wrapper, wrapper_ret_type);
/* We need a pointer to a function type. */
if (!POINTER_TYPE_P (TREE_TYPE (wrapped)))
{
decl = a68_make_anonymous_routine_decl (MOID (p));
a68_add_decl (decl);
- a68_wrap_formal_proc_hole (p, decl);
-
- /* XXX necessary */
a68_add_decl_expr (fold_build1_loc (a68_get_node_location (p),
DECL_EXPR,
TREE_TYPE (decl),
decl));
+ a68_wrap_formal_proc_hole (p, decl);
+
decl = fold_build1 (ADDR_EXPR,
build_pointer_type (TREE_TYPE (decl)),
decl);
--- /dev/null
+{ Freestanding formal hole. }
+
+begin
+ proc msleep = (int ms) void:
+ proc(bits)int (nest C "usleep") (BIN ms);
+ skip
+end