mirror of
				https://github.com/luanti-org/luanti.git
				synced 2025-10-25 13:45:23 +02:00 
			
		
		
		
	Fix some Game members not being freed after some startup errors (#14561)
This commit is contained in:
		| @@ -215,8 +215,9 @@ bool ClientLauncher::run(GameStartData &start_data, const Settings &cmd_args) | ||||
| 			L" " + utf8_to_wide(g_version_hash) + | ||||
| 			L" [" + wstrgettext("Main Menu") + L"]").c_str()); | ||||
| 
 | ||||
| 		try {	// This is used for catching disconnects
 | ||||
| 
 | ||||
| #ifdef NDEBUG | ||||
| 		try { | ||||
| #endif | ||||
| 			m_rendering_engine->get_gui_env()->clear(); | ||||
| 
 | ||||
| 			/*
 | ||||
| @@ -267,14 +268,8 @@ bool ClientLauncher::run(GameStartData &start_data, const Settings &cmd_args) | ||||
| 				chat_backend, | ||||
| 				&reconnect_requested | ||||
| 			); | ||||
| 		} //try
 | ||||
| 		catch (con::PeerNotFoundException &e) { | ||||
| 			error_message = gettext("Connection error (timed out?)"); | ||||
| 			errorstream << error_message << std::endl; | ||||
| 		} | ||||
| 
 | ||||
| #ifdef NDEBUG | ||||
| 		catch (std::exception &e) { | ||||
| 		} catch (std::exception &e) { | ||||
| 			error_message = "Some exception: "; | ||||
| 			error_message.append(debug_describe_exc(e)); | ||||
| 			errorstream << error_message << std::endl; | ||||
|   | ||||
| @@ -1057,6 +1057,12 @@ Game::Game() : | ||||
| 
 | ||||
| Game::~Game() | ||||
| { | ||||
| 	delete client; | ||||
| 	delete soundmaker; | ||||
| 	sound_manager.reset(); | ||||
| 
 | ||||
| 	delete server; | ||||
| 
 | ||||
| 	delete hud; | ||||
| 	delete camera; | ||||
| 	delete quicktune; | ||||
| @@ -1311,11 +1317,14 @@ void Game::shutdown() | ||||
| 	} | ||||
| 
 | ||||
| 	delete client; | ||||
| 	client = nullptr; | ||||
| 	delete soundmaker; | ||||
| 	soundmaker = nullptr; | ||||
| 	sound_manager.reset(); | ||||
| 
 | ||||
| 	auto stop_thread = runInThread([=] { | ||||
| 		delete server; | ||||
| 		server = nullptr; | ||||
| 	}, "ServerStop"); | ||||
| 
 | ||||
| 	FpsControl fps_control; | ||||
| @@ -4611,6 +4620,10 @@ void the_game(bool *kill, | ||||
| 		error_message = std::string("ModError: ") + e.what() + | ||||
| 				strgettext("\nCheck debug.txt for details."); | ||||
| 		errorstream << error_message << std::endl; | ||||
| 	} catch (con::PeerNotFoundException &e) { | ||||
| 		error_message = gettext("Connection error (timed out?)"); | ||||
| 		errorstream << error_message << std::endl; | ||||
| 	} | ||||
| 
 | ||||
| 	game.shutdown(); | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user