From: Jan Djärv Date: Thu, 10 Mar 2005 19:08:31 +0000 (+0000) Subject: * keyboard.c (Fexecute_extended_command): Restart hourglass X-Git-Tag: ttn-vms-21-2-B4~1844 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=a25e44b279d340849eeb55d1209e5409b664ad04;p=emacs.git * keyboard.c (Fexecute_extended_command): Restart hourglass after call to Fcompleting_read if already started. --- diff --git a/src/keyboard.c b/src/keyboard.c index f507ea348f1..a1c3334bbb8 100644 --- a/src/keyboard.c +++ b/src/keyboard.c @@ -1350,6 +1350,11 @@ DEFUN ("top-level", Ftop_level, Stop_level, 0, 0, "", cancel_hourglass (); #endif + /* Unblock input if we enter with input blocked. This may happen if + redisplay traps e.g. during tool-bar update with input blocked. */ + while (INPUT_BLOCKED_P) + UNBLOCK_INPUT; + return Fthrow (Qtop_level, Qnil); } @@ -9711,6 +9716,15 @@ DEFUN ("execute-extended-command", Fexecute_extended_command, Sexecute_extended_ Lisp_Object saved_keys, saved_last_point_position_buffer; Lisp_Object bindings, value; struct gcpro gcpro1, gcpro2, gcpro3; +#ifdef HAVE_X_WINDOWS + /* The call to Fcompleting_read wil start and cancel the hourglass, + but if the hourglass was already scheduled, this means that no + hourglass will be shown for the actual M-x command itself. + So we restart it if it is already scheduled. Note that checking + hourglass_shown_p is not enough, normally the hourglass is not shown, + just scheduled to be shown. */ + int hstarted = hourglass_started (); +#endif saved_keys = Fvector (this_command_key_count, XVECTOR (this_command_keys)->contents); @@ -9742,6 +9756,10 @@ DEFUN ("execute-extended-command", Fexecute_extended_command, Sexecute_extended_ Qt, Qnil, Qextended_command_history, Qnil, Qnil); +#ifdef HAVE_X_WINDOWS + if (hstarted) start_hourglass (); +#endif + if (STRINGP (function) && SCHARS (function) == 0) error ("No command name given");