From: Gerd Moellmann Date: Sat, 12 Feb 2000 13:13:13 +0000 (+0000) Subject: (stopped_atimers): New variable. X-Git-Tag: emacs-pretest-21.0.90~5044 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=9c2e3e8df1cac452d65c52f5c878ede6b24d16c8;p=emacs.git (stopped_atimers): New variable. (stop_other_atimers, run_all_atimers, unwind_stop_other_atimers): New functions. --- diff --git a/src/atimer.c b/src/atimer.c index d4cd6ef4801..9dc4f508f8b 100644 --- a/src/atimer.c +++ b/src/atimer.c @@ -44,6 +44,11 @@ Boston, MA 02111-1307, USA. */ static struct atimer *free_atimers; +/* List of currently not running timers due to a call to + lock_atimer. */ + +static struct atimer *stopped_atimers; + /* List of active atimers, sorted by expiration time. The timer that will become ripe next is always at the front of this list. */ @@ -95,6 +100,10 @@ start_atimer (type, time, fn, client_data) { struct atimer *t; + /* May not be called when some timers are stopped. */ + if (stopped_atimers) + abort (); + /* Round TIME up to the next full second if we don't have itimers. */ #ifndef HAVE_SETITIMER @@ -161,6 +170,10 @@ cancel_atimer (timer) { struct atimer *t, *prev; + /* May not be called when some timers are stopped. */ + if (stopped_atimers) + abort (); + BLOCK_ATIMERS; /* See if TIMER is active. */ @@ -185,12 +198,70 @@ cancel_atimer (timer) } +/* Stop all timers except timer T. T null means stop all timers. + This function may only be called when all timers are running. Two + calls of this function in a row will lead to an abort. You may not + call cancel_atimer or start_atimer while timers are stopped. */ + +void +stop_other_atimers (t) + struct atimer *t; +{ + BLOCK_ATIMERS; + + if (stopped_atimers) + abort (); + + if (t) + { + cancel_atimer (t); + if (free_atimers != t) + abort (); + free_atimers = free_atimers->next; + t->next = NULL; + } + + stopped_atimers = atimers; + atimers = t; + UNBLOCK_ATIMERS; +} + + +/* Run all timers again, if some have been stopped with a call to + stop_other_atimers. */ + +void +run_all_atimers () +{ + if (stopped_atimers) + { + struct atimer *t = atimers; + BLOCK_ATIMERS; + atimers = stopped_atimers; + stopped_atimers = NULL; + if (t) + schedule_atimer (t); + UNBLOCK_ATIMERS; + } +} + + +/* A version of run_all_timers suitable for a record_unwind_protect. */ + +Lisp_Object +unwind_stop_other_atimers (dummy) + Lisp_Object dummy; +{ + run_all_atimers (); + return Qnil; +} + + /* Arrange for a SIGALRM to arrive when the next timer is ripe. */ static void set_alarm () { - #if defined (USG) && !defined (POSIX_SIGNALS) /* USG systems forget handlers when they are used; must reestablish each time. */