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 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166
|
/* stmem.c - memory allocation routines. */
/* XLISP-STAT 2.1 Copyright (c) 1990, by Luke Tierney */
/* Additions to Xlisp 2.1, Copyright (c) 1989 by David Michael Betz */
/* You may give out copies of this software; for conditions see the */
/* file COPYING included with this distribution. */
#include "xlisp.h"
#include "xlstat.h"
#ifndef ANSI
extern ALLOCTYPE *calloc(), *realloc();
#endif
/**************************************************************************/
/** **/
/** Error Message and Memory Allocation Functions **/
/** **/
/**************************************************************************/
ALLOCTYPE *StCalloc P2C(int, n, int, m)
{
ALLOCTYPE *val;
if ((val = calloc(n, m)) == NULL) {
gc();
if ((val = calloc(n, m)) == NULL)
xlfail("allocation failed");
}
return(val);
}
VOID StFree P1C(ALLOCTYPE *, p)
{
if (p != NULL) free(p);
}
/**************************************************************************/
/** **/
/** Reallocatable Data Pointer Package **/
/** **/
/** (This is needed on the Mac because the realloc function does not **/
/** work and also to help reduce heap fragmentation.) **/
/** **/
/**************************************************************************/
#ifdef MACINTOSH
typedef ALLOCTYPE **StReallocData;
#else
typedef struct{
int size;
ALLOCTYPE *data;
} realloc_data, *StReallocData;
#endif /* MACINTOSH */
ALLOCTYPE *StRCalloc P2C(int, n, int, m)
{
#ifdef MACINTOSH
Handle h;
long size;
char *p;
size = ((long) n) * ((long) m);
if ((h = NewHandle(size)) == NULL || MemError()) {
gc();
if ((h = NewHandle(size)) == NULL || MemError())
xlfail("Allocation Failed");
}
for (p = (char *) *h; size > 0; *p++ = 0, size--);
return ((ALLOCTYPE *) h);
#else
StReallocData r;
r = (StReallocData) StCalloc(sizeof(realloc_data), 1);
r->size = n * m;
r->data = StCalloc(r->size, 1);
return((ALLOCTYPE *) r);
#endif /* MACINTOSH */
}
VOID StRFree P1C(ALLOCTYPE *, p)
{
StReallocData d = (StReallocData) p;
#ifdef MACINTOSH
if (d != NULL) DisposeHandle((Handle) d);
#else
if (d != NULL) {
StFree(d->data);
StFree(d);
}
#endif /* MACINTOSH */
}
ALLOCTYPE *StRRealloc P3C(ALLOCTYPE *, q, int, n, int, m)
{
StReallocData d = (StReallocData) q;
#ifdef MACINTOSH
long oldSize, newSize, i;
char *p;
oldSize = (d != NULL) ? GetHandleSize((Handle) d) : 0;
newSize = (long) n * (long) m;
if (d == NULL) d = (StReallocData) NewHandle(newSize);
else SetHandleSize((Handle) d, newSize);
if (d == NULL || MemError()) xlfail("Allocation Failed");
for (p = (char *) *d, i = oldSize; i < newSize; p[i] = 0, i++);
return ((ALLOCTYPE *) d);
#else
int oldsize, size;
if (d == NULL) {
d = (StReallocData) StRCalloc(n, m);
if (d == NULL) xlfail("Allocation Failed");
}
else {
size = n * m;
d->data = realloc(d->data, size);
if (d->data == NULL) xlfail("Allocation Failed");
oldsize = d->size;
d->size = size;
if (size > oldsize) {
MEMSET((char *)d->data + oldsize, 0, size - oldsize);
}
}
return((ALLOCTYPE *) d);
#endif /* MACINTOSH */
}
long StRSize P1C(ALLOCTYPE *, p)
{
StReallocData d = (StReallocData) p;
#ifdef MACINTOSH
return ((d != NULL) ? GetHandleSize((Handle) d) : 0L);
#else
return((d != NULL) ? d->size : 0);
#endif /* MACINTOSH */
}
ALLOCTYPE *StRPtr P1C(ALLOCTYPE *, p)
{
StReallocData d = (StReallocData) p;
#ifdef MACINTOSH
return ((d != NULL) ? (ALLOCTYPE *) *d : NULL);
#else
if (d != NULL && d->data == NULL) xlfail("bad relocatable data");
return((d != NULL) ? d->data : NULL);
#endif /* MACINTOSH */
}
VOID StRLock P1C(ALLOCTYPE *, p)
{
#ifdef MACINTOSH
HLock((Handle) p);
#endif /* MACINTOSH */
}
VOID StRUnlock P1C(ALLOCTYPE *, p)
{
#ifdef MACINTOSH
HUnlock((Handle) p);
#endif /* MACINTOSH */
}
|