From 35a201cc8ef0c3f5b2df88d2e528aabee1048348 Mon Sep 17 00:00:00 2001 From: Wojtek Kosior Date: Fri, 30 Apr 2021 18:47:09 +0200 Subject: Initial/Final commit --- libxml2-2.9.10/doc/devhelp/libxml2-xmlmemory.html | 186 ++++++++++++++++++++++ 1 file changed, 186 insertions(+) create mode 100644 libxml2-2.9.10/doc/devhelp/libxml2-xmlmemory.html (limited to 'libxml2-2.9.10/doc/devhelp/libxml2-xmlmemory.html') diff --git a/libxml2-2.9.10/doc/devhelp/libxml2-xmlmemory.html b/libxml2-2.9.10/doc/devhelp/libxml2-xmlmemory.html new file mode 100644 index 0000000..bf400d0 --- /dev/null +++ b/libxml2-2.9.10/doc/devhelp/libxml2-xmlmemory.html @@ -0,0 +1,186 @@ + + + + + xmlmemory: interface for the memory allocator + + + + + + + + + + + + + + + + +

+ xmlmemory +

+

xmlmemory - interface for the memory allocator

+

provides interfaces for the memory allocator, including debugging capabilities.

+

Author(s): Daniel Veillard

+
+

Synopsis

+
#define xmlRealloc;
+#define xmlMalloc;
+#define xmlMallocAtomic;
+#define DEBUG_MEMORY;
+#define xmlMemStrdup;
+void *	xmlMemRealloc			(void * ptr, 
size_t size); +int xmlInitMemory (void); +void xmlMemFree (void * ptr); +void * xmlMemMalloc (size_t size); +void xmlMemDisplayLast (FILE * fp,
long nbBytes); +int xmlMemGet (xmlFreeFunc * freeFunc,
xmlMallocFunc * mallocFunc,
xmlReallocFunc * reallocFunc,
xmlStrdupFunc * strdupFunc); +void xmlMemoryDump (void); +void * xmlMallocLoc (size_t size,
const char * file,
int line); +void xmlMemDisplay (FILE * fp); +int xmlMemBlocks (void); +int xmlGcMemGet (xmlFreeFunc * freeFunc,
xmlMallocFunc * mallocFunc,
xmlMallocFunc * mallocAtomicFunc,
xmlReallocFunc * reallocFunc,
xmlStrdupFunc * strdupFunc); +typedef char * xmlStrdupFunc (const char * str); +typedef void xmlFreeFunc (void * mem); +void xmlMemShow (FILE * fp,
int nr); +void * xmlMallocAtomicLoc (size_t size,
const char * file,
int line); +void * xmlReallocLoc (void * ptr,
size_t size,
const char * file,
int line); +void xmlCleanupMemory (void); +int xmlMemUsed (void); +int xmlMemSetup (xmlFreeFunc freeFunc,
xmlMallocFunc mallocFunc,
xmlReallocFunc reallocFunc,
xmlStrdupFunc strdupFunc); +typedef void * xmlReallocFunc (void * mem,
size_t size); +typedef void * xmlMallocFunc (size_t size); +int xmlGcMemSetup (xmlFreeFunc freeFunc,
xmlMallocFunc mallocFunc,
xmlMallocFunc mallocAtomicFunc,
xmlReallocFunc reallocFunc,
xmlStrdupFunc strdupFunc); +char * xmlMemoryStrdup (const char * str); +char * xmlMemStrdupLoc (const char * str,
const char * file,
int line); +
+
+
+

Description

+
+
+

Details

+
+

Macro DEBUG_MEMORY

#define 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

+
+
+ +
+
+
+
+
+
+
+
+
+

xmlGcMemGet ()

int	xmlGcMemGet			(xmlFreeFunc * freeFunc, 
xmlMallocFunc * mallocFunc,
xmlMallocFunc * mallocAtomicFunc,
xmlReallocFunc * reallocFunc,
xmlStrdupFunc * strdupFunc)
+

Provides the memory access functions set currently in use The mallocAtomicFunc is specialized for atomic block allocations (i.e. of areas useful for garbage collected memory allocators

+
freeFunc:place to save the free() function in use
mallocFunc:place to save the malloc() function in use
mallocAtomicFunc:place to save the atomic malloc() function in use
reallocFunc:place to save the realloc() function in use
strdupFunc:place to save the strdup() function in use
Returns:0 on success
+
+

xmlGcMemSetup ()

int	xmlGcMemSetup			(xmlFreeFunc freeFunc, 
xmlMallocFunc mallocFunc,
xmlMallocFunc mallocAtomicFunc,
xmlReallocFunc reallocFunc,
xmlStrdupFunc strdupFunc)
+

Override the default memory access functions with a new set This has to be called before any other libxml routines ! The mallocAtomicFunc is specialized for atomic block allocations (i.e. of areas useful for garbage collected memory allocators Should this be blocked if there was already some allocations done ?

+
freeFunc:the free() function to use
mallocFunc:the malloc() function to use
mallocAtomicFunc:the malloc() function to use for atomic allocations
reallocFunc:the realloc() function to use
strdupFunc:the strdup() function to use
Returns:0 on success
+
+ +
+
+
+
+
+
+
+
+
+
+
+
+
+

xmlMemGet ()

int	xmlMemGet			(xmlFreeFunc * freeFunc, 
xmlMallocFunc * mallocFunc,
xmlReallocFunc * reallocFunc,
xmlStrdupFunc * strdupFunc)
+

Provides the memory access functions set currently in use

+
freeFunc:place to save the free() function in use
mallocFunc:place to save the malloc() function in use
reallocFunc:place to save the realloc() function in use
strdupFunc:place to save the strdup() function in use
Returns:0 on success
+
+ +
+
+
+

xmlMemSetup ()

int	xmlMemSetup			(xmlFreeFunc freeFunc, 
xmlMallocFunc mallocFunc,
xmlReallocFunc reallocFunc,
xmlStrdupFunc strdupFunc)
+

Override the default memory access functions with a new set This has to be called before any other libxml routines ! Should this be blocked if there was already some allocations done ?

+
freeFunc:the free() function to use
mallocFunc:the malloc() function to use
reallocFunc:the realloc() function to use
strdupFunc:the strdup() function to use
Returns:0 on success
+
+ +
+
+
+
+
+
+
+
+
+
+
+
+
+ + -- cgit v1.2.3