X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~mdw/git/clg/blobdiff_plain/1e1c3903d51a4aaffb8c2b25e8adfde68eddcb8b..cc8d918eec6976ce68916fd15a4837f5b8e34dba:/gtk/gtkobject.lisp?ds=inline diff --git a/gtk/gtkobject.lisp b/gtk/gtkobject.lisp index a984022..c95abd4 100644 --- a/gtk/gtkobject.lisp +++ b/gtk/gtkobject.lisp @@ -20,7 +20,7 @@ ;; TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE ;; SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. -;; $Id: gtkobject.lisp,v 1.45 2008/02/28 18:33:12 espen Exp $ +;; $Id: gtkobject.lisp,v 1.46 2008/03/04 16:03:38 espen Exp $ (in-package "GTK") @@ -56,6 +56,9 @@ (defbinding %object-sink () nil ;;;; Main loop and event handling +(defparameter *reentrant-main-iteration* t) +(defvar *running-main-iteration* nil) + (defbinding events-pending-p () boolean) (defbinding get-current-event () gdk:event) @@ -74,9 +77,11 @@ (defbinding main-iteration-do (&optional (blocking t)) boolean (defun main-iterate-all (&rest args) (declare (ignore args)) - (loop - while (events-pending-p) - do (main-iteration-do nil)) + (unless (and (not *reentrant-main-iteration*) *running-main-iteration*) + (let ((*running-main-iteration* t)) + (loop + while (events-pending-p) + do (main-iteration-do nil)))) #+clisp 0)