]> gitweb.factorcode.org Git - factor.git/blob - basis/ui/tools/debugger/debugger.factor
Merge branch 'bloom-filters' of git://github.com/alec/factor
[factor.git] / basis / ui / tools / debugger / debugger.factor
1 ! Copyright (C) 2006, 2009 Slava Pestov.
2 ! See http://factorcode.org/license.txt for BSD license.
3 USING: accessors arrays hashtables io kernel math models
4 colors.constants namespaces sequences sequences words continuations
5 debugger prettyprint help editors fonts ui ui.commands ui.gestures
6 ui.gadgets ui.pens.solid ui.gadgets.worlds ui.gadgets.packs
7 ui.gadgets.buttons ui.gadgets.labels ui.gadgets.panes
8 ui.gadgets.presentations ui.gadgets.viewports ui.gadgets.tables
9 ui.gadgets.tracks ui.gadgets.scrollers ui.gadgets.panes
10 ui.gadgets.borders ui.gadgets.status-bar ui.tools.traceback
11 ui.tools.inspector ui.tools.browser ui.debugger ;
12 IN: ui.tools.debugger
13
14 TUPLE: debugger < track error restarts restart-hook restart-list continuation ;
15
16 <PRIVATE
17
18 SINGLETON: restart-renderer
19
20 M: restart-renderer row-columns
21     drop [ name>> ] [ "Abort" ] if* "• " prepend 1array ;
22
23 : <restart-list> ( debugger -- gadget )
24     dup restarts>> f prefix <model> restart-renderer <table>
25         [ [ \ restart invoke-command ] when* ] >>action
26         swap restart-hook>> >>hook
27         t >>selection-required?
28         t >>single-click? ; inline
29
30 : <error-display> ( debugger -- gadget )
31     [ <filled-pile> ] dip
32     [ error>> <error-pane> add-gadget ]
33     [
34         dup restart-hook>> [
35             [ "To continue, pick one of the options below:" <label> add-gadget ] dip
36             restart-list>> add-gadget
37         ] [ drop ] if
38     ] bi ;
39
40 PRIVATE>
41
42 : <debugger> ( error continuation restarts restart-hook -- debugger )
43     vertical debugger new-track
44         { 3 3 } >>gap
45         swap >>restart-hook
46         swap >>restarts
47         swap >>continuation
48         swap >>error
49         add-toolbar
50         dup <restart-list> >>restart-list
51         dup <error-display> f track-add
52         COLOR: white <solid> >>interior ;
53
54 M: debugger focusable-child*
55     dup restart-hook>> [ restart-list>> ] [ drop t ] if ;
56
57 : debugger-window ( error continuation -- )
58     #! No restarts for the debugger window
59     f f <debugger> "Error" open-status-window ;
60
61 GENERIC: error-in-debugger? ( error -- ? )
62
63 M: world-error error-in-debugger? world>> gadget-child debugger? ;
64
65 M: object error-in-debugger? drop f ;
66
67 [
68     dup error-in-debugger?
69     [ rethrow ] [ error-continuation get debugger-window ] if 
70 ] ui-error-hook set-global
71
72 debugger "gestures" f {
73     { T{ button-down } request-focus }
74 } define-command-map
75
76 : com-inspect ( debugger -- ) error>> inspector ;
77
78 : com-traceback ( debugger -- ) continuation>> traceback-window ;
79
80 : com-help ( debugger -- ) error>> error-help-window ;
81
82 : com-edit ( debugger -- ) error>> (:edit) ;
83
84 \ com-edit H{ { +listener+ t } } define-command
85
86 debugger "toolbar" f {
87     { T{ key-down f { C+ } "i" } com-inspect }
88     { T{ key-down f { C+ } "t" } com-traceback }
89     { T{ key-down f { C+ } "h" } com-help }
90     { T{ key-down f { C+ } "e" } com-edit }
91 } define-command-map