diff options
-rw-r--r-- | ai/ai_event.h | 23 |
1 files changed, 6 insertions, 17 deletions
diff --git a/ai/ai_event.h b/ai/ai_event.h index 684ce54b5..33d5d170a 100644 --- a/ai/ai_event.h +++ b/ai/ai_event.h @@ -7,25 +7,14 @@ # include "ai.h" /* This is how we call events (with safety-check) to GPMI */ -/* XXX -- This macro (vararg macro) isn't supported on old GCCs, but GPMI - * is using them too, so it isn't a real problem, yet */ -# define ai_event(player, event, params...) \ - if (player < MAX_PLAYERS && _ai_player[player].module != NULL) \ - gpmi_event(_ai_player[player].module, event, params) +# define ai_event(player, event, ...) \ + if ((player) < MAX_PLAYERS && _ai_player[(player)].module != NULL) \ + gpmi_event(_ai_player[(player)].module, (event), ##__VA_ARGS__) -#else -/* If GPMI isn't loaded, don't do a thing with the events (for now at least) - * Because old GCCs don't support vararg macros, and OTTD does support those - * GCCs, we need something tricky to ignore the events... and this is the solution :) - * Ugly, I know, but it works! */ - -# ifdef DEF_EVENTS - void CDECL empty_function(PlayerID player, int event, ...) {} -# else - extern void CDECL empty_function(PlayerID player, int event, ...); -# endif -# define ai_event empty_function +#else /* GPMI */ +/* If GPMI isn't loaded, don't do a thing with the events (for now at least) */ +# define ai_event(...) #endif /* GPMI */ /* To make our life a bit easier; you now only have to define new |