]> git.eshelyaron.com Git - emacs.git/commitdiff
Make it possible to C-g in a tight bytecode loop again (bug#5680).
authorStefan Monnier <monnier@iro.umontreal.ca>
Fri, 5 Mar 2010 23:08:18 +0000 (18:08 -0500)
committerStefan Monnier <monnier@iro.umontreal.ca>
Fri, 5 Mar 2010 23:08:18 +0000 (18:08 -0500)
* lisp.h (ELSE_PENDING_SIGNALS): New macro.
(QUIT): Use it to consolidate code and remove redundancy.
* bytecode.c (BYTE_CODE_QUIT): Use it as well.

src/ChangeLog
src/bytecode.c
src/lisp.h

index f7226d6fc6faefc6bb8a2829dcd6b9be8a36d9ce..ce4fe1cd7b4e9bccfc99a57433cf4c9aa705e932 100644 (file)
@@ -1,5 +1,10 @@
 2010-03-05  Stefan Monnier  <monnier@iro.umontreal.ca>
 
+       Make it possible to C-g in a tight bytecode loop again (bug#5680).
+       * lisp.h (ELSE_PENDING_SIGNALS): New macro.
+       (QUIT): Use it to consolidate code and remove redundancy.
+       * bytecode.c (BYTE_CODE_QUIT): Use it as well.
+
        * regex.c (regex_compile): Setup gl_state as well.
 
        * syntax.c (skip_chars): Setup gl_state (bug#3823).
index 31df65fd303271f5cf23b214117de8c231635438..e95614c72a9126bef52ee15d038f1fc049bc4d5c 100644 (file)
@@ -393,6 +393,7 @@ unmark_byte_stack ()
        Fsignal (Qquit, Qnil);                          \
        AFTER_POTENTIAL_GC ();                          \
       }                                                        \
+    ELSE_PENDING_SIGNALS                               \
   } while (0)
 
 
index 7032a3f48f4c0aaf967033783d6d7b4072cf219c..7f5d5df66c61106d5caf3223a929aa077ce4a2d7 100644 (file)
@@ -1933,22 +1933,12 @@ extern char *stack_bottom;
 #ifdef SYNC_INPUT
 extern void process_pending_signals P_ ((void));
 extern int pending_signals;
-
-#define QUIT                                           \
-  do {                                                 \
-    if (!NILP (Vquit_flag) && NILP (Vinhibit_quit))    \
-      {                                                        \
-        Lisp_Object flag = Vquit_flag;                 \
-       Vquit_flag = Qnil;                              \
-       if (EQ (Vthrow_on_input, flag))                 \
-         Fthrow (Vthrow_on_input, Qt);                 \
-       Fsignal (Qquit, Qnil);                          \
-      }                                                        \
-    else if (pending_signals)                          \
-      process_pending_signals ();                      \
-  } while (0)
-
+#define ELSE_PENDING_SIGNALS                           \
+  else if (pending_signals)                            \
+    process_pending_signals ();
 #else  /* not SYNC_INPUT */
+#define ELSE_PENDING_SIGNALS
+#endif /* not SYNC_INPUT */
 
 #define QUIT                                           \
   do {                                                 \
@@ -1960,10 +1950,9 @@ extern int pending_signals;
          Fthrow (Vthrow_on_input, Qt);                 \
        Fsignal (Qquit, Qnil);                          \
       }                                                        \
+    ELSE_PENDING_SIGNALS                               \
   } while (0)
 
-#endif /* not SYNC_INPUT */
-
 
 /* Nonzero if ought to quit now.  */