parent
0e78046101
commit
b909da1e5f
|
@ -215,9 +215,3 @@
|
||||||
(if (null? matches)
|
(if (null? matches)
|
||||||
'none
|
'none
|
||||||
(car (car matches)))))))
|
(car (car matches)))))))
|
||||||
|
|
||||||
(define (point-in-rectangle? r x y)
|
|
||||||
(and (>= x (rectangle:x r))
|
|
||||||
(>= y (rectangle:y r))
|
|
||||||
(< x (+ (rectangle:x r) (rectangle:width r)))
|
|
||||||
(< y (+ (rectangle:y r) (rectangle:height r)))))
|
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
(define-options-spec move-wm-options-spec
|
(define-options-spec move-wm-options-spec
|
||||||
(titlebar-colors colors '("#aaaaaa" "#eeeeee" "#777777" "black"))
|
(titlebar-colors colors '("#aaaaaa" "#eeeeee" "#777777" "black"))
|
||||||
(titlebar-colors-active colors '("#666699" "#aaaacc" "#333366" "#eeeeee"))
|
(titlebar-colors-focused colors '("#666699" "#aaaacc" "#333366" "#eeeeee"))
|
||||||
(titlebar-height int 18)
|
(titlebar-height int 18)
|
||||||
(titlebar-style symbol 'flat)
|
(titlebar-style symbol 'flat)
|
||||||
(font font "-*-helvetica-medium-r-normal-*-12-*-*-*-*-*-*-*")
|
(font font "-*-helvetica-medium-r-normal-*-12-*-*-*-*-*-*-*")
|
||||||
|
@ -52,7 +52,7 @@
|
||||||
(dpy (wm:dpy wm))
|
(dpy (wm:dpy wm))
|
||||||
(window (client:window client))
|
(window (client:window client))
|
||||||
(state (if (window-contains-focus? dpy window)
|
(state (if (window-contains-focus? dpy window)
|
||||||
'active
|
'focused
|
||||||
'normal))
|
'normal))
|
||||||
(titlebar (car (client:data client)))
|
(titlebar (car (client:data client)))
|
||||||
(name (client-name (wm:dpy wm) client)))
|
(name (client-name (wm:dpy wm) client)))
|
||||||
|
@ -90,9 +90,18 @@
|
||||||
(lambda (msg)
|
(lambda (msg)
|
||||||
(case (car msg)
|
(case (car msg)
|
||||||
((drop)
|
((drop)
|
||||||
;; TODO: check if outside...
|
;; check if outside...
|
||||||
|
(let ((window-x (second msg))
|
||||||
|
(window-y (third msg))
|
||||||
|
(root-x (fourth msg))
|
||||||
|
(root-y (fifth msg)))
|
||||||
|
(let ((r (root-rectangle dpy (wm:window wm))))
|
||||||
|
(if (point-in-rectangle? r root-x root-y)
|
||||||
(move-window dpy (client:client-window client)
|
(move-window dpy (client:client-window client)
|
||||||
(second msg) (third msg)))
|
window-x window-y)
|
||||||
|
(send (wm:out-channel wm)
|
||||||
|
(list 'root-drop (client:window client)
|
||||||
|
root-x root-y))))))
|
||||||
((kill-client)
|
((kill-client)
|
||||||
(let ((time (second msg)))
|
(let ((time (second msg)))
|
||||||
(delete-window dpy (client:window client) time)))))))
|
(delete-window dpy (client:window client) time)))))))
|
||||||
|
@ -112,9 +121,9 @@
|
||||||
(list (cons 'normal-colors
|
(list (cons 'normal-colors
|
||||||
(get-option options 'titlebar-colors))
|
(get-option options 'titlebar-colors))
|
||||||
(cons 'active-colors
|
(cons 'active-colors
|
||||||
(get-option options'titlebar-colors-active))
|
(get-option options'titlebar-colors-focused))
|
||||||
(cons 'focused-colors
|
(cons 'focused-colors
|
||||||
(get-option options 'titlebar-colors-active))
|
(get-option options 'titlebar-colors-focused))
|
||||||
(cons 'border-style
|
(cons 'border-style
|
||||||
(get-option options 'titlebar-style))))))
|
(get-option options 'titlebar-style))))))
|
||||||
|
|
||||||
|
|
|
@ -30,6 +30,7 @@
|
||||||
)
|
)
|
||||||
(mdisplay "creating titlebar " window "\n")
|
(mdisplay "creating titlebar " window "\n")
|
||||||
(spawn*
|
(spawn*
|
||||||
|
(list "titlebar " window)
|
||||||
(lambda (release)
|
(lambda (release)
|
||||||
(call-with-event-channel
|
(call-with-event-channel
|
||||||
dpy window (event-mask exposure structure-notify)
|
dpy window (event-mask exposure structure-notify)
|
||||||
|
@ -43,7 +44,8 @@
|
||||||
(lambda (xevent)
|
(lambda (xevent)
|
||||||
(cond
|
(cond
|
||||||
((expose-event? xevent)
|
((expose-event? xevent)
|
||||||
(if (= 0 (expose-event-count xevent))
|
(if (and (= 0 (expose-event-count xevent))
|
||||||
|
(window-exists? dpy window))
|
||||||
(draw-titlebar tb options gc)))
|
(draw-titlebar tb options gc)))
|
||||||
((destroy-window-event? xevent)
|
((destroy-window-event? xevent)
|
||||||
(exit)))))
|
(exit)))))
|
||||||
|
@ -52,14 +54,15 @@
|
||||||
(case (car msg)
|
(case (car msg)
|
||||||
((title)
|
((title)
|
||||||
(set-titlebar:title! tb (cdr msg))
|
(set-titlebar:title! tb (cdr msg))
|
||||||
(invalidate-window dpy window))
|
(draw-titlebar tb options gc))
|
||||||
((state)
|
((state)
|
||||||
(set-titlebar:state! tb (cdr msg))
|
(set-titlebar:state! tb (cdr msg))
|
||||||
(invalidate-window dpy window)))))
|
(draw-titlebar tb options gc)))))
|
||||||
)
|
)
|
||||||
(loop))))))
|
(loop))))))
|
||||||
(free-gc dpy gc)
|
(free-gc dpy gc)
|
||||||
(free-options options)))
|
;; colormap might to exists anymore...
|
||||||
|
(free-options options #t)))
|
||||||
tb))
|
tb))
|
||||||
|
|
||||||
(define (destroy-titlebar tb)
|
(define (destroy-titlebar tb)
|
||||||
|
|
|
@ -29,11 +29,20 @@
|
||||||
(define (sync-point-wait sp)
|
(define (sync-point-wait sp)
|
||||||
(placeholder-value sp))
|
(placeholder-value sp))
|
||||||
|
|
||||||
(define (spawn* fun)
|
(define (spawn* id . fun)
|
||||||
|
(let ((id (if (null? fun) "unnamed" id))
|
||||||
|
(fun (if (null? fun) id (car fun))))
|
||||||
(let ((sp (make-sync-point)))
|
(let ((sp (make-sync-point)))
|
||||||
(spawn (lambda ()
|
(spawn (lambda ()
|
||||||
(fun (lambda () (sync-point-release sp)))))
|
(with-handler
|
||||||
(sync-point-wait sp)))
|
(lambda (condition punt)
|
||||||
|
(mdisplay "condition in " id ":\n " condition "\n")
|
||||||
|
(punt))
|
||||||
|
(lambda ()
|
||||||
|
(fun (lambda () (sync-point-release sp)))
|
||||||
|
(mdisplay "thread " id " returned\n")
|
||||||
|
))))
|
||||||
|
(sync-point-wait sp))))
|
||||||
|
|
||||||
(define (with-lock lock thunk)
|
(define (with-lock lock thunk)
|
||||||
(obtain-lock lock)
|
(obtain-lock lock)
|
||||||
|
@ -76,7 +85,7 @@
|
||||||
(type (assq/false name (options:type-alist options))))
|
(type (assq/false name (options:type-alist options))))
|
||||||
(cond
|
(cond
|
||||||
((eq? (option-type font) type)
|
((eq? (option-type font) type)
|
||||||
(unload-font (options:dpy options) value))
|
(free-font (options:dpy options) value))
|
||||||
((eq? (option-type color) type)
|
((eq? (option-type color) type)
|
||||||
(free-colors (options:dpy options) (options:colormap options)
|
(free-colors (options:dpy options) (options:colormap options)
|
||||||
(list value) 0))
|
(list value) 0))
|
||||||
|
@ -338,9 +347,6 @@
|
||||||
|
|
||||||
(define (maximize-window dpy window . maybe-parent)
|
(define (maximize-window dpy window . maybe-parent)
|
||||||
(let ((r (apply maximal-rect/hints dpy window maybe-parent)))
|
(let ((r (apply maximal-rect/hints dpy window maybe-parent)))
|
||||||
(mdisplay "maximize-window: " window " "
|
|
||||||
(rectangle:x r) " " (rectangle:y r) " "
|
|
||||||
(rectangle:width r) " " (rectangle:height r) "\n")
|
|
||||||
(move-resize-window dpy window (rectangle:x r) (rectangle:y r)
|
(move-resize-window dpy window (rectangle:x r) (rectangle:y r)
|
||||||
(rectangle:width r) (rectangle:height r))))
|
(rectangle:width r) (rectangle:height r))))
|
||||||
|
|
||||||
|
@ -462,3 +468,24 @@
|
||||||
|
|
||||||
;; result ********************************************************
|
;; result ********************************************************
|
||||||
(cons width height)))
|
(cons width height)))
|
||||||
|
|
||||||
|
(define (point-in-rectangle? r x y)
|
||||||
|
(and (>= x (rectangle:x r))
|
||||||
|
(>= y (rectangle:y r))
|
||||||
|
(< x (+ (rectangle:x r) (rectangle:width r)))
|
||||||
|
(< y (+ (rectangle:y r) (rectangle:height r)))))
|
||||||
|
|
||||||
|
(define (window-level dpy win)
|
||||||
|
(length (window-path dpy win)))
|
||||||
|
|
||||||
|
(define (with-prevent-events dpy window event-mask thunk)
|
||||||
|
(let* ((before (window-attribute:your-event-mask
|
||||||
|
(get-window-attributes dpy window)))
|
||||||
|
(new (enum-set-intersection before
|
||||||
|
(enum-set-negation event-mask))))
|
||||||
|
(dynamic-wind
|
||||||
|
(lambda ()
|
||||||
|
(display-select-input dpy window new))
|
||||||
|
thunk
|
||||||
|
(lambda ()
|
||||||
|
(display-select-input dpy window before)))))
|
||||||
|
|
Loading…
Reference in New Issue