| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
6.25.1.1 Stack Capture
A Scheme program can use the make-stack primitive anywhere in its
code, with first arg #t, to construct a Scheme value that
describes the Scheme stack at that point.
(make-stack #t) ⇒ #<stack 25205a0>
Use start-stack to limit the stack extent captured by future
make-stack calls.
- Scheme Procedure: make-stack obj . args
- C Function: scm_make_stack (obj, args)
Create a new stack. If obj is
#t, the current evaluation stack is used for creating the stack frames, otherwise the frames are taken from obj (which must be a continuation or a frame object).args should be a list containing any combination of integer, procedure, prompt tag and
#tvalues.These values specify various ways of cutting away uninteresting stack frames from the top and bottom of the stack that
make-stackreturns. They come in pairs like this:(inner_cut_1 outer_cut_1 inner_cut_2 outer_cut_2 …).Each inner_cut_N can be
#t, an integer, a prompt tag, or a procedure.#tmeans to cut away all frames up to but excluding the first user module frame. An integer means to cut away exactly that number of frames. A prompt tag means to cut away all frames that are inside a prompt with the given tag. A procedure means to cut away all frames up to but excluding the application frame whose procedure matches the specified one.Each outer_cut_N can be an integer, a prompt tag, or a procedure. An integer means to cut away that number of frames. A prompt tag means to cut away all frames that are outside a prompt with the given tag. A procedure means to cut away frames down to but excluding the application frame whose procedure matches the specified one.
If the outer_cut_N of the last pair is missing, it is taken as 0.
- Scheme Syntax: start-stack id exp
Evaluate exp on a new calling stack with identity id. If exp is interrupted during evaluation, backtraces will not display frames farther back than exp’s top-level form. This macro is a way of artificially limiting backtraces and stack procedures, largely as a convenience to the user.
| [ << ] | [ < ] | [ Up ] | [ > ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
This document was generated on February 3, 2012 using texi2html 5.0.
