diff --git a/changelog.md b/changelog.md index 94c4325cd2..20729f88d3 100644 --- a/changelog.md +++ b/changelog.md @@ -8,6 +8,8 @@ Fixed main menu crash when returning from certain modded games Resolved #2794 - Save games and maps cannot have slashes/backslashes, to avoid foldername/filename confusion +Civ is properly destroyed when liberating the last city of the civ + By alkorolyov: - Basic spectator functionality - POC - Console mode for multiple game automation - POC diff --git a/core/src/com/unciv/MainMenuScreen.kt b/core/src/com/unciv/MainMenuScreen.kt index 0edb25e090..3af21a9a63 100644 --- a/core/src/com/unciv/MainMenuScreen.kt +++ b/core/src/com/unciv/MainMenuScreen.kt @@ -46,9 +46,9 @@ class MainMenuScreen: CameraStageBaseScreen() { ImageGetter.ruleset = RulesetCache.getBaseRuleset() ImageGetter.refreshAtlas() - thread(name="ShowMapBackground") { + thread(name = "ShowMapBackground") { val newMap = MapGenerator(RulesetCache.getBaseRuleset()) - .generateMap(MapParameters().apply { size = MapSize.Small; type=MapType.default }) + .generateMap(MapParameters().apply { size = MapSize.Small; type = MapType.default }) Gdx.app.postRunnable { // for GL context val mapHolder = EditorMapHolder(MapEditorScreen(), newMap) backgroundTable.addAction(Actions.sequence( @@ -72,35 +72,40 @@ class MainMenuScreen: CameraStageBaseScreen() { val table = Table().apply { defaults().pad(10f) } val autosaveGame = GameSaver.getSave(autosave, false) if (autosaveGame.exists()) { - val resumeTable = getTableBlock("Resume","OtherIcons/Resume") { autoLoadGame() } + val resumeTable = getTableBlock("Resume", "OtherIcons/Resume") { autoLoadGame() } table.add(resumeTable).row() } - val quickstartTable = getTableBlock("Quickstart","OtherIcons/Quickstart") { QuickstartNewGame() } + val quickstartTable = getTableBlock("Quickstart", "OtherIcons/Quickstart") { QuickstartNewGame() } table.add(quickstartTable).row() - val newGameButton = getTableBlock("Start new game","OtherIcons/New") { + val newGameButton = getTableBlock("Start new game", "OtherIcons/New") { game.setScreen(NewGameScreen(this)) + dispose() } table.add(newGameButton).row() if (GameSaver.getSaves(false).any()) { - val loadGameTable = getTableBlock("Load game","OtherIcons/Load") { game.setScreen(LoadGameScreen(this)) } + val loadGameTable = getTableBlock("Load game", "OtherIcons/Load") + { game.setScreen(LoadGameScreen(this)) } table.add(loadGameTable).row() } - val multiplayerTable = getTableBlock("Multiplayer","OtherIcons/Multiplayer") { game.setScreen(MultiplayerScreen(this)) } + val multiplayerTable = getTableBlock("Multiplayer", "OtherIcons/Multiplayer") + { game.setScreen(MultiplayerScreen(this)) } table.add(multiplayerTable).row() - val mapEditorScreenTable = getTableBlock("Map editor","OtherIcons/MapEditor") { openMapEditorPopup() } + val mapEditorScreenTable = getTableBlock("Map editor", "OtherIcons/MapEditor") + { openMapEditorPopup() } table.add(mapEditorScreenTable) // set the same width for all buttons table.pack() table.children.filterIsInstance