From ea9cb3ee5bd7e36ee344c42d4bd697ab7f177134 Mon Sep 17 00:00:00 2001 From: truelight Date: Thu, 1 Dec 2005 09:34:40 +0000 Subject: [PATCH] (svn r3251) -Fix: report errors from GPMI in a more detailed way (Igor2Code) --- ai/ai.c | 15 ++++++++++++++- 1 file changed, 14 insertions(+), 1 deletion(-) diff --git a/ai/ai.c b/ai/ai.c index c186d8051f..df457f6627 100644 --- a/ai/ai.c +++ b/ai/ai.c @@ -243,6 +243,15 @@ void AI_LoadAIControl(void) ottd_SetAIParam(_ai.gpmi_param); } + +/** + * Dump an entry of the GPMI error stack (callback routine). This helps the user to trace errors back to their roots. + */ +void AI_PrintErrorStack(gpmi_err_stack_t *entry, char *string) +{ + DEBUG(ai, 0)(string); +} + #endif /* GPMI */ /** @@ -262,6 +271,7 @@ void AI_StartNewAI(PlayerID player) char *params = NULL; ottd_GetNextAIData(&library, ¶ms); + gpmi_error_stack_enable = 1; if (library != NULL) { _ai_player[player].module = gpmi_mod_load(library, params); @@ -271,9 +281,12 @@ void AI_StartNewAI(PlayerID player) free(params); if (_ai_player[player].module == NULL) { - DEBUG(ai, 0)("[AI] Failed to load AI, aborting.."); + DEBUG(ai, 0)("[AI] Failed to load AI, aborting. GPMI error stack:"); + gpmi_err_stack_process_str(AI_PrintErrorStack); return; } + gpmi_error_stack_enable = 0; + } #endif /* GPMI */