diff options
author | Jim Meyering <jim@meyering.net> | 2003-10-25 15:28:09 +0000 |
---|---|---|
committer | Jim Meyering <jim@meyering.net> | 2003-10-25 15:28:09 +0000 |
commit | d34b02aa128928bcf3b8e4d9163a2f3b278648da (patch) | |
tree | 317b9932b7b2f3f48fe244196c4147fae42fb61a | |
parent | dc3b769bd7d0f539dc580a0501497e9fdb3d4ffb (diff) | |
download | coreutils-d34b02aa128928bcf3b8e4d9163a2f3b278648da.tar.xz |
Update from gnulib, plus filter through cppi.
-rw-r--r-- | lib/obstack.c | 53 |
1 files changed, 15 insertions, 38 deletions
diff --git a/lib/obstack.c b/lib/obstack.c index bf6bba86c..2ae9cdb6d 100644 --- a/lib/obstack.c +++ b/lib/obstack.c @@ -21,7 +21,11 @@ # include <config.h> #endif -#include "obstack.h" +#ifdef _LIBC +# include <obstack.h> +#else +# include "obstack.h" +#endif /* NOTE BEFORE MODIFYING THIS FILE: This version number must be incremented whenever callers compiled using an old obstack.h can no @@ -282,6 +286,9 @@ _obstack_newchunk (struct obstack *h, int length) /* The new chunk certainly contains no empty object yet. */ h->maybe_empty_object = 0; } +# ifdef _LIBC +libc_hidden_def (_obstack_newchunk) +# endif /* Return nonzero if object OBJ has been allocated from obstack H. This is here for debugging. @@ -314,41 +321,6 @@ _obstack_allocated_p (struct obstack *h, void *obj) # undef obstack_free -/* This function has two names with identical definitions. - This is the first one, called from non-ANSI code. */ - -void -_obstack_free (struct obstack *h, void *obj) -{ - register struct _obstack_chunk *lp; /* below addr of any objects in this chunk */ - register struct _obstack_chunk *plp; /* point to previous chunk if any */ - - lp = h->chunk; - /* We use >= because there cannot be an object at the beginning of a chunk. - But there can be an empty object at that address - at the end of another chunk. */ - while (lp != 0 && ((void *) lp >= obj || (void *) (lp)->limit < obj)) - { - plp = lp->prev; - CALL_FREEFUN (h, lp); - lp = plp; - /* If we switch chunks, we can't tell whether the new current - chunk contains an empty object, so assume that it may. */ - h->maybe_empty_object = 1; - } - if (lp) - { - h->object_base = h->next_free = (char *) (obj); - h->chunk_limit = lp->limit; - h->chunk = lp; - } - else if (obj != 0) - /* obj is not in any of the chunks! */ - abort (); -} - -/* This function is used from ANSI code. */ - void obstack_free (struct obstack *h, void *obj) { @@ -378,6 +350,12 @@ obstack_free (struct obstack *h, void *obj) /* obj is not in any of the chunks! */ abort (); } + +# ifdef _LIBC +/* Older versions of libc used a function _obstack_free intended to be + called by non-GCC compilers. */ +strong_alias (obstack_free, _obstack_free) +# endif int _obstack_memory_used (struct obstack *h) @@ -400,9 +378,8 @@ _obstack_memory_used (struct obstack *h) # endif # define _(msgid) gettext (msgid) -# if defined _LIBC && defined USE_IN_LIBIO +# ifdef _LIBC # include <libio/iolibio.h> -# define fputs(s, f) _IO_fputs (s, f) # endif # ifndef __attribute__ |