$65 GRAYBYTE WORDPRESS FILE MANAGER $80

SERVER : in-mum-web1330.main-hosting.eu #1 SMP Mon Feb 10 22:45:17 UTC 2025
SERVER IP : 147.79.69.219 | ADMIN IP 216.73.216.143
OPTIONS : CRL = ON | WGT = ON | SDO = OFF | PKEX = OFF
DEACTIVATED : NONE

/opt/alt/python37/include/python3.7m/

HOME
Current File : /opt/alt/python37/include/python3.7m//pymem.h
/* The PyMem_ family:  low-level memory allocation interfaces.
   See objimpl.h for the PyObject_ memory family.
*/

#ifndef Py_PYMEM_H
#define Py_PYMEM_H

#include "pyport.h"

#ifdef __cplusplus
extern "C" {
#endif

#ifndef Py_LIMITED_API
PyAPI_FUNC(void *) PyMem_RawMalloc(size_t size);
PyAPI_FUNC(void *) PyMem_RawCalloc(size_t nelem, size_t elsize);
PyAPI_FUNC(void *) PyMem_RawRealloc(void *ptr, size_t new_size);
PyAPI_FUNC(void) PyMem_RawFree(void *ptr);

/* Configure the Python memory allocators. Pass NULL to use default
   allocators. */
PyAPI_FUNC(int) _PyMem_SetupAllocators(const char *opt);

/* Try to get the allocators name set by _PyMem_SetupAllocators(). */
PyAPI_FUNC(const char*) _PyMem_GetAllocatorsName(void);

/* Track an allocated memory block in the tracemalloc module.
   Return 0 on success, return -1 on error (failed to allocate memory to store
   the trace).

   Return -2 if tracemalloc is disabled.

   If memory block is already tracked, update the existing trace. */
PyAPI_FUNC(int) PyTraceMalloc_Track(
    unsigned int domain,
    uintptr_t ptr,
    size_t size);

/* Untrack an allocated memory block in the tracemalloc module.
   Do nothing if the block was not tracked.

   Return -2 if tracemalloc is disabled, otherwise return 0. */
PyAPI_FUNC(int) PyTraceMalloc_Untrack(
    unsigned int domain,
    uintptr_t ptr);

/* Get the traceback where a memory block was allocated.

   Return a tuple of (filename: str, lineno: int) tuples.

   Return None if the tracemalloc module is disabled or if the memory block
   is not tracked by tracemalloc.

   Raise an exception and return NULL on error. */
PyAPI_FUNC(PyObject*) _PyTraceMalloc_GetTraceback(
    unsigned int domain,
    uintptr_t ptr);
#endif   /* !defined(Py_LIMITED_API) */


/* BEWARE:

   Each interface exports both functions and macros.  Extension modules should
   use the functions, to ensure binary compatibility across Python versions.
   Because the Python implementation is free to change internal details, and
   the macros may (or may not) expose details for speed, if you do use the
   macros you must recompile your extensions with each Python release.

   Never mix calls to PyMem_ with calls to the platform malloc/realloc/
   calloc/free.  For example, on Windows different DLLs may end up using
   different heaps, and if you use PyMem_Malloc you'll get the memory from the
   heap used by the Python DLL; it could be a disaster if you free()'ed that
   directly in your own extension.  Using PyMem_Free instead ensures Python
   can return the memory to the proper heap.  As another example, in
   PYMALLOC_DEBUG mode, Python wraps all calls to all PyMem_ and PyObject_
   memory functions in special debugging wrappers that add additional
   debugging info to dynamic memory blocks.  The system routines have no idea
   what to do with that stuff, and the Python wrappers have no idea what to do
   with raw blocks obtained directly by the system routines then.

   The GIL must be held when using these APIs.
*/

/*
 * Raw memory interface
 * ====================
 */

/* Functions

   Functions supplying platform-independent semantics for malloc/realloc/
   free.  These functions make sure that allocating 0 bytes returns a distinct
   non-NULL pointer (whenever possible -- if we're flat out of memory, NULL
   may be returned), even if the platform malloc and realloc don't.
   Returned pointers must be checked for NULL explicitly.  No action is
   performed on failure (no exception is set, no warning is printed, etc).
*/

PyAPI_FUNC(void *) PyMem_Malloc(size_t size);
#if !defined(Py_LIMITED_API) || Py_LIMITED_API+0 >= 0x03050000
PyAPI_FUNC(void *) PyMem_Calloc(size_t nelem, size_t elsize);
#endif
PyAPI_FUNC(void *) PyMem_Realloc(void *ptr, size_t new_size);
PyAPI_FUNC(void) PyMem_Free(void *ptr);

#ifndef Py_LIMITED_API
/* strdup() using PyMem_RawMalloc() */
PyAPI_FUNC(char *) _PyMem_RawStrdup(const char *str);

/* strdup() using PyMem_Malloc() */
PyAPI_FUNC(char *) _PyMem_Strdup(const char *str);

/* wcsdup() using PyMem_RawMalloc() */
PyAPI_FUNC(wchar_t*) _PyMem_RawWcsdup(const wchar_t *str);
#endif

/* Macros. */

/* PyMem_MALLOC(0) means malloc(1). Some systems would return NULL
   for malloc(0), which would be treated as an error. Some platforms
   would return a pointer with no memory behind it, which would break
   pymalloc. To solve these problems, allocate an extra byte. */
/* Returns NULL to indicate error if a negative size or size larger than
   Py_ssize_t can represent is supplied.  Helps prevents security holes. */
#define PyMem_MALLOC(n)         PyMem_Malloc(n)
#define PyMem_REALLOC(p, n)     PyMem_Realloc(p, n)
#define PyMem_FREE(p)           PyMem_Free(p)

/*
 * Type-oriented memory interface
 * ==============================
 *
 * Allocate memory for n objects of the given type.  Returns a new pointer
 * or NULL if the request was too large or memory allocation failed.  Use
 * these macros rather than doing the multiplication yourself so that proper
 * overflow checking is always done.
 */

#define PyMem_New(type, n) \
  ( ((size_t)(n) > PY_SSIZE_T_MAX / sizeof(type)) ? NULL :      \
        ( (type *) PyMem_Malloc((n) * sizeof(type)) ) )
#define PyMem_NEW(type, n) \
  ( ((size_t)(n) > PY_SSIZE_T_MAX / sizeof(type)) ? NULL :      \
        ( (type *) PyMem_MALLOC((n) * sizeof(type)) ) )

/*
 * The value of (p) is always clobbered by this macro regardless of success.
 * The caller MUST check if (p) is NULL afterwards and deal with the memory
 * error if so.  This means the original value of (p) MUST be saved for the
 * caller's memory error handler to not lose track of it.
 */
#define PyMem_Resize(p, type, n) \
  ( (p) = ((size_t)(n) > PY_SSIZE_T_MAX / sizeof(type)) ? NULL :        \
        (type *) PyMem_Realloc((p), (n) * sizeof(type)) )
#define PyMem_RESIZE(p, type, n) \
  ( (p) = ((size_t)(n) > PY_SSIZE_T_MAX / sizeof(type)) ? NULL :        \
        (type *) PyMem_REALLOC((p), (n) * sizeof(type)) )

/* PyMem{Del,DEL} are left over from ancient days, and shouldn't be used
 * anymore.  They're just confusing aliases for PyMem_{Free,FREE} now.
 */
#define PyMem_Del               PyMem_Free
#define PyMem_DEL               PyMem_FREE

#ifndef Py_LIMITED_API
typedef enum {
    /* PyMem_RawMalloc(), PyMem_RawRealloc() and PyMem_RawFree() */
    PYMEM_DOMAIN_RAW,

    /* PyMem_Malloc(), PyMem_Realloc() and PyMem_Free() */
    PYMEM_DOMAIN_MEM,

    /* PyObject_Malloc(), PyObject_Realloc() and PyObject_Free() */
    PYMEM_DOMAIN_OBJ
} PyMemAllocatorDomain;

typedef struct {
    /* user context passed as the first argument to the 4 functions */
    void *ctx;

    /* allocate a memory block */
    void* (*malloc) (void *ctx, size_t size);

    /* allocate a memory block initialized by zeros */
    void* (*calloc) (void *ctx, size_t nelem, size_t elsize);

    /* allocate or resize a memory block */
    void* (*realloc) (void *ctx, void *ptr, size_t new_size);

    /* release a memory block */
    void (*free) (void *ctx, void *ptr);
} PyMemAllocatorEx;

/* Get the memory block allocator of the specified domain. */
PyAPI_FUNC(void) PyMem_GetAllocator(PyMemAllocatorDomain domain,
                                    PyMemAllocatorEx *allocator);

/* Set the memory block allocator of the specified domain.

   The new allocator must return a distinct non-NULL pointer when requesting
   zero bytes.

   For the PYMEM_DOMAIN_RAW domain, the allocator must be thread-safe: the GIL
   is not held when the allocator is called.

   If the new allocator is not a hook (don't call the previous allocator), the
   PyMem_SetupDebugHooks() function must be called to reinstall the debug hooks
   on top on the new allocator. */
PyAPI_FUNC(void) PyMem_SetAllocator(PyMemAllocatorDomain domain,
                                    PyMemAllocatorEx *allocator);

/* Setup hooks to detect bugs in the following Python memory allocator
   functions:

   - PyMem_RawMalloc(), PyMem_RawRealloc(), PyMem_RawFree()
   - PyMem_Malloc(), PyMem_Realloc(), PyMem_Free()
   - PyObject_Malloc(), PyObject_Realloc() and PyObject_Free()

   Newly allocated memory is filled with the byte 0xCB, freed memory is filled
   with the byte 0xDB. Additional checks:

   - detect API violations, ex: PyObject_Free() called on a buffer allocated
     by PyMem_Malloc()
   - detect write before the start of the buffer (buffer underflow)
   - detect write after the end of the buffer (buffer overflow)

   The function does nothing if Python is not compiled is debug mode. */
PyAPI_FUNC(void) PyMem_SetupDebugHooks(void);
#endif

#ifdef Py_BUILD_CORE
/* Set the memory allocator of the specified domain to the default.
   Save the old allocator into *old_alloc if it's non-NULL.
   Return on success, or return -1 if the domain is unknown. */
PyAPI_FUNC(int) _PyMem_SetDefaultAllocator(
    PyMemAllocatorDomain domain,
    PyMemAllocatorEx *old_alloc);
#endif

#ifdef __cplusplus
}
#endif

#endif /* !Py_PYMEM_H */

Current_dir [ NOT WRITEABLE ] Document_root [ WRITEABLE ]


[ Back ]
NAME
SIZE
LAST TOUCH
USER
CAN-I?
FUNCTIONS
..
--
25 Jan 2024 2.15 PM
root / root
0755
internal
--
28 Feb 2025 12.49 AM
root / 996
0755
Python-ast.h
21.291 KB
5 Jun 2023 8.46 PM
root / 996
0644
Python.h
3.471 KB
5 Jun 2023 8.45 PM
root / 996
0644
abstract.h
39.842 KB
5 Jun 2023 8.45 PM
root / 996
0644
accu.h
0.992 KB
5 Jun 2023 8.45 PM
root / 996
0644
asdl.h
1.185 KB
5 Jun 2023 8.45 PM
root / 996
0644
ast.h
0.626 KB
5 Jun 2023 8.45 PM
root / 996
0644
bitset.h
0.791 KB
5 Jun 2023 8.45 PM
root / 996
0644
bltinmodule.h
0.258 KB
5 Jun 2023 8.45 PM
root / 996
0644
boolobject.h
0.865 KB
5 Jun 2023 8.45 PM
root / 996
0644
bytearrayobject.h
2.064 KB
5 Jun 2023 8.45 PM
root / 996
0644
bytes_methods.h
3.224 KB
5 Jun 2023 8.45 PM
root / 996
0644
bytesobject.h
8.294 KB
5 Jun 2023 8.45 PM
root / 996
0644
cellobject.h
0.696 KB
5 Jun 2023 8.45 PM
root / 996
0644
ceval.h
8.513 KB
5 Jun 2023 8.45 PM
root / 996
0644
classobject.h
1.64 KB
5 Jun 2023 8.45 PM
root / 996
0644
code.h
5.923 KB
5 Jun 2023 8.45 PM
root / 996
0644
codecs.h
6.634 KB
5 Jun 2023 8.45 PM
root / 996
0644
compile.h
2.877 KB
5 Jun 2023 8.45 PM
root / 996
0644
complexobject.h
1.765 KB
5 Jun 2023 8.45 PM
root / 996
0644
context.h
1.967 KB
5 Jun 2023 8.45 PM
root / 996
0644
datetime.h
9.617 KB
5 Jun 2023 8.45 PM
root / 996
0644
descrobject.h
3.062 KB
5 Jun 2023 8.45 PM
root / 996
0644
dictobject.h
7.151 KB
5 Jun 2023 8.45 PM
root / 996
0644
dtoa.h
0.447 KB
5 Jun 2023 8.45 PM
root / 996
0644
dynamic_annotations.h
21.942 KB
5 Jun 2023 8.45 PM
root / 996
0644
enumobject.h
0.247 KB
5 Jun 2023 8.45 PM
root / 996
0644
errcode.h
1.655 KB
5 Jun 2023 8.45 PM
root / 996
0644
eval.h
1.181 KB
5 Jun 2023 8.45 PM
root / 996
0644
fileobject.h
1.769 KB
5 Jun 2023 8.45 PM
root / 996
0644
fileutils.h
4.428 KB
5 Jun 2023 8.45 PM
root / 996
0644
floatobject.h
4.682 KB
5 Jun 2023 8.45 PM
root / 996
0644
frameobject.h
3.24 KB
5 Jun 2023 8.45 PM
root / 996
0644
funcobject.h
4.08 KB
5 Jun 2023 8.45 PM
root / 996
0644
genobject.h
3.561 KB
5 Jun 2023 8.45 PM
root / 996
0644
graminit.h
1.945 KB
5 Jun 2023 8.45 PM
root / 996
0644
grammar.h
2.265 KB
5 Jun 2023 8.45 PM
root / 996
0644
import.h
4.86 KB
5 Jun 2023 8.45 PM
root / 996
0644
intrcheck.h
0.841 KB
5 Jun 2023 8.45 PM
root / 996
0644
iterobject.h
0.554 KB
5 Jun 2023 8.45 PM
root / 996
0644
listobject.h
2.858 KB
5 Jun 2023 8.45 PM
root / 996
0644
longintrepr.h
3.71 KB
5 Jun 2023 8.45 PM
root / 996
0644
longobject.h
8.393 KB
5 Jun 2023 8.45 PM
root / 996
0644
marshal.h
0.784 KB
5 Jun 2023 8.45 PM
root / 996
0644
memoryobject.h
2.7 KB
5 Jun 2023 8.45 PM
root / 996
0644
metagrammar.h
0.247 KB
5 Jun 2023 8.45 PM
root / 996
0644
methodobject.h
4.413 KB
5 Jun 2023 8.45 PM
root / 996
0644
modsupport.h
8.358 KB
5 Jun 2023 8.45 PM
root / 996
0644
moduleobject.h
2.25 KB
5 Jun 2023 8.45 PM
root / 996
0644
namespaceobject.h
0.341 KB
5 Jun 2023 8.45 PM
root / 996
0644
node.h
1.087 KB
5 Jun 2023 8.45 PM
root / 996
0644
object.h
40.861 KB
5 Jun 2023 8.45 PM
root / 996
0644
objimpl.h
14.135 KB
5 Jun 2023 8.45 PM
root / 996
0644
odictobject.h
1.25 KB
5 Jun 2023 8.45 PM
root / 996
0644
opcode.h
4.989 KB
5 Jun 2023 8.45 PM
root / 996
0644
osdefs.h
0.675 KB
5 Jun 2023 8.45 PM
root / 996
0644
osmodule.h
0.284 KB
5 Jun 2023 8.45 PM
root / 996
0644
parsetok.h
2.837 KB
5 Jun 2023 8.45 PM
root / 996
0644
patchlevel.h
1.269 KB
5 Jun 2023 8.45 PM
root / 996
0644
pgen.h
0.247 KB
5 Jun 2023 8.45 PM
root / 996
0644
pgenheaders.h
1.193 KB
5 Jun 2023 8.45 PM
root / 996
0644
py_curses.h
3.967 KB
5 Jun 2023 8.45 PM
root / 996
0644
pyarena.h
2.68 KB
5 Jun 2023 8.45 PM
root / 996
0644
pyatomic.h
15.743 KB
5 Jun 2023 8.45 PM
root / 996
0644
pycapsule.h
1.686 KB
5 Jun 2023 8.45 PM
root / 996
0644
pyconfig-64.h
44.246 KB
17 Apr 2024 5.33 PM
root / 996
0644
pyconfig.h
0.158 KB
17 Apr 2024 5.35 PM
root / 996
0644
pyctype.h
1.289 KB
5 Jun 2023 8.45 PM
root / 996
0644
pydebug.h
1.186 KB
5 Jun 2023 8.45 PM
root / 996
0644
pydtrace.h
2.231 KB
5 Jun 2023 8.45 PM
root / 996
0644
pyerrors.h
16.962 KB
5 Jun 2023 8.45 PM
root / 996
0644
pyexpat.h
2.393 KB
5 Jun 2023 8.45 PM
root / 996
0644
pyfpe.h
0.333 KB
5 Jun 2023 8.45 PM
root / 996
0644
pyhash.h
4.042 KB
5 Jun 2023 8.45 PM
root / 996
0644
pylifecycle.h
7.598 KB
5 Jun 2023 8.45 PM
root / 996
0644
pymacconfig.h
2.919 KB
5 Jun 2023 8.45 PM
root / 996
0644
pymacro.h
3.452 KB
5 Jun 2023 8.45 PM
root / 996
0644
pymath.h
8.117 KB
5 Jun 2023 8.45 PM
root / 996
0644
pymem.h
8.782 KB
5 Jun 2023 8.45 PM
root / 996
0644
pyport.h
27.573 KB
5 Jun 2023 8.45 PM
root / 996
0644
pystate.h
15.941 KB
5 Jun 2023 8.45 PM
root / 996
0644
pystrcmp.h
0.426 KB
5 Jun 2023 8.45 PM
root / 996
0644
pystrhex.h
0.483 KB
5 Jun 2023 8.45 PM
root / 996
0644
pystrtod.h
1.448 KB
5 Jun 2023 8.45 PM
root / 996
0644
pythonrun.h
6.059 KB
5 Jun 2023 8.45 PM
root / 996
0644
pythread.h
5.207 KB
5 Jun 2023 8.45 PM
root / 996
0644
pytime.h
8.717 KB
5 Jun 2023 8.45 PM
root / 996
0644
rangeobject.h
0.614 KB
5 Jun 2023 8.45 PM
root / 996
0644
setobject.h
3.283 KB
5 Jun 2023 8.45 PM
root / 996
0644
sliceobject.h
2.422 KB
5 Jun 2023 8.45 PM
root / 996
0644
structmember.h
1.982 KB
5 Jun 2023 8.45 PM
root / 996
0644
structseq.h
1.345 KB
5 Jun 2023 8.45 PM
root / 996
0644
symtable.h
4.813 KB
5 Jun 2023 8.45 PM
root / 996
0644
sysmodule.h
1.476 KB
5 Jun 2023 8.45 PM
root / 996
0644
token.h
2.422 KB
5 Jun 2023 8.45 PM
root / 996
0644
traceback.h
3.559 KB
5 Jun 2023 8.45 PM
root / 996
0644
tupleobject.h
2.413 KB
5 Jun 2023 8.45 PM
root / 996
0644
typeslots.h
2.2 KB
5 Jun 2023 8.45 PM
root / 996
0644
ucnhash.h
1.031 KB
5 Jun 2023 8.45 PM
root / 996
0644
unicodeobject.h
80.35 KB
5 Jun 2023 8.45 PM
root / 996
0644
warnings.h
1.734 KB
5 Jun 2023 8.45 PM
root / 996
0644
weakrefobject.h
2.799 KB
5 Jun 2023 8.45 PM
root / 996
0644

GRAYBYTE WORDPRESS FILE MANAGER @ 2026 CONTACT ME
Static GIF