From e5b530115130560738f46c41813889f4a95d6439 Mon Sep 17 00:00:00 2001 From: "Andre A. Gomes" Date: Tue, 15 Oct 2024 00:09:12 +0300 Subject: [PATCH 1/2] renderer/gtk: Refactor prompt-buffer creation and deletion. Closes #3489. --- source/renderer/gtk.lisp | 62 +++++++++++++++------------------------- 1 file changed, 23 insertions(+), 39 deletions(-) diff --git a/source/renderer/gtk.lisp b/source/renderer/gtk.lisp index 461e2b4f0f4..91bb6401434 100644 --- a/source/renderer/gtk.lisp +++ b/source/renderer/gtk.lisp @@ -73,8 +73,6 @@ (horizontal-box-layout) (main-buffer-container) (prompt-buffer-container) - (prompt-buffer-view - :documentation "Shared web view between all prompt buffers of this window.") (status-container) (message-container) (key-string-buffer)) @@ -342,7 +340,7 @@ response. The BODY is wrapped with `with-protect'." (lambda () (with-slots (gtk-object root-box-layout horizontal-box-layout main-buffer-container - prompt-buffer-container prompt-buffer-view + prompt-buffer-container status-buffer status-container message-buffer message-container key-string-buffer) @@ -397,13 +395,9 @@ response. The BODY is wrapped with `with-protect'." :expand t) (setf (gtk:gtk-widget-size-request status-container) (list -1 (height status-buffer))) - (setf prompt-buffer-view (make-instance 'webkit:webkit-web-view)) (gtk:gtk-box-pack-end root-box-layout prompt-buffer-container :expand nil) - (gtk:gtk-box-pack-start prompt-buffer-container - prompt-buffer-view - :expand t) (setf (gtk:gtk-widget-size-request prompt-buffer-container) (list -1 0)) (gtk:gtk-container-add gtk-object root-box-layout) @@ -544,9 +538,6 @@ Return nil when key must be discarded, e.g. for modifiers." (dispatch-input-event event sender)) t))) -(defmethod gtk-object ((prompt-buffer prompt-buffer)) - (prompt-buffer-view (window prompt-buffer))) - (define-ffi-method on-signal-button-press-event ((sender gtk-buffer) event) (let ((key-string (format nil "button~s" (gdk:gdk-event-button-button event))) (modifiers (input-modifier-translator sender (button-event-modifiers event))) @@ -1005,18 +996,20 @@ See `finalize-buffer'." (define-ffi-method ffi-height ((buffer prompt-buffer)) (nth-value 1 (gtk:gtk-widget-size-request (prompt-buffer-container (window buffer))))) (define-ffi-method (setf ffi-height) ((height integer) (buffer prompt-buffer)) - "Sets the prompt height. -As a special case, setting height to 0 means hiding prompt buffer and focusing -the `active-buffer'." - (setf (gtk:gtk-widget-size-request (prompt-buffer-container (window buffer))) - (list -1 height)) - (if (eql 0 height) - (gtk:gtk-widget-grab-focus (gtk-object (active-buffer (window buffer)))) - (ffi-focus-prompt-buffer buffer))) + (with-slots (window gtk-object) buffer + (with-slots (prompt-buffer-container active-buffer) window + (setf (gtk:gtk-widget-size-request (prompt-buffer-container window)) + (list -1 height)) + (case height + (0 (gtk:gtk-widget-grab-focus (gtk-object (active-buffer window)))) + (t + (gtk:gtk-box-pack-start (prompt-buffer-container window) gtk-object :expand t) + (setf (gtk:gtk-widget-visible gtk-object) t) + (ffi-focus-prompt-buffer buffer)))))) (define-ffi-method ffi-focus-prompt-buffer ((prompt-buffer prompt-buffer)) "Focus PROMPT-BUFFER in WINDOW." - (gtk:gtk-widget-grab-focus (prompt-buffer-view (window prompt-buffer))) + (gtk:gtk-widget-grab-focus (gtk-object prompt-buffer)) prompt-buffer) (define-ffi-method ffi-height ((buffer status-buffer)) @@ -1201,19 +1194,11 @@ the `active-buffer'." (echo "[~a] ~a: ~a" (webkit:webkit-web-view-uri web-view) title body) t))) -(defun buffer-destroy (buffer) - (mapc (lambda (handler-id) - (gobject:g-signal-handler-disconnect (gtk-object buffer) handler-id)) - (handler-ids buffer)) - (nyxt::buffer-hide buffer) - (gtk:gtk-widget-destroy (gtk-object buffer)) - (setf (gtk-object buffer) nil)) - (define-ffi-method ffi-buffer-make ((buffer gtk-buffer)) "Initialize BUFFER's GTK web view." - (unless (gtk-object buffer) ; Buffer may already have a view, e.g. the prompt-buffer. - (setf (gtk-object buffer) - (make-instance 'webkit:webkit-web-view :web-context (make-context)))) + (setf (gtk-object buffer) + (make-instance 'webkit:webkit-web-view + :web-context (unless (prompt-buffer-p buffer) (make-context)))) (when (document-buffer-p buffer) (setf (ffi-buffer-smooth-scrolling-enabled-p buffer) (smooth-scrolling buffer))) ;; TODO: Maybe define an FFI method? @@ -1300,7 +1285,7 @@ the `active-buffer'." (buffer-delete buffer)) (connect-signal buffer "close" nil (web-view) (declare (ignore web-view)) - (buffer-destroy buffer)) + (log:debug "Closed ~a" buffer)) (connect-signal buffer "load-failed" nil (web-view load-event failing-url error) (declare (ignore load-event web-view)) ;; TODO: WebKitGTK sometimes (when?) triggers "load-failed" when loading a @@ -1418,14 +1403,13 @@ the `active-buffer'." buffer) (define-ffi-method ffi-buffer-delete ((buffer gtk-buffer)) - (cond ((not (slot-value buffer 'gtk-object)) - (mapc (lambda (handler-id) - (gobject:g-signal-handler-disconnect (gtk-object buffer) handler-id)) - (handler-ids buffer)) - (nyxt::buffer-hide buffer)) - ((webkit:webkit-web-view-is-web-process-responsive (gtk-object buffer)) - (webkit:webkit-web-view-try-close (gtk-object buffer))) - (t (buffer-destroy buffer)))) + (webkit:webkit-web-view-try-close (gtk-object buffer)) + (mapc (lambda (handler-id) + (gobject:g-signal-handler-disconnect (gtk-object buffer) handler-id)) + (handler-ids buffer)) + (nyxt::buffer-hide buffer) + (gtk:gtk-widget-destroy (gtk-object buffer)) + (setf (gtk-object buffer) nil)) (define-ffi-method ffi-buffer-load ((buffer gtk-buffer) url) "Load URL in BUFFER. From fd7f13635f015a0381510702e9ef4ac1a7f40e2d Mon Sep 17 00:00:00 2001 From: "Andre A. Gomes" Date: Tue, 15 Oct 2024 17:09:46 +0300 Subject: [PATCH 2/2] renderer/electron: Refactor prompt buffer's ffi-height method. --- source/renderer/electron.lisp | 1 - 1 file changed, 1 deletion(-) diff --git a/source/renderer/electron.lisp b/source/renderer/electron.lisp index 83436193288..b48ea8a61ed 100644 --- a/source/renderer/electron.lisp +++ b/source/renderer/electron.lisp @@ -211,7 +211,6 @@ Note that by changing the default value, modifier keys can be remapped.")) (with-slots (window) prompt-buffer (case height (0 - (ffi-buffer-delete prompt-buffer) (when (current-window) (electron:focus (active-buffer window)))) (t (electron:on window "resize"