From cee3df1e4b1b8103bf81e5281a46aab7881f93df Mon Sep 17 00:00:00 2001 From: ajs Date: Wed, 24 Nov 2004 17:14:49 +0000 Subject: 2004-11-24 Andrew J. Schorr * zassert.h: New header file to declare a quagga-specific assert macro. * log.c: (_zlog_assert_failed) New function called when assert fails to log the error and abort. * zebra.h: Include "zassert.h" instead of . * regex.c: Include "zassert.h" instead of . * dict.c: Include "zassert.h" instead of . --- lib/ChangeLog | 8 ++++++++ lib/log.c | 9 +++++++++ lib/regex.c | 2 +- lib/zassert.h | 23 +++++++++++++++++++++++ lib/zebra.h | 2 +- 5 files changed, 42 insertions(+), 2 deletions(-) create mode 100644 lib/zassert.h (limited to 'lib') diff --git a/lib/ChangeLog b/lib/ChangeLog index 10092d1c..6ba1d6f4 100644 --- a/lib/ChangeLog +++ b/lib/ChangeLog @@ -1,3 +1,11 @@ +2004-11-24 Andrew J. Schorr + + * zassert.h: New header file to declare a quagga-specific assert macro. + * log.c: (_zlog_assert_failed) New function called when assert fails + to log the error and abort. + * zebra.h: Include "zassert.h" instead of . + * regex.c: Include "zassert.h" instead of . + 2004-11-23 Andrew J. Schorr * sigevent.c: (signal_init) Set up some default signal handlers diff --git a/lib/log.c b/lib/log.c index c55bfcb1..38f8ecea 100644 --- a/lib/log.c +++ b/lib/log.c @@ -315,6 +315,15 @@ PLOG_FUNC(plog_debug, LOG_DEBUG) #undef PLOG_FUNC +void +_zlog_assert_failed (const char *assertion, const char *file, + unsigned int line, const char *function) +{ + zlog_err("Assertion `%s' failed in file %s, line %u, function %s", + assertion,file,line,(function ? function : "?")); + abort(); +} + /* Open log stream */ struct zlog * diff --git a/lib/regex.c b/lib/regex.c index 2eb7c118..2f90dded 100644 --- a/lib/regex.c +++ b/lib/regex.c @@ -613,7 +613,7 @@ extract_number_and_incr (destination, source) # include /* It is useful to test things that ``must'' be true when debugging. */ -# include +# include "zassert.h" static int debug; diff --git a/lib/zassert.h b/lib/zassert.h new file mode 100644 index 00000000..77ebf5d3 --- /dev/null +++ b/lib/zassert.h @@ -0,0 +1,23 @@ +#ifndef _QUAGGA_ASSERT_H +#define _QUAGGA_ASSERT_H + +extern void _zlog_assert_failed (const char *assertion, const char *file, + unsigned int line, const char *function) + __attribute__ ((noreturn)); + +#if defined(__STDC_VERSION__) && __STDC_VERSION__ >= 199901L +#define __ASSERT_FUNCTION __func__ +#elif defined(__GNUC__) +#define __ASSERT_FUNCTION __FUNCTION__ +#else +#define __ASSERT_FUNCTION NULL +#endif + +#define zassert(EX) ((void)((EX) ? 0 : \ + (_zlog_assert_failed(#EX, __FILE__, __LINE__, \ + __ASSERT_FUNCTION), 0))) + +#undef assert +#define assert(EX) zassert(EX) + +#endif /* _QUAGGA_ASSERT_H */ diff --git a/lib/zebra.h b/lib/zebra.h index f2c396d8..5d0e2385 100644 --- a/lib/zebra.h +++ b/lib/zebra.h @@ -95,7 +95,7 @@ typedef int socklen_t; /* misc include group */ #include -#include +#include "zassert.h" #ifdef HAVE_LCAPS #include -- cgit v1.2.1