aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorJim Blandy1993-03-31 10:47:13 +0000
committerJim Blandy1993-03-31 10:47:13 +0000
commit357f32fcd0e00337a3c1359a4919e716ed81fe52 (patch)
treeb9916406d852f7545445cb4709e3b61071b240a3 /src
parent33f9662a640a52593f99f87b8ce1a313dd79e2f4 (diff)
downloademacs-357f32fcd0e00337a3c1359a4919e716ed81fe52.tar.gz
emacs-357f32fcd0e00337a3c1359a4919e716ed81fe52.zip
* xfaces.c: Doc fixes.
Put interrupt input blocking in a separate file from xterm.h. This isn't specific to X, and it allows us to avoid #including xterm.h in files that don't really have anything to do with X. * blockinput.h: New file. * xterm.h (BLOCK_INPUT, UNBLOCK_INPUT, TOTALLY_UNBLOCK_INPUT, UNBLOCK_INPUT_RESIGNAL): These are now in blockinput.h. (x_input_blocked, x_pending_input): Deleted; there are analogs in blockinput.h called interrupt_input_blocked and interrupt_input_pending. * keyboard.c (interrupt_input_blocked, interrupt_input_pending): New variables, used by the macros in blockinput.h. * xterm.c: #include blockinput.h. (x_input_blocked, x_pending_input): Deleted. (XTread_socket): Test and set interrupt_input_blocked and interrupt_input_pending instead of the old variables. * alloc.c, xfaces.c, xfns.c, xmenu.c, xselect.c, keymap.c: #include blockinput.h. * eval.c: #include blockinput.h instead of xterm.h. * keyboard.c: #include blockinput.h. (input_poll_signal): Just test interrupt_input_blocked, instead of testing HAVE_X_WINDOWS and x_input_blocked. Block the processing of interrupt input while we're manipulating the malloc heap. * alloc.c: (xfree): New function, to make it easy to free things safely. (xmalloc, xrealloc): Block X input while doing the deed. (VALIDATE_LISP_STORAGE, gc_sweep, compact_strings): Use xfree instead of free. (uninterrupt_malloc): New function, to install input-blocking hooks into the GNU malloc routines. * emacs.c [not SYSTEM_MALLOC] (main): Call uninterrupt_malloc on startup. * alloc.c: (make_interval, make_float, Fcons, Fmake_vector, Fmake_symbol, Fmake_marker, make_uninit_string, Fgarbage_collect): Use xmalloc instead of malloc; don't bother to check if out of memory here. (Fgarbage_collect): Call xrealloc instead of realloc. * buffer.c: Use xmalloc and xfree instead of malloc and free; don't bother to check if out of memory here. (Fget_buffer_create): Put BLOCK_INPUT/UNBLOCK_INPUT pair around calls to ralloc routines. * insdel.c: Same. * lisp.h (xfree): New extern declaration. * xfaces.c (xfree): Don't #define this to be free; use the definition in alloc.c. * dispnew.c, doc.c, doprnt.c, fileio.c, lread.c, term.c, xfns.c, xmenu.c, xterm.c: Use xfree instead of free. * hftctl.c: Use xfree and xmalloc instead of free and malloc. * keymap.c (current_minor_maps): BLOCK_INPUT while calling realloc and malloc. * search.c: Since the regexp routines can malloc, BLOCK_INPUT while runing them. #include blockinput.h. * sysdep.c: #include blockinput.h. Call xfree and xmalloc instead of free and malloc. BLOCK_INPUT around routines which we know will call malloc. ymakefile (keyboard.o, keymap.o, search.o, sysdep.o, xfaces.o, xfns.o, xmenu.o, xterm.o, xselect.o, alloc.o, eval.o): Note that these depend on blockinput.h.
Diffstat (limited to 'src')
-rw-r--r--src/xfaces.c7
1 files changed, 3 insertions, 4 deletions
diff --git a/src/xfaces.c b/src/xfaces.c
index 6d946059760..643c8de18a5 100644
--- a/src/xfaces.c
+++ b/src/xfaces.c
@@ -17,7 +17,7 @@ You should have received a copy of the GNU General Public License
17along with GNU Emacs; see the file COPYING. If not, write to 17along with GNU Emacs; see the file COPYING. If not, write to
18the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. */ 18the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. */
19 19
20/* This derived from work by Lucid (some parts very loosely so). */ 20/* This is derived from work by Lucid (some parts very loosely so). */
21 21
22#include <sys/types.h> 22#include <sys/types.h>
23#include <sys/stat.h> 23#include <sys/stat.h>
@@ -29,6 +29,7 @@ the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. */
29#include "buffer.h" 29#include "buffer.h"
30#include "dispextern.h" 30#include "dispextern.h"
31#include "frame.h" 31#include "frame.h"
32#include "blockinput.h"
32/* #include "window.h" */ 33/* #include "window.h" */
33 34
34/* Display Context for the icons */ 35/* Display Context for the icons */
@@ -45,7 +46,7 @@ the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. */
45 The faces in these vectors are called "frame faces". 46 The faces in these vectors are called "frame faces".
46 47
47 Faces number 0 and 1 have graphics contexts. 48 Faces number 0 and 1 have graphics contexts.
48 They can be user in the redisplay code directly. 49 They can be used in the redisplay code directly.
49 Higher numbered frame faces do not have graphics contexts. 50 Higher numbered frame faces do not have graphics contexts.
50 51
51 There are also "cached faces". They have graphics contexts. 52 There are also "cached faces". They have graphics contexts.
@@ -67,8 +68,6 @@ int next_face_id;
67 68
68#define FACE_DEFAULT (~0) 69#define FACE_DEFAULT (~0)
69 70
70#define xfree free
71
72Lisp_Object Qface, Qwindow, Qpriority; 71Lisp_Object Qface, Qwindow, Qpriority;
73 72
74static struct face *allocate_face (); 73static struct face *allocate_face ();