1996-08-20 17:08:53 +00:00
|
|
|
|
/* classes: h_files */
|
|
|
|
|
|
|
|
|
|
|
|
#ifndef DEBUGH
|
|
|
|
|
|
#define DEBUGH
|
|
|
|
|
|
/* Copyright (C) 1995,1996 Mikael Djurfeldt
|
|
|
|
|
|
*
|
|
|
|
|
|
* 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, 675 Mass Ave, Cambridge, MA 02139, 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.
|
|
|
|
|
|
*
|
|
|
|
|
|
* The author can be reached at djurfeldt@nada.kth.se
|
|
|
|
|
|
* Mikael Djurfeldt, SANS/NADA KTH, 10044 STOCKHOLM, SWEDEN
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
|
* alist.h, append.h, arbiters.h, async.h, boolean.h, chars.h,
continuations.h, debug.h, dynwind.h, error.h, eval.h, fdsocket.h,
feature.h, filesys.h, fports.h, gc.h, gdbint.h, genio.h, gsubr.h,
hash.h, init.h, ioext.h, kw.h, list.h, markers.h, marksweep.h,
mbstrings.h, numbers.h, objprop.h, options.h, pairs.h, ports.h,
posix.h, print.h, procprop.h, procs.h, ramap.h, read.h, root.h,
sequences.h, smob.h, socket.h, srcprop.h, stackchk.h, stime.h,
strings.h, strop.h, strorder.h, strports.h, struct.h, symbols.h,
tag.h, throw.h, unif.h, variable.h, vectors.h, version.h,
vports.h, weaks.h: #include "libguile/__scm.h", not
<libguile/__scm.h>. This allows 'gcc -MM' to determine which
dependencies are within libguile properly.
1996-09-05 21:19:08 +00:00
|
|
|
|
#include "libguile/__scm.h"
|
1996-08-20 17:08:53 +00:00
|
|
|
|
|
C files should #include only the header files they need, not
libguile.h (which #includes all the header files); the pointless
recompilation was wasting my time.
* Makefile.in (all .o dependency lists): Regenerated.
* libguile.h: Don't try to get a definition for size_t here...
* __scm.h: Do it here.
* _scm.h: Since this is the internal libguile header, put things
here that all (or a majority) of the libguile files will want.
Don't #include <libguile.h> here; that generates dependencies on
way too much. Instead, get "__scm.h", "error.h", "pairs.h",
"list.h", "gc.h", "gsubr.h", "procs.h", "numbers.h", "symbols.h",
"boolean.h", "strings.h", "vectors.h", "root.h", "ports.h", and
"async.h".
* alist.c: Get "eq.h", "list.h", "alist.h".
* append.c: Get "append.h", "list.h".
* arbiters.c: Get "arbiters.h", "smob.h".
* async.c: Get "async.h", "smob.h", "throw.h", "eval.h".
* boolean.c: Get "boolean.h".
* chars.c: Get "chars.h".
* continuations.c: Get "continuations.h", "dynwind.h", "debug.h",
"stackchk.h".
* debug.c: Get "debug.h", "feature.h", "read.h", "strports.h",
"continuations.h", "alist.h", "srcprop.h", "procprop.h", "smob.h",
"genio.h", "throw.h", "eval.h".
* dynwind.c: Get "dynwind.h", "alist.h", "eval.h".
* eq.c: Get "eq.h", "unif.h", "smob.h", "strorder.h",
"stackchk.h".
* error.c: Get "error.h", "throw.h", "genio.h", "pairs.h".
* eval.c: Get "eval.h", "stackchk.h", "srcprop.h", "debug.h",
"hashtab.h", "procprop.h", "markers.h", "smob.h", "throw.h",
"continuations.h", "eq.h", "sequences.h", "alist.h", "append.h",
"debug.h".
* fdsocket.c: Get "fdsocket.h", "unif.h", "filesys.h".
* feature.c: Get "feature.h".
* files.c: Get "files.h".
* filesys.c: Get "filesys.h", "smob.h", "genio.h".
* fports.c: Get "fports.h", "markers.h".
* gc.c: Get "async.h", "unif.h", "smob.h", "weaks.h",
"genio.h", "struct.h", "stackchk.h", "stime.h".
* gdbint.c: Get "gdbint.h", "chars.h", "eval.h", "print.h",
"read.h", "strports.h", "tag.h".
* genio.c: Get "genio.h", "chars.h".
* gsubr.c: Get "gsubr.h", "genio.h".
* hash.c: Get "hash.h", "chars.h".
* hashtab.c: Get "hashtab.h", "eval.h", "hash.h", "alist.h".
* init.c: Get everyone who has an scm_init_mumble function:
"weaks.h", "vports.h", "version.h", "vectors.h", "variable.h",
"unif.h", "throw.h", "tag.h", "symbols.h", "struct.h",
"strports.h", "strorder.h", "strop.h", "strings.h", "stime.h",
"stackchk.h", "srcprop.h", "socket.h", "simpos.h", "sequences.h",
"scmsigs.h", "read.h", "ramap.h", "procs.h", "procprop.h",
"print.h", "posix.h", "ports.h", "pairs.h", "options.h",
"objprop.h", "numbers.h", "mbstrings.h", "mallocs.h", "load.h",
"list.h", "kw.h", "ioext.h", "hashtab.h", "hash.h", "gsubr.h",
"gdbint.h", "gc.h", "fports.h", "filesys.h", "files.h",
"feature.h", "fdsocket.h", "eval.h", "error.h", "eq.h",
"dynwind.h", "debug.h", "continuations.h", "chars.h", "boolean.h",
"async.h", "arbiters.h", "append.h", "alist.h".
* ioext.c: Get "ioext.h", "fports.h".
* kw.c: Get "kw.h", "smob.h", "mbstrings.h", "genio.h".
* list.c: Get "list.h", "eq.h".
* load.c: Get "load.h", "eval.h", "read.h", "fports.h".
* mallocs.c: Get "smob.h", "genio.h".
* markers.c: Get "markers.h".
* mbstrings.c: Get "mbstrings.h", "read.h", "genio.h", "unif.h",
"chars.h".
* numbers.c: Get "unif.h", "genio.h".
* objprop.c: Get "objprop.h", "weaks.h", "alist.h", "hashtab.h".
* options.c: Get "options.h".
* ports.c: Get "ports.h", "vports.h", "strports.h", "fports.h",
"markers.h", "chars.h", "genio.h".
* posix.c: Get "posix.h", "sequences.h", "feature.h", "unif.h",
"read.h", "scmsigs.h", "genio.h", "fports.h".
* print.c: Get "print.h", "unif.h", "weaks.h", "read.h",
"procprop.h", "eval.h", "smob.h", "mbstrings.h", "genio.h",
"chars.h".
* procprop.c: Get "procprop.h", "eval.h", "alist.h".
* procs.c: Get "procs.h".
* ramap.c: Get "ramap.h", "feature.h", "eval.h", "eq.h",
"chars.h", "smob.h", "unif.h".
* read.c: Get "alist.h", "kw.h", "mbstrings.h", "unif.h",
"eval.h", "genio.h", "chars.h".
* root.c: Get "root.h", "stackchk.h".
* scmsigs.c: Get "scmsigs.h".
* sequences.c: Get "sequences.h".
* simpos.c: Get "simpos.h", "scmsigs.h".
* smob.c: Get "smob.h".
* socket.c: Get "socket.h", "feature.h".
* srcprop.c: Get "srcprop.h", "weaks.h", "hashtab.h", "debug.h",
"alist.h", "smob.h".
* stackchk.c: Get "stackchk.h", "genio.h".
* stime.c: Get "stime.h"."libguile/continuations.h".
* strings.c: Get "strings.h", "chars.h".
* strop.c: Get "strop.h", "chars.h".
* strorder.c: Get "strorder.h", "chars.h".
* strports.c: Get "strports.h", "print.h", "eval.h", "unif.h".
* struct.c: Get "struct.h", "chars.h".
* symbols.c: Get "symbols.h", "mbstrings.h", "alist.h",
"variable.h", "eval.h", "chars.h".
* tag.c: Get "tag.h", "struct.h", "chars.h".
* throw.c: Get "throw.h", "continuations.h", "debug.h",
"dynwind.h", "eval.h", "alist.h", "smob.h", "genio.h".
* unif.c: Get "unif.h", "feature.h", "strop.h", "sequences.h",
"smob.h", "genio.h", "eval.h", "chars.h".
* variable.c: Get "variable.h", "smob.h", "genio.h".
* vectors.c: Get "vectors.h", "eq.h".
* version.c: Get "version.h".
* vports.c: Get "vports.h", "fports.h", "chars.h", "eval.h".
* weaks.c: Get "weaks.h".
* stackchk.h: #include "libguile/debug.h",
* debug.h: Don't #include "options.h"; the compiler won't be able
to find that once the headers are installed; instead, #include
"libguile/options.h".
* gc.h: Same, with marksweep.h.
* mbstrings.h: Same, with symbols.h.
* scmhob.h: Same, with _scm.h.
* smob.h: Same, with params.h.
1996-09-10 02:27:02 +00:00
|
|
|
|
#include "libguile/options.h"
|
1996-08-20 17:08:53 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
|
* Here comes some definitions for the debugging machinery.
|
|
|
|
|
|
* It might seem strange to represent debug flags as ints,
|
|
|
|
|
|
* but consider that any particular piece of code is normally
|
|
|
|
|
|
* only interested in one flag at a time. This is then
|
|
|
|
|
|
* the most efficient representation.
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/* {Options}
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
1996-08-23 01:19:03 +00:00
|
|
|
|
/* scm_debug_opts and scm_evaluator_trap_table are defined in eval.c.
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
1996-08-20 17:08:53 +00:00
|
|
|
|
extern scm_option scm_debug_opts[];
|
|
|
|
|
|
|
1996-08-23 01:19:03 +00:00
|
|
|
|
#define SCM_CHEAPTRAPS_P scm_debug_opts[0].val
|
|
|
|
|
|
#define SCM_BREAKPOINTS_P scm_debug_opts[1].val
|
|
|
|
|
|
#define SCM_TRACE_P scm_debug_opts[2].val
|
|
|
|
|
|
#define SCM_REC_PROCNAMES_P scm_debug_opts[3].val
|
|
|
|
|
|
#define SCM_BACKWARDS_P scm_debug_opts[4].val
|
|
|
|
|
|
#define SCM_N_FRAMES scm_debug_opts[5].val
|
|
|
|
|
|
#define SCM_BACKTRACE_DEPTH scm_debug_opts[6].val
|
|
|
|
|
|
#define SCM_BACKTRACE_P scm_debug_opts[7].val
|
|
|
|
|
|
#define SCM_DEVAL_P scm_debug_opts[8].val
|
|
|
|
|
|
#define SCM_STACK_LIMIT scm_debug_opts[9].val
|
|
|
|
|
|
#define SCM_N_DEBUG_OPTIONS 10
|
1996-08-20 17:08:53 +00:00
|
|
|
|
|
|
|
|
|
|
extern scm_option scm_evaluator_trap_table[];
|
|
|
|
|
|
|
1996-08-23 01:19:03 +00:00
|
|
|
|
#define SCM_ENTER_FRAME_P scm_evaluator_trap_table[0].val
|
|
|
|
|
|
#define SCM_APPLY_FRAME_P scm_evaluator_trap_table[1].val
|
|
|
|
|
|
#define SCM_EXIT_FRAME_P scm_evaluator_trap_table[2].val
|
|
|
|
|
|
#define SCM_N_EVALUATOR_TRAPS 3
|
1996-08-20 17:08:53 +00:00
|
|
|
|
|
|
|
|
|
|
#ifdef __STDC__
|
|
|
|
|
|
extern SCM (*scm_ceval_ptr) (SCM exp, SCM env);
|
|
|
|
|
|
#else
|
|
|
|
|
|
extern SCM (*scm_ceval_ptr) ();
|
|
|
|
|
|
#endif
|
1996-08-23 01:19:03 +00:00
|
|
|
|
extern int scm_debug_mode;
|
|
|
|
|
|
extern int scm_check_entry_p, scm_check_apply_p, scm_check_exit_p;
|
1996-08-20 17:08:53 +00:00
|
|
|
|
|
1996-08-23 01:19:03 +00:00
|
|
|
|
#define CHECK_ENTRY scm_check_entry_p
|
|
|
|
|
|
#define CHECK_APPLY scm_check_apply_p
|
|
|
|
|
|
#define CHECK_EXIT scm_check_exit_p
|
1996-08-20 17:08:53 +00:00
|
|
|
|
|
1996-08-23 01:19:03 +00:00
|
|
|
|
#define SCM_RESET_DEBUG_MODE \
|
1996-08-20 17:08:53 +00:00
|
|
|
|
{\
|
1996-08-23 01:19:03 +00:00
|
|
|
|
if (SCM_ENTER_FRAME_P || SCM_BREAKPOINTS_P) CHECK_ENTRY = 1;\
|
|
|
|
|
|
if (SCM_APPLY_FRAME_P || SCM_TRACE_P) CHECK_APPLY = 1;\
|
|
|
|
|
|
if (SCM_EXIT_FRAME_P || SCM_TRACE_P) CHECK_EXIT = 1;\
|
|
|
|
|
|
scm_debug_mode = SCM_DEVAL_P || SCM_BACKTRACE_P || CHECK_ENTRY || CHECK_APPLY || CHECK_EXIT;\
|
|
|
|
|
|
scm_ceval_ptr = scm_debug_mode ? scm_deval : scm_ceval;\
|
1996-08-20 17:08:53 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* {Evaluator}
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
typedef union scm_debug_info
|
|
|
|
|
|
{
|
|
|
|
|
|
struct { SCM exp, env; } e;
|
|
|
|
|
|
struct { SCM proc, args; } a;
|
|
|
|
|
|
} scm_debug_info;
|
|
|
|
|
|
|
|
|
|
|
|
extern int scm_debug_eframe_size;
|
|
|
|
|
|
|
|
|
|
|
|
typedef struct scm_debug_frame
|
|
|
|
|
|
{
|
|
|
|
|
|
struct scm_debug_frame *prev;
|
|
|
|
|
|
long status;
|
|
|
|
|
|
scm_debug_info vect[1];
|
|
|
|
|
|
} scm_debug_frame;
|
|
|
|
|
|
|
|
|
|
|
|
extern scm_debug_frame *last_debug_info_frame;
|
|
|
|
|
|
|
1996-08-23 01:19:03 +00:00
|
|
|
|
#define SCM_TAILREC (1L << 10)
|
|
|
|
|
|
#define SCM_TRACED_FRAME (1L << 9)
|
|
|
|
|
|
#define SCM_APPLYFRAME (1L << 8)
|
|
|
|
|
|
#define SCM_ARGS_READY (1L << 7)
|
|
|
|
|
|
#define SCM_DOVERFLOW (1L << 6)
|
|
|
|
|
|
#define SCM_MAX_FRAME_SIZE 63 /* also used as a mask for the size field */
|
|
|
|
|
|
|
|
|
|
|
|
#define SCM_EVALFRAMEP(x) (((x).status & SCM_APPLYFRAME) == 0)
|
|
|
|
|
|
#define SCM_APPLYFRAMEP(x) (((x).status & SCM_APPLYFRAME) != 0)
|
|
|
|
|
|
#define SCM_OVERFLOWP(x) (((x).status & SCM_DOVERFLOW) != 0)
|
|
|
|
|
|
#define SCM_ARGS_READY_P(x) (((x).status & SCM_ARGS_READY) != 0)
|
|
|
|
|
|
#define SCM_TRACED_FRAME_P(x) (((x).status & SCM_TRACED_FRAME) != 0)
|
|
|
|
|
|
#define SCM_TAILRECP(x) (((x).status & SCM_TAILREC) != 0)
|
|
|
|
|
|
#define SCM_SET_OVERFLOW(x) ((x).status |= SCM_DOVERFLOW)
|
|
|
|
|
|
#define SCM_SET_ARGSREADY(x) ((x).status |= SCM_ARGS_READY)
|
|
|
|
|
|
#define SCM_CLEAR_ARGSREADY(x) ((x).status &= ~SCM_ARGS_READY)
|
|
|
|
|
|
#define SCM_SET_TRACED_FRAME(x) ((x).status |= SCM_TRACED_FRAME)
|
|
|
|
|
|
#define SCM_CLEAR_TRACED_FRAME(x) ((x).status &= ~SCM_TRACED_FRAME)
|
|
|
|
|
|
#define SCM_SET_TAILREC(x) ((x).status |= SCM_TAILREC)
|
|
|
|
|
|
|
|
|
|
|
|
#define SCM_DEBUGGINGP scm_debug_mode
|
|
|
|
|
|
#define SCM_DSIDEVAL(x, env) if NIMP(x) scm_deval((x), (env))
|
1996-08-20 17:08:53 +00:00
|
|
|
|
|
|
|
|
|
|
/* {Memoized Source}
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
extern long scm_tc16_memoized;
|
|
|
|
|
|
|
|
|
|
|
|
#define SCM_MEMOIZEDP(x) (scm_tc16_memoized == SCM_TYP16 (x))
|
|
|
|
|
|
#define SCM_MEMOEXP(x) SCM_CAR (SCM_CDR (x))
|
|
|
|
|
|
#define SCM_MEMOENV(x) SCM_CDR (SCM_CDR (x))
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#ifdef __STDC__
|
1996-09-11 20:25:28 +00:00
|
|
|
|
extern SCM * scm_lookup_cstr (char *str, int len, SCM env);
|
|
|
|
|
|
extern SCM * scm_lookup_soft (SCM var, SCM genv);
|
|
|
|
|
|
extern SCM scm_evstr (char *str);
|
|
|
|
|
|
extern SCM scm_eval_string (SCM str);
|
|
|
|
|
|
extern int scm_ready_p (void);
|
|
|
|
|
|
extern void debug_print (SCM obj);
|
|
|
|
|
|
extern SCM scm_expr_stack (SCM obj);
|
|
|
|
|
|
extern SCM scm_last_stack_frame (SCM obj);
|
|
|
|
|
|
extern SCM scm_debug_object_p (SCM obj);
|
|
|
|
|
|
extern SCM scm_local_eval (SCM exp, SCM env);
|
|
|
|
|
|
extern SCM scm_procedure_environment (SCM proc);
|
|
|
|
|
|
extern SCM scm_procedure_source (SCM proc);
|
|
|
|
|
|
extern SCM scm_procedure_name (SCM proc);
|
|
|
|
|
|
extern SCM scm_memoized_environment (SCM m);
|
|
|
|
|
|
extern SCM scm_make_memoized (SCM exp, SCM env);
|
|
|
|
|
|
extern SCM scm_memoized_p (SCM obj);
|
|
|
|
|
|
extern SCM scm_single_step (SCM cont, SCM val);
|
|
|
|
|
|
extern SCM scm_evaluator_traps (SCM setting);
|
|
|
|
|
|
extern SCM scm_debug_options (SCM setting);
|
1996-08-20 17:08:53 +00:00
|
|
|
|
extern SCM scm_unmemoize (SCM memoized);
|
|
|
|
|
|
extern SCM scm_make_debugobj (scm_debug_frame* debug);
|
|
|
|
|
|
extern void scm_init_debug (void);
|
|
|
|
|
|
#else
|
1996-09-11 20:25:28 +00:00
|
|
|
|
extern SCM * scm_lookup_cstr ();
|
|
|
|
|
|
extern SCM * scm_lookup_soft ();
|
|
|
|
|
|
extern SCM scm_evstr ();
|
|
|
|
|
|
extern SCM scm_eval_string ();
|
|
|
|
|
|
extern int scm_ready_p ();
|
|
|
|
|
|
extern void debug_print ();
|
|
|
|
|
|
extern SCM scm_expr_stack ();
|
|
|
|
|
|
extern SCM scm_last_stack_frame ();
|
|
|
|
|
|
extern SCM scm_debug_object_p ();
|
|
|
|
|
|
extern SCM scm_local_eval ();
|
|
|
|
|
|
extern SCM scm_procedure_environment ();
|
|
|
|
|
|
extern SCM scm_procedure_source ();
|
|
|
|
|
|
extern SCM scm_procedure_name ();
|
|
|
|
|
|
extern SCM scm_memoized_environment ();
|
|
|
|
|
|
extern SCM scm_make_memoized ();
|
|
|
|
|
|
extern SCM scm_memoized_p (SCM obj);
|
|
|
|
|
|
extern SCM scm_single_step ();
|
|
|
|
|
|
extern SCM scm_evaluator_traps ();
|
|
|
|
|
|
extern SCM scm_debug_options ();
|
1996-08-20 17:08:53 +00:00
|
|
|
|
extern SCM scm_unmemoize ();
|
|
|
|
|
|
extern SCM scm_make_debugobj ();
|
|
|
|
|
|
extern void scm_init_debug ();
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
#endif /* DEBUGH */
|