Skip to content

Commit c2c8656

Browse files
committed
Merge branch 'ef/msvc-noreturn'
* ef/msvc-noreturn: add NORETURN_PTR for function pointers increase portability of NORETURN declarations
2 parents 302e99b + 18660bc commit c2c8656

File tree

3 files changed

+11
-9
lines changed

3 files changed

+11
-9
lines changed

git-compat-util.h

Lines changed: 6 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -176,8 +176,10 @@ extern char *gitbasename(char *);
176176

177177
#ifdef __GNUC__
178178
#define NORETURN __attribute__((__noreturn__))
179+
#define NORETURN_PTR __attribute__((__noreturn__))
179180
#else
180181
#define NORETURN
182+
#define NORETURN_PTR
181183
#ifndef __attribute__
182184
#define __attribute__(x)
183185
#endif
@@ -186,13 +188,13 @@ extern char *gitbasename(char *);
186188
#include "compat/bswap.h"
187189

188190
/* General helper functions */
189-
extern void usage(const char *err) NORETURN;
190-
extern void die(const char *err, ...) NORETURN __attribute__((format (printf, 1, 2)));
191-
extern void die_errno(const char *err, ...) NORETURN __attribute__((format (printf, 1, 2)));
191+
extern NORETURN void usage(const char *err);
192+
extern NORETURN void die(const char *err, ...) __attribute__((format (printf, 1, 2)));
193+
extern NORETURN void die_errno(const char *err, ...) __attribute__((format (printf, 1, 2)));
192194
extern int error(const char *err, ...) __attribute__((format (printf, 1, 2)));
193195
extern void warning(const char *err, ...) __attribute__((format (printf, 1, 2)));
194196

195-
extern void set_die_routine(void (*routine)(const char *err, va_list params) NORETURN);
197+
extern void set_die_routine(NORETURN_PTR void (*routine)(const char *err, va_list params));
196198

197199
extern int prefixcmp(const char *str, const char *prefix);
198200
extern time_t tm_to_time_t(const struct tm *tm);

index-pack.c

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -206,8 +206,8 @@ static void parse_pack_header(void)
206206
use(sizeof(struct pack_header));
207207
}
208208

209-
static void bad_object(unsigned long offset, const char *format,
210-
...) NORETURN __attribute__((format (printf, 2, 3)));
209+
static NORETURN void bad_object(unsigned long offset, const char *format,
210+
...) __attribute__((format (printf, 2, 3)));
211211

212212
static void bad_object(unsigned long offset, const char *format, ...)
213213
{

usage.c

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -36,12 +36,12 @@ static void warn_builtin(const char *warn, va_list params)
3636

3737
/* If we are in a dlopen()ed .so write to a global variable would segfault
3838
* (ugh), so keep things static. */
39-
static void (*usage_routine)(const char *err) NORETURN = usage_builtin;
40-
static void (*die_routine)(const char *err, va_list params) NORETURN = die_builtin;
39+
static NORETURN_PTR void (*usage_routine)(const char *err) = usage_builtin;
40+
static NORETURN_PTR void (*die_routine)(const char *err, va_list params) = die_builtin;
4141
static void (*error_routine)(const char *err, va_list params) = error_builtin;
4242
static void (*warn_routine)(const char *err, va_list params) = warn_builtin;
4343

44-
void set_die_routine(void (*routine)(const char *err, va_list params) NORETURN)
44+
void set_die_routine(NORETURN_PTR void (*routine)(const char *err, va_list params))
4545
{
4646
die_routine = routine;
4747
}

0 commit comments

Comments
 (0)