Cocoa UI cleanup
parent
ea7301062d
commit
005de25156
|
@ -30,7 +30,8 @@ IN: cocoa.windows
|
||||||
: <ViewWindow> ( view rect -- window )
|
: <ViewWindow> ( view rect -- window )
|
||||||
<NSWindow> [ swap -> setContentView: ] keep
|
<NSWindow> [ swap -> setContentView: ] keep
|
||||||
dup dup -> contentView -> setInitialFirstResponder:
|
dup dup -> contentView -> setInitialFirstResponder:
|
||||||
dup 1 -> setAcceptsMouseMovedEvents: ;
|
dup 1 -> setAcceptsMouseMovedEvents:
|
||||||
|
dup 0 -> setReleasedWhenClosed: ;
|
||||||
|
|
||||||
: window-content-rect ( window -- rect )
|
: window-content-rect ( window -- rect )
|
||||||
NSWindow over -> frame rot -> styleMask
|
NSWindow over -> frame rot -> styleMask
|
||||||
|
|
|
@ -30,8 +30,6 @@ DEFER: start-walker-thread
|
||||||
2dup start-walker-thread
|
2dup start-walker-thread
|
||||||
] if* ;
|
] if* ;
|
||||||
|
|
||||||
USING: io.streams.c prettyprint ;
|
|
||||||
|
|
||||||
: show-walker ( -- thread )
|
: show-walker ( -- thread )
|
||||||
get-walker-thread
|
get-walker-thread
|
||||||
[ show-walker-hook get call ] keep ;
|
[ show-walker-hook get call ] keep ;
|
||||||
|
@ -40,7 +38,7 @@ USING: io.streams.c prettyprint ;
|
||||||
{
|
{
|
||||||
{ [ dup continuation? ] [ (continue) ] }
|
{ [ dup continuation? ] [ (continue) ] }
|
||||||
{ [ dup quotation? ] [ call ] }
|
{ [ dup quotation? ] [ call ] }
|
||||||
{ [ dup not ] [ "Single stepping abandoned" throw ] }
|
{ [ dup not ] [ "Single stepping abandoned" rethrow ] }
|
||||||
} cond ;
|
} cond ;
|
||||||
|
|
||||||
: break ( -- )
|
: break ( -- )
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
! Copyright (C) 2006, 2007 Slava Pestov.
|
! Copyright (C) 2006, 2008 Slava Pestov.
|
||||||
! See http://factorcode.org/license.txt for BSD license.
|
! See http://factorcode.org/license.txt for BSD license.
|
||||||
USING: math arrays cocoa cocoa.application command-line
|
USING: math arrays cocoa cocoa.application command-line
|
||||||
kernel memory namespaces cocoa.messages cocoa.runtime
|
kernel memory namespaces cocoa.messages cocoa.runtime
|
||||||
|
@ -8,6 +8,10 @@ ui.clipboards ui.gadgets ui.gadgets.worlds ui.cocoa.views
|
||||||
core-foundation threads ;
|
core-foundation threads ;
|
||||||
IN: ui.cocoa
|
IN: ui.cocoa
|
||||||
|
|
||||||
|
TUPLE: handle view window ;
|
||||||
|
|
||||||
|
C: <handle> handle
|
||||||
|
|
||||||
TUPLE: cocoa-ui-backend ;
|
TUPLE: cocoa-ui-backend ;
|
||||||
|
|
||||||
SYMBOL: stop-after-last-window?
|
SYMBOL: stop-after-last-window?
|
||||||
|
@ -47,27 +51,30 @@ M: pasteboard set-clipboard-contents
|
||||||
dup rot world>NSRect <ViewWindow>
|
dup rot world>NSRect <ViewWindow>
|
||||||
dup install-window-delegate
|
dup install-window-delegate
|
||||||
over -> release
|
over -> release
|
||||||
2array
|
<handle>
|
||||||
] keep set-world-handle ;
|
] keep set-world-handle ;
|
||||||
|
|
||||||
M: cocoa-ui-backend set-title ( string world -- )
|
M: cocoa-ui-backend set-title ( string world -- )
|
||||||
world-handle second swap <NSString> -> setTitle: ;
|
world-handle handle-window swap <NSString> -> setTitle: ;
|
||||||
|
|
||||||
: enter-fullscreen ( world -- )
|
: enter-fullscreen ( world -- )
|
||||||
world-handle first NSScreen -> mainScreen f -> enterFullScreenMode:withOptions: drop ;
|
world-handle handle-view
|
||||||
|
NSScreen -> mainScreen
|
||||||
|
f -> enterFullScreenMode:withOptions:
|
||||||
|
drop ;
|
||||||
|
|
||||||
: exit-fullscreen ( world -- )
|
: exit-fullscreen ( world -- )
|
||||||
world-handle first f -> exitFullScreenModeWithOptions: ;
|
world-handle handle-view f -> exitFullScreenModeWithOptions: ;
|
||||||
|
|
||||||
M: cocoa-ui-backend set-fullscreen* ( ? world -- )
|
M: cocoa-ui-backend set-fullscreen* ( ? world -- )
|
||||||
swap [ enter-fullscreen ] [ exit-fullscreen ] if ;
|
swap [ enter-fullscreen ] [ exit-fullscreen ] if ;
|
||||||
|
|
||||||
M: cocoa-ui-backend fullscreen* ( world -- ? )
|
M: cocoa-ui-backend fullscreen* ( world -- ? )
|
||||||
world-handle first -> isInFullScreenMode zero? not ;
|
world-handle handle-view -> isInFullScreenMode zero? not ;
|
||||||
|
|
||||||
: auto-position ( world -- )
|
: auto-position ( world -- )
|
||||||
dup world-loc { 0 0 } = [
|
dup world-loc { 0 0 } = [
|
||||||
world-handle second -> center
|
world-handle handle-window -> center
|
||||||
] [
|
] [
|
||||||
drop
|
drop
|
||||||
] if ;
|
] if ;
|
||||||
|
@ -75,27 +82,29 @@ M: cocoa-ui-backend fullscreen* ( world -- ? )
|
||||||
M: cocoa-ui-backend (open-window) ( world -- )
|
M: cocoa-ui-backend (open-window) ( world -- )
|
||||||
dup gadget-window
|
dup gadget-window
|
||||||
dup auto-position
|
dup auto-position
|
||||||
world-handle second f -> makeKeyAndOrderFront: ;
|
world-handle handle-window f -> makeKeyAndOrderFront: ;
|
||||||
|
|
||||||
M: cocoa-ui-backend (close-window) ( handle -- )
|
M: cocoa-ui-backend (close-window) ( handle -- )
|
||||||
first unregister-window ;
|
handle-window -> release ;
|
||||||
|
|
||||||
M: cocoa-ui-backend close-window ( gadget -- )
|
M: cocoa-ui-backend close-window ( gadget -- )
|
||||||
find-world [
|
find-world [
|
||||||
world-handle second f -> performClose:
|
world-handle [
|
||||||
|
handle-window f -> performClose:
|
||||||
|
] when*
|
||||||
] when* ;
|
] when* ;
|
||||||
|
|
||||||
M: cocoa-ui-backend raise-window* ( world -- )
|
M: cocoa-ui-backend raise-window* ( world -- )
|
||||||
world-handle [
|
world-handle [
|
||||||
second dup f -> orderFront: -> makeKeyWindow
|
handle-window dup f -> orderFront: -> makeKeyWindow
|
||||||
NSApp 1 -> activateIgnoringOtherApps:
|
NSApp 1 -> activateIgnoringOtherApps:
|
||||||
] when* ;
|
] when* ;
|
||||||
|
|
||||||
M: cocoa-ui-backend select-gl-context ( handle -- )
|
M: cocoa-ui-backend select-gl-context ( handle -- )
|
||||||
first -> openGLContext -> makeCurrentContext ;
|
handle-view -> openGLContext -> makeCurrentContext ;
|
||||||
|
|
||||||
M: cocoa-ui-backend flush-gl-context ( handle -- )
|
M: cocoa-ui-backend flush-gl-context ( handle -- )
|
||||||
first -> openGLContext -> flushBuffer ;
|
handle-view -> openGLContext -> flushBuffer ;
|
||||||
|
|
||||||
SYMBOL: cocoa-init-hook
|
SYMBOL: cocoa-init-hook
|
||||||
|
|
||||||
|
|
|
@ -313,6 +313,7 @@ CLASS: {
|
||||||
{ "dealloc" "void" { "id" "SEL" }
|
{ "dealloc" "void" { "id" "SEL" }
|
||||||
[
|
[
|
||||||
drop
|
drop
|
||||||
|
dup unregister-window
|
||||||
dup remove-observer
|
dup remove-observer
|
||||||
SUPER-> dealloc
|
SUPER-> dealloc
|
||||||
]
|
]
|
||||||
|
@ -349,7 +350,13 @@ CLASS: {
|
||||||
|
|
||||||
{ "windowShouldClose:" "bool" { "id" "SEL" "id" }
|
{ "windowShouldClose:" "bool" { "id" "SEL" "id" }
|
||||||
[
|
[
|
||||||
2nip -> contentView window ungraft t
|
3drop t
|
||||||
|
]
|
||||||
|
}
|
||||||
|
|
||||||
|
{ "windowWillClose:" "void" { "id" "SEL" "id" }
|
||||||
|
[
|
||||||
|
2nip -> object -> contentView window ungraft
|
||||||
]
|
]
|
||||||
} ;
|
} ;
|
||||||
|
|
||||||
|
|
|
@ -376,22 +376,6 @@ SYMBOL: trace-messages?
|
||||||
|
|
||||||
: peek-message? ( msg -- ? ) f 0 0 PM_REMOVE PeekMessage zero? ;
|
: peek-message? ( msg -- ? ) f 0 0 PM_REMOVE PeekMessage zero? ;
|
||||||
|
|
||||||
! ! ! !
|
|
||||||
: set-world-dim ( dim world -- )
|
|
||||||
swap >r world-handle win-hWnd HWND_TOP 20 20 r> first2 0
|
|
||||||
SetWindowPos drop ;
|
|
||||||
USE: random
|
|
||||||
USE: arrays
|
|
||||||
|
|
||||||
: twiddle
|
|
||||||
100 500 random +
|
|
||||||
100 500 random +
|
|
||||||
2array
|
|
||||||
"x" get-global find-world
|
|
||||||
set-world-dim
|
|
||||||
yield ;
|
|
||||||
! ! ! !
|
|
||||||
|
|
||||||
: event-loop ( msg -- )
|
: event-loop ( msg -- )
|
||||||
{
|
{
|
||||||
{ [ windows get empty? ] [ drop ] }
|
{ [ windows get empty? ] [ drop ] }
|
||||||
|
|
Loading…
Reference in New Issue