renamed ase_memchr/ase_memrchr to ase_membyte/ase_memrbyte
This commit is contained in:
		| @ -1,5 +1,5 @@ | ||||
| /* | ||||
|  * $Id: mem.h 223 2008-06-26 06:44:41Z baconevi $ | ||||
|  * $Id: mem.h 328 2008-08-16 14:07:34Z baconevi $ | ||||
|  * | ||||
|  * {License} | ||||
|  */ | ||||
| @ -10,18 +10,182 @@ | ||||
| #include <ase/types.h> | ||||
| #include <ase/macros.h> | ||||
|  | ||||
| /* gets the default memory manager */ | ||||
| #define ASE_MMGR_GETDFL()  (ase_mmgr) | ||||
|  | ||||
| /* sets the default memory manager */ | ||||
| #define ASE_MMGR_SETDFL(m) ((ase_mmgr) = (m)) | ||||
|  | ||||
| #if defined(_WIN32) && defined(_MSC_VER) && defined(_DEBUG) | ||||
| 	#include <stdlib.h> | ||||
| 	#define _CRTDBG_MAP_ALLOC | ||||
| 	#include <crtdbg.h> | ||||
|  | ||||
| 	#define ASE_MMGR_ALLOC(mmgr,size)       malloc  (size) | ||||
| 	#define ASE_MMGR_REALLOC(mmgr,ptr,size) realloc (ptr, size) | ||||
| 	#define ASE_MMGR_FREE(mmgr,ptr)         free    (ptr) | ||||
| #else | ||||
|         #define ASE_MMGR_ALLOC(mmgr,size) \ | ||||
|                 (mmgr)->malloc((mmgr)->custom_data, size) | ||||
|         #define ASE_MMGR_EALLOC(mmgr,ptr,size) \ | ||||
|                 (mmgr)->realloc((mmgr)->custom_data, ptr, size) | ||||
|         #define ASE_MMGR_FREE(mmgr,ptr) \ | ||||
|                 (mmgr)->free((mmgr)->custom_data, ptr) | ||||
| #endif | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
|  | ||||
| void* ase_memcpy (void* dst, const void* src, ase_size_t n); | ||||
| void* ase_memmove (void* dst, const void* src, ase_size_t n); | ||||
| void* ase_memset (void* dst, int val, ase_size_t n); | ||||
| int   ase_memcmp (const void* s1, const void* s2, ase_size_t n); | ||||
| void* ase_memchr (const void* s, int val, ase_size_t n); | ||||
| void* ase_memrchr (const void* s, int val, ase_size_t n); | ||||
| void* ase_memmem (const void* hs, ase_size_t hl, const void* nd, ase_size_t nl); | ||||
| void* ase_memrmem (const void* hs, ase_size_t hl, const void* nd, ase_size_t nl); | ||||
| extern ase_mmgr_t* ase_mmgr; | ||||
|  | ||||
| /* | ||||
|  * NAME: copy memory area | ||||
|  * | ||||
|  * DESCRIPTION: | ||||
|  *  The ase_memcpy() functions copies n bytes from the source memory area src  | ||||
|  *  to the destinaion memory area dst.  | ||||
|  * | ||||
|  * RETURNS: the destination memory area dst. | ||||
|  * | ||||
|  * WARNING: | ||||
|  *  The memory areas should not overlap. Use the ase_memmove() function if | ||||
|  *  they overlap. | ||||
|  */ | ||||
|  | ||||
| void* ase_memcpy ( | ||||
| 	void* dst /* a pointer to the destination memory area */ ,  | ||||
| 	const void* src /* a pointer to the source memory area */ ,  | ||||
| 	ase_size_t n /* the number of bytes to copy */ | ||||
| ); | ||||
|  | ||||
| /* | ||||
|  * NAME: copy memory area with more care  | ||||
|  * | ||||
|  * DESCRIPTION: | ||||
|  *  The ase_memmove() functions copies n bytes from the source memory area src  | ||||
|  *  to the destinaion memory area dst without corrupting overlapping zone. | ||||
|  * | ||||
|  * RETURNS: the destination memory area dst. | ||||
|  */ | ||||
| void* ase_memmove ( | ||||
| 	void* dst /* a pointer to the destination memory area */, | ||||
| 	const void* src /* a pointer to the source memory area */, | ||||
| 	ase_size_t n /* the number of bytes to copy */ | ||||
| ); | ||||
|  | ||||
| /* | ||||
|  * NAME: fill memory area | ||||
|  * | ||||
|  * DESCRIPTION: | ||||
|  *  The ase_memset() function fills leading n bytes of the destination  | ||||
|  *  memory area dst with the byte val. | ||||
|  *  | ||||
|  * RETURNS: the destination memory area dst | ||||
|  */ | ||||
| void* ase_memset ( | ||||
| 	void* dst /* a pointer to the destination memory area */, | ||||
| 	int val /* the byte to fill the memory area with */, | ||||
| 	ase_size_t n /* the number of bytes to fill */ | ||||
| ); | ||||
|  | ||||
| /* | ||||
|  * NAME: compare memory areas | ||||
|  *  | ||||
|  * DESCRIPTION: | ||||
|  *  The ase_memcmp() function compares leading n bytes of two memory areas  | ||||
|  *  s1 and s2. | ||||
|  * | ||||
|  * RETURNS:  | ||||
|  *  0 if two memory ares have the same leadning n bytes. | ||||
|  *  a positive number if the first different byte of s1 is greater than that  | ||||
|  *  of s2. | ||||
|  *  a negative number if the first different byte of s1 is less than that of s2. | ||||
|  */ | ||||
| int ase_memcmp ( | ||||
| 	const void* s1 /* a pointer to the first memory area to compare */,  | ||||
| 	const void* s2 /* a pointer to the second memory area to compare */,  | ||||
| 	ase_size_t n /* the number of bytes to compare */ | ||||
| ); | ||||
|  | ||||
| /* | ||||
|  * NAME: find a byte forward in memory area | ||||
|  *  | ||||
|  * DESCRIPTION: | ||||
|  *  The ase_membyte() function scans the memory area s from the first byte | ||||
|  *  up to the nth byte in search of the byte val. If it finds a match, | ||||
|  *  it aborts scanning the memory area and returns the pointer to the matching | ||||
|  *  location. | ||||
|  * | ||||
|  * RETURNS: | ||||
|  *  ASE_NULL if the byte val is not found. | ||||
|  *  The pointer to the location in the memory area s matching the byte val | ||||
|  *  if a match is found. | ||||
|  */ | ||||
| void* ase_membyte ( | ||||
| 	const void* s /* a pointer to the memory area to scan */, | ||||
| 	int val /* a byte to find */, | ||||
| 	ase_size_t n /* the number of bytes to scan */  | ||||
| ); | ||||
|  | ||||
| /* | ||||
|  * NAME: find a byte backward in memory area | ||||
|  *  | ||||
|  * DESCRIPTION: | ||||
|  *  The ase_memrbyte() function scans the memory area s from the nth byte | ||||
|  *  backward to the first byte in search of the byte val. If it finds a match, | ||||
|  *  it aborts scanning the memory area and returns the pointer to the matching  | ||||
|  *  location. | ||||
|  * | ||||
|  * RETURNS: | ||||
|  *  ASE_NULL if the byte val is not found. | ||||
|  *  The pointer to the location in the memory area s matching the byte val | ||||
|  *  if a match is found. | ||||
|  */ | ||||
| void* ase_memrbyte ( | ||||
| 	const void* s /* a pointer to the memory area to scan */, | ||||
| 	int val /* a byte to find */, | ||||
| 	ase_size_t n /* the number of bytes to scan */  | ||||
| ); | ||||
|  | ||||
| /* | ||||
|  * NAME: find a block of bytes forward in memory area | ||||
|  *  | ||||
|  * DESCRIPTION: | ||||
|  *  The ase_memmem() functions scans the first hl bytes of the memory area hs | ||||
|  *  in search of the byte block nd of the length nl bytes. | ||||
|  * | ||||
|  * RETURNS: | ||||
|  *  ASE_NULL if the byte val is not found. | ||||
|  *  The pointer to the location in the memory area s matching the byte val | ||||
|  *  if a match is found. | ||||
|  * | ||||
|  * RETURNS: | ||||
|  *  ASE_NULL if no match is found. | ||||
|  */ | ||||
| void* ase_memmem ( | ||||
| 	const void* hs /* a pointer to the memory area to scan */, | ||||
| 	ase_size_t hl /* the number of bytes to scan */, | ||||
| 	const void* nd /* a pointer to the byte block to find */, | ||||
| 	ase_size_t nl /* the number of bytes in the block */ | ||||
| ); | ||||
|  | ||||
| /* | ||||
|  * NAME: find a block of bytes backward in memory area | ||||
|  * | ||||
|  * DESCRIPTION: | ||||
|  *  The ase_memrmem() functions scans the first hl bytes of the memory area hs | ||||
|  *  backward in search of the byte block nd of the length nl bytes. | ||||
|  * | ||||
|  * RETURNS: | ||||
|  *  ASE_NULL if no match is found. | ||||
|  */ | ||||
| void* ase_memrmem ( | ||||
| 	const void* hs /* a pointer to the memory area to scan */, | ||||
| 	ase_size_t hl /* the number of bytes to scan */, | ||||
| 	const void* nd /* a pointer to the byte block to find */, | ||||
| 	ase_size_t nl /* the number of bytes in the block */ | ||||
| ); | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| } | ||||
|  | ||||
		Reference in New Issue
	
	Block a user