Files
MaxScale/include/maxscale/debug.h
2018-08-15 09:29:28 +03:00

48 lines
1.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: 2022-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 <signal.h>
#include <stdio.h>
#include <stdlib.h>
#include <maxscale/log_manager.h>
MXS_BEGIN_DECLS
#if defined(SS_DEBUG)
#define ss_dassert(exp) do { if(!(exp)){\
const char *debug_expr = #exp; /** The MXS_ERROR marco doesn't seem to like stringification */ \
MXS_ERROR("debug assert at %s:%d failed: %s\n", (char*)__FILE__, __LINE__, debug_expr); \
fprintf(stderr, "debug assert at %s:%d failed: %s\n", (char*)__FILE__, __LINE__, debug_expr); \
raise(SIGABRT);} } while (false)
#define ss_info_dassert(exp,info) do { if(!(exp)){\
const char *debug_expr = #exp; \
MXS_ERROR("debug assert at %s:%d failed: %s (%s)\n", (char*)__FILE__, __LINE__, info, debug_expr); \
fprintf(stderr, "debug assert at %s:%d failed: %s (%s)\n", (char*)__FILE__, __LINE__, info, debug_expr); \
raise(SIGABRT);} } while (false)
#define ss_debug(exp) exp
#else /* SS_DEBUG */
#define ss_dassert(exp)
#define ss_info_dassert(exp, info)
#define ss_debug(exp)
#endif /* SS_DEBUG */
MXS_END_DECLS