- added root-drop

- added thread names
This commit is contained in:
frese 2003-04-01 13:17:22 +00:00
parent 0e78046101
commit b909da1e5f
4 changed files with 59 additions and 26 deletions

View File

@ -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)))))

View File

@ -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))))))

View File

@ -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)

View File

@ -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)))))