diff options
author | Erik Faye-Lund <kusmabite@googlemail.com> | 2009-09-30 20:05:50 +0200 |
---|---|---|
committer | Jeff King <peff@peff.net> | 2009-10-01 10:12:21 +0200 |
commit | 18660bc96ec0419cc096a53998d3197f2b905e8a (patch) | |
tree | 58038677551d5500049b48019bfe8debf904e2cb /usage.c | |
parent | increase portability of NORETURN declarations (diff) | |
download | git-18660bc96ec0419cc096a53998d3197f2b905e8a.tar.xz git-18660bc96ec0419cc096a53998d3197f2b905e8a.zip |
add NORETURN_PTR for function pointers
Some compilers (including at least MSVC and ARM RVDS) supports
NORETURN on function declarations, but not on function pointers.
This patch makes it possible to define NORETURN for these compilers,
by splitting the NORETURN macro into two - one for function
declarations and one for function pointers.
Signed-off-by: Erik Faye-Lund <kusmabite@gmail.com>
Signed-off-by: Jeff King <peff@peff.net>
Diffstat (limited to 'usage.c')
-rw-r--r-- | usage.c | 6 |
1 files changed, 3 insertions, 3 deletions
@@ -36,12 +36,12 @@ static void warn_builtin(const char *warn, va_list params) /* If we are in a dlopen()ed .so write to a global variable would segfault * (ugh), so keep things static. */ -static NORETURN void (*usage_routine)(const char *err) = usage_builtin; -static NORETURN void (*die_routine)(const char *err, va_list params) = die_builtin; +static NORETURN_PTR void (*usage_routine)(const char *err) = usage_builtin; +static NORETURN_PTR void (*die_routine)(const char *err, va_list params) = die_builtin; static void (*error_routine)(const char *err, va_list params) = error_builtin; static void (*warn_routine)(const char *err, va_list params) = warn_builtin; -void set_die_routine(NORETURN void (*routine)(const char *err, va_list params)) +void set_die_routine(NORETURN_PTR void (*routine)(const char *err, va_list params)) { die_routine = routine; } |