mirror of
https://github.com/python/cpython.git
synced 2025-07-24 19:54:21 +00:00
patch from Vladimir (move Py_Mem* interface to Include/pymem.h)
This commit is contained in:
parent
b88b0bce2a
commit
25f68944c2
10 changed files with 221 additions and 177 deletions
|
@ -54,6 +54,8 @@ redistribution of this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
|
|
||||||
#include "pyport.h"
|
#include "pyport.h"
|
||||||
|
|
||||||
|
#include "pymem.h"
|
||||||
|
|
||||||
#include "object.h"
|
#include "object.h"
|
||||||
#include "objimpl.h"
|
#include "objimpl.h"
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,3 @@
|
||||||
#ifndef Py_MYMALLOC_H
|
|
||||||
#define Py_MYMALLOC_H
|
|
||||||
/***********************************************************
|
/***********************************************************
|
||||||
Copyright (c) 2000, BeOpen.com.
|
Copyright (c) 2000, BeOpen.com.
|
||||||
Copyright (c) 1995-2000, Corporation for National Research Initiatives.
|
Copyright (c) 1995-2000, Corporation for National Research Initiatives.
|
||||||
|
@ -15,6 +13,9 @@ THIS FILE IS OBSOLETE
|
||||||
USE "pyport.h" INSTEAD
|
USE "pyport.h" INSTEAD
|
||||||
***************************************/
|
***************************************/
|
||||||
|
|
||||||
|
#ifndef Py_MYMALLOC_H
|
||||||
|
#define Py_MYMALLOC_H
|
||||||
|
|
||||||
/* Lowest-level memory allocation interface */
|
/* Lowest-level memory allocation interface */
|
||||||
|
|
||||||
#define ANY void /* For API compatibility only. Obsolete, do not use. */
|
#define ANY void /* For API compatibility only. Obsolete, do not use. */
|
||||||
|
|
|
@ -1,3 +1,13 @@
|
||||||
|
/***********************************************************
|
||||||
|
Copyright (c) 2000, BeOpen.com.
|
||||||
|
Copyright (c) 1995-2000, Corporation for National Research Initiatives.
|
||||||
|
Copyright (c) 1990-1995, Stichting Mathematisch Centrum.
|
||||||
|
All rights reserved.
|
||||||
|
|
||||||
|
See the file "Misc/COPYRIGHT" for information on usage and
|
||||||
|
redistribution of this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
|
******************************************************************/
|
||||||
|
|
||||||
/***************************************
|
/***************************************
|
||||||
THIS FILE IS OBSOLETE
|
THIS FILE IS OBSOLETE
|
||||||
USE "pyport.h" INSTEAD
|
USE "pyport.h" INSTEAD
|
||||||
|
|
|
@ -1,9 +1,3 @@
|
||||||
#ifndef Py_PROTO_H
|
|
||||||
#define Py_PROTO_H
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/***********************************************************
|
/***********************************************************
|
||||||
Copyright (c) 2000, BeOpen.com.
|
Copyright (c) 2000, BeOpen.com.
|
||||||
Copyright (c) 1995-2000, Corporation for National Research Initiatives.
|
Copyright (c) 1995-2000, Corporation for National Research Initiatives.
|
||||||
|
@ -19,6 +13,12 @@ THIS FILE IS OBSOLETE
|
||||||
DON'T USE Py_PROTO or Py_FPROTO anymore.
|
DON'T USE Py_PROTO or Py_FPROTO anymore.
|
||||||
***************************************/
|
***************************************/
|
||||||
|
|
||||||
|
#ifndef Py_PROTO_H
|
||||||
|
#define Py_PROTO_H
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef HAVE_PROTOTYPES
|
#ifdef HAVE_PROTOTYPES
|
||||||
#define Py_PROTO(x) x
|
#define Py_PROTO(x) x
|
||||||
#else
|
#else
|
||||||
|
|
|
@ -1,9 +1,3 @@
|
||||||
#ifndef Py_MYSELECT_H
|
|
||||||
#define Py_MYSELECT_H
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/***********************************************************
|
/***********************************************************
|
||||||
Copyright (c) 2000, BeOpen.com.
|
Copyright (c) 2000, BeOpen.com.
|
||||||
Copyright (c) 1995-2000, Corporation for National Research Initiatives.
|
Copyright (c) 1995-2000, Corporation for National Research Initiatives.
|
||||||
|
@ -19,6 +13,12 @@ THIS FILE IS OBSOLETE
|
||||||
USE "pyport.h" INSTEAD
|
USE "pyport.h" INSTEAD
|
||||||
***************************************/
|
***************************************/
|
||||||
|
|
||||||
|
#ifndef Py_MYSELECT_H
|
||||||
|
#define Py_MYSELECT_H
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Include file for users of select() */
|
/* Include file for users of select() */
|
||||||
|
|
||||||
/* NB caller must include <sys/types.h> */
|
/* NB caller must include <sys/types.h> */
|
||||||
|
|
|
@ -1,9 +1,3 @@
|
||||||
#ifndef Py_MYTIME_H
|
|
||||||
#define Py_MYTIME_H
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/***********************************************************
|
/***********************************************************
|
||||||
Copyright (c) 2000, BeOpen.com.
|
Copyright (c) 2000, BeOpen.com.
|
||||||
Copyright (c) 1995-2000, Corporation for National Research Initiatives.
|
Copyright (c) 1995-2000, Corporation for National Research Initiatives.
|
||||||
|
@ -19,6 +13,12 @@ THIS FILE IS OBSOLETE
|
||||||
USE "pyport.h" INSTEAD
|
USE "pyport.h" INSTEAD
|
||||||
***************************************/
|
***************************************/
|
||||||
|
|
||||||
|
#ifndef Py_MYTIME_H
|
||||||
|
#define Py_MYTIME_H
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Include file instead of <time.h> and/or <sys/time.h> */
|
/* Include file instead of <time.h> and/or <sys/time.h> */
|
||||||
|
|
||||||
#ifdef TIME_WITH_SYS_TIME
|
#ifdef TIME_WITH_SYS_TIME
|
||||||
|
|
|
@ -10,12 +10,13 @@ redistribution of this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
|
|
||||||
#ifndef Py_OBJIMPL_H
|
#ifndef Py_OBJIMPL_H
|
||||||
#define Py_OBJIMPL_H
|
#define Py_OBJIMPL_H
|
||||||
|
|
||||||
|
#include "pymem.h"
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include "pyport.h"
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
Functions and macros for modules that implement new object types.
|
Functions and macros for modules that implement new object types.
|
||||||
You must first include "object.h".
|
You must first include "object.h".
|
||||||
|
|
|
@ -30,7 +30,7 @@ redistribution of this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include "pyport.h"
|
#include "pymem.h"
|
||||||
|
|
||||||
#include "pydebug.h"
|
#include "pydebug.h"
|
||||||
|
|
||||||
|
|
179
Include/pymem.h
Normal file
179
Include/pymem.h
Normal file
|
@ -0,0 +1,179 @@
|
||||||
|
/***********************************************************
|
||||||
|
Copyright (c) 2000, BeOpen.com.
|
||||||
|
Copyright (c) 1995-2000, Corporation for National Research Initiatives.
|
||||||
|
Copyright (c) 1990-1995, Stichting Mathematisch Centrum.
|
||||||
|
All rights reserved.
|
||||||
|
|
||||||
|
See the file "Misc/COPYRIGHT" for information on usage and
|
||||||
|
redistribution of this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
|
******************************************************************/
|
||||||
|
|
||||||
|
/* Lowest-level memory allocation interface */
|
||||||
|
|
||||||
|
#ifndef Py_PYMEM_H
|
||||||
|
#define Py_PYMEM_H
|
||||||
|
|
||||||
|
#include "pyport.h"
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Core memory allocator
|
||||||
|
* =====================
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* To make sure the interpreter is user-malloc friendly, all memory
|
||||||
|
APIs are implemented on top of this one.
|
||||||
|
|
||||||
|
The PyCore_* macros can be defined to make the interpreter use a
|
||||||
|
custom allocator. Note that they are for internal use only. Both
|
||||||
|
the core and extension modules should use the PyMem_* API.
|
||||||
|
|
||||||
|
See the comment block at the end of this file for two scenarios
|
||||||
|
showing how to use this to use a different allocator. */
|
||||||
|
|
||||||
|
#ifndef PyCore_MALLOC_FUNC
|
||||||
|
#undef PyCore_REALLOC_FUNC
|
||||||
|
#undef PyCore_FREE_FUNC
|
||||||
|
#define PyCore_MALLOC_FUNC malloc
|
||||||
|
#define PyCore_REALLOC_FUNC realloc
|
||||||
|
#define PyCore_FREE_FUNC free
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef PyCore_MALLOC_PROTO
|
||||||
|
#undef PyCore_REALLOC_PROTO
|
||||||
|
#undef PyCore_FREE_PROTO
|
||||||
|
#define PyCore_MALLOC_PROTO (size_t)
|
||||||
|
#define PyCore_REALLOC_PROTO (void *, size_t)
|
||||||
|
#define PyCore_FREE_PROTO (void *)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef NEED_TO_DECLARE_MALLOC_AND_FRIEND
|
||||||
|
extern void *PyCore_MALLOC_FUNC PyCore_MALLOC_PROTO;
|
||||||
|
extern void *PyCore_REALLOC_FUNC PyCore_REALLOC_PROTO;
|
||||||
|
extern void PyCore_FREE_FUNC PyCore_FREE_PROTO;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef PyCore_MALLOC
|
||||||
|
#undef PyCore_REALLOC
|
||||||
|
#undef PyCore_FREE
|
||||||
|
#define PyCore_MALLOC(n) PyCore_MALLOC_FUNC(n)
|
||||||
|
#define PyCore_REALLOC(p, n) PyCore_REALLOC_FUNC((p), (n))
|
||||||
|
#define PyCore_FREE(p) PyCore_FREE_FUNC(p)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* BEWARE:
|
||||||
|
|
||||||
|
Each interface exports both functions and macros. Extension modules
|
||||||
|
should normally use the functions for ensuring binary compatibility
|
||||||
|
of the user's code across Python versions. Subsequently, if the
|
||||||
|
Python runtime switches to its own malloc (different from standard
|
||||||
|
malloc), no recompilation is required for the extensions.
|
||||||
|
|
||||||
|
The macro versions trade compatibility for speed. They can be used
|
||||||
|
whenever there is a performance problem, but their use implies
|
||||||
|
recompilation of the code for each new Python release. The Python
|
||||||
|
core uses the macros because it *is* compiled on every upgrade.
|
||||||
|
This might not be the case with 3rd party extensions in a custom
|
||||||
|
setup (for example, a customer does not always have access to the
|
||||||
|
source of 3rd party deliverables). You have been warned! */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Raw memory interface
|
||||||
|
* ====================
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Functions */
|
||||||
|
|
||||||
|
/* Function wrappers around PyCore_MALLOC and friends; useful if you
|
||||||
|
need to be sure that you are using the same memory allocator as
|
||||||
|
Python. Note that the wrappers make sure that allocating 0 bytes
|
||||||
|
returns a non-NULL pointer, even if the underlying malloc
|
||||||
|
doesn't. Returned pointers must be checked for NULL explicitly.
|
||||||
|
No action is performed on failure. */
|
||||||
|
extern DL_IMPORT(void *) PyMem_Malloc(size_t);
|
||||||
|
extern DL_IMPORT(void *) PyMem_Realloc(void *, size_t);
|
||||||
|
extern DL_IMPORT(void) PyMem_Free(void *);
|
||||||
|
|
||||||
|
/* Starting from Python 1.6, the wrappers Py_{Malloc,Realloc,Free} are
|
||||||
|
no longer supported. They used to call PyErr_NoMemory() on failure. */
|
||||||
|
|
||||||
|
/* Macros */
|
||||||
|
#define PyMem_MALLOC(n) PyCore_MALLOC(n)
|
||||||
|
#define PyMem_REALLOC(p, n) PyCore_REALLOC((void *)(p), (n))
|
||||||
|
#define PyMem_FREE(p) PyCore_FREE((void *)(p))
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Type-oriented memory interface
|
||||||
|
* ==============================
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Functions */
|
||||||
|
#define PyMem_New(type, n) \
|
||||||
|
( (type *) PyMem_Malloc((n) * sizeof(type)) )
|
||||||
|
#define PyMem_Resize(p, type, n) \
|
||||||
|
( (p) = (type *) PyMem_Realloc((n) * sizeof(type)) )
|
||||||
|
#define PyMem_Del(p) PyMem_Free(p)
|
||||||
|
|
||||||
|
/* Macros */
|
||||||
|
#define PyMem_NEW(type, n) \
|
||||||
|
( (type *) PyMem_MALLOC(_PyMem_EXTRA + (n) * sizeof(type)) )
|
||||||
|
#define PyMem_RESIZE(p, type, n) \
|
||||||
|
if ((p) == NULL) \
|
||||||
|
(p) = (type *)(PyMem_MALLOC( \
|
||||||
|
_PyMem_EXTRA + (n) * sizeof(type))); \
|
||||||
|
else \
|
||||||
|
(p) = (type *)(PyMem_REALLOC((p), \
|
||||||
|
_PyMem_EXTRA + (n) * sizeof(type)))
|
||||||
|
#define PyMem_DEL(p) PyMem_FREE(p)
|
||||||
|
|
||||||
|
/* PyMem_XDEL is deprecated. To avoid the call when p is NULL,
|
||||||
|
it is recommended to write the test explicitly in the code.
|
||||||
|
Note that according to ANSI C, free(NULL) has no effect. */
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* SCENARIOS
|
||||||
|
|
||||||
|
Here are two scenarios by Vladimir Marangozov (the author of the
|
||||||
|
memory allocation redesign).
|
||||||
|
|
||||||
|
1) Scenario A
|
||||||
|
|
||||||
|
Suppose you want to use a debugging malloc library that collects info on
|
||||||
|
where the malloc calls originate from. Assume the interface is:
|
||||||
|
|
||||||
|
d_malloc(size_t n, char* src_file, unsigned long src_line) c.s.
|
||||||
|
|
||||||
|
In this case, you would define (for example in config.h) :
|
||||||
|
|
||||||
|
#define PyCore_MALLOC_FUNC d_malloc
|
||||||
|
...
|
||||||
|
#define PyCore_MALLOC_PROTO (size_t, char *, unsigned long)
|
||||||
|
...
|
||||||
|
#define NEED_TO_DECLARE_MALLOC_AND_FRIEND
|
||||||
|
|
||||||
|
#define PyCore_MALLOC(n) PyCore_MALLOC_FUNC((n), __FILE__, __LINE__)
|
||||||
|
...
|
||||||
|
|
||||||
|
2) Scenario B
|
||||||
|
|
||||||
|
Suppose you want to use malloc hooks (defined & initialized in a 3rd party
|
||||||
|
malloc library) instead of malloc functions. In this case, you would
|
||||||
|
define:
|
||||||
|
|
||||||
|
#define PyCore_MALLOC_FUNC (*malloc_hook)
|
||||||
|
...
|
||||||
|
#define NEED_TO_DECLARE_MALLOC_AND_FRIEND
|
||||||
|
|
||||||
|
and ignore the previous definitions about PyCore_MALLOC_FUNC, etc.
|
||||||
|
|
||||||
|
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#endif /* !Py_PYMEM_H */
|
159
Include/pyport.h
159
Include/pyport.h
|
@ -9,6 +9,8 @@ redistribution of this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
#ifndef Py_PYPORT_H
|
#ifndef Py_PYPORT_H
|
||||||
#define Py_PYPORT_H
|
#define Py_PYPORT_H
|
||||||
|
|
||||||
|
#include "config.h" /* include for defines */
|
||||||
|
|
||||||
/**************************************************************************
|
/**************************************************************************
|
||||||
Symbols and macros to supply platform-independent interfaces to basic
|
Symbols and macros to supply platform-independent interfaces to basic
|
||||||
C language & library operations whose spellings vary across platforms.
|
C language & library operations whose spellings vary across platforms.
|
||||||
|
@ -220,9 +222,9 @@ extern double hypot(double, double);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/***********************************
|
/************************************
|
||||||
* WRAPPER FOR malloc/realloc/free *
|
* MALLOC COMPATIBILITY FOR pymem.h *
|
||||||
***********************************/
|
************************************/
|
||||||
|
|
||||||
#ifndef DL_IMPORT /* declarations for DLL import */
|
#ifndef DL_IMPORT /* declarations for DLL import */
|
||||||
#define DL_IMPORT(RTYPE) RTYPE
|
#define DL_IMPORT(RTYPE) RTYPE
|
||||||
|
@ -240,157 +242,6 @@ extern double hypot(double, double);
|
||||||
#define _PyMem_EXTRA 0
|
#define _PyMem_EXTRA 0
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/*
|
|
||||||
* Core memory allocator
|
|
||||||
* =====================
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* To make sure the interpreter is user-malloc friendly, all memory
|
|
||||||
APIs are implemented on top of this one.
|
|
||||||
|
|
||||||
The PyCore_* macros can be defined to make the interpreter use a
|
|
||||||
custom allocator. Note that they are for internal use only. Both
|
|
||||||
the core and extension modules should use the PyMem_* API.
|
|
||||||
|
|
||||||
See the comment block at the end of this file for two scenarios
|
|
||||||
showing how to use this to use a different allocator. */
|
|
||||||
|
|
||||||
#ifndef PyCore_MALLOC_FUNC
|
|
||||||
#undef PyCore_REALLOC_FUNC
|
|
||||||
#undef PyCore_FREE_FUNC
|
|
||||||
#define PyCore_MALLOC_FUNC malloc
|
|
||||||
#define PyCore_REALLOC_FUNC realloc
|
|
||||||
#define PyCore_FREE_FUNC free
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef PyCore_MALLOC_PROTO
|
|
||||||
#undef PyCore_REALLOC_PROTO
|
|
||||||
#undef PyCore_FREE_PROTO
|
|
||||||
#define PyCore_MALLOC_PROTO (size_t)
|
|
||||||
#define PyCore_REALLOC_PROTO (void *, size_t)
|
|
||||||
#define PyCore_FREE_PROTO (void *)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef NEED_TO_DECLARE_MALLOC_AND_FRIEND
|
|
||||||
extern void *PyCore_MALLOC_FUNC PyCore_MALLOC_PROTO;
|
|
||||||
extern void *PyCore_REALLOC_FUNC PyCore_REALLOC_PROTO;
|
|
||||||
extern void PyCore_FREE_FUNC PyCore_FREE_PROTO;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef PyCore_MALLOC
|
|
||||||
#undef PyCore_REALLOC
|
|
||||||
#undef PyCore_FREE
|
|
||||||
#define PyCore_MALLOC(n) PyCore_MALLOC_FUNC(n)
|
|
||||||
#define PyCore_REALLOC(p, n) PyCore_REALLOC_FUNC((p), (n))
|
|
||||||
#define PyCore_FREE(p) PyCore_FREE_FUNC(p)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* BEWARE:
|
|
||||||
|
|
||||||
Each interface exports both functions and macros. Extension modules
|
|
||||||
should normally use the functions for ensuring binary compatibility
|
|
||||||
of the user's code across Python versions. Subsequently, if the
|
|
||||||
Python runtime switches to its own malloc (different from standard
|
|
||||||
malloc), no recompilation is required for the extensions.
|
|
||||||
|
|
||||||
The macro versions trade compatibility for speed. They can be used
|
|
||||||
whenever there is a performance problem, but their use implies
|
|
||||||
recompilation of the code for each new Python release. The Python
|
|
||||||
core uses the macros because it *is* compiled on every upgrade.
|
|
||||||
This might not be the case with 3rd party extensions in a custom
|
|
||||||
setup (for example, a customer does not always have access to the
|
|
||||||
source of 3rd party deliverables). You have been warned! */
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Raw memory interface
|
|
||||||
* ====================
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* Functions */
|
|
||||||
|
|
||||||
/* Function wrappers around PyCore_MALLOC and friends; useful if you
|
|
||||||
need to be sure that you are using the same memory allocator as
|
|
||||||
Python. Note that the wrappers make sure that allocating 0 bytes
|
|
||||||
returns a non-NULL pointer, even if the underlying malloc
|
|
||||||
doesn't. Returned pointers must be checked for NULL explicitly.
|
|
||||||
No action is performed on failure. */
|
|
||||||
extern DL_IMPORT(void *) PyMem_Malloc(size_t);
|
|
||||||
extern DL_IMPORT(void *) PyMem_Realloc(void *, size_t);
|
|
||||||
extern DL_IMPORT(void) PyMem_Free(void *);
|
|
||||||
|
|
||||||
/* Starting from Python 1.6, the wrappers Py_{Malloc,Realloc,Free} are
|
|
||||||
no longer supported. They used to call PyErr_NoMemory() on failure. */
|
|
||||||
|
|
||||||
/* Macros */
|
|
||||||
#define PyMem_MALLOC(n) PyCore_MALLOC(n)
|
|
||||||
#define PyMem_REALLOC(p, n) PyCore_REALLOC((void *)(p), (n))
|
|
||||||
#define PyMem_FREE(p) PyCore_FREE((void *)(p))
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Type-oriented memory interface
|
|
||||||
* ==============================
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* Functions */
|
|
||||||
#define PyMem_New(type, n) \
|
|
||||||
( (type *) PyMem_Malloc((n) * sizeof(type)) )
|
|
||||||
#define PyMem_Resize(p, type, n) \
|
|
||||||
( (p) = (type *) PyMem_Realloc((n) * sizeof(type)) )
|
|
||||||
#define PyMem_Del(p) PyMem_Free(p)
|
|
||||||
|
|
||||||
/* Macros */
|
|
||||||
#define PyMem_NEW(type, n) \
|
|
||||||
( (type *) PyMem_MALLOC(_PyMem_EXTRA + (n) * sizeof(type)) )
|
|
||||||
#define PyMem_RESIZE(p, type, n) \
|
|
||||||
if ((p) == NULL) \
|
|
||||||
(p) = (type *)(PyMem_MALLOC( \
|
|
||||||
_PyMem_EXTRA + (n) * sizeof(type))); \
|
|
||||||
else \
|
|
||||||
(p) = (type *)(PyMem_REALLOC((p), \
|
|
||||||
_PyMem_EXTRA + (n) * sizeof(type)))
|
|
||||||
#define PyMem_DEL(p) PyMem_FREE(p)
|
|
||||||
|
|
||||||
/* PyMem_XDEL is deprecated. To avoid the call when p is NULL,
|
|
||||||
it is recommended to write the test explicitly in the code.
|
|
||||||
Note that according to ANSI C, free(NULL) has no effect. */
|
|
||||||
|
|
||||||
/* SCENARIOS
|
|
||||||
|
|
||||||
Here are two scenarios by Vladimir Marangozov (the author of the
|
|
||||||
memory allocation redesign).
|
|
||||||
|
|
||||||
1) Scenario A
|
|
||||||
|
|
||||||
Suppose you want to use a debugging malloc library that collects info on
|
|
||||||
where the malloc calls originate from. Assume the interface is:
|
|
||||||
|
|
||||||
d_malloc(size_t n, char* src_file, unsigned long src_line) c.s.
|
|
||||||
|
|
||||||
In this case, you would define (for example in config.h) :
|
|
||||||
|
|
||||||
#define PyCore_MALLOC_FUNC d_malloc
|
|
||||||
...
|
|
||||||
#define PyCore_MALLOC_PROTO (size_t, char *, unsigned long)
|
|
||||||
...
|
|
||||||
#define NEED_TO_DECLARE_MALLOC_AND_FRIEND
|
|
||||||
|
|
||||||
#define PyCore_MALLOC(n) PyCore_MALLOC_FUNC((n), __FILE__, __LINE__)
|
|
||||||
...
|
|
||||||
|
|
||||||
2) Scenario B
|
|
||||||
|
|
||||||
Suppose you want to use malloc hooks (defined & initialized in a 3rd party
|
|
||||||
malloc library) instead of malloc functions. In this case, you would
|
|
||||||
define:
|
|
||||||
|
|
||||||
#define PyCore_MALLOC_FUNC (*malloc_hook)
|
|
||||||
...
|
|
||||||
#define NEED_TO_DECLARE_MALLOC_AND_FRIEND
|
|
||||||
|
|
||||||
and ignore the previous definitions about PyCore_MALLOC_FUNC, etc.
|
|
||||||
|
|
||||||
|
|
||||||
*/
|
|
||||||
|
|
||||||
/********************************************
|
/********************************************
|
||||||
* WRAPPER FOR <time.h> and/or <sys/time.h> *
|
* WRAPPER FOR <time.h> and/or <sys/time.h> *
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue