| 
									
										
										
										
											2009-01-06 14:56:14 -05:00
										 |  |  | ! Copyright (C) 2006, 2009 Slava Pestov. | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | ! See http://factorcode.org/license.txt for BSD license. | 
					
						
							| 
									
										
										
										
											2009-01-08 18:02:54 -05:00
										 |  |  | USING: accessors inspector namespaces kernel models fry | 
					
						
							| 
									
										
										
										
											2009-02-26 17:15:28 -05:00
										 |  |  | colors.constants models.arrow prettyprint sequences mirrors assocs | 
					
						
							| 
									
										
										
										
											2009-02-17 09:26:33 -05:00
										 |  |  | classes io io.styles arrays hashtables math.order sorting refs fonts | 
					
						
							| 
									
										
										
										
											2009-01-26 19:08:54 -05:00
										 |  |  | ui.tools.browser ui.commands ui.operations ui.gadgets ui.gadgets.panes | 
					
						
							| 
									
										
										
										
											2009-02-17 09:26:33 -05:00
										 |  |  | ui.gadgets.scrollers ui.gadgets.slots ui.gadgets.tracks ui.gestures | 
					
						
							|  |  |  | ui.gadgets.buttons ui.gadgets.tables ui.gadgets.status-bar | 
					
						
							|  |  |  | ui.gadgets.labeled ui.tools.common ui ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | IN: ui.tools.inspector | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-08 19:56:39 -05:00
										 |  |  | TUPLE: inspector-gadget < tool table ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-07 00:30:08 -05:00
										 |  |  | TUPLE: slot-description key key-string value value-string ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : <slot-description> ( key value -- slot-description )
 | 
					
						
							|  |  |  |     [ dup unparse-short ] bi@ slot-description boa ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-06 17:53:08 -05:00
										 |  |  | SINGLETON: inspector-renderer | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-06 17:53:08 -05:00
										 |  |  | M: inspector-renderer row-columns | 
					
						
							| 
									
										
										
										
											2009-01-07 00:30:08 -05:00
										 |  |  |     drop [ key-string>> ] [ value-string>> ] bi 2array ;
 | 
					
						
							| 
									
										
										
										
											2009-01-06 17:53:08 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-07 13:18:42 -05:00
										 |  |  | M: inspector-renderer row-value | 
					
						
							|  |  |  |     drop value>> ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-16 05:25:15 -05:00
										 |  |  | M: inspector-renderer column-titles | 
					
						
							|  |  |  |     drop { "Key" "Value" } ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-06 17:53:08 -05:00
										 |  |  | : <summary-gadget> ( model -- gadget )
 | 
					
						
							|  |  |  |     [ | 
					
						
							|  |  |  |         standard-table-style [ | 
					
						
							|  |  |  |             [ | 
					
						
							|  |  |  |                 [ | 
					
						
							|  |  |  |                     [ "Class:" write ] with-cell | 
					
						
							| 
									
										
										
										
											2009-03-11 04:17:30 -04:00
										 |  |  |                     [ class pprint ] with-cell | 
					
						
							| 
									
										
										
										
											2009-01-06 17:53:08 -05:00
										 |  |  |                 ] with-row | 
					
						
							|  |  |  |             ] | 
					
						
							|  |  |  |             [ | 
					
						
							|  |  |  |                 [ | 
					
						
							|  |  |  |                     [ "Object:" write ] with-cell | 
					
						
							| 
									
										
										
										
											2009-03-11 04:17:30 -04:00
										 |  |  |                     [ pprint-short ] with-cell | 
					
						
							| 
									
										
										
										
											2009-01-06 17:53:08 -05:00
										 |  |  |                 ] with-row | 
					
						
							|  |  |  |             ] | 
					
						
							|  |  |  |             [ | 
					
						
							|  |  |  |                 [ | 
					
						
							|  |  |  |                     [ "Summary:" write ] with-cell | 
					
						
							| 
									
										
										
										
											2009-03-11 04:17:30 -04:00
										 |  |  |                     [ print-summary ] with-cell | 
					
						
							| 
									
										
										
										
											2009-01-06 17:53:08 -05:00
										 |  |  |                 ] with-row | 
					
						
							|  |  |  |             ] tri
 | 
					
						
							|  |  |  |         ] tabular-output | 
					
						
							|  |  |  |     ] <pane-control> ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-07 16:06:43 -05:00
										 |  |  | GENERIC: make-slot-descriptions ( obj -- seq )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: object make-slot-descriptions | 
					
						
							| 
									
										
										
										
											2009-01-07 00:30:08 -05:00
										 |  |  |     make-mirror [ <slot-description> ] { } assoc>map ;
 | 
					
						
							| 
									
										
										
										
											2009-01-06 17:53:08 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-07 16:06:43 -05:00
										 |  |  | M: hashtable make-slot-descriptions | 
					
						
							| 
									
										
										
										
											2009-08-02 21:09:23 -04:00
										 |  |  |     call-next-method [ key-string>> ] sort-with ;
 | 
					
						
							| 
									
										
										
										
											2009-01-07 16:06:43 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-06 17:53:08 -05:00
										 |  |  | : <inspector-table> ( model -- table )
 | 
					
						
							| 
									
										
										
										
											2009-02-26 17:15:28 -05:00
										 |  |  |     [ make-slot-descriptions ] <arrow> inspector-renderer <table> | 
					
						
							| 
									
										
										
										
											2009-02-17 09:26:33 -05:00
										 |  |  |         [ invoke-primary-operation ] >>action | 
					
						
							| 
									
										
										
										
											2009-02-16 05:34:22 -05:00
										 |  |  |         monospace-font >>font | 
					
						
							| 
									
										
										
										
											2009-02-17 09:26:33 -05:00
										 |  |  |         COLOR: dark-gray >>column-line-color | 
					
						
							|  |  |  |         6 >>gap | 
					
						
							| 
									
										
										
										
											2009-02-16 05:34:22 -05:00
										 |  |  |         15 >>min-rows | 
					
						
							|  |  |  |         15 >>max-rows | 
					
						
							|  |  |  |         40 >>min-cols | 
					
						
							|  |  |  |         40 >>max-cols ;
 | 
					
						
							| 
									
										
										
										
											2009-01-06 17:53:08 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-05 05:00:27 -05:00
										 |  |  | : <inspector-gadget> ( model -- gadget )
 | 
					
						
							| 
									
										
										
										
											2009-02-02 01:02:55 -05:00
										 |  |  |     vertical inspector-gadget new-track | 
					
						
							| 
									
										
										
										
											2009-02-16 05:25:15 -05:00
										 |  |  |         { 3 3 } >>gap | 
					
						
							| 
									
										
										
										
											2008-11-20 22:58:30 -05:00
										 |  |  |         add-toolbar | 
					
						
							| 
									
										
										
										
											2009-02-05 05:00:27 -05:00
										 |  |  |         swap >>model | 
					
						
							| 
									
										
										
										
											2009-01-06 17:53:08 -05:00
										 |  |  |         dup model>> <inspector-table> >>table | 
					
						
							| 
									
										
										
										
											2009-02-14 20:48:32 -05:00
										 |  |  |         dup model>> <summary-gadget> "Object" <labeled-gadget> f track-add | 
					
						
							|  |  |  |         dup table>> <scroller> "Contents" <labeled-gadget> 1 track-add ;
 | 
					
						
							| 
									
										
										
										
											2008-09-27 15:36:04 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-06 17:53:08 -05:00
										 |  |  | M: inspector-gadget focusable-child* | 
					
						
							|  |  |  |     table>> ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-06 17:53:08 -05:00
										 |  |  | : com-refresh ( inspector -- )
 | 
					
						
							|  |  |  |     model>> notify-connections ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-06 17:53:08 -05:00
										 |  |  | : com-push ( inspector -- obj )
 | 
					
						
							|  |  |  |     control-value ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | \ com-push H{ { +listener+ t } } define-command | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-08 18:02:54 -05:00
										 |  |  | : slot-editor-window ( close-hook update-hook assoc key key-string -- )
 | 
					
						
							|  |  |  |     [ <value-ref> <slot-editor> ] [ "Slot editor: " prepend ] bi*
 | 
					
						
							| 
									
										
										
										
											2009-09-23 23:51:25 -04:00
										 |  |  |     open-status-window ;
 | 
					
						
							| 
									
										
										
										
											2009-01-08 18:02:54 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | : com-edit-slot ( inspector -- )
 | 
					
						
							|  |  |  |     [ close-window ] swap
 | 
					
						
							|  |  |  |     [ '[ _ com-refresh ] ] | 
					
						
							|  |  |  |     [ control-value make-mirror ] | 
					
						
							|  |  |  |     [ table>> (selected-row) ] tri [ | 
					
						
							|  |  |  |         [ key>> ] [ key-string>> ] bi
 | 
					
						
							|  |  |  |         slot-editor-window | 
					
						
							|  |  |  |     ] [ 2drop 2drop ] if ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-18 22:01:19 -05:00
										 |  |  | : inspector-help ( -- ) "ui-inspector" com-browse ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | \ inspector-help H{ { +nullary+ t } } define-command | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inspector-gadget "toolbar" f { | 
					
						
							| 
									
										
										
										
											2009-01-06 17:53:08 -05:00
										 |  |  |     { T{ update-object } com-refresh } | 
					
						
							|  |  |  |     { T{ key-down f f "p" } com-push } | 
					
						
							| 
									
										
										
										
											2009-01-08 18:02:54 -05:00
										 |  |  |     { T{ key-down f f "e" } com-edit-slot } | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     { T{ key-down f f "F1" } inspector-help } | 
					
						
							|  |  |  | } define-command-map | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-07 13:18:42 -05:00
										 |  |  | inspector-gadget "multi-touch" f { | 
					
						
							| 
									
										
										
										
											2009-01-28 01:30:57 -05:00
										 |  |  |     { up-action com-refresh } | 
					
						
							| 
									
										
										
										
											2009-01-07 13:18:42 -05:00
										 |  |  | } define-command-map | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-05 05:00:27 -05:00
										 |  |  | : inspect-model ( model -- )
 | 
					
						
							|  |  |  |     <inspector-gadget> "Inspector" open-status-window ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-07 00:30:08 -05:00
										 |  |  | : inspector ( obj -- )
 | 
					
						
							| 
									
										
										
										
											2009-02-05 05:00:27 -05:00
										 |  |  |     <model> inspect-model ;
 |