mirror of
https://git.savannah.gnu.org/git/guile.git
synced 2025-06-11 14:21:10 +02:00
* eval.c (SCM_CEVAL): Jump to badfun if trying to apply a struct
which isn't an operator. (SCM_APPLY): Ditto, but jump to badproc.
This commit is contained in:
parent
b325a6c8ac
commit
9b07e212d5
1 changed files with 15 additions and 5 deletions
|
@ -2145,7 +2145,9 @@ evapply:
|
||||||
env = EXTEND_ENV (SCM_CAR (x), SCM_EOL, SCM_ENV (proc));
|
env = EXTEND_ENV (SCM_CAR (x), SCM_EOL, SCM_ENV (proc));
|
||||||
goto cdrxbegin;
|
goto cdrxbegin;
|
||||||
case scm_tcs_cons_gloc:
|
case scm_tcs_cons_gloc:
|
||||||
if (SCM_I_OPERATORP (proc))
|
if (!SCM_I_OPERATORP (proc))
|
||||||
|
goto badfun;
|
||||||
|
else
|
||||||
{
|
{
|
||||||
x = (SCM_I_ENTITYP (proc)
|
x = (SCM_I_ENTITYP (proc)
|
||||||
? SCM_ENTITY_PROC_0 (proc)
|
? SCM_ENTITY_PROC_0 (proc)
|
||||||
|
@ -2290,7 +2292,9 @@ evapply:
|
||||||
case scm_tc7_contin:
|
case scm_tc7_contin:
|
||||||
scm_call_continuation (proc, t.arg1);
|
scm_call_continuation (proc, t.arg1);
|
||||||
case scm_tcs_cons_gloc:
|
case scm_tcs_cons_gloc:
|
||||||
if (SCM_I_OPERATORP (proc))
|
if (!SCM_I_OPERATORP (proc))
|
||||||
|
goto badfun;
|
||||||
|
else
|
||||||
{
|
{
|
||||||
x = (SCM_I_ENTITYP (proc)
|
x = (SCM_I_ENTITYP (proc)
|
||||||
? SCM_ENTITY_PROC_1 (proc)
|
? SCM_ENTITY_PROC_1 (proc)
|
||||||
|
@ -2389,7 +2393,9 @@ evapply:
|
||||||
goto evap3; */
|
goto evap3; */
|
||||||
#endif
|
#endif
|
||||||
case scm_tcs_cons_gloc:
|
case scm_tcs_cons_gloc:
|
||||||
if (SCM_I_OPERATORP (proc))
|
if (!SCM_I_OPERATORP (proc))
|
||||||
|
goto badfun;
|
||||||
|
else
|
||||||
{
|
{
|
||||||
x = (SCM_I_ENTITYP (proc)
|
x = (SCM_I_ENTITYP (proc)
|
||||||
? SCM_ENTITY_PROC_2 (proc)
|
? SCM_ENTITY_PROC_2 (proc)
|
||||||
|
@ -2562,7 +2568,9 @@ evapply:
|
||||||
goto cdrxbegin;
|
goto cdrxbegin;
|
||||||
#endif /* DEVAL */
|
#endif /* DEVAL */
|
||||||
case scm_tcs_cons_gloc:
|
case scm_tcs_cons_gloc:
|
||||||
if (SCM_I_OPERATORP (proc))
|
if (!SCM_I_OPERATORP (proc))
|
||||||
|
goto badfun;
|
||||||
|
else
|
||||||
{
|
{
|
||||||
SCM p = (SCM_I_ENTITYP (proc)
|
SCM p = (SCM_I_ENTITYP (proc)
|
||||||
? SCM_ENTITY_PROC_3 (proc)
|
? SCM_ENTITY_PROC_3 (proc)
|
||||||
|
@ -2935,7 +2943,9 @@ tail:
|
||||||
goto tail;
|
goto tail;
|
||||||
#endif
|
#endif
|
||||||
case scm_tcs_cons_gloc:
|
case scm_tcs_cons_gloc:
|
||||||
if (SCM_I_OPERATORP (proc))
|
if (!SCM_I_OPERATORP (proc))
|
||||||
|
goto badproc;
|
||||||
|
else
|
||||||
{
|
{
|
||||||
#ifdef DEVAL
|
#ifdef DEVAL
|
||||||
args = (SCM_UNBNDP(arg1) ? SCM_EOL : debug.vect[0].a.args);
|
args = (SCM_UNBNDP(arg1) ? SCM_EOL : debug.vect[0].a.args);
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue