trying to stop cleanly
This commit is contained in:
@@ -577,14 +577,20 @@
|
|||||||
) ; close without closing windows
|
) ; close without closing windows
|
||||||
)
|
)
|
||||||
|
|
||||||
|
(define evt-guard-stop -93273)
|
||||||
|
|
||||||
(define (start-event-processing)
|
(define (start-event-processing)
|
||||||
(thread (λ ()
|
(thread (λ ()
|
||||||
(letrec
|
(letrec
|
||||||
((f
|
((f
|
||||||
(λ ()
|
(λ ()
|
||||||
(let ((waiting (sync events-channel)))
|
(let ((waiting (sync events-channel)))
|
||||||
|
(if (= waiting evt-guard-stop)
|
||||||
|
(begin
|
||||||
|
(displayln "got evt-guard-stop, exiting event processing")
|
||||||
|
evt-guard-stop)
|
||||||
|
(begin
|
||||||
(set! waiting (rkt_webview_events_waiting))
|
(set! waiting (rkt_webview_events_waiting))
|
||||||
;(displayln (format "Events waiting: ~a" waiting))
|
|
||||||
(while (> waiting 0)
|
(while (> waiting 0)
|
||||||
(let* ((rkt-evt (rkt_webview_get_event)))
|
(let* ((rkt-evt (rkt_webview_get_event)))
|
||||||
(if (eq? rkt-evt #f)
|
(if (eq? rkt-evt #f)
|
||||||
@@ -605,10 +611,13 @@
|
|||||||
(cb evt)))))))
|
(cb evt)))))))
|
||||||
(set! waiting (- waiting 1))
|
(set! waiting (- waiting 1))
|
||||||
)
|
)
|
||||||
)
|
|
||||||
(f))
|
(f))
|
||||||
|
)
|
||||||
|
)
|
||||||
|
)
|
||||||
))
|
))
|
||||||
(f)))))
|
(f))))
|
||||||
|
)
|
||||||
|
|
||||||
(define evt-processing-thread (start-event-processing))
|
(define evt-processing-thread (start-event-processing))
|
||||||
|
|
||||||
@@ -813,6 +822,7 @@
|
|||||||
|
|
||||||
|
|
||||||
(define (rkt-webview-finalizer rkt-wv-store close-windows message)
|
(define (rkt-webview-finalizer rkt-wv-store close-windows message)
|
||||||
|
(displayln "rkt-webview-finalizer active")
|
||||||
(when close-windows
|
(when close-windows
|
||||||
(let ((open-windows (hash->list rkt-wv-store)))
|
(let ((open-windows (hash->list rkt-wv-store)))
|
||||||
(for-each (λ (kv)
|
(for-each (λ (kv)
|
||||||
@@ -820,6 +830,7 @@
|
|||||||
(handle (cdr kv)))
|
(handle (cdr kv)))
|
||||||
(rkt-webview-close handle)))
|
(rkt-webview-close handle)))
|
||||||
open-windows)))
|
open-windows)))
|
||||||
|
(event-callback evt-guard-stop)
|
||||||
(rkt_webview_cleanup)
|
(rkt_webview_cleanup)
|
||||||
(unless (eq? message #f) (error message))
|
(unless (eq? message #f) (error message))
|
||||||
(stop-event-processing)
|
(stop-event-processing)
|
||||||
|
|||||||
Reference in New Issue
Block a user