mirror of
https://git.savannah.gnu.org/git/guile.git
synced 2025-04-30 03:40:34 +02:00
SCM_DEBUGGINGP: * debug.h (scm_debug_mode_p, scm_debug_mode, SCM_DEBUGGINGP), eval.c (scm_debug_mode_p): Deprecated scm_debug_mode and SCM_DEBUGGINGP. Provided scm_debug_mode_p instead, to have one single interface that also matches the naming conventions. Probably scm_debug_mode_p should be part of the private interface anyway. * debug.h (scm_debug_mode_p), backtrace.c (display_error_body), eval.c (SCM_APPLY, scm_trampoline_0, scm_trampoline_1, scm_trampoline_2): Change uses of scm_debug_mode or SCM_DEBUGGINGP to scm_debug_mode_p. Deprecate direct access to scm_ceval, scm_deval and scm_ceval_ptr: * eval.h (scm_ceval, scm_deval, scm_ceval_ptr), debug.h (scm_ceval_ptr): Deprecated. Moved declaration of scm_ceval_ptr from debug.h to eval.h. * debug.h (SCM_RESET_DEBUG_MODE): Don't access scm_ceval_ptr any more, just leave it with setting scm_debug_mode_p, which is equivalent for practical purposes. * deprecated.h (SCM_XEVAL, SCM_XEVALCAR): Call scm_i_eval_x instead of *scm_ceval_ptr. Leave all evaluating to scm_i_eval_x. * gdbint.c (gdb_eval): Call scm_i_eval_x instead of scm_ceval. * eval.c (ceval, deval, scm_ceval, scm_deval): Made scm_ceval static and renamed it to ceval throughout. Provide a new exported but deprecated function scm_ceval as a wrapper for backwards compatibility. The same is done for the deval/scm_deval pair of functions. * eval.c (CEVAL, SCM_CEVAL): Renamed SCM_CEVAL to CEVAL throughout. Defined CEVAL to ceval or deval, based on compilation phase. * eval.c (SCM_XEVAL, SCM_XEVALCAR): Dispatch on scm_debug_mode_p to ceval and deval instead of calling *scm_ceval_ptr. * eval.c (dispatching_eval): New deprecated static function. * eval.c (scm_ceval_ptr): Initialized to dispatching_eval in order to emulate its old behaviour as closely as possible. Change the evaluator such that only expressions for which pair? is true are passed to CEVAL, and such that all other expressions are evaluated outside of CEVAL: * eval.c (EVAL): New, provided in analogy to EVALCAR. Evaluate an expression that is assumed to be memoized already. All but expressions of the form '(<form> <form> ...)' are evaluated inline without calling an evaluator. * eval.c (SCM_XEVAL, SCM_XEVALCAR, EVALCAR): Evaluate all but expressions of the form '(<form> <form> ...)' inline without calling an evaluator. * eval.c (scm_i_eval_x, scm_i_eval, scm_ceval, scm_deval): Handle the special case of unmemoized symbols passed on the top level. * eval.c (CEVAL): Change calls to CEVAL to EVAL, except where it is known that the expression passed to CEVAL is of the form '(<form> <form> ...)'. Remove handling of the tc7-objects, since now it is known that the input expression of CEVAL is a pair.
290 lines
9.7 KiB
C
290 lines
9.7 KiB
C
/* This file contains definitions for deprecated features. When you
|
|
deprecate something, move it here when that is feasible.
|
|
*/
|
|
|
|
#ifndef SCM_DEPRECATED_H
|
|
#define SCM_DEPRECATED_H
|
|
|
|
/* Copyright (C) 2003,2004 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
|
|
* License as published by the Free Software Foundation; either
|
|
* version 2.1 of the License, or (at your option) any later version.
|
|
*
|
|
* This library 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
|
|
* Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
* License along with this library; if not, write to the Free Software
|
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
*/
|
|
|
|
#include "libguile/__scm.h"
|
|
#include "libguile/strings.h"
|
|
|
|
#if (SCM_ENABLE_DEPRECATED == 1)
|
|
|
|
/* From tags.h: Macro checking for two tc16 types that are allocated to differ
|
|
* only in the 's'-bit. Deprecated in guile 1.7.0 on 2003-09-21. */
|
|
#define SCM_TYP16S(x) (0xfeff & SCM_CELL_TYPE (x))
|
|
|
|
|
|
/* From numbers.h: Macros checking for types, but avoiding a redundant check
|
|
* for !SCM_IMP. These were deprecated in guile 1.7.0 on 2003-09-06. */
|
|
#define SCM_SLOPPY_INEXACTP(x) (SCM_TYP16S (x) == scm_tc16_real)
|
|
#define SCM_SLOPPY_REALP(x) (SCM_TYP16 (x) == scm_tc16_real)
|
|
#define SCM_SLOPPY_COMPLEXP(x) (SCM_TYP16 (x) == scm_tc16_complex)
|
|
|
|
|
|
/* From eval.h: Macros for handling ilocs. These were deprecated in guile
|
|
* 1.7.0 on 2003-06-04. */
|
|
#define SCM_ILOC00 SCM_MAKE_ITAG8(0L, scm_tc8_iloc)
|
|
#define SCM_IDINC (0x00100000L)
|
|
#define SCM_IDSTMSK (-SCM_IDINC)
|
|
|
|
|
|
/* From eval.h: Error messages of the evaluator. These were deprecated in
|
|
* guile 1.7.0 on 2003-06-02. */
|
|
SCM_API const char scm_s_expression[];
|
|
SCM_API const char scm_s_test[];
|
|
SCM_API const char scm_s_body[];
|
|
SCM_API const char scm_s_bindings[];
|
|
SCM_API const char scm_s_variable[];
|
|
SCM_API const char scm_s_clauses[];
|
|
SCM_API const char scm_s_formals[];
|
|
|
|
|
|
/* From eval.h: Helper macros for evaluation and application. These were
|
|
* deprecated in guile 1.7.0 on 2003-06-02. */
|
|
#define SCM_EVALIM2(x) \
|
|
((SCM_EQ_P ((x), SCM_EOL) \
|
|
? scm_misc_error (NULL, scm_s_expression, SCM_EOL), 0 \
|
|
: 0), \
|
|
(x))
|
|
#define SCM_EVALIM(x, env) (SCM_ILOCP (x) \
|
|
? *scm_ilookup ((x), env) \
|
|
: SCM_EVALIM2(x))
|
|
#define SCM_XEVAL(x, env) (scm_i_eval_x ((x), (env)))
|
|
#define SCM_XEVALCAR(x, env) (SCM_SYMBOLP (SCM_CAR (x)) \
|
|
? *scm_lookupcar (x, env, 1) \
|
|
: scm_i_eval_x (SCM_CAR (x), (env)))
|
|
|
|
|
|
#define scm_substring_move_left_x scm_substring_move_x
|
|
#define scm_substring_move_right_x scm_substring_move_x
|
|
|
|
#define scm_sizet size_t
|
|
|
|
SCM_API SCM scm_wta (SCM arg, const char *pos, const char *s_subr);
|
|
|
|
#define SCM_WNA 8
|
|
#define SCM_OUTOFRANGE 10
|
|
#define SCM_NALLOC 11
|
|
|
|
SCM_API void scm_register_module_xxx (char *module_name, void *init_func);
|
|
SCM_API SCM scm_registered_modules (void);
|
|
SCM_API SCM scm_clear_registered_modules (void);
|
|
|
|
SCM_API SCM scm_protect_object (SCM obj);
|
|
SCM_API SCM scm_unprotect_object (SCM obj);
|
|
|
|
#define SCM_SETAND_CAR(x, y) \
|
|
(SCM_SETCAR ((x), SCM_PACK (SCM_UNPACK (SCM_CAR (x)) & (y))))
|
|
#define SCM_SETOR_CAR(x, y)\
|
|
(SCM_SETCAR ((x), SCM_PACK (SCM_UNPACK (SCM_CAR (x)) | (y))))
|
|
#define SCM_SETAND_CDR(x, y)\
|
|
(SCM_SETCDR ((x), SCM_PACK (SCM_UNPACK (SCM_CDR (x)) & (y))))
|
|
#define SCM_SETOR_CDR(x, y)\
|
|
(SCM_SETCDR ((x), SCM_PACK (SCM_UNPACK (SCM_CDR (x)) | (y))))
|
|
#define SCM_FREEP(x) (SCM_FREE_CELL_P (x))
|
|
#define SCM_NFREEP(x) (!SCM_FREE_CELL_P (x))
|
|
#define SCM_GC8MARKP(x) SCM_GC_MARK_P (x)
|
|
#define SCM_SETGC8MARK(x) SCM_SET_GC_MARK (x)
|
|
#define SCM_CLRGC8MARK(x) SCM_CLEAR_GC_MARK (x)
|
|
#define SCM_GCTYP16(x) SCM_TYP16 (x)
|
|
#define SCM_GCCDR(x) SCM_CDR (x)
|
|
SCM_API void scm_remember (SCM * ptr);
|
|
|
|
SCM_API SCM scm_the_root_module (void);
|
|
SCM_API SCM scm_make_module (SCM name);
|
|
SCM_API SCM scm_ensure_user_module (SCM name);
|
|
SCM_API SCM scm_load_scheme_module (SCM name);
|
|
|
|
#define scm_port scm_t_port
|
|
#define scm_ptob_descriptor scm_t_ptob_descriptor
|
|
#define scm_port_rw_active scm_t_port_rw_active
|
|
|
|
SCM_API SCM scm_close_all_ports_except (SCM ports);
|
|
|
|
#define scm_rstate scm_t_rstate
|
|
#define scm_rng scm_t_rng
|
|
|
|
#define SCM_SLOPPY_CONSP(x) ((1 & SCM_CELL_TYPE (x)) == 0)
|
|
#define SCM_SLOPPY_NCONSP(x) (!SCM_SLOPPY_CONSP(x))
|
|
|
|
#define scm_tc7_ssymbol scm_tc7_symbol
|
|
#define scm_tc7_msymbol scm_tc7_symbol
|
|
#define scm_tcs_symbols scm_tc7_symbol
|
|
|
|
SCM_API SCM scm_makstr (size_t len, int);
|
|
SCM_API SCM scm_makfromstr (const char *src, size_t len, int);
|
|
|
|
SCM_API SCM scm_variable_set_name_hint (SCM var, SCM hint);
|
|
SCM_API SCM scm_builtin_variable (SCM name);
|
|
|
|
SCM_API SCM scm_internal_with_fluids (SCM fluids, SCM vals,
|
|
SCM (*cproc)(void *), void *cdata);
|
|
|
|
SCM_API SCM scm_make_gsubr (const char *name, int req, int opt, int rst,
|
|
SCM (*fcn)());
|
|
SCM_API SCM scm_make_gsubr_with_generic (const char *name,
|
|
int req,
|
|
int opt,
|
|
int rst,
|
|
SCM (*fcn)(),
|
|
SCM *gf);
|
|
|
|
extern SCM scm_create_hook (const char* name, int n_args);
|
|
|
|
#define SCM_LIST0 SCM_EOL
|
|
#define SCM_LIST1(e0) scm_cons ((e0), SCM_EOL)
|
|
#define SCM_LIST2(e0, e1) scm_cons2 ((e0), (e1), SCM_EOL)
|
|
#define SCM_LIST3(e0, e1, e2) scm_cons ((e0), SCM_LIST2 ((e1), (e2)))
|
|
#define SCM_LIST4(e0, e1, e2, e3)\
|
|
scm_cons2 ((e0), (e1), SCM_LIST2 ((e2), (e3)))
|
|
#define SCM_LIST5(e0, e1, e2, e3, e4)\
|
|
scm_cons ((e0), SCM_LIST4 ((e1), (e2), (e3), (e4)))
|
|
#define SCM_LIST6(e0, e1, e2, e3, e4, e5)\
|
|
scm_cons2 ((e0), (e1), SCM_LIST4 ((e2), (e3), (e4), (e5)))
|
|
#define SCM_LIST7(e0, e1, e2, e3, e4, e5, e6)\
|
|
scm_cons ((e0), SCM_LIST6 ((e1), (e2), (e3), (e4), (e5), (e6)))
|
|
#define SCM_LIST8(e0, e1, e2, e3, e4, e5, e6, e7)\
|
|
scm_cons2 ((e0), (e1), SCM_LIST6 ((e2), (e3), (e4), (e5), (e6), (e7)))
|
|
#define SCM_LIST9(e0, e1, e2, e3, e4, e5, e6, e7, e8)\
|
|
scm_cons ((e0),\
|
|
SCM_LIST8 ((e1), (e2), (e3), (e4), (e5), (e6), (e7), (e8)))
|
|
|
|
#define scm_listify scm_list_n
|
|
|
|
SCM_API SCM scm_sloppy_memq (SCM x, SCM lst);
|
|
SCM_API SCM scm_sloppy_memv (SCM x, SCM lst);
|
|
SCM_API SCM scm_sloppy_member (SCM x, SCM lst);
|
|
|
|
SCM_API SCM scm_read_and_eval_x (SCM port);
|
|
|
|
#define scm_subr_entry scm_t_subr_entry
|
|
|
|
#define SCM_SUBR_DOC(x) SCM_BOOL_F
|
|
|
|
SCM_API SCM scm_make_subr (const char *name, int type, SCM (*fcn) ());
|
|
SCM_API SCM scm_make_subr_with_generic (const char *name,
|
|
int type,
|
|
SCM (*fcn) (),
|
|
SCM *gf);
|
|
SCM_API SCM scm_make_subr_opt (const char *name,
|
|
int type,
|
|
SCM (*fcn) (),
|
|
int set);
|
|
|
|
SCM_API SCM scm_call_catching_errors (SCM (*thunk)(), SCM (*err_filter)(),
|
|
void * closure);
|
|
|
|
SCM_API long scm_make_smob_type_mfpe (char *name, size_t size,
|
|
SCM (*mark) (SCM),
|
|
size_t (*free) (SCM),
|
|
int (*print) (SCM, SCM,
|
|
scm_print_state*),
|
|
SCM (*equalp) (SCM, SCM));
|
|
|
|
SCM_API void scm_set_smob_mfpe (long tc,
|
|
SCM (*mark) (SCM),
|
|
size_t (*free) (SCM),
|
|
int (*print) (SCM, SCM, scm_print_state*),
|
|
SCM (*equalp) (SCM, SCM));
|
|
|
|
SCM_API SCM scm_strprint_obj (SCM obj);
|
|
SCM_API SCM scm_read_0str (char *expr);
|
|
SCM_API SCM scm_eval_0str (const char *expr);
|
|
|
|
SCM_API char *scm_i_object_chars (SCM);
|
|
|
|
#define SCM_CHARS(x) scm_i_object_chars(x)
|
|
#define SCM_UCHARS(x) ((unsigned char *)SCM_CHARS(x))
|
|
|
|
SCM_API long scm_i_object_length (SCM);
|
|
|
|
#define SCM_LENGTH(x) scm_i_object_length(x)
|
|
|
|
#define scm_strhash(str, len, n) (scm_string_hash ((str), (len)) % (n))
|
|
|
|
SCM_API SCM scm_sym2ovcell_soft (SCM sym, SCM obarray);
|
|
SCM_API SCM scm_sym2ovcell (SCM sym, SCM obarray);
|
|
SCM_API SCM scm_intern_obarray_soft (const char *name, size_t len,
|
|
SCM obarray, unsigned int softness);
|
|
SCM_API SCM scm_intern_obarray (const char *name, size_t len, SCM obarray);
|
|
SCM_API SCM scm_symbol_value0 (const char *name);
|
|
|
|
SCM_API SCM scm_string_to_obarray_symbol (SCM o, SCM s, SCM softp);
|
|
SCM_API SCM scm_intern_symbol (SCM o, SCM s);
|
|
SCM_API SCM scm_unintern_symbol (SCM o, SCM s);
|
|
SCM_API SCM scm_symbol_binding (SCM o, SCM s);
|
|
#if 0
|
|
/* This name has been reused for real uninterned symbols. */
|
|
SCM_API SCM scm_symbol_interned_p (SCM o, SCM s);
|
|
#endif
|
|
SCM_API SCM scm_symbol_bound_p (SCM o, SCM s);
|
|
SCM_API SCM scm_symbol_set_x (SCM o, SCM s, SCM v);
|
|
|
|
SCM_API SCM scm_gentemp (SCM prefix, SCM obarray);
|
|
|
|
#define SCM_OPDIRP(x) (SCM_DIRP (x) && (SCM_DIR_OPEN_P (x)))
|
|
#define scm_fport scm_t_fport
|
|
#define scm_option scm_t_option
|
|
#define scm_srcprops scm_t_srcprops
|
|
#define scm_srcprops_chunk scm_t_srcprops_chunk
|
|
#define scm_info_frame scm_t_info_frame
|
|
#define scm_stack scm_t_stack
|
|
#define scm_array scm_t_array
|
|
#define scm_array_dim scm_t_array_dim
|
|
#define SCM_ARRAY_CONTIGUOUS SCM_ARRAY_FLAG_CONTIGUOUS
|
|
#define SCM_FUNC_NAME (scm_makfrom0str (FUNC_NAME))
|
|
|
|
#define SCM_WTA(pos, scm) \
|
|
do { scm_wta (scm, (char *) pos, FUNC_NAME); } while (0)
|
|
|
|
#define RETURN_SCM_WTA(pos, scm) \
|
|
do { return scm_wta (scm, (char *) pos, FUNC_NAME); } while (0)
|
|
|
|
#define SCM_VALIDATE_NUMBER_COPY(pos, z, cvar) \
|
|
do { \
|
|
if (SCM_INUMP (z)) \
|
|
cvar = (double) SCM_INUM (z); \
|
|
else if (SCM_REALP (z)) \
|
|
cvar = SCM_REAL_VALUE (z); \
|
|
else if (SCM_BIGP (z)) \
|
|
cvar = scm_i_big2dbl (z); \
|
|
else \
|
|
{ \
|
|
cvar = 0.0; \
|
|
SCM_WRONG_TYPE_ARG (pos, z); \
|
|
} \
|
|
} while (0)
|
|
|
|
#define SCM_VALIDATE_NUMBER_DEF_COPY(pos, number, def, cvar) \
|
|
do { \
|
|
if (SCM_UNBNDP (number)) \
|
|
cvar = def; \
|
|
else \
|
|
SCM_VALIDATE_NUMBER_COPY(pos, number, cvar); \
|
|
} while (0)
|
|
|
|
#define SCM_VALIDATE_OPDIR(pos, port) SCM_MAKE_VALIDATE (pos, port, OPDIRP)
|
|
|
|
void scm_i_init_deprecated (void);
|
|
|
|
#endif
|
|
|
|
#endif /* SCM_DEPRECATED_H */
|