home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
OS/2 Shareware BBS: 10 Tools
/
10-Tools.zip
/
mitsch75.zip
/
scheme-7_5_17-src.zip
/
scheme-7.5.17
/
src
/
microcode
/
intext.c
< prev
next >
Wrap
C/C++ Source or Header
|
1999-01-02
|
3KB
|
84 lines
/* -*-C-*-
$Id: intext.c,v 1.5 1999/01/02 06:11:34 cph Exp $
Copyright (c) 1990-1999 Massachusetts Institute of Technology
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or (at
your option) any later version.
This program is distributed in the hope that it will be useful, but
WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
*/
#include "ansidecl.h"
#include "dstack.h"
#include "intext.h"
extern void EXFUN (preserve_signal_mask, (void));
struct interruptable_extent * current_interruptable_extent;
void
DEFUN_VOID (initialize_interruptable_extent)
{
current_interruptable_extent = 0;
}
void
DEFUN_VOID (reset_interruptable_extent)
{
current_interruptable_extent = 0;
}
struct interruptable_extent *
DEFUN_VOID (enter_interruptable_extent)
{
PTR position = dstack_position;
struct interruptable_extent * frame;
/* Inside the interrupt handler, the signal mask will be different.
Push a winding frame that will restore it to its current value.
Do this before any other changes so that the other changes are
undone before the signal mask is restored (possibly causing
another interrupt). */
preserve_signal_mask ();
frame = (dstack_alloc (sizeof (struct interruptable_extent)));
(frame -> position) = position;
(frame -> interrupted) = 0;
/* Create a dynamic binding frame but don't assign the new frame to
it until the setjmp has been done. */
dstack_bind ((¤t_interruptable_extent), current_interruptable_extent);
return (frame);
}
/* It is possible that two signals arriving close together could both
set `interrupted'. This does not matter, because the signal
handlers haven't done anything at this point, and the net effect is
to cause the second signal handler to do the longjmp, rather than
the first. However, the first signal handler never runs, which may
be a problem for some applications. */
int
DEFUN_VOID (enter_interruption_extent)
{
if ((current_interruptable_extent == 0)
|| (current_interruptable_extent -> interrupted))
return (0);
(current_interruptable_extent -> interrupted) = 1;
return (1);
}
void
DEFUN_VOID (exit_interruption_extent)
{
longjmp ((current_interruptable_extent -> control_point), 1);
}