annotate lib/obstack.c @ 4020:7158a1db8695

change license to gpl.
author Karl Berry <karl@freefriends.org>
date Mon, 25 Nov 2002 00:17:33 +0000
parents 22d3032f0239
children 117a6d2af03b
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
1 /* obstack.c - subroutines used implicitly by object stack macros
3966
22d3032f0239 Include gettext.h instead of <libintl.h> with #ifdefs.
Bruno Haible <bruno@clisp.org>
parents: 3552
diff changeset
2 Copyright (C) 1988-1994, 1996-1999, 2000-2002 Free Software Foundation, Inc.
4020
7158a1db8695 change license to gpl.
Karl Berry <karl@freefriends.org>
parents: 3966
diff changeset
3 This program is free software; you can redistribute it and/or modify
7158a1db8695 change license to gpl.
Karl Berry <karl@freefriends.org>
parents: 3966
diff changeset
4 it under the terms of the GNU General Public License as published by
7158a1db8695 change license to gpl.
Karl Berry <karl@freefriends.org>
parents: 3966
diff changeset
5 the Free Software Foundation; either version 2, or (at your option)
7158a1db8695 change license to gpl.
Karl Berry <karl@freefriends.org>
parents: 3966
diff changeset
6 any later version.
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
7
4020
7158a1db8695 change license to gpl.
Karl Berry <karl@freefriends.org>
parents: 3966
diff changeset
8 This program is distributed in the hope that it will be useful,
881
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
9 but WITHOUT ANY WARRANTY; without even the implied warranty of
4020
7158a1db8695 change license to gpl.
Karl Berry <karl@freefriends.org>
parents: 3966
diff changeset
10 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
7158a1db8695 change license to gpl.
Karl Berry <karl@freefriends.org>
parents: 3966
diff changeset
11 GNU General Public License for more details.
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
12
4020
7158a1db8695 change license to gpl.
Karl Berry <karl@freefriends.org>
parents: 3966
diff changeset
13 You should have received a copy of the GNU General Public License along
7158a1db8695 change license to gpl.
Karl Berry <karl@freefriends.org>
parents: 3966
diff changeset
14 with this program; if not, write to the Free Software Foundation,
7158a1db8695 change license to gpl.
Karl Berry <karl@freefriends.org>
parents: 3966
diff changeset
15 Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
16
2475
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
17 #ifdef HAVE_CONFIG_H
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
18 # include <config.h>
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
19 #endif
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
20
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
21 #include "obstack.h"
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
22
779
d183d24934d4 from franc,ois
Jim Meyering <jim@meyering.net>
parents: 650
diff changeset
23 /* NOTE BEFORE MODIFYING THIS FILE: This version number must be
d183d24934d4 from franc,ois
Jim Meyering <jim@meyering.net>
parents: 650
diff changeset
24 incremented whenever callers compiled using an old obstack.h can no
d183d24934d4 from franc,ois
Jim Meyering <jim@meyering.net>
parents: 650
diff changeset
25 longer properly call the functions in this obstack.c. */
d183d24934d4 from franc,ois
Jim Meyering <jim@meyering.net>
parents: 650
diff changeset
26 #define OBSTACK_INTERFACE_VERSION 1
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
27
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
28 /* Comment out all this code if we are using the GNU C Library, and are not
779
d183d24934d4 from franc,ois
Jim Meyering <jim@meyering.net>
parents: 650
diff changeset
29 actually compiling the library itself, and the installed library
d183d24934d4 from franc,ois
Jim Meyering <jim@meyering.net>
parents: 650
diff changeset
30 supports the same library interface we do. This code is part of the GNU
d183d24934d4 from franc,ois
Jim Meyering <jim@meyering.net>
parents: 650
diff changeset
31 C Library, but also included in many other GNU distributions. Compiling
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
32 and linking in this code is a waste when using the GNU C library
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
33 (especially if it is a shared library). Rather than having every GNU
779
d183d24934d4 from franc,ois
Jim Meyering <jim@meyering.net>
parents: 650
diff changeset
34 program understand `configure --with-gnu-libc' and omit the object
d183d24934d4 from franc,ois
Jim Meyering <jim@meyering.net>
parents: 650
diff changeset
35 files, it is simpler to just do this in the source for each such file. */
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
36
779
d183d24934d4 from franc,ois
Jim Meyering <jim@meyering.net>
parents: 650
diff changeset
37 #include <stdio.h> /* Random thing to get __GNU_LIBRARY__. */
3362
cb3db42cafb9 update from libc
Jim Meyering <jim@meyering.net>
parents: 3361
diff changeset
38 #if !defined _LIBC && defined __GNU_LIBRARY__ && __GNU_LIBRARY__ > 1
2475
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
39 # include <gnu-versions.h>
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
40 # if _GNU_OBSTACK_INTERFACE_VERSION == OBSTACK_INTERFACE_VERSION
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
41 # define ELIDE_CODE
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
42 # endif
779
d183d24934d4 from franc,ois
Jim Meyering <jim@meyering.net>
parents: 650
diff changeset
43 #endif
d183d24934d4 from franc,ois
Jim Meyering <jim@meyering.net>
parents: 650
diff changeset
44
3361
9594c5ad3ab8 update from glibc
Jim Meyering <jim@meyering.net>
parents: 3293
diff changeset
45 #if defined _LIBC && defined USE_IN_LIBIO
9594c5ad3ab8 update from glibc
Jim Meyering <jim@meyering.net>
parents: 3293
diff changeset
46 # include <wchar.h>
9594c5ad3ab8 update from glibc
Jim Meyering <jim@meyering.net>
parents: 3293
diff changeset
47 #endif
779
d183d24934d4 from franc,ois
Jim Meyering <jim@meyering.net>
parents: 650
diff changeset
48
d183d24934d4 from franc,ois
Jim Meyering <jim@meyering.net>
parents: 650
diff changeset
49 #ifndef ELIDE_CODE
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
50
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
51
3362
cb3db42cafb9 update from libc
Jim Meyering <jim@meyering.net>
parents: 3361
diff changeset
52 # if defined __STDC__ && __STDC__
2475
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
53 # define POINTER void *
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
54 # else
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
55 # define POINTER char *
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
56 # endif
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
57
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
58 /* Determine default alignment. */
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
59 struct fooalign {char x; double d;};
2475
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
60 # define DEFAULT_ALIGNMENT \
881
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
61 ((PTR_INT_TYPE) ((char *) &((struct fooalign *) 0)->d - (char *) 0))
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
62 /* If malloc were really smart, it would round addresses to DEFAULT_ALIGNMENT.
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
63 But in fact it might be less smart and round addresses to as much as
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
64 DEFAULT_ROUNDING. So we prepare for it to do that. */
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
65 union fooround {long x; double d;};
2475
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
66 # define DEFAULT_ROUNDING (sizeof (union fooround))
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
67
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
68 /* When we copy a long block of data, this is the unit to do it with.
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
69 On some machines, copying successive ints does not work;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
70 in such a case, redefine COPYING_UNIT to `long' (if that works)
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
71 or `char' as a last resort. */
2475
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
72 # ifndef COPYING_UNIT
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
73 # define COPYING_UNIT int
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
74 # endif
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
75
881
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
76
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
77 /* The functions allocating more room by calling `obstack_chunk_alloc'
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
78 jump to the handler pointed to by `obstack_alloc_failed_handler'.
2475
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
79 This can be set to a user defined function which should either
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
80 abort gracefully or use longjump - but shouldn't return. This
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
81 variable by default points to the internal function
881
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
82 `print_and_abort'. */
3362
cb3db42cafb9 update from libc
Jim Meyering <jim@meyering.net>
parents: 3361
diff changeset
83 # if defined __STDC__ && __STDC__
881
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
84 static void print_and_abort (void);
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
85 void (*obstack_alloc_failed_handler) (void) = print_and_abort;
2475
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
86 # else
881
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
87 static void print_and_abort ();
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
88 void (*obstack_alloc_failed_handler) () = print_and_abort;
2475
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
89 # endif
881
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
90
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
91 /* Exit value used when `print_and_abort' is used. */
2475
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
92 # if defined __GNU_LIBRARY__ || defined HAVE_STDLIB_H
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
93 # include <stdlib.h>
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
94 # endif
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
95 # ifndef EXIT_FAILURE
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
96 # define EXIT_FAILURE 1
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
97 # endif
881
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
98 int obstack_exit_failure = EXIT_FAILURE;
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
99
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
100 /* The non-GNU-C macros copy the obstack into this global variable
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
101 to avoid multiple evaluation. */
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
102
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
103 struct obstack *_obstack;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
104
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
105 /* Define a macro that either calls functions with the traditional malloc/free
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
106 calling interface, or calls functions with the mmalloc/mfree interface
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
107 (that adds an extra first argument), based on the state of use_extra_arg.
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
108 For free, do not use ?:, since some compilers, like the MIPS compilers,
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
109 do not allow (expr) ? void : void. */
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
110
3362
cb3db42cafb9 update from libc
Jim Meyering <jim@meyering.net>
parents: 3361
diff changeset
111 # if defined __STDC__ && __STDC__
2475
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
112 # define CALL_CHUNKFUN(h, size) \
881
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
113 (((h) -> use_extra_arg) \
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
114 ? (*(h)->chunkfun) ((h)->extra_arg, (size)) \
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
115 : (*(struct _obstack_chunk *(*) (long)) (h)->chunkfun) ((size)))
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
116
2475
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
117 # define CALL_FREEFUN(h, old_chunk) \
881
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
118 do { \
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
119 if ((h) -> use_extra_arg) \
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
120 (*(h)->freefun) ((h)->extra_arg, (old_chunk)); \
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
121 else \
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
122 (*(void (*) (void *)) (h)->freefun) ((old_chunk)); \
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
123 } while (0)
2475
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
124 # else
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
125 # define CALL_CHUNKFUN(h, size) \
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
126 (((h) -> use_extra_arg) \
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
127 ? (*(h)->chunkfun) ((h)->extra_arg, (size)) \
779
d183d24934d4 from franc,ois
Jim Meyering <jim@meyering.net>
parents: 650
diff changeset
128 : (*(struct _obstack_chunk *(*) ()) (h)->chunkfun) ((size)))
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
129
2475
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
130 # define CALL_FREEFUN(h, old_chunk) \
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
131 do { \
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
132 if ((h) -> use_extra_arg) \
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
133 (*(h)->freefun) ((h)->extra_arg, (old_chunk)); \
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
134 else \
779
d183d24934d4 from franc,ois
Jim Meyering <jim@meyering.net>
parents: 650
diff changeset
135 (*(void (*) ()) (h)->freefun) ((old_chunk)); \
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
136 } while (0)
2475
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
137 # endif
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
138
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
139
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
140 /* Initialize an obstack H for use. Specify chunk size SIZE (0 means default).
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
141 Objects start on multiples of ALIGNMENT (0 means use default).
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
142 CHUNKFUN is the function to use to allocate chunks,
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
143 and FREEFUN the function to free them.
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
144
2475
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
145 Return nonzero if successful, calls obstack_alloc_failed_handler if
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
146 allocation fails. */
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
147
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
148 int
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
149 _obstack_begin (h, size, alignment, chunkfun, freefun)
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
150 struct obstack *h;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
151 int size;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
152 int alignment;
3362
cb3db42cafb9 update from libc
Jim Meyering <jim@meyering.net>
parents: 3361
diff changeset
153 # if defined __STDC__ && __STDC__
881
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
154 POINTER (*chunkfun) (long);
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
155 void (*freefun) (void *);
2475
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
156 # else
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
157 POINTER (*chunkfun) ();
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
158 void (*freefun) ();
2475
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
159 # endif
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
160 {
881
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
161 register struct _obstack_chunk *chunk; /* points to new chunk */
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
162
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
163 if (alignment == 0)
2475
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
164 alignment = (int) DEFAULT_ALIGNMENT;
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
165 if (size == 0)
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
166 /* Default size is what GNU malloc can fit in a 4096-byte block. */
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
167 {
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
168 /* 12 is sizeof (mhead) and 4 is EXTRA from GNU malloc.
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
169 Use the values for range checking, because if range checking is off,
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
170 the extra bytes won't be missed terribly, but if range checking is on
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
171 and we used a larger request, a whole extra 4096 bytes would be
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
172 allocated.
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
173
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
174 These number are irrelevant to the new GNU malloc. I suspect it is
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
175 less sensitive to the size of the request. */
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
176 int extra = ((((12 + DEFAULT_ROUNDING - 1) & ~(DEFAULT_ROUNDING - 1))
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
177 + 4 + DEFAULT_ROUNDING - 1)
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
178 & ~(DEFAULT_ROUNDING - 1));
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
179 size = 4096 - extra;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
180 }
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
181
3362
cb3db42cafb9 update from libc
Jim Meyering <jim@meyering.net>
parents: 3361
diff changeset
182 # if defined __STDC__ && __STDC__
881
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
183 h->chunkfun = (struct _obstack_chunk * (*)(void *, long)) chunkfun;
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
184 h->freefun = (void (*) (void *, struct _obstack_chunk *)) freefun;
2475
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
185 # else
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
186 h->chunkfun = (struct _obstack_chunk * (*)()) chunkfun;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
187 h->freefun = freefun;
2475
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
188 # endif
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
189 h->chunk_size = size;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
190 h->alignment_mask = alignment - 1;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
191 h->use_extra_arg = 0;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
192
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
193 chunk = h->chunk = CALL_CHUNKFUN (h, h -> chunk_size);
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
194 if (!chunk)
881
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
195 (*obstack_alloc_failed_handler) ();
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
196 h->next_free = h->object_base = chunk->contents;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
197 h->chunk_limit = chunk->limit
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
198 = (char *) chunk + h->chunk_size;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
199 chunk->prev = 0;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
200 /* The initial chunk now contains no empty object. */
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
201 h->maybe_empty_object = 0;
881
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
202 h->alloc_failed = 0;
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
203 return 1;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
204 }
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
205
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
206 int
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
207 _obstack_begin_1 (h, size, alignment, chunkfun, freefun, arg)
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
208 struct obstack *h;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
209 int size;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
210 int alignment;
3362
cb3db42cafb9 update from libc
Jim Meyering <jim@meyering.net>
parents: 3361
diff changeset
211 # if defined __STDC__ && __STDC__
881
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
212 POINTER (*chunkfun) (POINTER, long);
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
213 void (*freefun) (POINTER, POINTER);
2475
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
214 # else
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
215 POINTER (*chunkfun) ();
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
216 void (*freefun) ();
2475
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
217 # endif
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
218 POINTER arg;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
219 {
881
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
220 register struct _obstack_chunk *chunk; /* points to new chunk */
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
221
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
222 if (alignment == 0)
2475
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
223 alignment = (int) DEFAULT_ALIGNMENT;
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
224 if (size == 0)
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
225 /* Default size is what GNU malloc can fit in a 4096-byte block. */
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
226 {
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
227 /* 12 is sizeof (mhead) and 4 is EXTRA from GNU malloc.
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
228 Use the values for range checking, because if range checking is off,
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
229 the extra bytes won't be missed terribly, but if range checking is on
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
230 and we used a larger request, a whole extra 4096 bytes would be
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
231 allocated.
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
232
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
233 These number are irrelevant to the new GNU malloc. I suspect it is
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
234 less sensitive to the size of the request. */
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
235 int extra = ((((12 + DEFAULT_ROUNDING - 1) & ~(DEFAULT_ROUNDING - 1))
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
236 + 4 + DEFAULT_ROUNDING - 1)
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
237 & ~(DEFAULT_ROUNDING - 1));
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
238 size = 4096 - extra;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
239 }
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
240
3362
cb3db42cafb9 update from libc
Jim Meyering <jim@meyering.net>
parents: 3361
diff changeset
241 # if defined __STDC__ && __STDC__
881
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
242 h->chunkfun = (struct _obstack_chunk * (*)(void *,long)) chunkfun;
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
243 h->freefun = (void (*) (void *, struct _obstack_chunk *)) freefun;
2475
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
244 # else
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
245 h->chunkfun = (struct _obstack_chunk * (*)()) chunkfun;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
246 h->freefun = freefun;
2475
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
247 # endif
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
248 h->chunk_size = size;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
249 h->alignment_mask = alignment - 1;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
250 h->extra_arg = arg;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
251 h->use_extra_arg = 1;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
252
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
253 chunk = h->chunk = CALL_CHUNKFUN (h, h -> chunk_size);
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
254 if (!chunk)
881
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
255 (*obstack_alloc_failed_handler) ();
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
256 h->next_free = h->object_base = chunk->contents;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
257 h->chunk_limit = chunk->limit
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
258 = (char *) chunk + h->chunk_size;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
259 chunk->prev = 0;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
260 /* The initial chunk now contains no empty object. */
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
261 h->maybe_empty_object = 0;
881
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
262 h->alloc_failed = 0;
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
263 return 1;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
264 }
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
265
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
266 /* Allocate a new current chunk for the obstack *H
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
267 on the assumption that LENGTH bytes need to be added
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
268 to the current object, or a new object of length LENGTH allocated.
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
269 Copies any partial object from the end of the old chunk
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
270 to the beginning of the new one. */
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
271
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
272 void
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
273 _obstack_newchunk (h, length)
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
274 struct obstack *h;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
275 int length;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
276 {
881
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
277 register struct _obstack_chunk *old_chunk = h->chunk;
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
278 register struct _obstack_chunk *new_chunk;
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
279 register long new_size;
2475
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
280 register long obj_size = h->next_free - h->object_base;
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
281 register long i;
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
282 long already;
2915
5690d50326cb Update from libc.
Jim Meyering <jim@meyering.net>
parents: 2813
diff changeset
283 char *object_base;
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
284
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
285 /* Compute size for new chunk. */
2915
5690d50326cb Update from libc.
Jim Meyering <jim@meyering.net>
parents: 2813
diff changeset
286 new_size = (obj_size + length) + (obj_size >> 3) + h->alignment_mask + 100;
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
287 if (new_size < h->chunk_size)
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
288 new_size = h->chunk_size;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
289
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
290 /* Allocate and initialize the new chunk. */
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
291 new_chunk = CALL_CHUNKFUN (h, new_size);
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
292 if (!new_chunk)
881
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
293 (*obstack_alloc_failed_handler) ();
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
294 h->chunk = new_chunk;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
295 new_chunk->prev = old_chunk;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
296 new_chunk->limit = h->chunk_limit = (char *) new_chunk + new_size;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
297
2915
5690d50326cb Update from libc.
Jim Meyering <jim@meyering.net>
parents: 2813
diff changeset
298 /* Compute an aligned object_base in the new chunk */
5690d50326cb Update from libc.
Jim Meyering <jim@meyering.net>
parents: 2813
diff changeset
299 object_base =
5690d50326cb Update from libc.
Jim Meyering <jim@meyering.net>
parents: 2813
diff changeset
300 __INT_TO_PTR ((__PTR_TO_INT (new_chunk->contents) + h->alignment_mask)
5690d50326cb Update from libc.
Jim Meyering <jim@meyering.net>
parents: 2813
diff changeset
301 & ~ (h->alignment_mask));
5690d50326cb Update from libc.
Jim Meyering <jim@meyering.net>
parents: 2813
diff changeset
302
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
303 /* Move the existing object to the new chunk.
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
304 Word at a time is fast and is safe if the object
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
305 is sufficiently aligned. */
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
306 if (h->alignment_mask + 1 >= DEFAULT_ALIGNMENT)
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
307 {
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
308 for (i = obj_size / sizeof (COPYING_UNIT) - 1;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
309 i >= 0; i--)
2915
5690d50326cb Update from libc.
Jim Meyering <jim@meyering.net>
parents: 2813
diff changeset
310 ((COPYING_UNIT *)object_base)[i]
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
311 = ((COPYING_UNIT *)h->object_base)[i];
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
312 /* We used to copy the odd few remaining bytes as one extra COPYING_UNIT,
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
313 but that can cross a page boundary on a machine
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
314 which does not do strict alignment for COPYING_UNITS. */
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
315 already = obj_size / sizeof (COPYING_UNIT) * sizeof (COPYING_UNIT);
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
316 }
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
317 else
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
318 already = 0;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
319 /* Copy remaining bytes one by one. */
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
320 for (i = already; i < obj_size; i++)
2915
5690d50326cb Update from libc.
Jim Meyering <jim@meyering.net>
parents: 2813
diff changeset
321 object_base[i] = h->object_base[i];
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
322
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
323 /* If the object just copied was the only data in OLD_CHUNK,
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
324 free that chunk and remove it from the chain.
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
325 But not if that chunk might contain an empty object. */
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
326 if (h->object_base == old_chunk->contents && ! h->maybe_empty_object)
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
327 {
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
328 new_chunk->prev = old_chunk->prev;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
329 CALL_FREEFUN (h, old_chunk);
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
330 }
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
331
2915
5690d50326cb Update from libc.
Jim Meyering <jim@meyering.net>
parents: 2813
diff changeset
332 h->object_base = object_base;
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
333 h->next_free = h->object_base + obj_size;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
334 /* The new chunk certainly contains no empty object yet. */
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
335 h->maybe_empty_object = 0;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
336 }
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
337
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
338 /* Return nonzero if object OBJ has been allocated from obstack H.
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
339 This is here for debugging.
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
340 If you use it in a program, you are probably losing. */
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
341
3362
cb3db42cafb9 update from libc
Jim Meyering <jim@meyering.net>
parents: 3361
diff changeset
342 # if defined __STDC__ && __STDC__
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
343 /* Suppress -Wmissing-prototypes warning. We don't want to declare this in
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
344 obstack.h because it is just for debugging. */
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
345 int _obstack_allocated_p (struct obstack *h, POINTER obj);
2475
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
346 # endif
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
347
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
348 int
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
349 _obstack_allocated_p (h, obj)
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
350 struct obstack *h;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
351 POINTER obj;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
352 {
881
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
353 register struct _obstack_chunk *lp; /* below addr of any objects in this chunk */
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
354 register struct _obstack_chunk *plp; /* point to previous chunk if any */
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
355
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
356 lp = (h)->chunk;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
357 /* We use >= rather than > since the object cannot be exactly at
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
358 the beginning of the chunk but might be an empty object exactly
881
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
359 at the end of an adjacent chunk. */
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
360 while (lp != 0 && ((POINTER) lp >= obj || (POINTER) (lp)->limit < obj))
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
361 {
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
362 plp = lp->prev;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
363 lp = plp;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
364 }
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
365 return lp != 0;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
366 }
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
367
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
368 /* Free objects in obstack H, including OBJ and everything allocate
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
369 more recently than OBJ. If OBJ is zero, free everything in H. */
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
370
2475
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
371 # undef obstack_free
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
372
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
373 /* This function has two names with identical definitions.
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
374 This is the first one, called from non-ANSI code. */
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
375
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
376 void
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
377 _obstack_free (h, obj)
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
378 struct obstack *h;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
379 POINTER obj;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
380 {
881
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
381 register struct _obstack_chunk *lp; /* below addr of any objects in this chunk */
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
382 register struct _obstack_chunk *plp; /* point to previous chunk if any */
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
383
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
384 lp = h->chunk;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
385 /* We use >= because there cannot be an object at the beginning of a chunk.
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
386 But there can be an empty object at that address
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
387 at the end of another chunk. */
881
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
388 while (lp != 0 && ((POINTER) lp >= obj || (POINTER) (lp)->limit < obj))
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
389 {
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
390 plp = lp->prev;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
391 CALL_FREEFUN (h, lp);
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
392 lp = plp;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
393 /* If we switch chunks, we can't tell whether the new current
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
394 chunk contains an empty object, so assume that it may. */
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
395 h->maybe_empty_object = 1;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
396 }
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
397 if (lp)
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
398 {
881
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
399 h->object_base = h->next_free = (char *) (obj);
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
400 h->chunk_limit = lp->limit;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
401 h->chunk = lp;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
402 }
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
403 else if (obj != 0)
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
404 /* obj is not in any of the chunks! */
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
405 abort ();
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
406 }
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
407
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
408 /* This function is used from ANSI code. */
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
409
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
410 void
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
411 obstack_free (h, obj)
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
412 struct obstack *h;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
413 POINTER obj;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
414 {
881
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
415 register struct _obstack_chunk *lp; /* below addr of any objects in this chunk */
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
416 register struct _obstack_chunk *plp; /* point to previous chunk if any */
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
417
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
418 lp = h->chunk;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
419 /* We use >= because there cannot be an object at the beginning of a chunk.
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
420 But there can be an empty object at that address
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
421 at the end of another chunk. */
881
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
422 while (lp != 0 && ((POINTER) lp >= obj || (POINTER) (lp)->limit < obj))
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
423 {
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
424 plp = lp->prev;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
425 CALL_FREEFUN (h, lp);
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
426 lp = plp;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
427 /* If we switch chunks, we can't tell whether the new current
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
428 chunk contains an empty object, so assume that it may. */
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
429 h->maybe_empty_object = 1;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
430 }
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
431 if (lp)
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
432 {
881
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
433 h->object_base = h->next_free = (char *) (obj);
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
434 h->chunk_limit = lp->limit;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
435 h->chunk = lp;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
436 }
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
437 else if (obj != 0)
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
438 /* obj is not in any of the chunks! */
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
439 abort ();
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
440 }
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
441
881
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
442 int
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
443 _obstack_memory_used (h)
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
444 struct obstack *h;
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
445 {
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
446 register struct _obstack_chunk* lp;
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
447 register int nbytes = 0;
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
448
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
449 for (lp = h->chunk; lp != 0; lp = lp->prev)
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
450 {
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
451 nbytes += lp->limit - (char *) lp;
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
452 }
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
453 return nbytes;
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
454 }
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
455
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
456 /* Define the error handler. */
3966
22d3032f0239 Include gettext.h instead of <libintl.h> with #ifdefs.
Bruno Haible <bruno@clisp.org>
parents: 3552
diff changeset
457 # ifdef _LIBC
22d3032f0239 Include gettext.h instead of <libintl.h> with #ifdefs.
Bruno Haible <bruno@clisp.org>
parents: 3552
diff changeset
458 # include <libintl.h>
22d3032f0239 Include gettext.h instead of <libintl.h> with #ifdefs.
Bruno Haible <bruno@clisp.org>
parents: 3552
diff changeset
459 # else
22d3032f0239 Include gettext.h instead of <libintl.h> with #ifdefs.
Bruno Haible <bruno@clisp.org>
parents: 3552
diff changeset
460 # include "gettext.h"
881
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
461 # endif
3966
22d3032f0239 Include gettext.h instead of <libintl.h> with #ifdefs.
Bruno Haible <bruno@clisp.org>
parents: 3552
diff changeset
462 # define _(msgid) gettext (msgid)
22d3032f0239 Include gettext.h instead of <libintl.h> with #ifdefs.
Bruno Haible <bruno@clisp.org>
parents: 3552
diff changeset
463
2475
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
464 # if defined _LIBC && defined USE_IN_LIBIO
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
465 # include <libio/iolibio.h>
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
466 # define fputs(s, f) _IO_fputs (s, f)
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
467 # endif
881
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
468
3361
9594c5ad3ab8 update from glibc
Jim Meyering <jim@meyering.net>
parents: 3293
diff changeset
469 # ifndef __attribute__
3293
a3e558e29878 (__attribute__): Define it to be empty for compilers
Jim Meyering <jim@meyering.net>
parents: 3280
diff changeset
470 /* This feature is available in gcc versions 2.5 and later. */
3361
9594c5ad3ab8 update from glibc
Jim Meyering <jim@meyering.net>
parents: 3293
diff changeset
471 # if __GNUC__ < 2 || (__GNUC__ == 2 && __GNUC_MINOR__ < 5)
9594c5ad3ab8 update from glibc
Jim Meyering <jim@meyering.net>
parents: 3293
diff changeset
472 # define __attribute__(Spec) /* empty */
9594c5ad3ab8 update from glibc
Jim Meyering <jim@meyering.net>
parents: 3293
diff changeset
473 # endif
3293
a3e558e29878 (__attribute__): Define it to be empty for compilers
Jim Meyering <jim@meyering.net>
parents: 3280
diff changeset
474 # endif
a3e558e29878 (__attribute__): Define it to be empty for compilers
Jim Meyering <jim@meyering.net>
parents: 3280
diff changeset
475
881
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
476 static void
3280
7fed086612ed update from libc
Jim Meyering <jim@meyering.net>
parents: 2979
diff changeset
477 __attribute__ ((noreturn))
881
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
478 print_and_abort ()
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
479 {
3361
9594c5ad3ab8 update from glibc
Jim Meyering <jim@meyering.net>
parents: 3293
diff changeset
480 /* Don't change any of these strings. Yes, it would be possible to add
9594c5ad3ab8 update from glibc
Jim Meyering <jim@meyering.net>
parents: 3293
diff changeset
481 the newline to the string and use fputs or so. But this must not
9594c5ad3ab8 update from glibc
Jim Meyering <jim@meyering.net>
parents: 3293
diff changeset
482 happen because the "memory exhausted" message appears in other places
9594c5ad3ab8 update from glibc
Jim Meyering <jim@meyering.net>
parents: 3293
diff changeset
483 like this and the translation should be reused instead of creating
9594c5ad3ab8 update from glibc
Jim Meyering <jim@meyering.net>
parents: 3293
diff changeset
484 a very similar string which requires a separate translation. */
9594c5ad3ab8 update from glibc
Jim Meyering <jim@meyering.net>
parents: 3293
diff changeset
485 # if defined _LIBC && defined USE_IN_LIBIO
9594c5ad3ab8 update from glibc
Jim Meyering <jim@meyering.net>
parents: 3293
diff changeset
486 if (_IO_fwide (stderr, 0) > 0)
9594c5ad3ab8 update from glibc
Jim Meyering <jim@meyering.net>
parents: 3293
diff changeset
487 __fwprintf (stderr, L"%s\n", _("memory exhausted"));
9594c5ad3ab8 update from glibc
Jim Meyering <jim@meyering.net>
parents: 3293
diff changeset
488 else
9594c5ad3ab8 update from glibc
Jim Meyering <jim@meyering.net>
parents: 3293
diff changeset
489 # endif
9594c5ad3ab8 update from glibc
Jim Meyering <jim@meyering.net>
parents: 3293
diff changeset
490 fprintf (stderr, "%s\n", _("memory exhausted"));
881
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
491 exit (obstack_exit_failure);
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
492 }
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
493
2475
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
494 # if 0
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
495 /* These are now turned off because the applications do not use it
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
496 and it uses bcopy via obstack_grow, which causes trouble on sysV. */
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
497
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
498 /* Now define the functional versions of the obstack macros.
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
499 Define them to simply use the corresponding macros to do the job. */
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
500
3361
9594c5ad3ab8 update from glibc
Jim Meyering <jim@meyering.net>
parents: 3293
diff changeset
501 # if defined __STDC__ && __STDC__
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
502 /* These function definitions do not work with non-ANSI preprocessors;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
503 they won't pass through the macro names in parentheses. */
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
504
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
505 /* The function names appear in parentheses in order to prevent
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
506 the macro-definitions of the names from being expanded there. */
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
507
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
508 POINTER (obstack_base) (obstack)
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
509 struct obstack *obstack;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
510 {
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
511 return obstack_base (obstack);
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
512 }
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
513
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
514 POINTER (obstack_next_free) (obstack)
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
515 struct obstack *obstack;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
516 {
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
517 return obstack_next_free (obstack);
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
518 }
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
519
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
520 int (obstack_object_size) (obstack)
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
521 struct obstack *obstack;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
522 {
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
523 return obstack_object_size (obstack);
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
524 }
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
525
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
526 int (obstack_room) (obstack)
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
527 struct obstack *obstack;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
528 {
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
529 return obstack_room (obstack);
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
530 }
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
531
881
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
532 int (obstack_make_room) (obstack, length)
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
533 struct obstack *obstack;
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
534 int length;
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
535 {
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
536 return obstack_make_room (obstack, length);
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
537 }
bdd51dfe45e2 new obstack from libc
Jim Meyering <jim@meyering.net>
parents: 779
diff changeset
538
2979
9c55c384b97b Update from GNU libc.
Jim Meyering <jim@meyering.net>
parents: 2916
diff changeset
539 void (obstack_grow) (obstack, data, length)
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
540 struct obstack *obstack;
2979
9c55c384b97b Update from GNU libc.
Jim Meyering <jim@meyering.net>
parents: 2916
diff changeset
541 const POINTER data;
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
542 int length;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
543 {
2979
9c55c384b97b Update from GNU libc.
Jim Meyering <jim@meyering.net>
parents: 2916
diff changeset
544 obstack_grow (obstack, data, length);
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
545 }
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
546
2979
9c55c384b97b Update from GNU libc.
Jim Meyering <jim@meyering.net>
parents: 2916
diff changeset
547 void (obstack_grow0) (obstack, data, length)
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
548 struct obstack *obstack;
2979
9c55c384b97b Update from GNU libc.
Jim Meyering <jim@meyering.net>
parents: 2916
diff changeset
549 const POINTER data;
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
550 int length;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
551 {
2979
9c55c384b97b Update from GNU libc.
Jim Meyering <jim@meyering.net>
parents: 2916
diff changeset
552 obstack_grow0 (obstack, data, length);
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
553 }
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
554
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
555 void (obstack_1grow) (obstack, character)
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
556 struct obstack *obstack;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
557 int character;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
558 {
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
559 obstack_1grow (obstack, character);
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
560 }
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
561
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
562 void (obstack_blank) (obstack, length)
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
563 struct obstack *obstack;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
564 int length;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
565 {
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
566 obstack_blank (obstack, length);
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
567 }
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
568
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
569 void (obstack_1grow_fast) (obstack, character)
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
570 struct obstack *obstack;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
571 int character;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
572 {
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
573 obstack_1grow_fast (obstack, character);
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
574 }
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
575
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
576 void (obstack_blank_fast) (obstack, length)
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
577 struct obstack *obstack;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
578 int length;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
579 {
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
580 obstack_blank_fast (obstack, length);
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
581 }
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
582
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
583 POINTER (obstack_finish) (obstack)
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
584 struct obstack *obstack;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
585 {
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
586 return obstack_finish (obstack);
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
587 }
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
588
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
589 POINTER (obstack_alloc) (obstack, length)
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
590 struct obstack *obstack;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
591 int length;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
592 {
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
593 return obstack_alloc (obstack, length);
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
594 }
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
595
2979
9c55c384b97b Update from GNU libc.
Jim Meyering <jim@meyering.net>
parents: 2916
diff changeset
596 POINTER (obstack_copy) (obstack, address, length)
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
597 struct obstack *obstack;
2979
9c55c384b97b Update from GNU libc.
Jim Meyering <jim@meyering.net>
parents: 2916
diff changeset
598 const POINTER address;
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
599 int length;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
600 {
2979
9c55c384b97b Update from GNU libc.
Jim Meyering <jim@meyering.net>
parents: 2916
diff changeset
601 return obstack_copy (obstack, address, length);
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
602 }
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
603
2979
9c55c384b97b Update from GNU libc.
Jim Meyering <jim@meyering.net>
parents: 2916
diff changeset
604 POINTER (obstack_copy0) (obstack, address, length)
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
605 struct obstack *obstack;
2979
9c55c384b97b Update from GNU libc.
Jim Meyering <jim@meyering.net>
parents: 2916
diff changeset
606 const POINTER address;
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
607 int length;
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
608 {
2979
9c55c384b97b Update from GNU libc.
Jim Meyering <jim@meyering.net>
parents: 2916
diff changeset
609 return obstack_copy0 (obstack, address, length);
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
610 }
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
611
2475
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
612 # endif /* __STDC__ */
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
613
2475
a76f490708a7 filter through cppi
Jim Meyering <jim@meyering.net>
parents: 995
diff changeset
614 # endif /* 0 */
334
0f8efd187be0 Initial revision
Jim Meyering <jim@meyering.net>
parents:
diff changeset
615
779
d183d24934d4 from franc,ois
Jim Meyering <jim@meyering.net>
parents: 650
diff changeset
616 #endif /* !ELIDE_CODE */