Merge pull request #15059 from ZehMatt/fix-15048

Fix #15048: Crash removing litter from cheats
This commit is contained in:
ζeh Matt 2021-07-22 22:37:58 +03:00 committed by GitHub
commit 935e5b28dd
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 8 additions and 7 deletions

View File

@ -1,6 +1,7 @@
0.3.4+ (in development)
------------------------------------------------------------------------
- Fix: [#15028] Crash when placing large scenery.
- Fix: [#15048] Crash when removing litter with cheats.
- Fix: [#15052] Crash when using banner window.
- Improved: [#12626] Allow using RCT2 saves to mark RCT Classic (.sea) parks as finished and vice versa.

View File

@ -474,7 +474,7 @@ InteractionInfo ViewportInteractionGetItemRight(const ScreenCoordsXY& screenCoor
{
ft.Add<rct_string_id>(STR_BROKEN);
}
ft.Add<rct_string_id>(pathAddEntry->name);
ft.Add<rct_string_id>(pathAddEntry != nullptr ? pathAddEntry->name : STR_NONE);
SetMapTooltip(ft);
return info;
}

View File

@ -417,20 +417,20 @@ void SetCheatAction::RemoveLitter() const
sprite_remove(litter);
}
tile_element_iterator it;
tile_element_iterator it{};
tile_element_iterator_begin(&it);
do
{
if (it.element->GetType() != TILE_ELEMENT_TYPE_PATH)
continue;
if (!(it.element)->AsPath()->HasAddition())
auto* path = it.element->AsPath();
if (path->HasAddition())
continue;
auto* pathBitEntry = it.element->AsPath()->GetAdditionEntry();
if (pathBitEntry->flags & PATH_BIT_FLAG_IS_BIN)
it.element->AsPath()->SetAdditionStatus(0xFF);
auto* pathBitEntry = path->GetAdditionEntry();
if (pathBitEntry != nullptr && pathBitEntry->flags & PATH_BIT_FLAG_IS_BIN)
path->SetAdditionStatus(0xFF);
} while (tile_element_iterator_next(&it));