factor/basis/ui/tools/traceback/traceback.factor

83 lines
2.5 KiB
Factor
Raw Normal View History

! Copyright (C) 2006, 2010 Slava Pestov.
2007-09-20 18:09:08 -04:00
! See http://factorcode.org/license.txt for BSD license.
2013-04-10 21:50:11 -04:00
USING: accessors arrays continuations fonts fry inspector
kernel models models.arrow prettyprint sequences ui.commands
ui.gadgets ui.gadgets.borders ui.gadgets.buttons
ui.gadgets.labeled ui.gadgets.panes ui.gadgets.scrollers
ui.gadgets.status-bar ui.gadgets.tables ui.gadgets.tracks
ui.gestures ui.tools.common ;
QUALIFIED-WITH: ui.tools.inspector i
2007-09-20 18:09:08 -04:00
IN: ui.tools.traceback
2009-02-09 01:25:05 -05:00
TUPLE: stack-entry object string ;
: <stack-entry> ( object -- stack-entry )
dup [ unparse-short ] [ drop error-in-pprint ] recover
2013-04-10 21:50:11 -04:00
stack-entry boa ;
2009-02-09 01:25:05 -05:00
SINGLETON: stack-entry-renderer
M: stack-entry-renderer row-columns drop string>> 1array ;
M: stack-entry-renderer row-value drop object>> ;
: <stack-table> ( model -- table )
2009-02-26 17:15:28 -05:00
[ [ <stack-entry> ] map ] <arrow> stack-entry-renderer <table>
10 >>min-rows
10 >>max-rows
40 >>min-cols
40 >>max-cols
2009-02-12 03:09:22 -05:00
monospace-font >>font
2009-02-09 01:25:05 -05:00
[ i:inspector ] >>action
t >>single-click? ;
: <stack-display> ( model quot title -- gadget )
2009-02-26 17:15:28 -05:00
[ '[ dup _ when ] <arrow> <stack-table> <scroller> ] dip
<labeled-gadget> ;
2009-02-09 01:25:05 -05:00
2007-11-16 01:19:13 -05:00
: <callstack-display> ( model -- gadget )
2008-08-31 17:17:46 -04:00
[ [ call>> callstack. ] when* ]
2009-02-14 01:45:10 -05:00
<pane-control> t >>scrolls? <scroller>
"Call stack" <labeled-gadget> ;
2007-09-20 18:09:08 -04:00
2007-11-16 01:19:13 -05:00
: <datastack-display> ( model -- gadget )
2009-02-09 01:25:05 -05:00
[ data>> ] "Data stack" <stack-display> ;
2007-09-20 18:09:08 -04:00
2007-11-16 01:19:13 -05:00
: <retainstack-display> ( model -- gadget )
2009-02-09 01:25:05 -05:00
[ retain>> ] "Retain stack" <stack-display> ;
2008-02-21 02:25:59 -05:00
TUPLE: traceback-gadget < tool ;
2007-09-20 18:09:08 -04:00
: <traceback-gadget> ( model -- gadget )
2009-02-14 01:45:10 -05:00
[
vertical traceback-gadget new-track
{ 3 3 } >>gap
] dip
2009-02-05 05:12:57 -05:00
[ >>model ]
[
2009-02-14 01:45:10 -05:00
[ vertical <track> { 3 3 } >>gap ] dip
[
[ horizontal <track> { 3 3 } >>gap ] dip
[ <datastack-display> 1/2 track-add ]
[ <retainstack-display> 1/2 track-add ] bi
1/3 track-add
]
[ <callstack-display> 2/3 track-add ] bi
{ 3 3 } <filled-border> 1 track-add
] bi
2008-11-20 22:58:30 -05:00
add-toolbar ;
2007-09-20 18:09:08 -04:00
: variables ( traceback -- )
2009-02-26 17:15:28 -05:00
model>> [ dup [ name>> vars-in-scope ] when ] <arrow> i:inspect-model ;
2007-09-20 18:09:08 -04:00
: traceback-window ( continuation -- )
2008-11-24 13:29:24 -05:00
<model> <traceback-gadget> "Traceback" open-status-window ;
: inspect-continuation ( traceback -- )
control-value i:inspector ;
traceback-gadget "toolbar" f {
{ T{ key-down f f "v" } variables }
{ T{ key-down f f "n" } inspect-continuation }
} define-command-map