mirror of
https://git.savannah.gnu.org/git/guile.git
synced 2025-06-20 02:30:23 +02:00
remove debug frames
* libguile/debug.h (scm_t_debug_frame): Remove this type, as it was internal to the old evaluator. (SCM_EVALFRAME, SCM_APPLYFRAME, SCM_VOIDFRAME, SCM_MACROEXPF) (SCM_TAILREC, SCM_TRACED_FRAME, SCM_ARGS_READY, SCM_DOVERFLOW) (SCM_MAX_FRAME_SIZE, SCM_FRAMETYPE) (SCM_EVALFRAMEP, SCM_APPLYFRAMEP, SCM_VOIDFRAMEP, SCM_MACROEXPFP) (SCM_TAILRECP, SCM_TRACED_FRAME_P, SCM_ARGS_READY_P, SCM_OVERFLOWP) (SCM_SET_MACROEXP, SCM_SET_TAILREC, SCM_SET_TRACED_FRAME) (SCM_SET_ARGSREADY, SCM_SET_OVERFLOW) (SCM_CLEAR_MACROEXP, SCM_CLEAR_TRACED_FRAME, SCM_CLEAR_ARGSREADY): Remove macro accessors to scm_t_debug_frame. (SCM_DEBUGOBJP, SCM_DEBUGOBJ_FRAME, SCM_SET_DEBUGOBJ_FRAME): (scm_debug_object_p, scm_make_debugobj): Remove debugobj accessors. (scm_i_unmemoize_expr): Remove unused declaration. * libguile/debug.c (scm_debug_options): No more max limit on frame sizes. (scm_start_stack): Just call out to scm_vm_call_with_new_stack. (scm_debug_object_p, scm_make_debugobj, scm_init_debug): No more debugobj smob type. * libguile/deprecated.h: * libguile/deprecated.c (scm_i_deprecated_last_debug_frame) (scm_last_debug_frame): Remove deprecated debug-frame bits. * libguile/stacks.c (scm_make_stack): Rework this function and its dependents to only walk VM frames. (scm_stack_id): Call out to the holder of the VM frame in question, which should be a VM or a VM continuation, for the stack ID. Currently this bit is stubbed out. (scm_last_stack_frame): Removed. It seems this is mainly useful for a debugger, and we need to rewrite the debugger to work on the Scheme level. * test-suite/tests/continuations.test ("continuations"): Remove test for last-stack-frame. * libguile/continuations.h (struct scm_t_contregs): * libguile/continuations.c (scm_make_continuation): (copy_stack_and_call, scm_i_with_continuation_barrier): No need to save and restore debug frames. * libguile/threads.h (scm_i_thread): Don't track debug frames. (scm_i_last_debug_frame, scm_i_set_last_debug_frame): Remove macro accessors. * libguile/threads.c (guilify_self_1): Don't track debug frames. * libguile/throw.c: No need to track debug frames in a jmpbuf. * libguile/vm-engine.c (vm_engine, VM_PUSH_DEBUG_FRAMES): Don't push debug frames. * libguile/vm.h: * libguile/vm.c (scm_vm_call_with_new_stack): New function. Currently stubbed out though.
This commit is contained in:
parent
b2b554efd3
commit
14aa25e410
14 changed files with 88 additions and 500 deletions
|
@ -29,22 +29,6 @@
|
|||
#include "libguile/options.h"
|
||||
|
||||
|
||||
/*
|
||||
* 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}
|
||||
*/
|
||||
|
||||
/* scm_debug_opts is defined in eval.c.
|
||||
*/
|
||||
|
||||
|
||||
|
||||
/* {Evaluator}
|
||||
*/
|
||||
|
||||
|
@ -55,57 +39,8 @@ typedef union scm_t_debug_info
|
|||
SCM id;
|
||||
} scm_t_debug_info;
|
||||
|
||||
typedef struct scm_t_debug_frame
|
||||
{
|
||||
struct scm_t_debug_frame *prev;
|
||||
long status;
|
||||
scm_t_debug_info *vect;
|
||||
scm_t_debug_info *info;
|
||||
} scm_t_debug_frame;
|
||||
|
||||
#define SCM_EVALFRAME (0L << 11)
|
||||
#define SCM_APPLYFRAME (1L << 11)
|
||||
#define SCM_VOIDFRAME (3L << 11)
|
||||
#define SCM_MACROEXPF (1L << 10)
|
||||
#define SCM_TAILREC (1L << 9)
|
||||
#define SCM_TRACED_FRAME (1L << 8)
|
||||
#define SCM_ARGS_READY (1L << 7)
|
||||
#define SCM_DOVERFLOW (1L << 6)
|
||||
#define SCM_MAX_FRAME_SIZE 63
|
||||
|
||||
#define SCM_FRAMETYPE (3L << 11)
|
||||
|
||||
#define SCM_EVALFRAMEP(x) (((x).status & SCM_FRAMETYPE) == SCM_EVALFRAME)
|
||||
#define SCM_APPLYFRAMEP(x) (((x).status & SCM_FRAMETYPE) == SCM_APPLYFRAME)
|
||||
#define SCM_VOIDFRAMEP(x) (((x).status & SCM_FRAMETYPE) == SCM_VOIDFRAME)
|
||||
#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_MACROEXPP(x) (((x).status & SCM_MACROEXPF) != 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_SET_MACROEXP(x) ((x).status |= SCM_MACROEXPF)
|
||||
#define SCM_CLEAR_MACROEXP(x) ((x).status &= ~SCM_MACROEXPF)
|
||||
|
||||
/* {Debug Objects}
|
||||
*/
|
||||
|
||||
SCM_API scm_t_bits scm_tc16_debugobj;
|
||||
|
||||
#define SCM_DEBUGOBJP(x) \
|
||||
SCM_TYP16_PREDICATE (scm_tc16_debugobj, x)
|
||||
#define SCM_DEBUGOBJ_FRAME(x) \
|
||||
((scm_t_debug_frame *) SCM_CELL_WORD_1 (x))
|
||||
#define SCM_SET_DEBUGOBJ_FRAME(x, f) SCM_SET_CELL_WORD_1 (x, f)
|
||||
|
||||
|
||||
|
||||
SCM_API SCM scm_debug_object_p (SCM obj);
|
||||
SCM_API SCM scm_reverse_lookup (SCM env, SCM data);
|
||||
SCM_API SCM scm_sys_start_stack (SCM info_id, SCM thunk);
|
||||
SCM_API SCM scm_procedure_module (SCM proc);
|
||||
|
@ -114,9 +49,7 @@ SCM_API SCM scm_procedure_name (SCM proc);
|
|||
SCM_API SCM scm_with_traps (SCM thunk);
|
||||
SCM_API SCM scm_evaluator_traps (SCM setting);
|
||||
SCM_API SCM scm_debug_options (SCM setting);
|
||||
SCM_API SCM scm_make_debugobj (scm_t_debug_frame *debug);
|
||||
|
||||
SCM_INTERNAL SCM scm_i_unmemoize_expr (SCM memoized);
|
||||
SCM_INTERNAL void scm_init_debug (void);
|
||||
|
||||
#ifdef GUILE_DEBUG
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue