Mercurial > emacs
view src/s/irix4-0.h @ 5415:95882472f2da
(rotate_right, rotate_left): Simplify
total_length calculation. Minimize pointer dereferencing.
(balance_an_interval): Remove recursive rebalancing.
Rebalance precisely when imbalanced. If a rotation is done,
rebalance only the node which may have become unbalanced.
Iterate until the current node is balanced.
(balance_possible_root_interval): New function.
(balance_intervals): Move the interation into rebalance_an_interval.
(balance_intervals_internal): New subroutine of balance_intervals.
(split_interval_right, split_interval_left): Speed up by
not checking LEAF_INTERVAL_P.
(split_interval_right, split_interval_left, find_interval,
adjust_intervals_for_insertion, graft_intervals_into_buffer):
Add dynamic rebalancing anywhere a node may become unbalanced.
(graft_intervals_into_buffer, copy_intervals): No longer
any need to do a full rebalance as the tree stays balanced.
author | Richard M. Stallman <rms@gnu.org> |
---|---|
date | Sun, 02 Jan 1994 19:01:15 +0000 |
parents | 647bef18618f |
children | 191acacfa1ec |
line wrap: on
line source
#include "irix3-3.h" #define USG5_3 #define IRIX4 #define HAVE_ALLOCA #ifndef NOT_C_CODE #include <alloca.h> #endif #undef IRIS_UTIME #undef NEED_SIOCTL /* Make process_send_signal work by "typing" a signal character on the pty. */ #define SIGNALS_VIA_CHARACTERS /* use K&R C */ #ifndef __GNUC__ #define C_SWITCH_MACHINE -cckr #endif /* SGI has all the fancy wait stuff, but we can't include sys/wait.h because it defines BIG_ENDIAN and LITTLE_ENDIAN (ugh!.) Instead we'll just define WNOHANG right here. (An implicit decl is good enough for wait3.) */ #define WNOHANG 0x1 /* No need to use sprintf to get the tty name--we get that from _getpty. */ #undef PTY_TTY_NAME_SPRINTF #define PTY_TTY_NAME_SPRINTF /* No need to get the pty name at all. */ #define PTY_NAME_SPRINTF /* We need only try once to open a pty. */ #define PTY_ITERATION /* Here is how to do it. */ /* It is necessary to prevent SIGCHLD signals within _getpty. So we block them. */ #define PTY_OPEN \ { \ int mask = sigblock (sigmask (SIGCHLD)); \ char *name = _getpty (&fd, O_RDWR | O_NDELAY, 0600, 0); \ sigsetmask(mask); \ if (name == 0) \ return -1; \ if (fd < 0) \ return -1; \ if (fstat (fd, &stb) < 0) \ return -1; \ strcpy (pty_name, name); \ } /* jpff@maths.bath.ac.uk reports `struct exception' is not defined on this system, so inhibit use of matherr. */ #define NO_MATHERR