mirror of
https://git.savannah.gnu.org/git/guile.git
synced 2025-07-03 16:20:39 +02:00
Change to be less sloppy as regards functions without prototypes
* libguile/gsubr.h (scm_t_subr_0, scm_t_subr_1, etc): New precise typedefs. (SCM_AS_SUBR): Use C11's _Generic to cast subrs to the generic subr type, while also producing a warning/error if the function isn't compatible. (SCM_DEFINE_GSUBR, SCM_PRIMITIVE_GENERIC, SCM_DEFINE_PUBLIC) (SCM_DEFINE_STATIC, SCM_PROC, SCM_REGISTER_PROC, SCM_GPROC): Use SCM_AS_SUBR. * libguile/gsubr-internal.h (scm_t_subr_with_thread_0) (scm_t_subr_with_thread_1, etc): New precise typedefs. (SCM_AS_SUBR_WITH_THREAD): Like SCM_AS_SUBR. * libguile/gsubr.c (scm_apply_subr): Cast callee to the right type before calling. * libguile/hash.c (floor): Remove weird unused declaration. * libguile/init.c (scm_boot_guile): Fix type of main_func in definition. * libguile/jit.c: Fix type of enter_mcode. * libguile/smob.c (apply_0, apply_1, apply_2, apply_3): Cast callee to right type. (scm_smob_trampoline): Use SCM_AS_SUBR. * libguile/smob.h (SCM_SMOB_APPLY): Use SCM_AS_SUBR. * libguile/backtrace.c: * libguile/control.c: * libguile/dynl.c: * libguile/eval.c: * libguile/exceptions.c: * libguile/expand.c: * libguile/finalizers.c: * libguile/fluids.c: * libguile/fports.c: * libguile/frames.c: * libguile/gc.c: * libguile/load.c: * libguile/loader.c: * libguile/macros.c: * libguile/memoize.c: * libguile/pairs.c: * libguile/poll.c: * libguile/ports.c: * libguile/posix.c: * libguile/rdelim.c: * libguile/rw.c: * libguile/vm.c: Adapt scm_c_make_gsubr / scm_c_define_gsubr callers to use SCM_AS_SUBR.
This commit is contained in:
parent
a7d7ff5019
commit
c79d5bd0f7
30 changed files with 180 additions and 130 deletions
|
@ -137,7 +137,6 @@ scm_c_with_exception_handler (SCM type, scm_t_exception_handler handler,
|
|||
SCM prompt_tag = scm_cons (SCM_INUM0, SCM_EOL);
|
||||
scm_thread *t = SCM_I_CURRENT_THREAD;
|
||||
scm_t_dynstack *dynstack = &t->dynstack;
|
||||
scm_t_dynamic_state *dynamic_state = &t->dynamic_state;
|
||||
jmp_buf registers;
|
||||
jmp_buf *prev_registers;
|
||||
ptrdiff_t saved_stack_depth;
|
||||
|
@ -524,11 +523,11 @@ scm_init_exceptions ()
|
|||
raise_exception_var =
|
||||
scm_c_define ("raise-exception",
|
||||
scm_c_make_gsubr ("raise-exception", 1, 0, 0,
|
||||
(scm_t_subr) pre_boot_raise));
|
||||
SCM_AS_SUBR (pre_boot_raise)));
|
||||
|
||||
scm_c_define ("%init-exceptions!",
|
||||
scm_c_make_gsubr ("%init-exceptions!", 3, 0, 0,
|
||||
(scm_t_subr) sys_init_exceptions_x));
|
||||
SCM_AS_SUBR (sys_init_exceptions_x)));
|
||||
|
||||
#include "exceptions.x"
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue