diff --git a/object_creator/creator_main.cpp b/object_creator/creator_main.cpp index d1f0431b51a3b..72c79eb516819 100644 --- a/object_creator/creator_main.cpp +++ b/object_creator/creator_main.cpp @@ -22,13 +22,6 @@ #include #include -//Required by the sigaction function in the exit_handler -#if defined(_WIN32) -#include "platform_win.h" -#else -#include -#endif - #ifdef _WIN32 #include Q_IMPORT_PLUGIN( QWindowsIntegrationPlugin ); @@ -52,20 +45,7 @@ void exit_handler( int s ) catacurses::endwin(); - // As suggested by https://github.com/CleverRaven/Cataclysm-DDA/pull/67893 - #if !defined(_WIN32) - if( s == 2 ) { - struct sigaction sigIntHandler; - sigIntHandler.sa_handler = SIG_DFL; - sigemptyset( &sigIntHandler.sa_mask ); - sigIntHandler.sa_flags = 0; - sigaction( SIGINT, &sigIntHandler, nullptr ); - kill( getpid(), s ); - } else - #endif - { - exit( exit_status ); - } + exit( exit_status ); } inp_mngr.set_timeout( old_timeout ); } diff --git a/src/debug.cpp b/src/debug.cpp index 469e8d56f5e0c..ce3ba7fd1998b 100644 --- a/src/debug.cpp +++ b/src/debug.cpp @@ -33,7 +33,6 @@ #include "color.h" #include "cursesdef.h" #include "filesystem.h" -#include "game.h" #include "get_version.h" #include "input.h" #include "loading_ui.h" @@ -383,15 +382,7 @@ static void debug_error_prompt( #endif for( bool stop = false; !stop; ) { ui_manager::redraw(); - inp_mngr.set_timeout( 50 ); - input_event ievent = inp_mngr.get_input_event(); - if( ievent.type == input_event_t::timeout ) { - if( are_we_quitting() ) { - g->query_exit_to_OS(); - } - continue; - } - switch( ievent.get_first_input() ) { + switch( inp_mngr.get_input_event().get_first_input() ) { #if defined(TILES) case 'c': case 'C': diff --git a/src/do_turn.cpp b/src/do_turn.cpp index cc0e48668d5db..400ef97d66230 100644 --- a/src/do_turn.cpp +++ b/src/do_turn.cpp @@ -103,9 +103,6 @@ namespace turn_handler bool cleanup_at_end() { avatar &u = get_avatar(); - if( are_we_quitting() ) { - return true; - } if( g->uquit == QUIT_DIED || g->uquit == QUIT_SUICIDE ) { // Put (non-hallucinations) into the overmap so they are not lost. for( monster &critter : g->all_monsters() ) { diff --git a/src/flexbuffer_json.cpp b/src/flexbuffer_json.cpp index 11a3cec8f06fa..28c279d04c7f1 100644 --- a/src/flexbuffer_json.cpp +++ b/src/flexbuffer_json.cpp @@ -7,7 +7,6 @@ #include "cata_unreachable.h" #include "filesystem.h" -#include "game.h" #include "json.h" namespace @@ -253,9 +252,6 @@ bool JsonValue::read( std::string &s, bool throw_on_error ) const void JsonObject::report_unvisited() const { #ifndef CATA_IN_TOOL - if( g && g->uquit == quit_status::QUIT_EXIT ) { - return; - } if( !std::uncaught_exceptions() && report_unvisited_members && !visited_fields_bitset_.all() ) { std::vector skipped_members; skipped_members.reserve( visited_fields_bitset_.size() ); diff --git a/src/game.cpp b/src/game.cpp index 7d2efce71726a..0df9b2c418f9b 100644 --- a/src/game.cpp +++ b/src/game.cpp @@ -2868,27 +2868,8 @@ bool game::try_get_right_click_action( action_id &act, const tripoint_bub_ms &mo return true; } -bool game::query_exit_to_OS() -{ - const int old_timeout = inp_mngr.get_timeout(); - inp_mngr.reset_timeout(); - uquit = QUIT_EXIT_PENDING; // change it before query so input_context doesn't get confused - if( query_yn( _( "Really Quit? All unsaved changes will be lost." ) ) ) { - uquit = QUIT_EXIT; - throw exit_exception(); - } - uquit = QUIT_NO; - inp_mngr.set_timeout( old_timeout ); - ui_manager::redraw_invalidated(); - catacurses::doupdate(); - return false; -} - bool game::is_game_over() { - if( are_we_quitting() ) { - return query_exit_to_OS(); - } if( uquit == QUIT_DIED || uquit == QUIT_WATCH ) { Creature *player_killer = u.get_killer(); if( player_killer && player_killer->as_character() ) { @@ -14155,8 +14136,3 @@ global_variables &get_globals() { return g->global_variables_instance; } - -bool are_we_quitting() -{ - return g && ( g->uquit == QUIT_EXIT || g->uquit == QUIT_EXIT_PENDING ); -} diff --git a/src/game.h b/src/game.h index 12b8baff6853c..4eeb65a8acc7c 100644 --- a/src/game.h +++ b/src/game.h @@ -57,8 +57,6 @@ enum quit_status { QUIT_NOSAVED, // Quit without saving QUIT_DIED, // Actual death QUIT_WATCH, // Died, and watching aftermath - QUIT_EXIT, // Skip main menu and quit directly to OS - QUIT_EXIT_PENDING, // same as above, used temporarily so input_context doesn't get confused }; enum safe_mode_type { @@ -1010,8 +1008,6 @@ class game void bury_screen() const;// Bury a dead character (record their last words) void death_screen(); // Display our stats, "GAME OVER BOO HOO" public: - bool query_exit_to_OS(); - class exit_exception: public std::exception {}; /** * If there is a robot (that can be disabled), query the player * and try to disable it. @@ -1322,6 +1318,4 @@ namespace cata_event_dispatch void avatar_moves( const tripoint_abs_ms &old_abs_pos, const avatar &u, const map &m ); } // namespace cata_event_dispatch -bool are_we_quitting(); - #endif // CATA_SRC_GAME_H diff --git a/src/handle_action.cpp b/src/handle_action.cpp index c0db327e8ec02..724f5d5d9256c 100644 --- a/src/handle_action.cpp +++ b/src/handle_action.cpp @@ -336,9 +336,6 @@ input_context game::get_player_input( std::string &action ) creature_tracker &creatures = get_creature_tracker(); do { - if( are_we_quitting() ) { - break; - } if( bWeatherEffect && get_option( "ANIMATION_RAIN" ) ) { /* Location to add rain drop animation bits! Since it refreshes w_terrain it can be added to the animation section easily @@ -2846,9 +2843,11 @@ bool game::do_regular_action( action_id &act, avatar &player_character, break; case ACTION_SAVE: - if( save() ) { - player_character.set_moves( 0 ); - uquit = QUIT_SAVED; + if( query_yn( _( "Save and quit?" ) ) ) { + if( save() ) { + player_character.set_moves( 0 ); + uquit = QUIT_SAVED; + } } break; @@ -3153,10 +3152,6 @@ bool game::handle_action() // of location clicked. std::optional mouse_target; - if( are_we_quitting() ) { - return false; - } - if( uquit == QUIT_WATCH && action == "QUIT" ) { uquit = QUIT_DIED; return false; diff --git a/src/init.cpp b/src/init.cpp index cec7aacbeae98..928a741788851 100644 --- a/src/init.cpp +++ b/src/init.cpp @@ -44,7 +44,6 @@ #include "field_type.h" #include "filesystem.h" #include "flag.h" -#include "game.h" #include "gates.h" #include "harvest.h" #include "help.h" @@ -104,7 +103,6 @@ #include "translations.h" #include "trap.h" #include "type_id.h" -#include "ui_manager.h" #include "veh_type.h" #include "vehicle_group.h" #include "vitamin.h" @@ -126,18 +124,6 @@ DynamicDataLoader &DynamicDataLoader::get_instance() return theDynamicDataLoader; } -namespace -{ - -void check_sigint() -{ - if( g && g->uquit == quit_status::QUIT_EXIT ) { - g->query_exit_to_OS(); - } -} - -} // namespace - void DynamicDataLoader::load_object( const JsonObject &jo, const std::string &src, const cata_path &base_path, const cata_path &full_path ) @@ -187,7 +173,6 @@ void DynamicDataLoader::load_deferred( deferred_json &data ) } ++it; inp_mngr.pump_events(); - check_sigint(); } data.erase( data.begin(), it ); if( data.size() == n ) { @@ -631,7 +616,6 @@ void DynamicDataLoader::load_all_from_json( const JsonValue &jsin, const std::st // find type and dispatch each object until array close for( JsonObject jo : ja ) { load_object( jo, src, base_path, full_path ); - check_sigint(); } } else { // not an object or an array? @@ -863,7 +847,6 @@ void DynamicDataLoader::finalize_loaded_data() for( const named_entry &e : entries ) { loading_ui::show( _( "Finalizing" ), e.first ); e.second(); - check_sigint(); } if( !get_option( "SKIP_VERIFICATION" ) ) { @@ -969,6 +952,5 @@ void DynamicDataLoader::check_consistency() for( const named_entry &e : entries ) { loading_ui::show( _( "Verifying" ), e.first ); e.second(); - check_sigint(); } } diff --git a/src/input_context.cpp b/src/input_context.cpp index 927363df459bd..93869ae4532ee 100644 --- a/src/input_context.cpp +++ b/src/input_context.cpp @@ -134,7 +134,6 @@ static const std::string ANY_INPUT = "ANY_INPUT"; static const std::string HELP_KEYBINDINGS = "HELP_KEYBINDINGS"; static const std::string COORDINATE = "COORDINATE"; static const std::string TIMEOUT = "TIMEOUT"; -static const std::string QUIT = "QUIT"; const std::string &input_context::input_to_action( const input_event &inp ) const { @@ -446,11 +445,6 @@ const std::string &input_context::handle_input( const int timeout ) break; } - if( g->uquit == QUIT_EXIT ) { - g->uquit = QUIT_EXIT_PENDING; - result = &QUIT; - break; - } const std::string &action = input_to_action( next_action ); //Special global key to toggle language to english and back diff --git a/src/main.cpp b/src/main.cpp index 45ffcb8739414..d5d183ab514cb 100644 --- a/src/main.cpp +++ b/src/main.cpp @@ -60,9 +60,6 @@ #include "type_id.h" #include "ui_manager.h" #include "cata_imgui.h" -#if defined(MACOSX) || defined(__CYGWIN__) -# include // getpid() -#endif #if defined(EMSCRIPTEN) #include @@ -143,30 +140,30 @@ namespace // Used only if AttachConsole() works FILE *CONOUT; #endif - -#if !defined(_WIN32) -extern "C" void sigint_handler( int /* s */ ) -{ - if( g->uquit != QUIT_EXIT_PENDING ) { - g->uquit = QUIT_EXIT; - } -} -#endif - -void exit_handler( int /* s */ ) +void exit_handler( int s ) { - deinitDebug(); + const int old_timeout = inp_mngr.get_timeout(); + inp_mngr.reset_timeout(); + if( s != 2 || query_yn( _( "Really Quit? All unsaved changes will be lost." ) ) ) { + deinitDebug(); - g.reset(); + int exit_status = 0; + g.reset(); - catacurses::endwin(); + catacurses::endwin(); #if defined(__ANDROID__) - // Avoid capturing SIGABRT on exit on Android in crash report - // Can be removed once the SIGABRT on exit problem is fixed - signal( SIGABRT, SIG_DFL ); + // Avoid capturing SIGABRT on exit on Android in crash report + // Can be removed once the SIGABRT on exit problem is fixed + signal( SIGABRT, SIG_DFL ); #endif + imclient.reset(); + exit( exit_status ); + } + inp_mngr.set_timeout( old_timeout ); + ui_manager::redraw_invalidated(); + catacurses::doupdate(); } struct arg_handler { @@ -827,7 +824,7 @@ int main( int argc, const char *argv[] ) #if !defined(_WIN32) struct sigaction sigIntHandler; - sigIntHandler.sa_handler = sigint_handler; + sigIntHandler.sa_handler = exit_handler; sigemptyset( &sigIntHandler.sa_mask ); sigIntHandler.sa_flags = 0; sigaction( SIGINT, &sigIntHandler, nullptr ); @@ -853,17 +850,13 @@ int main( int argc, const char *argv[] ) while( true ) { main_menu menu; - try { - if( !menu.opening_screen() ) { - break; - } - - shared_ptr_fast ui = g->create_or_get_main_ui_adaptor(); - get_event_bus().send( getVersionString() ); - while( !do_turn() ) { } - } catch( game::exit_exception const &/* ex */ ) { + if( !menu.opening_screen() ) { break; } + + shared_ptr_fast ui = g->create_or_get_main_ui_adaptor(); + get_event_bus().send( getVersionString() ); + while( !do_turn() ) {} } exit_handler( -999 ); diff --git a/src/main_menu.cpp b/src/main_menu.cpp index b2cd92cf247c5..9331200dd2e84 100644 --- a/src/main_menu.cpp +++ b/src/main_menu.cpp @@ -648,10 +648,6 @@ bool main_menu::opening_screen() #endif while( !start ) { - if( are_we_quitting() ) { - return false; - } - ui_manager::redraw(); std::string action = ctxt.handle_input(); input_event sInput = ctxt.get_raw_input(); @@ -741,8 +737,9 @@ bool main_menu::opening_screen() // also check special keys if( action == "QUIT" ) { #if !defined(EMSCRIPTEN) - g->uquit = QUIT_EXIT; - return false; + if( query_yn( _( "Really quit?" ) ) ) { + return false; + } #endif } else if( action == "LEFT" || action == "PREV_TAB" || action == "RIGHT" || action == "NEXT_TAB" ) { sel_line = 0; @@ -1004,8 +1001,6 @@ bool main_menu::new_character_tab() world_generator->set_active_world( world ); try { g->setup(); - } catch( const game::exit_exception &ex ) { - throw ex; // re-throw to main loop } catch( const std::exception &err ) { debugmsg( "Error: %s", err.what() ); return false; @@ -1058,8 +1053,6 @@ bool main_menu::load_game( std::string const &worldname, save_t const &savegame try { g->setup(); - } catch( game::exit_exception const &/* ex */ ) { - return false; } catch( const std::exception &err ) { debugmsg( "Error: %s", err.what() ); return false; diff --git a/src/sdltiles.cpp b/src/sdltiles.cpp index 45fb732c42256..e1d5762c2b91e 100644 --- a/src/sdltiles.cpp +++ b/src/sdltiles.cpp @@ -3540,9 +3540,8 @@ static void CheckMessages() try_sdl_update(); } if( quit ) { - if( g->uquit != quit_status::QUIT_EXIT_PENDING ) { - g->uquit = quit_status::QUIT_EXIT; - } + catacurses::endwin(); + exit( 0 ); } } diff --git a/src/ui.cpp b/src/ui.cpp index 66b82a69761bb..612342c27b50e 100644 --- a/src/ui.cpp +++ b/src/ui.cpp @@ -994,8 +994,7 @@ void uilist::query( bool loop, int timeout, bool allow_unfiltered_hotkeys ) if( entries[ selected ].enabled || allow_disabled ) { ret = entries[selected].retval; } - } else if( ( allow_cancel && ret_act == "UILIST.QUIT" ) || - ( are_we_quitting() && ret_act == "QUIT" ) ) { + } else if( allow_cancel && ret_act == "UILIST.QUIT" ) { ret = UILIST_CANCEL; } else if( ret_act == "TIMEOUT" ) { ret = UILIST_WAIT_INPUT;