Fix copyright date.
[become] / src / utils.h
CommitLineData
c4f2d992 1/* -*-c-*-
2 *
c758e654 3 * $Id: utils.h,v 1.4 1998/01/12 16:46:52 mdw Exp $
c4f2d992 4 *
5 * Miscellaneous useful bits of code.
6 *
c758e654 7 * (c) 1998 Mark Wooding
c4f2d992 8 */
9
03f996bd 10/*----- Licensing notice --------------------------------------------------*
c4f2d992 11 *
12 * This file is part of `become'
13 *
14 * `Become' is free software; you can redistribute it and/or modify
15 * it under the terms of the GNU General Public License as published by
16 * the Free Software Foundation; either version 2 of the License, or
17 * (at your option) any later version.
18 *
19 * `Become' is distributed in the hope that it will be useful,
20 * but WITHOUT ANY WARRANTY; without even the implied warranty of
21 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
22 * GNU General Public License for more details.
23 *
24 * You should have received a copy of the GNU General Public License
03f996bd 25 * along with `become'; if not, write to the Free Software Foundation,
26 * Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
c4f2d992 27 */
28
29/*----- Revision history --------------------------------------------------*
30 *
31 * $Log: utils.h,v $
c758e654 32 * Revision 1.4 1998/01/12 16:46:52 mdw
33 * Fix copyright date.
34 *
35 * Revision 1.3 1997/08/20 16:25:37 mdw
deab2ee8 36 * Add some simple `malloc' tracking.
37 *
03f996bd 38 * Revision 1.2 1997/08/04 10:24:26 mdw
39 * Sources placed under CVS control.
40 *
41 * Revision 1.1 1997/07/21 13:47:42 mdw
c4f2d992 42 * Initial revision
43 *
44 */
45
46#ifndef UTILS_H
47#define UTILS_H
48
49#ifdef __cplusplus
50 extern "C" {
51#endif
52
53/*----- Required header files ---------------------------------------------*/
54
55#include <stddef.h>
56#include <stdlib.h>
57
58/*----- Storing and retrieving numbers ------------------------------------*
59 *
60 * These use big-endian conventions, because they seem more usual in network
61 * applications. I actually think that little-endian is more sensible...
62 */
63
64#define load32(p) \
65 ((((unsigned char)(p)[0] & 0xFF) << 24) | \
66 (((unsigned char)(p)[1] & 0xFF) << 16) | \
67 (((unsigned char)(p)[2] & 0xFF) << 8) | \
68 (((unsigned char)(p)[3] & 0xFF) << 0))
69
70#define store32(p, v) \
71 ((p)[0] = ((unsigned long)(v) >> 24) & 0xFF, \
72 (p)[1] = ((unsigned long)(v) >> 16) & 0xFF, \
73 (p)[2] = ((unsigned long)(v) >> 8) & 0xFF, \
74 (p)[3] = ((unsigned long)(v) >> 0) & 0xFF)
75
76/* --- Little-endian versions (for MD5) --- */
77
78#define load32_l(p) \
79 ((((unsigned char)(p)[0] & 0xFF) << 0) | \
80 (((unsigned char)(p)[1] & 0xFF) << 8) | \
81 (((unsigned char)(p)[2] & 0xFF) << 16) | \
82 (((unsigned char)(p)[3] & 0xFF) << 24))
83
84#define store32_l(p, v) \
85 ((p)[0] = ((unsigned long)(v) >> 0) & 0xFF, \
86 (p)[1] = ((unsigned long)(v) >> 8) & 0xFF, \
87 (p)[2] = ((unsigned long)(v) >> 16) & 0xFF, \
88 (p)[3] = ((unsigned long)(v) >> 24) & 0xFF)
89
03f996bd 90/*----- Other macros ------------------------------------------------------*/
91
92/* --- @burn@ --- *
93 *
94 * Arguments: @obj@ = some object
95 *
96 * Use: Writes zero bytes over the object.
97 */
98
99#define burn(obj) ((void)memset(&obj, 0, sizeof(obj)))
100
c4f2d992 101/*----- Program name handling ---------------------------------------------*/
102
103/* --- @quis@ --- *
104 *
105 * Arguments: ---
106 *
107 * Returns: Pointer to the program name.
108 *
109 * Use: Returns the program name.
110 */
111
112extern const char *quis(void);
113
114/* --- @ego@ --- *
115 *
116 * Arguments: @const char *p@ = pointer to program name
117 *
118 * Returns: ---
119 *
120 * Use: Tells the utils library what the program's name is.
121 */
122
123extern void ego(const char */*p*/);
124
125/*----- Error reporting ---------------------------------------------------*/
126
127/* --- @moan@ --- *
128 *
129 * Arguments: @const char *f@ = a @printf@-style format string
130 * @...@ = other arguments
131 *
132 * Returns: ---
133 *
134 * Use: Reports an error.
135 */
136
137extern void moan(const char */*f*/, ...);
138
139/* --- @die@ --- *
140 *
141 * Arguments: @const char *f@ = a @printf@-style format string
142 * @...@ = other arguments
143 *
144 * Returns: Never.
145 *
146 * Use: Reports an error and hari-kiris. Like @moan@ above, only
147 * more permanent.
148 */
149
150extern void die(const char */*f*/, ...);
151
03f996bd 152/*----- Trace messages ----------------------------------------------------*/
153
154#if !defined(NDEBUG) && !defined(TRACING)
155# define TRACING
156#endif
157
158#ifdef TRACING
159
160/* --- @trace@ --- *
161 *
162 * Arguments: @unsigned int lvl@ = trace level for output
163 * @const char *f@ = a @printf@-style format string
164 * @...@ = other arguments
165 *
166 * Returns: ---
167 *
168 * Use: Reports a message to the trace output.
169 */
170
171extern void trace(unsigned int /*lvl*/, const char */*f*/, ...);
172
173/* --- @traceblk@ --- *
174 *
175 * Arguments: @unsigned int lvl@ = trace level for output
176 * @const char *hdr@ = some header string to write
177 * @const void *blk@ = pointer to a block of memory to dump
178 * @size_t sz@ = size of the block of memory
179 *
180 * Returns: ---
181 *
182 * Use: Dumps the contents of a block to the trace output.
183 */
184
185extern void traceblk(unsigned int /*lvl*/, const char */*hdr*/,
186 const void */*blk*/, size_t /*sz*/);
187
188/* --- @traceon@ --- *
189 *
190 * Arguments: @FILE *fp@ = a file to trace on
191 * @unsigned int lvl@ = trace level to set
192 *
193 * Returns: ---
194 *
195 * Use: Enables tracing to a file.
196 */
197
198extern void traceon(FILE */*fp*/, unsigned int /*lvl*/);
199
200/* --- @tracesetlvl@ --- *
201 *
202 * Arguments: @unsigned int lvl@ = trace level to set
203 *
204 * Returns: ---
205 *
206 * Use: Sets the tracing level.
207 */
208
209extern void tracesetlvl(unsigned int /*lvl*/);
210
211/* --- @tracing@ --- *
212 *
213 * Arguments: ---
214 *
215 * Returns: Zero if not tracing, tracing level if tracing.
216 *
217 * Use: Informs the caller whether tracing is enabled.
218 */
219
220extern unsigned int tracing(void);
221
222#endif
223
224/* --- Some hacky macros --- */
225
226#ifdef TRACING
227# define T(x) x
228# define IF_TRACING(lvl, x) if ((lvl) & tracing()) x
229#else
230# define T(x)
231# define IF_TRACING(lvl, x)
232#endif
233
c4f2d992 234/*----- Memory management functions ---------------------------------------*/
235
236/* --- @xmalloc@ --- *
237 *
238 * Arguments: @size_t sz@ = size of block to allocate
239 *
240 * Returns: Pointer to allocated block.
241 *
242 * Use: Allocates memory. If the memory isn't available, we don't
243 * hang aroung long enough for a normal function return.
244 */
245
246extern void *xmalloc(size_t /*sz*/);
247
248/* --- @xstrdup@ --- *
249 *
250 * Arguments: @const char *s@ = pointer to a string
251 *
252 * Returns: Pointer to a copy of the string.
253 *
254 * Use: Copies a string (like @strdup@ would, if it existed).
255 */
256
257extern char *xstrdup(const char */*s*/);
258
259/* --- @xrealloc@ --- *
260 *
261 * Arguments: @void *p@ = pointer to a block of memory
262 * @size_t sz@ = new size desired for the block
263 *
264 * Returns: Pointer to the resized memory block (which is almost
265 * certainly not in the same place any more).
266 *
267 * Use: Resizes a memory block.
268 */
269
270extern void *xrealloc(void */*p*/, size_t /*sz*/);
271
deab2ee8 272/*----- Simple memory use tracking ----------------------------------------*/
273
274#undef TRACK_MALLOC
275
276#ifdef TRACK_MALLOC
277
278/* --- @track_malloc@ --- *
279 *
280 * Arguments: @size_t sz@ = size requested
281 *
282 * Returns: Pointer to allocated space, or null
283 *
284 * Use: Allocates memory, and tracks how much is allocated.
285 */
286
287extern void *track_malloc(size_t /*sz*/);
288
289/* --- @track_free@ --- *
290 *
291 * Arguments: @void *p@ = pointer to an allocated block
292 *
293 * Returns: ---
294 *
295 * Use: Frees memory, and tracks how much is still allocated.
296 */
297
298extern void track_free(void */*p*/);
299
300/* --- @track_realloc@ --- *
301 *
302 * Arguments: @void *p@ = pointer to an allocated block
303 * @size_t sz@ = how big it wants to be
304 *
305 * Returns: Pointer to the new block.
306 *
307 * Use: Reallocates a block, tracking how much memory is still
308 * available.
309 */
310
311extern void *track_realloc(void */*p*/, size_t /*sz*/);
312
313/* --- @track_memused@ --- *
314 *
315 * Arguments: ---
316 *
317 * Returns: A count of how much memory is used currently.
318 *
319 * Use: Returns the amount of memory which the @track_@-functions
320 * above have counted as being currently allocated.
321 */
322
323extern unsigned long track_memused(void);
324
325/* --- @track_memlist@ --- *
326 *
327 * Arguments: ---
328 *
329 * Returns: ---
330 *
331 * Use: Dumps a list of allocated blocks to standard output.
332 */
333
334extern void track_memlist(void);
335
336#undef malloc
337#define malloc(sz) track_malloc(sz)
338
339#undef free
340#define free(p) track_free(p)
341
342#undef realloc
343#define realloc(p, sz) track_realloc(p, sz)
344
345#endif
346
c4f2d992 347/*----- That's all, folks -------------------------------------------------*/
348
349#ifdef __cplusplus
350 }
351#endif
352
353#endif