2006-07-30 22:08:47 -04:00
|
|
|
! Copyright (C) 2006 Slava Pestov.
|
|
|
|
! See http://factorcode.org/license.txt for BSD license.
|
|
|
|
IN: gadgets-walker
|
2006-07-31 16:12:29 -04:00
|
|
|
USING: arrays errors gadgets gadgets-buttons gadgets-frames
|
2006-07-30 23:20:08 -04:00
|
|
|
gadgets-listener gadgets-panes gadgets-scrolling gadgets-text
|
|
|
|
gadgets-tiles gadgets-tracks generic hashtables inspector
|
|
|
|
interpreter io kernel kernel-internals listener math models
|
|
|
|
namespaces sequences shells threads vectors ;
|
2006-07-30 22:08:47 -04:00
|
|
|
|
2006-08-24 04:08:21 -04:00
|
|
|
: <scrolling-tile> ( model quot title -- gadget )
|
|
|
|
>r <pane-control> <scroller> r> f <tile> ;
|
2006-07-30 22:08:47 -04:00
|
|
|
|
2006-08-24 04:08:21 -04:00
|
|
|
: <callstack-display> ( model -- )
|
|
|
|
[ continuation-call callstack. ]
|
|
|
|
"Call stack" <scrolling-tile> ;
|
|
|
|
|
|
|
|
: <datastack-display> ( model -- )
|
|
|
|
[ continuation-data stack. ]
|
|
|
|
"Data stack" <scrolling-tile> ;
|
|
|
|
|
|
|
|
: <retainstack-display> ( model -- )
|
|
|
|
[ continuation-retain stack. ]
|
|
|
|
"Retain stack" <scrolling-tile> ;
|
2006-07-30 22:08:47 -04:00
|
|
|
|
2006-08-24 04:08:21 -04:00
|
|
|
: <namestack-display> ( model -- )
|
|
|
|
[ continuation-name stack. ]
|
|
|
|
"Name stack" <scrolling-tile> ;
|
|
|
|
|
|
|
|
: <catchstack-display> ( model -- )
|
|
|
|
[ continuation-catch stack. ]
|
|
|
|
"Catch stack" <scrolling-tile> ;
|
2006-07-30 22:08:47 -04:00
|
|
|
|
|
|
|
: <quotation-display> ( quot -- gadget )
|
|
|
|
[ [ first2 callframe. ] when* ] <pane-control> <scroller> ;
|
|
|
|
|
2006-08-24 04:08:21 -04:00
|
|
|
: <walker-track> ( model quot -- gadget )
|
2006-07-30 22:08:47 -04:00
|
|
|
{
|
2006-08-24 04:08:21 -04:00
|
|
|
{ [ <quotation-display> ] f f 1/6 }
|
|
|
|
{ [ dup <callstack-display> ] f f 1/6 }
|
|
|
|
{ [ dup <datastack-display> ] f f 1/6 }
|
|
|
|
{ [ dup <retainstack-display> ] f f 1/6 }
|
|
|
|
{ [ dup <namestack-display> ] f f 1/6 }
|
|
|
|
{ [ <catchstack-display> ] f f 1/6 }
|
|
|
|
} { 0 1 } make-track ;
|
2006-07-30 22:08:47 -04:00
|
|
|
|
2006-08-24 04:08:21 -04:00
|
|
|
TUPLE: walker-gadget model quot ns ;
|
2006-07-30 22:08:47 -04:00
|
|
|
|
2006-07-30 23:20:08 -04:00
|
|
|
: update-stacks ( walker -- )
|
2006-08-24 04:08:21 -04:00
|
|
|
meta-interp get over walker-gadget-model set-model
|
2006-07-30 23:20:08 -04:00
|
|
|
meta-callframe swap walker-gadget-quot set-model ;
|
|
|
|
|
2006-08-24 02:40:03 -04:00
|
|
|
: with-walker ( gadget quot -- )
|
2006-08-24 18:23:48 -04:00
|
|
|
swap dup walker-gadget-ns
|
|
|
|
[ slip update-stacks ] bind ; inline
|
2006-07-30 23:20:08 -04:00
|
|
|
|
2006-08-24 02:40:03 -04:00
|
|
|
: walker-step [ step ] with-walker ;
|
|
|
|
: walker-step-in [ step-in ] with-walker ;
|
|
|
|
: walker-step-out [ step-out ] with-walker ;
|
|
|
|
: walker-step-all [ step-all ] with-walker ;
|
|
|
|
: walker-step-back [ step-back ] with-walker ;
|
2006-07-30 22:08:47 -04:00
|
|
|
|
2006-08-24 18:23:48 -04:00
|
|
|
walker-gadget {
|
|
|
|
{ f "Step" T{ key-down f f "s" } [ walker-step ] }
|
|
|
|
{ f "Step in" T{ key-down f f "i" } [ walker-step-in ] }
|
|
|
|
{ f "Step out" T{ key-down f f "o" } [ walker-step-out ] }
|
|
|
|
{ f "Step back" T{ key-down f f "b" } [ walker-step-back ] }
|
|
|
|
{ f "Continue" T{ key-down f f "c" } [ walker-step-all ] }
|
|
|
|
} define-commands
|
2006-07-30 22:08:47 -04:00
|
|
|
|
|
|
|
: init-walker-models ( walker -- )
|
2006-08-24 04:08:21 -04:00
|
|
|
f <model> over set-walker-gadget-model
|
2006-07-30 22:08:47 -04:00
|
|
|
f <model> swap set-walker-gadget-quot ;
|
|
|
|
|
2006-08-24 04:08:21 -04:00
|
|
|
: walker-models ( -- model quot )
|
|
|
|
gadget get walker-gadget-model
|
2006-07-30 22:08:47 -04:00
|
|
|
gadget get walker-gadget-quot ;
|
|
|
|
|
|
|
|
M: walker-gadget gadget-title
|
|
|
|
drop "Single stepper" <model> ;
|
|
|
|
|
|
|
|
M: walker-gadget pref-dim*
|
2006-08-24 04:08:21 -04:00
|
|
|
delegate pref-dim { 500 600 } vmax ;
|
2006-07-30 22:08:47 -04:00
|
|
|
|
2006-08-24 04:08:21 -04:00
|
|
|
: (walk) ( quot continuation walker -- )
|
|
|
|
H{ } clone over set-walker-gadget-ns [
|
2006-08-24 02:40:03 -04:00
|
|
|
V{ } clone meta-history set
|
2006-08-24 02:09:54 -04:00
|
|
|
meta-interp set
|
2006-08-24 04:08:21 -04:00
|
|
|
(meta-call)
|
2006-07-30 23:20:08 -04:00
|
|
|
] with-walker ;
|
|
|
|
|
2006-07-30 22:08:47 -04:00
|
|
|
C: walker-gadget ( -- gadget )
|
|
|
|
dup init-walker-models {
|
2006-08-24 18:23:48 -04:00
|
|
|
{ [ gadget get <toolbar> ] f f @top }
|
2006-08-24 04:08:21 -04:00
|
|
|
{ [ walker-models <walker-track> ] f f @center }
|
|
|
|
} make-frame* ;
|
2006-07-30 22:08:47 -04:00
|
|
|
|
2006-08-24 04:08:21 -04:00
|
|
|
: walk ( quot -- )
|
|
|
|
continuation dup continuation-data pop*
|
|
|
|
<walker-gadget> [ (walk) ] keep open-window stop ;
|