mirror of
https://git.savannah.gnu.org/git/guile.git
synced 2025-06-10 05:50:26 +02:00
This set of patches contains no functional changes, only debatable
minor stylistic ones. Still, in order to prepare a patch between my local copy and the CVS version, I decided to submit the changes below. Then, the patch will hopefully only contain relevant modifications :-) * eval.c (iqq): Added const specifier. * eval.c (scm_trampoline_0, scm_trampoline_1, scm_trampoline_2): Use NULL instead of 0 to indicate that a pointer is returned. Removed some misleading 'fall through' comments. * eval.c (scm_i_call_closure_0, call_closure_1, call_closure_2): Split up long expressions into smaller ones to be more debugging friendly.
This commit is contained in:
parent
a98e8e985b
commit
d0b07b5def
2 changed files with 61 additions and 35 deletions
|
@ -1,3 +1,21 @@
|
|||
2003-04-23 Dirk Herrmann <D.Herrmann@tu-bs.de>
|
||||
|
||||
This set of patches contains no functional changes, only debatable
|
||||
minor stylistic ones. Still, in order to prepare a patch between
|
||||
my local copy and the CVS version, I decided to submit the changes
|
||||
below. Then, the patch will hopefully only contain relevant
|
||||
modifications :-)
|
||||
|
||||
* eval.c (iqq): Added const specifier.
|
||||
|
||||
* eval.c (scm_trampoline_0, scm_trampoline_1, scm_trampoline_2):
|
||||
Use NULL instead of 0 to indicate that a pointer is returned.
|
||||
Removed some misleading 'fall through' comments.
|
||||
|
||||
* eval.c (scm_i_call_closure_0, call_closure_1, call_closure_2):
|
||||
Split up long expressions into smaller ones to be more debugging
|
||||
friendly.
|
||||
|
||||
2003-04-23 Dirk Herrmann <D.Herrmann@tu-bs.de>
|
||||
|
||||
* eval.h (SCM_ENTER_FRAME_HDLR, SCM_APPLY_FRAME_HDLR,
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
/* Copyright (C) 1995,1996,1997,1998,1999,2000,2001,2002, 2003 Free Software Foundation, Inc.
|
||||
/* Copyright (C) 1995,1996,1997,1998,1999,2000,2001,2002,2003 Free Software Foundation, Inc.
|
||||
*
|
||||
* This library is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU Lesser General Public
|
||||
|
@ -757,7 +757,7 @@ iqq (SCM form, SCM env, unsigned long int depth)
|
|||
else if (SCM_VECTORP (form))
|
||||
{
|
||||
size_t i = SCM_VECTOR_LENGTH (form);
|
||||
SCM const *data = SCM_VELTS (form);
|
||||
SCM const *const data = SCM_VELTS (form);
|
||||
SCM tmp = SCM_EOL;
|
||||
while (i != 0)
|
||||
tmp = scm_cons (data[--i], tmp);
|
||||
|
@ -1583,6 +1583,7 @@ scm_eval_args (SCM l, SCM env, SCM proc)
|
|||
return results;
|
||||
}
|
||||
|
||||
|
||||
SCM
|
||||
scm_eval_body (SCM code, SCM env)
|
||||
{
|
||||
|
@ -1611,7 +1612,6 @@ scm_eval_body (SCM code, SCM env)
|
|||
return SCM_XEVALCAR (code, env);
|
||||
}
|
||||
|
||||
|
||||
#endif /* !DEVAL */
|
||||
|
||||
|
||||
|
@ -1755,6 +1755,7 @@ SCM_DEFINE (scm_eval_options_interface, "eval-options-interface", 0, 1, 0,
|
|||
}
|
||||
#undef FUNC_NAME
|
||||
|
||||
|
||||
SCM_DEFINE (scm_evaluator_traps, "evaluator-traps-interface", 0, 1, 0,
|
||||
(SCM setting),
|
||||
"Option interface for the evaluator trap options.")
|
||||
|
@ -1772,6 +1773,7 @@ SCM_DEFINE (scm_evaluator_traps, "evaluator-traps-interface", 0, 1, 0,
|
|||
}
|
||||
#undef FUNC_NAME
|
||||
|
||||
|
||||
static SCM
|
||||
deval_args (SCM l, SCM env, SCM proc, SCM *lloc)
|
||||
{
|
||||
|
@ -1801,7 +1803,7 @@ deval_args (SCM l, SCM env, SCM proc, SCM *lloc)
|
|||
#define UPDATE_TOPLEVEL_ENV(env) \
|
||||
do { \
|
||||
SCM p = scm_current_module_lookup_closure (); \
|
||||
if (p != SCM_CAR(env)) \
|
||||
if (p != SCM_CAR (env)) \
|
||||
env = scm_top_level_env (p); \
|
||||
} while (0)
|
||||
|
||||
|
@ -3323,6 +3325,7 @@ ret:
|
|||
#ifndef DEVAL
|
||||
|
||||
|
||||
|
||||
/* Simple procedure calls
|
||||
*/
|
||||
|
||||
|
@ -3446,7 +3449,7 @@ scm_apply (SCM proc, SCM arg1, SCM args)
|
|||
#if 0
|
||||
SCM
|
||||
scm_dapply (SCM proc, SCM arg1, SCM args)
|
||||
{ /* empty */ }
|
||||
{}
|
||||
#endif
|
||||
|
||||
|
||||
|
@ -3821,17 +3824,19 @@ call_lsubr_0 (SCM proc)
|
|||
SCM
|
||||
scm_i_call_closure_0 (SCM proc)
|
||||
{
|
||||
return scm_eval_body (SCM_CLOSURE_BODY (proc),
|
||||
SCM_EXTEND_ENV (SCM_CLOSURE_FORMALS (proc),
|
||||
SCM_EOL,
|
||||
SCM_ENV (proc)));
|
||||
const SCM env = SCM_ENV (proc);
|
||||
const SCM formals = SCM_CLOSURE_FORMALS (proc);
|
||||
const SCM new_env = SCM_EXTEND_ENV (formals, SCM_EOL, env);
|
||||
const SCM body = SCM_CLOSURE_BODY (proc);
|
||||
const SCM result = scm_eval_body (body, new_env);
|
||||
return result;
|
||||
}
|
||||
|
||||
scm_t_trampoline_0
|
||||
scm_trampoline_0 (SCM proc)
|
||||
{
|
||||
if (SCM_IMP (proc))
|
||||
return 0;
|
||||
return NULL;
|
||||
if (SCM_DEBUGGINGP)
|
||||
return scm_call_0;
|
||||
switch (SCM_TYP7 (proc))
|
||||
|
@ -3848,27 +3853,26 @@ scm_trampoline_0 (SCM proc)
|
|||
if (SCM_NULLP (formals) || !SCM_CONSP (formals))
|
||||
return scm_i_call_closure_0;
|
||||
else
|
||||
return 0;
|
||||
return NULL;
|
||||
}
|
||||
case scm_tcs_struct:
|
||||
if (SCM_OBJ_CLASS_FLAGS (proc) & SCM_CLASSF_PURE_GENERIC)
|
||||
return scm_call_generic_0;
|
||||
else if (!SCM_I_OPERATORP (proc))
|
||||
return 0;
|
||||
return NULL;
|
||||
return scm_call_0;
|
||||
case scm_tc7_smob:
|
||||
if (SCM_SMOB_APPLICABLE_P (proc))
|
||||
return SCM_SMOB_DESCRIPTOR (proc).apply_0;
|
||||
else
|
||||
return 0;
|
||||
/* fall through */
|
||||
return NULL;
|
||||
case scm_tc7_asubr:
|
||||
case scm_tc7_rpsubr:
|
||||
case scm_tc7_cclo:
|
||||
case scm_tc7_pws:
|
||||
return scm_call_0;
|
||||
default:
|
||||
return 0; /* not applicable on one arg */
|
||||
return NULL; /* not applicable on one arg */
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -3926,17 +3930,20 @@ call_cxr_1 (SCM proc, SCM arg1)
|
|||
static SCM
|
||||
call_closure_1 (SCM proc, SCM arg1)
|
||||
{
|
||||
return scm_eval_body (SCM_CLOSURE_BODY (proc),
|
||||
SCM_EXTEND_ENV (SCM_CLOSURE_FORMALS (proc),
|
||||
scm_list_1 (arg1),
|
||||
SCM_ENV (proc)));
|
||||
const SCM env = SCM_ENV (proc);
|
||||
const SCM formals = SCM_CLOSURE_FORMALS (proc);
|
||||
const SCM args = scm_list_1 (arg1);
|
||||
const SCM new_env = SCM_EXTEND_ENV (formals, args, env);
|
||||
const SCM body = SCM_CLOSURE_BODY (proc);
|
||||
const SCM result = scm_eval_body (body, new_env);
|
||||
return result;
|
||||
}
|
||||
|
||||
scm_t_trampoline_1
|
||||
scm_trampoline_1 (SCM proc)
|
||||
{
|
||||
if (SCM_IMP (proc))
|
||||
return 0;
|
||||
return NULL;
|
||||
if (SCM_DEBUGGINGP)
|
||||
return scm_call_1;
|
||||
switch (SCM_TYP7 (proc))
|
||||
|
@ -3960,27 +3967,26 @@ scm_trampoline_1 (SCM proc)
|
|||
&& (!SCM_CONSP (formals) || !SCM_CONSP (SCM_CDR (formals))))
|
||||
return call_closure_1;
|
||||
else
|
||||
return 0;
|
||||
return NULL;
|
||||
}
|
||||
case scm_tcs_struct:
|
||||
if (SCM_OBJ_CLASS_FLAGS (proc) & SCM_CLASSF_PURE_GENERIC)
|
||||
return scm_call_generic_1;
|
||||
else if (!SCM_I_OPERATORP (proc))
|
||||
return 0;
|
||||
return NULL;
|
||||
return scm_call_1;
|
||||
case scm_tc7_smob:
|
||||
if (SCM_SMOB_APPLICABLE_P (proc))
|
||||
return SCM_SMOB_DESCRIPTOR (proc).apply_1;
|
||||
else
|
||||
return 0;
|
||||
/* fall through */
|
||||
return NULL;
|
||||
case scm_tc7_asubr:
|
||||
case scm_tc7_rpsubr:
|
||||
case scm_tc7_cclo:
|
||||
case scm_tc7_pws:
|
||||
return scm_call_1;
|
||||
default:
|
||||
return 0; /* not applicable on one arg */
|
||||
return NULL; /* not applicable on one arg */
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -4005,17 +4011,20 @@ call_lsubr_2 (SCM proc, SCM arg1, SCM arg2)
|
|||
static SCM
|
||||
call_closure_2 (SCM proc, SCM arg1, SCM arg2)
|
||||
{
|
||||
return scm_eval_body (SCM_CLOSURE_BODY (proc),
|
||||
SCM_EXTEND_ENV (SCM_CLOSURE_FORMALS (proc),
|
||||
scm_list_2 (arg1, arg2),
|
||||
SCM_ENV (proc)));
|
||||
const SCM env = SCM_ENV (proc);
|
||||
const SCM formals = SCM_CLOSURE_FORMALS (proc);
|
||||
const SCM args = scm_list_2 (arg1, arg2);
|
||||
const SCM new_env = SCM_EXTEND_ENV (formals, args, env);
|
||||
const SCM body = SCM_CLOSURE_BODY (proc);
|
||||
const SCM result = scm_eval_body (body, new_env);
|
||||
return result;
|
||||
}
|
||||
|
||||
scm_t_trampoline_2
|
||||
scm_trampoline_2 (SCM proc)
|
||||
{
|
||||
if (SCM_IMP (proc))
|
||||
return 0;
|
||||
return NULL;
|
||||
if (SCM_DEBUGGINGP)
|
||||
return scm_call_2;
|
||||
switch (SCM_TYP7 (proc))
|
||||
|
@ -4039,25 +4048,24 @@ scm_trampoline_2 (SCM proc)
|
|||
|| !SCM_CONSP (SCM_CDDR (formals))))))
|
||||
return call_closure_2;
|
||||
else
|
||||
return 0;
|
||||
return NULL;
|
||||
}
|
||||
case scm_tcs_struct:
|
||||
if (SCM_OBJ_CLASS_FLAGS (proc) & SCM_CLASSF_PURE_GENERIC)
|
||||
return scm_call_generic_2;
|
||||
else if (!SCM_I_OPERATORP (proc))
|
||||
return 0;
|
||||
return NULL;
|
||||
return scm_call_2;
|
||||
case scm_tc7_smob:
|
||||
if (SCM_SMOB_APPLICABLE_P (proc))
|
||||
return SCM_SMOB_DESCRIPTOR (proc).apply_2;
|
||||
else
|
||||
return 0;
|
||||
/* fall through */
|
||||
return NULL;
|
||||
case scm_tc7_cclo:
|
||||
case scm_tc7_pws:
|
||||
return scm_call_2;
|
||||
default:
|
||||
return 0; /* not applicable on two args */
|
||||
return NULL; /* not applicable on two args */
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue