123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237 |
- /* classes: h_files */
- #ifndef EVALH
- #define EVALH
- /* Copyright (C) 1995, 1996 ,1998, 1999, 2000 Free Software Foundation, Inc.
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2, or (at your option)
- * any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this software; see the file COPYING. If not, write to
- * the Free Software Foundation, Inc., 59 Temple Place, Suite 330,
- * Boston, MA 02111-1307 USA
- *
- * As a special exception, the Free Software Foundation gives permission
- * for additional uses of the text contained in its release of GUILE.
- *
- * The exception is that, if you link the GUILE library with other files
- * to produce an executable, this does not by itself cause the
- * resulting executable to be covered by the GNU General Public License.
- * Your use of that executable is in no way restricted on account of
- * linking the GUILE library code into it.
- *
- * This exception does not however invalidate any other reasons why
- * the executable file might be covered by the GNU General Public License.
- *
- * This exception applies only to the code released by the
- * Free Software Foundation under the name GUILE. If you copy
- * code from other Free Software Foundation releases into a copy of
- * GUILE, as the General Public License permits, the exception does
- * not apply to the code that you add in this way. To avoid misleading
- * anyone as to the status of such modified files, you must delete
- * this exception notice from them.
- *
- * If you write modifications of your own for GUILE, it is your choice
- * whether to permit this exception to apply to your modifications.
- * If you do not wish that, delete this exception notice. */
- #include "libguile/__scm.h"
- /* {Options}
- */
- extern scm_option scm_eval_opts[];
- #define SCM_EVAL_STACK scm_eval_opts[0].val
- #define SCM_N_EVAL_OPTIONS 1
- extern int scm_eval_stack;
- extern scm_option scm_evaluator_trap_table[];
- extern SCM scm_eval_options_interface (SCM setting);
- #define SCM_TRAPS_P scm_evaluator_trap_table[0].val
- #define SCM_ENTER_FRAME_P scm_evaluator_trap_table[1].val
- #define SCM_APPLY_FRAME_P scm_evaluator_trap_table[2].val
- #define SCM_EXIT_FRAME_P scm_evaluator_trap_table[3].val
- #define SCM_N_EVALUATOR_TRAPS 4
- /* {Ilocs}
- *
- * Ilocs are relative pointers into local environment structures.
- *
- */
- #define SCM_ILOCP(n) (SCM_ITAG8(n)==scm_tc8_iloc)
- #define SCM_ILOC00 SCM_MAKE_ITAG8(0L, scm_tc8_iloc)
- #define SCM_IDINC (0x00100000L)
- #define SCM_ICDR (0x00080000L)
- #define SCM_IFRINC (0x00000100L)
- #define SCM_IDSTMSK (-SCM_IDINC)
- #define SCM_IFRAME(n) ((int)((SCM_ICDR-SCM_IFRINC)>>8) \
- & (SCM_UNPACK (n) >> 8))
- #define SCM_IDIST(n) (SCM_UNPACK (n) >> 20)
- #define SCM_ICDRP(n) (SCM_ICDR & SCM_UNPACK (n))
- /* {Evaluator}
- *
- * For an explanation of symbols containing "EVAL", see beginning of eval.c.
- */
- #ifdef MEMOIZE_LOCALS
- #define SCM_EVALIM(x, env) (SCM_ILOCP (x) ? *scm_ilookup ((x), env) : x)
- #else
- #define SCM_EVALIM(x, env) x
- #endif
- #ifdef DEBUG_EXTENSIONS
- #define SCM_XEVAL(x, env) (SCM_IMP (x) \
- ? (x) \
- : (*scm_ceval_ptr) ((x), (env)))
- #define SCM_XEVALCAR(x, env) (SCM_NCELLP (SCM_CAR (x)) \
- ? (SCM_IMP (SCM_CAR (x)) \
- ? SCM_EVALIM (SCM_CAR (x), env) \
- : SCM_GLOC_VAL (SCM_CAR (x))) \
- : (SCM_SYMBOLP (SCM_CAR (x)) \
- ? *scm_lookupcar (x, env, 1) \
- : (*scm_ceval_ptr) (SCM_CAR (x), env)))
- #else
- #define SCM_XEVAL(x, env) (SCM_IMP (x) ? (x) : scm_ceval ((x), (env)))
- #define SCM_XEVALCAR(x, env) EVALCAR (x, env)
- #endif /* DEBUG_EXTENSIONS */
- #define SCM_EXTEND_ENV scm_acons
- extern const char scm_s_expression[];
- extern const char scm_s_test[];
- extern const char scm_s_body[];
- extern const char scm_s_bindings[];
- extern const char scm_s_variable[];
- extern const char scm_s_clauses[];
- extern const char scm_s_formals[];
- extern const char scm_s_set_x[];
- extern SCM scm_sym_and;
- extern SCM scm_sym_begin;
- extern SCM scm_sym_case;
- extern SCM scm_sym_cond;
- extern SCM scm_sym_define;
- extern SCM scm_sym_do;
- extern SCM scm_sym_if;
- extern SCM scm_sym_lambda;
- extern SCM scm_sym_let;
- extern SCM scm_sym_letstar;
- extern SCM scm_sym_letrec;
- extern SCM scm_sym_quote;
- extern SCM scm_sym_quasiquote;
- extern SCM scm_sym_unquote;
- extern SCM scm_sym_uq_splicing;
- extern SCM scm_sym_dot;
- extern SCM scm_sym_atapply;
- extern SCM scm_sym_atcall_cc;
- extern SCM scm_sym_delay;
- extern SCM scm_sym_arrow;
- extern SCM scm_sym_else;
- extern SCM scm_sym_apply;
- extern SCM scm_sym_set_x;
- extern SCM scm_sym_args;
- extern SCM scm_f_apply;
- extern long scm_tc16_macro;
- /* A resolved global variable reference in the CAR position
- * of a list is stored (in code only) as a pointer to a pair with a
- * tag of 1. This is called a "gloc".
- */
- #define SCM_GLOC_SYM(x) (SCM_CAR (SCM_PACK (SCM_UNPACK (x) - 1L)))
- #define SCM_GLOC_VAL(x) (SCM_CDR (SCM_PACK (SCM_UNPACK (x) - 1L)))
- #define SCM_GLOC_VAL_LOC(x) (SCM_CDRLOC (SCM_PACK (SCM_UNPACK (x) - 1L)))
- extern SCM * scm_ilookup (SCM iloc, SCM env);
- extern SCM * scm_lookupcar (SCM vloc, SCM genv, int check);
- extern SCM scm_unmemocar (SCM form, SCM env);
- extern SCM scm_unmemocopy (SCM form, SCM env);
- extern SCM scm_eval_car (SCM pair, SCM env);
- extern SCM scm_eval_body (SCM code, SCM env);
- extern SCM scm_eval_args (SCM i, SCM env, SCM proc);
- extern SCM scm_deval_args (SCM l, SCM env, SCM proc, SCM *lloc);
- extern SCM scm_m_quote (SCM xorig, SCM env);
- extern SCM scm_m_begin (SCM xorig, SCM env);
- extern SCM scm_m_if (SCM xorig, SCM env);
- extern SCM scm_m_set_x (SCM xorig, SCM env);
- extern SCM scm_m_vref (SCM xorig, SCM env);
- extern SCM scm_m_vset (SCM xorig, SCM env);
- extern SCM scm_m_and (SCM xorig, SCM env);
- extern SCM scm_m_or (SCM xorig, SCM env);
- extern SCM scm_m_case (SCM xorig, SCM env);
- extern SCM scm_m_cond (SCM xorig, SCM env);
- extern SCM scm_m_lambda (SCM xorig, SCM env);
- extern SCM scm_m_letstar (SCM xorig, SCM env);
- extern SCM scm_m_do (SCM xorig, SCM env);
- extern SCM scm_m_quasiquote (SCM xorig, SCM env);
- extern SCM scm_m_delay (SCM xorig, SCM env);
- extern SCM scm_m_define (SCM x, SCM env);
- extern SCM scm_m_letrec (SCM xorig, SCM env);
- extern SCM scm_m_let (SCM xorig, SCM env);
- extern SCM scm_m_apply (SCM xorig, SCM env);
- extern SCM scm_m_cont (SCM xorig, SCM env);
- extern SCM scm_m_nil_cond (SCM xorig, SCM env);
- extern SCM scm_m_nil_ify (SCM xorig, SCM env);
- extern SCM scm_m_t_ify (SCM xorig, SCM env);
- extern SCM scm_m_0_cond (SCM xorig, SCM env);
- extern SCM scm_m_0_ify (SCM xorig, SCM env);
- extern SCM scm_m_1_ify (SCM xorig, SCM env);
- extern SCM scm_m_atfop (SCM xorig, SCM env);
- extern SCM scm_m_atbind (SCM xorig, SCM env);
- extern int scm_badargsp (SCM formals, SCM args);
- extern SCM scm_ceval (SCM x, SCM env);
- extern SCM scm_deval (SCM x, SCM env);
- extern SCM scm_nconc2last (SCM lst);
- extern SCM scm_apply (SCM proc, SCM arg1, SCM args);
- extern SCM scm_dapply (SCM proc, SCM arg1, SCM args);
- extern SCM scm_m_expand_body (SCM xorig, SCM env);
- extern SCM scm_macroexp (SCM x, SCM env);
- extern SCM scm_map (SCM proc, SCM arg1, SCM args);
- extern SCM scm_for_each (SCM proc, SCM arg1, SCM args);
- extern SCM scm_closure (SCM code, SCM env);
- extern SCM scm_makprom (SCM code);
- extern SCM scm_force (SCM x);
- extern SCM scm_promise_p (SCM x);
- extern SCM scm_cons_source (SCM xorig, SCM x, SCM y);
- extern SCM scm_copy_tree (SCM obj);
- extern SCM scm_eval_3 (SCM obj, int copyp, SCM env);
- extern SCM scm_eval2 (SCM obj, SCM env_thunk);
- extern SCM scm_eval (SCM obj);
- extern SCM scm_eval_x (SCM obj);
- extern void scm_init_eval (void);
- #endif /* EVALH */
- /*
- Local Variables:
- c-file-style: "gnu"
- End:
- */
|