blob: 26ef10f217778a6426363029d5d4b55cacd2cd12 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
|
/*
* This file is part of libdyn.a, the C Dynamic Object library. It
* contains the private header file.
*
* There are no restrictions on this code; however, if you make any
* changes, I request that you document them so that I do not get
* credit or blame for your modifications.
*
* Written by Barr3y Jaspan, Student Information Processing Board (SIPB)
* and MIT-Project Athena, 1989.
*/
/*
* dynP.h -- private header file included by source files for libdyn.a.
*/
#ifndef _DynP_h
#define _DynP_h
#include <sysdep.h>
#include <dyn.h>
/*
* Rep invariant:
* 1) el_size is the number of bytes per element in the object
* 2) num_el is the number of elements currently in the object. It is
* one higher than the highest index at which an element lives.
* 3) size is the number of elements the object can hold without
* resizing. num_el <= index.
* 4) inc is a multiple of the number of elements the object grows by
* each time it is reallocated.
*/
typedef struct _DynObject {
DynPtr array;
int el_size, num_el, size, inc;
char debug, paranoid;
} DynObjectRec;
/* Internal functions */
int _DynRealloc __P((DynObject obj, int num_incs));
#define _DynResize(obj, req) \
((obj)->size > (req) ? DYN_OK : \
(_DynRealloc((obj), (((req) - (obj)->size) / (obj)->inc) + 1)))
#endif /* _DynP_h */
/* DON'T ADD STUFF AFTER THIS #endif */
|