factor/library/ui/ui.factor

107 lines
2.6 KiB
Factor
Raw Normal View History

! Copyright (C) 2006 Slava Pestov.
! See http://factorcode.org/license.txt for BSD license.
IN: gadgets
USING: gadgets gadgets-labels gadgets-layouts gadgets-theme
2006-05-26 02:29:44 -04:00
gadgets-viewports hashtables kernel math namespaces queues
sequences threads ;
! Hash mapping aliens to gadgets
SYMBOL: windows
: reset-windows ( hash -- hash ) H{ } clone windows set-global ;
2006-05-27 17:56:11 -04:00
: window ( handle -- world ) windows get hash ;
2006-05-27 17:56:11 -04:00
: register-window ( world handle -- ) windows get set-hash ;
2006-05-27 17:56:11 -04:00
: unregister-window ( handle -- ) windows get remove-hash ;
: layout-queued ( -- )
invalid dup queue-empty? [
drop
] [
deque dup layout
find-world [ dup world-handle set ] when*
layout-queued
] if ;
: init-ui ( -- )
H{ } clone \ timers set-global
<queue> \ invalid set-global ;
: ui-step ( -- )
do-timers
[ layout-queued ] make-hash hash-values
[ dup world-handle [ draw-world ] [ drop ] if ] each
10 sleep ;
: <status-bar> ( -- gadget ) "" <label> dup highlight-theme ;
2006-05-26 02:29:44 -04:00
GENERIC: gadget-title ( gadget -- string )
M: gadget gadget-title drop "Factor" ;
M: world gadget-title world-gadget gadget-title ;
TUPLE: titled-gadget title ;
M: titled-gadget gadget-title titled-gadget-title ;
M: titled-gadget pref-dim* viewport-dim ;
M: titled-gadget layout*
dup rect-dim swap gadget-child set-gadget-dim ;
2006-05-26 02:44:31 -04:00
C: titled-gadget ( gadget title -- )
dup delegate>gadget
2006-05-26 02:44:31 -04:00
[ set-titled-gadget-title ] keep
[ add-gadget ] keep ;
2006-05-26 02:29:44 -04:00
: update-title ( gadget -- )
dup gadget-parent dup world?
[ >r gadget-title r> set-title ] [ 2drop ] if ;
: open-window ( gadget -- )
2006-05-26 02:44:31 -04:00
<status-bar> <world> dup prefer open-window* ;
2006-05-26 02:29:44 -04:00
: open-titled-window ( gadget title -- )
<titled-gadget> open-window ;
: restore-windows ( -- )
windows get hash-values reset-windows
[ dup reset-world open-window* ] each ;
: restore-windows? ( -- ? )
windows get [ hash-empty? not ] [ f ] if* ;
: (open-tool) ( arg cons setter -- )
2006-05-26 02:29:44 -04:00
>r call tuck r> call open-window ; inline
: open-tool ( arg pred cons setter -- )
rot drop (open-tool) ;
: call-tool ( arg gadget pred cons setter -- )
>r >r find-parent dup [
r> drop r> call
] [
drop r> r> (open-tool)
] if ;
: start-world ( world -- )
dup add-notify
dup gadget-title over set-title
dup relayout
world-gadget request-focus ;
: close-global ( world global -- )
dup get-global find-world rot eq?
[ f swap set-global ] [ drop ] if ;
: close-world ( world -- )
dup hand-clicked close-global
dup hand-gadget close-global
f over request-focus*
dup remove-notify
dup free-fonts
reset-world ;