factor/library/ui/tools/walker.factor

94 lines
3.0 KiB
Factor
Raw Normal View History

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
USING: arrays errors gadgets gadgets-buttons gadgets-frames
2006-07-30 23:20:08 -04:00
gadgets-listener gadgets-panes gadgets-scrolling gadgets-text
2006-09-14 16:15:39 -04:00
gadgets-tracks gadgets-workspace generic hashtables tools
2006-07-30 23:20:08 -04:00
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
: <callstack-display> ( model -- )
[ [ continuation-call callstack. ] when* ]
2006-08-29 18:27:51 -04:00
"Call stack" <labelled-pane> ;
2006-08-24 04:08:21 -04:00
: <datastack-display> ( model -- )
[ [ continuation-data stack. ] when* ]
2006-08-29 18:27:51 -04:00
"Data stack" <labelled-pane> ;
2006-08-24 04:08:21 -04:00
: <retainstack-display> ( model -- )
[ [ continuation-retain stack. ] when* ]
2006-08-29 18:27:51 -04:00
"Retain stack" <labelled-pane> ;
2006-07-30 22:08:47 -04:00
: <quotation-display> ( quot -- gadget )
2006-08-28 18:14:54 -04:00
[ [ first2 callframe. ] when* ]
2006-08-29 18:27:51 -04:00
"Current quotation" <labelled-pane> ;
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-28 03:08:58 -04:00
: walker-command ( gadget quot -- )
2006-09-08 02:32:14 -04:00
meta-interp pick walker-gadget-ns hash
[ with-walker ] [ 2drop ] if ; inline
2006-08-28 03:08:58 -04:00
: reset-walker ( walker -- )
dup H{ } clone swap set-walker-gadget-ns
update-stacks ;
2006-08-28 03:08:58 -04:00
: walker-step [ step ] walker-command ;
: walker-step-in [ step-in ] walker-command ;
: walker-step-out [ step-out ] walker-command ;
: walker-step-back [ step-back ] walker-command ;
2006-07-30 22:08:47 -04:00
2006-09-08 02:32:14 -04:00
: init-walker-models ( walker -- )
2006-08-26 17:13:24 -04:00
f <model> over set-walker-gadget-quot
f <model> swap set-walker-gadget-model ;
2006-07-30 22:08:47 -04:00
2006-08-26 17:13:24 -04:00
: walker-gadget-quot$ gadget get walker-gadget-quot ;
: walker-gadget-model$ gadget get walker-gadget-model ;
2006-07-30 22:08:47 -04:00
C: walker-gadget ( -- gadget )
dup init-walker-models {
2006-08-26 17:13:24 -04:00
{ [ walker-gadget-quot$ <quotation-display> ] f f 1/6 }
2006-09-07 17:58:27 -04:00
{ [ walker-gadget-model$ <datastack-display> ] f f 1/4 }
{ [ walker-gadget-model$ <retainstack-display> ] f f 1/4 }
{ [ walker-gadget-model$ <callstack-display> ] f f 1/3 }
2006-08-26 17:13:24 -04:00
} { 0 1 } make-track* ;
2006-09-14 16:15:39 -04:00
M: walker-gadget call-tool* ( continuation walker -- )
dup reset-walker [
V{ } clone meta-history set
restore-normally
] with-walker ;
M: walker-gadget tool-help drop "ui-walker" ;
2006-09-14 16:15:39 -04:00
: walker-inspect ( walker -- )
walker-gadget-ns [ meta-interp get ] bind
2006-10-04 00:40:10 -04:00
[ inspect ] curry call-listener ;
2006-09-14 16:15:39 -04:00
: walker-step-all ( walker -- )
dup [ step-all ] walker-command reset-walker
find-workspace listener-gadget select-tool ;
2006-10-09 23:57:32 -04:00
walker-gadget "toolbar" {
{ "Step" T{ key-down f f "s" } [ walker-step ] }
{ "Step in" T{ key-down f f "i" } [ walker-step-in ] }
{ "Step out" T{ key-down f f "o" } [ walker-step-out ] }
{ "Step back" T{ key-down f f "b" } [ walker-step-back ] }
{ "Continue" T{ key-down f f "c" } [ walker-step-all ] }
{ "Inspect" T{ key-down f f "n" } [ walker-inspect ] }
2006-09-14 16:15:39 -04:00
} define-commands
[ walker-gadget call-tool stop ] break-hook set-global
IN: tools
: walk ( quot -- ) [ break ] swap append call ;