diff options
author | Andy Wingo <wingo@pobox.com> | 2009-12-03 11:03:39 +0100 |
---|---|---|
committer | Andy Wingo <wingo@pobox.com> | 2009-12-03 11:03:39 +0100 |
commit | 14aa25e410d49586c8ff9b4a80d2b6046b769905 (patch) | |
tree | 89a58226d6c994a23498585bf79546b0b4e1fabd /libguile/debug.h | |
parent | b2b554efd3fee1bd110cb286a1b185042db0a27f (diff) | |
download | guile-14aa25e410d49586c8ff9b4a80d2b6046b769905.tar.gz |
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.
Diffstat (limited to 'libguile/debug.h')
-rw-r--r-- | libguile/debug.h | 67 |
1 files changed, 0 insertions, 67 deletions
diff --git a/libguile/debug.h b/libguile/debug.h index 24c6b9e94..2ca0b529a 100644 --- a/libguile/debug.h +++ b/libguile/debug.h @@ -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 |