diff options
author | ajs <ajs> | 2004-11-24 18:14:49 +0100 |
---|---|---|
committer | ajs <ajs> | 2004-11-24 18:14:49 +0100 |
commit | cee3df1e4b1b8103bf81e5281a46aab7881f93df (patch) | |
tree | 40d7cc8c22da9634739256a9d577b140b41730b8 /lib | |
parent | 2004-11-24 Paul Jakma <paul@dishone.st> (diff) | |
download | frr-cee3df1e4b1b8103bf81e5281a46aab7881f93df.tar.xz frr-cee3df1e4b1b8103bf81e5281a46aab7881f93df.zip |
2004-11-24 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
* 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 <assert.h>.
* regex.c: Include "zassert.h" instead of <assert.h>.
* dict.c: Include "zassert.h" instead of <assert.h>.
Diffstat (limited to 'lib')
-rw-r--r-- | lib/ChangeLog | 8 | ||||
-rw-r--r-- | lib/log.c | 9 | ||||
-rw-r--r-- | lib/regex.c | 2 | ||||
-rw-r--r-- | lib/zassert.h | 23 | ||||
-rw-r--r-- | lib/zebra.h | 2 |
5 files changed, 42 insertions, 2 deletions
diff --git a/lib/ChangeLog b/lib/ChangeLog index 10092d1c5..6ba1d6f4f 100644 --- a/lib/ChangeLog +++ b/lib/ChangeLog @@ -1,3 +1,11 @@ +2004-11-24 Andrew J. Schorr <ajschorr@alumni.princeton.edu> + + * 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 <assert.h>. + * regex.c: Include "zassert.h" instead of <assert.h>. + 2004-11-23 Andrew J. Schorr <ajschorr@alumni.princeton.edu> * sigevent.c: (signal_init) Set up some default signal handlers @@ -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 2eb7c1181..2f90dded9 100644 --- a/lib/regex.c +++ b/lib/regex.c @@ -613,7 +613,7 @@ extract_number_and_incr (destination, source) # include <stdio.h> /* It is useful to test things that ``must'' be true when debugging. */ -# include <assert.h> +# include "zassert.h" static int debug; diff --git a/lib/zassert.h b/lib/zassert.h new file mode 100644 index 000000000..77ebf5d38 --- /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 f2c396d8a..5d0e23855 100644 --- a/lib/zebra.h +++ b/lib/zebra.h @@ -95,7 +95,7 @@ typedef int socklen_t; /* misc include group */ #include <stdarg.h> -#include <assert.h> +#include "zassert.h" #ifdef HAVE_LCAPS #include <sys/capability.h> |