diff options
author | Guido van Rossum <guido@python.org> | 1992-08-19 16:46:30 (GMT) |
---|---|---|
committer | Guido van Rossum <guido@python.org> | 1992-08-19 16:46:30 (GMT) |
commit | 1e28e5e59634f56cdeaff528afb122a5735adf09 (patch) | |
tree | 2afa725a3a344c2350902947c30f59d1a22e00ff /Include | |
parent | b001f7adb16e054baa31213e4609b3be2138cade (diff) | |
download | cpython-1e28e5e59634f56cdeaff528afb122a5735adf09.zip cpython-1e28e5e59634f56cdeaff528afb122a5735adf09.tar.gz cpython-1e28e5e59634f56cdeaff528afb122a5735adf09.tar.bz2 |
* renamed malloc.h mymalloc.h, and added MALLARG as the type of the
argument to malloc() (size_t or unsigned int)
* listobject.c: check for overflow of the size of the object,
so things like range(0x7fffffff) will raise MemoryError instead
of calling malloc() with -4 (and then crashing -- malloc's fault)
Diffstat (limited to 'Include')
-rw-r--r-- | Include/allobjects.h | 2 | ||||
-rw-r--r-- | Include/mymalloc.h | 74 | ||||
-rw-r--r-- | Include/pgenheaders.h | 2 |
3 files changed, 76 insertions, 2 deletions
diff --git a/Include/allobjects.h b/Include/allobjects.h index 348f04e..dd78a83 100644 --- a/Include/allobjects.h +++ b/Include/allobjects.h @@ -50,7 +50,7 @@ OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. #include "fileobject.h" #include "errors.h" -#include "malloc.h" +#include "mymalloc.h" extern char *strdup PROTO((const char *)); extern void fatal PROTO((char *)); diff --git a/Include/mymalloc.h b/Include/mymalloc.h new file mode 100644 index 0000000..aadd0f3 --- /dev/null +++ b/Include/mymalloc.h @@ -0,0 +1,74 @@ +/*********************************************************** +Copyright 1991, 1992 by Stichting Mathematisch Centrum, Amsterdam, The +Netherlands. + + All Rights Reserved + +Permission to use, copy, modify, and distribute this software and its +documentation for any purpose and without fee is hereby granted, +provided that the above copyright notice appear in all copies and that +both that copyright notice and this permission notice appear in +supporting documentation, and that the names of Stichting Mathematisch +Centrum or CWI not be used in advertising or publicity pertaining to +distribution of the software without specific, written prior permission. + +STICHTING MATHEMATISCH CENTRUM DISCLAIMS ALL WARRANTIES WITH REGARD TO +THIS SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND +FITNESS, IN NO EVENT SHALL STICHTING MATHEMATISCH CENTRUM BE LIABLE +FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES +WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN +ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT +OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + +******************************************************************/ + +/* Lowest-level memory allocation interface */ + +#ifdef macintosh +#define ANY void +#ifndef THINK_C_3_0 +#define HAVE_STDLIB +#endif +#endif + +#ifdef sun +/* Maybe not for very old versions of SunOS ? */ +#define HAVE_STDLIB +#endif + +#ifdef sgi +#define HAVE_STDLIB +#endif + +#ifdef __STDC__ +#define ANY void +#define HAVE_STDLIB +#endif + +#ifndef ANY +#define ANY char +#endif + +#ifndef NULL +#define NULL 0 +#endif + +#define NEW(type, n) ( (type *) malloc((n) * sizeof(type)) ) +#define RESIZE(p, type, n) \ + if ((p) == NULL) \ + (p) = (type *) malloc((n) * sizeof(type)); \ + else \ + (p) = (type *) realloc((ANY *)(p), (n) * sizeof(type)) +#define DEL(p) free((ANY *)p) +#define XDEL(p) if ((p) == NULL) ; else DEL(p) + +#ifdef HAVE_STDLIB +#include <stdlib.h> +#define MALLARG size_t +#else +#define MALLARG size_t +extern ANY *malloc PROTO((MALLARG)); +extern ANY *calloc PROTO((MALLARG, MALLARG)); +extern ANY *realloc PROTO((ANY *, MALLARG)); +extern void free PROTO((ANY *)); /* XXX sometimes int on Unix old systems */ +#endif diff --git a/Include/pgenheaders.h b/Include/pgenheaders.h index 42319cd..8607142 100644 --- a/Include/pgenheaders.h +++ b/Include/pgenheaders.h @@ -49,6 +49,6 @@ OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. #endif #include "PROTO.h" -#include "malloc.h" +#include "mymalloc.h" extern void fatal PROTO((char *)); |