mirror of https://github.com/OpenTTD/OpenTTD
(svn r24929) -Fix [FS#5415]: Don't try to pause or unpause crashed scripts.
parent
dafff99b2a
commit
a00320c61d
|
@ -987,6 +987,19 @@ struct AIDebugWindow : public Window {
|
||||||
return (ScriptLog::LogData *)Company::Get(ai_debug_company)->ai_instance->GetLogPointer();
|
return (ScriptLog::LogData *)Company::Get(ai_debug_company)->ai_instance->GetLogPointer();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check whether the currently selected AI/GS is dead.
|
||||||
|
* @return true if dead.
|
||||||
|
*/
|
||||||
|
bool IsDead() const
|
||||||
|
{
|
||||||
|
if (ai_debug_company == OWNER_DEITY) {
|
||||||
|
GameInstance *game = Game::GetInstance();
|
||||||
|
return game == NULL || game->IsDead();
|
||||||
|
}
|
||||||
|
return !Company::IsValidAiID(ai_debug_company) || Company::Get(ai_debug_company)->ai_instance->IsDead();
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Constructor for the window.
|
* Constructor for the window.
|
||||||
* @param desc The description of the window.
|
* @param desc The description of the window.
|
||||||
|
@ -1286,12 +1299,14 @@ struct AIDebugWindow : public Window {
|
||||||
|
|
||||||
case WID_AID_CONTINUE_BTN:
|
case WID_AID_CONTINUE_BTN:
|
||||||
/* Unpause current AI / game script and mark the corresponding script button dirty. */
|
/* Unpause current AI / game script and mark the corresponding script button dirty. */
|
||||||
if (ai_debug_company == OWNER_DEITY) {
|
if (!IsDead()) {
|
||||||
Game::Unpause();
|
if (ai_debug_company == OWNER_DEITY) {
|
||||||
this->SetWidgetDirty(WID_AID_SCRIPT_GAME);
|
Game::Unpause();
|
||||||
} else {
|
this->SetWidgetDirty(WID_AID_SCRIPT_GAME);
|
||||||
AI::Unpause(ai_debug_company);
|
} else {
|
||||||
this->SetWidgetDirty(WID_AID_COMPANY_BUTTON_START + ai_debug_company);
|
AI::Unpause(ai_debug_company);
|
||||||
|
this->SetWidgetDirty(WID_AID_COMPANY_BUTTON_START + ai_debug_company);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* If the last AI/Game Script is unpaused, unpause the game too. */
|
/* If the last AI/Game Script is unpaused, unpause the game too. */
|
||||||
|
@ -1365,10 +1380,12 @@ struct AIDebugWindow : public Window {
|
||||||
this->break_string_filter.AddLine(log->lines[log->pos]);
|
this->break_string_filter.AddLine(log->lines[log->pos]);
|
||||||
if (this->break_string_filter.GetState()) {
|
if (this->break_string_filter.GetState()) {
|
||||||
/* Pause execution of script. */
|
/* Pause execution of script. */
|
||||||
if (ai_debug_company == OWNER_DEITY) {
|
if (!IsDead()) {
|
||||||
Game::Pause();
|
if (ai_debug_company == OWNER_DEITY) {
|
||||||
} else {
|
Game::Pause();
|
||||||
AI::Pause(ai_debug_company);
|
} else {
|
||||||
|
AI::Pause(ai_debug_company);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Pause the game. */
|
/* Pause the game. */
|
||||||
|
|
Loading…
Reference in New Issue