PHP 7.4.33
Preview: xmlmemory.h Size: 5.81 KB
/home/godevadmin/public_html/upload_images/home/000~ROOT~000/usr/include/libxml2/libxml/xmlmemory.h

/*
 * Summary: interface for the memory allocator
 * Description: provides interfaces for the memory allocator,
 *              including debugging capabilities.
 *
 * Copy: See Copyright for the status of this software.
 *
 * Author: Daniel Veillard
 */


#ifndef __DEBUG_MEMORY_ALLOC__
#define __DEBUG_MEMORY_ALLOC__

#include <stdio.h>
#include <libxml/xmlversion.h>

/**
 * DEBUG_MEMORY:
 *
 * DEBUG_MEMORY replaces the allocator with a collect and debug
 * shell to the libc allocator.
 * DEBUG_MEMORY should only be activated when debugging
 * libxml i.e. if libxml has been configured with --with-debug-mem too.
 */
/* #define DEBUG_MEMORY_FREED */
/* #define DEBUG_MEMORY_LOCATION */

#ifdef DEBUG
#ifndef DEBUG_MEMORY
#define DEBUG_MEMORY
#endif
#endif

/**
 * DEBUG_MEMORY_LOCATION:
 *
 * DEBUG_MEMORY_LOCATION should be activated only when debugging
 * libxml i.e. if libxml has been configured with --with-debug-mem too.
 */
#ifdef DEBUG_MEMORY_LOCATION
#endif

#ifdef __cplusplus
extern "C" {
#endif

/*
 * The XML memory wrapper support 4 basic overloadable functions.
 */
/**
 * xmlFreeFunc:
 * @mem: an already allocated block of memory
 *
 * Signature for a free() implementation.
 */
typedef void (XMLCALL *xmlFreeFunc)(void *mem);
/**
 * xmlMallocFunc:
 * @size:  the size requested in bytes
 *
 * Signature for a malloc() implementation.
 *
 * Returns a pointer to the newly allocated block or NULL in case of error.
 */
typedef void *(LIBXML_ATTR_ALLOC_SIZE(1) XMLCALL *xmlMallocFunc)(size_t size);

/**
 * xmlReallocFunc:
 * @mem: an already allocated block of memory
 * @size:  the new size requested in bytes
 *
 * Signature for a realloc() implementation.
 *
 * Returns a pointer to the newly reallocated block or NULL in case of error.
 */
typedef void *(XMLCALL *xmlReallocFunc)(void *mem, size_t size);

/**
 * xmlStrdupFunc:
 * @str: a zero terminated string
 *
 * Signature for an strdup() implementation.
 *
 * Returns the copy of the string or NULL in case of error.
 */
typedef char *(XMLCALL *xmlStrdupFunc)(const char *str);

/*
 * The 4 interfaces used for all memory handling within libxml.
LIBXML_DLL_IMPORT xmlFreeFunc xmlFree;
LIBXML_DLL_IMPORT xmlMallocFunc xmlMalloc;
LIBXML_DLL_IMPORT xmlMallocFunc xmlMallocAtomic;
LIBXML_DLL_IMPORT xmlReallocFunc xmlRealloc;
LIBXML_DLL_IMPORT xmlStrdupFunc xmlMemStrdup;
 */

/*
 * The way to overload the existing functions.
 * The xmlGc function have an extra entry for atomic block
 * allocations useful for garbage collected memory allocators
 */
XMLPUBFUN int XMLCALL
	xmlMemSetup	(xmlFreeFunc freeFunc,
			 xmlMallocFunc mallocFunc,
			 xmlReallocFunc reallocFunc,
			 xmlStrdupFunc strdupFunc);
XMLPUBFUN int XMLCALL
	xmlMemGet	(xmlFreeFunc *freeFunc,
			 xmlMallocFunc *mallocFunc,
			 xmlReallocFunc *reallocFunc,
			 xmlStrdupFunc *strdupFunc);
XMLPUBFUN int XMLCALL
	xmlGcMemSetup	(xmlFreeFunc freeFunc,
			 xmlMallocFunc mallocFunc,
			 xmlMallocFunc mallocAtomicFunc,
			 xmlReallocFunc reallocFunc,
			 xmlStrdupFunc strdupFunc);
XMLPUBFUN int XMLCALL
	xmlGcMemGet	(xmlFreeFunc *freeFunc,
			 xmlMallocFunc *mallocFunc,
			 xmlMallocFunc *mallocAtomicFunc,
			 xmlReallocFunc *reallocFunc,
			 xmlStrdupFunc *strdupFunc);

/*
 * Initialization of the memory layer.
 */
XMLPUBFUN int XMLCALL
	xmlInitMemory	(void);

/*
 * Cleanup of the memory layer.
 */
XMLPUBFUN void XMLCALL
                xmlCleanupMemory        (void);
/*
 * These are specific to the XML debug memory wrapper.
 */
XMLPUBFUN int XMLCALL
	xmlMemUsed	(void);
XMLPUBFUN int XMLCALL
	xmlMemBlocks	(void);
XMLPUBFUN void XMLCALL
	xmlMemDisplay	(FILE *fp);
XMLPUBFUN void XMLCALL
	xmlMemDisplayLast(FILE *fp, long nbBytes);
XMLPUBFUN void XMLCALL
	xmlMemShow	(FILE *fp, int nr);
XMLPUBFUN void XMLCALL
	xmlMemoryDump	(void);
XMLPUBFUN void * XMLCALL
	xmlMemMalloc	(size_t size) LIBXML_ATTR_ALLOC_SIZE(1);
XMLPUBFUN void * XMLCALL
	xmlMemRealloc	(void *ptr,size_t size);
XMLPUBFUN void XMLCALL
	xmlMemFree	(void *ptr);
XMLPUBFUN char * XMLCALL
	xmlMemoryStrdup	(const char *str);
XMLPUBFUN void * XMLCALL
	xmlMallocLoc	(size_t size, const char *file, int line) LIBXML_ATTR_ALLOC_SIZE(1);
XMLPUBFUN void * XMLCALL
	xmlReallocLoc	(void *ptr, size_t size, const char *file, int line);
XMLPUBFUN void * XMLCALL
	xmlMallocAtomicLoc (size_t size, const char *file, int line) LIBXML_ATTR_ALLOC_SIZE(1);
XMLPUBFUN char * XMLCALL
	xmlMemStrdupLoc	(const char *str, const char *file, int line);


#ifdef DEBUG_MEMORY_LOCATION
/**
 * xmlMalloc:
 * @size:  number of bytes to allocate
 *
 * Wrapper for the malloc() function used in the XML library.
 *
 * Returns the pointer to the allocated area or NULL in case of error.
 */
#define xmlMalloc(size) xmlMallocLoc((size), __FILE__, __LINE__)
/**
 * xmlMallocAtomic:
 * @size:  number of bytes to allocate
 *
 * Wrapper for the malloc() function used in the XML library for allocation
 * of block not containing pointers to other areas.
 *
 * Returns the pointer to the allocated area or NULL in case of error.
 */
#define xmlMallocAtomic(size) xmlMallocAtomicLoc((size), __FILE__, __LINE__)
/**
 * xmlRealloc:
 * @ptr:  pointer to the existing allocated area
 * @size:  number of bytes to allocate
 *
 * Wrapper for the realloc() function used in the XML library.
 *
 * Returns the pointer to the allocated area or NULL in case of error.
 */
#define xmlRealloc(ptr, size) xmlReallocLoc((ptr), (size), __FILE__, __LINE__)
/**
 * xmlMemStrdup:
 * @str:  pointer to the existing string
 *
 * Wrapper for the strdup() function, xmlStrdup() is usually preferred.
 *
 * Returns the pointer to the allocated area or NULL in case of error.
 */
#define xmlMemStrdup(str) xmlMemStrdupLoc((str), __FILE__, __LINE__)

#endif /* DEBUG_MEMORY_LOCATION */

#ifdef __cplusplus
}
#endif /* __cplusplus */

#ifndef __XML_GLOBALS_H
#ifndef __XML_THREADS_H__
#include <libxml/threads.h>
#include <libxml/globals.h>
#endif
#endif

#endif  /* __DEBUG_MEMORY_ALLOC__ */

Directory Contents

Dirs: 0 × Files: 47

Name Size Perms Modified Actions
3.04 KB lrw-r--r-- 2016-06-07 10:04:14
Edit Download
4.79 KB lrw-r--r-- 2016-06-07 10:04:14
Edit Download
5.04 KB lrw-r--r-- 2009-07-30 15:24:34
Edit Download
5.03 KB lrw-r--r-- 2016-06-07 10:04:14
Edit Download
1.91 KB lrw-r--r-- 2016-06-07 10:04:14
Edit Download
3.08 KB lrw-r--r-- 2016-06-07 10:04:14
Edit Download
8.11 KB lrw-r--r-- 2016-06-07 10:04:14
Edit Download
4.78 KB lrw-r--r-- 2025-06-12 01:40:55
Edit Download
14.35 KB lrw-r--r-- 2016-06-07 10:04:14
Edit Download
6.34 KB lrw-r--r-- 2016-06-07 10:04:14
Edit Download
9.19 KB lrw-r--r-- 2017-07-23 05:10:06
Edit Download
3.56 KB lrw-r--r-- 2016-06-07 10:04:14
Edit Download
3.29 KB lrw-r--r-- 2016-06-07 10:04:14
Edit Download
3.67 KB lrw-r--r-- 2017-10-26 07:54:40
Edit Download
1.96 KB lrw-r--r-- 2016-06-07 10:04:14
Edit Download
38.79 KB lrw-r--r-- 2017-07-23 05:10:06
Edit Download
17.01 KB lrw-r--r-- 2016-06-07 10:04:14
Edit Download
2.53 KB lrw-r--r-- 2009-07-30 15:24:34
Edit Download
5.86 KB lrw-r--r-- 2016-06-07 10:04:14
Edit Download
4.24 KB lrw-r--r-- 2016-06-07 10:04:14
Edit Download
4.83 KB lrw-r--r-- 2016-06-07 10:04:14
Edit Download
25.63 KB lrw-r--r-- 2017-07-23 05:10:06
Edit Download
4.27 KB lrw-r--r-- 2016-06-07 10:04:14
Edit Download
1.91 KB lrw-r--r-- 2017-10-26 07:54:40
Edit Download
37.21 KB lrw-r--r-- 2016-06-07 10:04:14
Edit Download
2.60 KB lrw-r--r-- 2016-06-07 05:44:54
Edit Download
13.30 KB lrw-r--r-- 2016-06-07 10:04:14
Edit Download
2.90 KB lrw-r--r-- 2016-06-07 05:44:54
Edit Download
4.92 KB lrw-r--r-- 2016-06-07 10:04:14
Edit Download
3.86 KB lrw-r--r-- 2016-06-07 10:04:14
Edit Download
35.95 KB lrw-r--r-- 2017-07-23 05:10:06
Edit Download
3.83 KB lrw-r--r-- 2016-06-07 10:04:14
Edit Download
10.36 KB lrw-r--r-- 2017-07-23 05:10:06
Edit Download
5.81 KB lrw-r--r-- 2016-06-07 05:44:54
Edit Download
1.14 KB lrw-r--r-- 2016-06-07 10:04:14
Edit Download
12.31 KB lrw-r--r-- 2017-07-23 05:10:06
Edit Download
5.33 KB lrw-r--r-- 2016-06-07 05:44:54
Edit Download
2.28 KB lrw-r--r-- 2016-06-07 10:04:14
Edit Download
6.90 KB lrw-r--r-- 2016-06-07 10:04:14
Edit Download
4.73 KB lrw-r--r-- 2016-06-07 10:04:14
Edit Download
5.38 KB lrw-r--r-- 2016-06-07 10:04:14
Edit Download
9.76 KB lrw-r--r-- 2009-07-30 15:24:34
Edit Download
7.95 KB lrw-r--r-- 2025-06-12 01:41:01
Edit Download
20.77 KB lrw-r--r-- 2016-06-07 10:04:14
Edit Download
16.01 KB lrw-r--r-- 2016-06-07 10:04:14
Edit Download
18.90 KB lrw-r--r-- 2016-06-07 10:04:14
Edit Download
3.28 KB lrw-r--r-- 2016-06-07 10:04:14
Edit Download

If ZipArchive is unavailable, a .tar will be created (no compression).