80 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			80 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #pragma once
 | |
| /*
 | |
|  * Copyright (c) 2016 MariaDB Corporation Ab
 | |
|  *
 | |
|  * Use of this software is governed by the Business Source License included
 | |
|  * in the LICENSE.TXT file and at www.mariadb.com/bsl11.
 | |
|  *
 | |
|  * Change Date: 2020-01-01
 | |
|  *
 | |
|  * On the date above, in accordance with the Business Source License, use
 | |
|  * of this software will be governed by version 2 or later of the General
 | |
|  * Public License.
 | |
|  */
 | |
| 
 | |
| #include <maxscale/cdefs.h>
 | |
| #include <stdlib.h>
 | |
| #include <string.h>
 | |
| 
 | |
| MXS_BEGIN_DECLS
 | |
| 
 | |
| /*
 | |
|  * NOTE: Do not use these functions directly, use the macros below.
 | |
|  */
 | |
| 
 | |
| // "caller" arg temporarily disabled so that existing code
 | |
| // using the previous version of mxs_alloc etc. will continue
 | |
| // to compile.
 | |
| void *mxs_malloc(size_t size/*, const char *caller*/);
 | |
| void *mxs_calloc(size_t nmemb, size_t size/*, const char *caller*/);
 | |
| void *mxs_realloc(void *ptr, size_t size/*, const char *caller*/);
 | |
| void mxs_free(void *ptr/*, const char *caller*/);
 | |
| 
 | |
| char *mxs_strdup(const char *s/*, const char *caller*/);
 | |
| char *mxs_strndup(const char *s, size_t n/*, const char *caller*/);
 | |
| 
 | |
| char *mxs_strdup_a(const char *s/*, const char *caller*/);
 | |
| char *mxs_strndup_a(const char *s, size_t n/*, const char *caller*/);
 | |
| 
 | |
| 
 | |
| /*
 | |
|  * NOTE: USE these macros instead of the functions above.
 | |
|  */
 | |
| #define MXS_MALLOC(size)         mxs_malloc(size/*, __func__*/)
 | |
| #define MXS_CALLOC(nmemb, size)  mxs_calloc(nmemb, size/*, __func__*/)
 | |
| #define MXS_REALLOC(ptr, size)   mxs_realloc(ptr, size/*, __func__*/)
 | |
| #define MXS_FREE(ptr)            mxs_free(ptr/*, __func__*/)
 | |
| 
 | |
| #define MXS_STRDUP(s)            mxs_strdup(s/*, __func__*/)
 | |
| #define MXS_STRNDUP(s, n)        mxs_strndup(s, n/*, __func__*/)
 | |
| 
 | |
| #define MXS_STRDUP_A(s)          mxs_strdup_a(s/*, __func__*/)
 | |
| #define MXS_STRNDUP_A(s, n)      mxs_strndup_a(s, n/*, __func__*/)
 | |
| 
 | |
| 
 | |
| /**
 | |
|  * @brief Abort the process if the pointer is NULL.
 | |
|  *
 | |
|  * To be used in circumstances where a memory allocation failure
 | |
|  * cannot - currently - be dealt with properly.
 | |
|  */
 | |
| #define MXS_ABORT_IF_NULL(p) do { if (!p) { abort(); } } while (false)
 | |
| 
 | |
| /**
 | |
|  * @brief Abort the process if the provided value is non-zero.
 | |
|  *
 | |
|  * To be used in circumstances where a memory allocation or other
 | |
|  * fatal error cannot - currently - be dealt with properly.
 | |
|  */
 | |
| #define MXS_ABORT_IF_TRUE(b) do { if (b) { abort(); } } while (false)
 | |
| 
 | |
| /**
 | |
|  * @brief Abort the process if the provided value is zero.
 | |
|  *
 | |
|  * To be used in circumstances where a memory allocation or other
 | |
|  * fatal error cannot - currently - be dealt with properly.
 | |
|  */
 | |
| #define MXS_ABORT_IF_FALSE(b) do { if (!b) { abort(); } } while (false)
 | |
| 
 | |
| MXS_END_DECLS
 | 
