comparison libgui/src/main-window.cc @ 19748:21015ca26566

Restructure shutdown flow and behavior for improved robustness * file-editor-interface.h (file_editor_interface::check_closing): Remove closing_state argument from input. * file-editor-tab.cc (file_editor_tab::_cancelled): New static variable for managing chain of file closes. (file_editor_tab::file_editor_tab): Discard _app_closing and _modal_dialog initializations. (file_editor_tab::closeEvent): Upon accepting the close event, als request tab removal. (file_editor_tab::check_modified_file): New simple routine checking for modified file if there hasn't been cancellation yet. (file_editor_tab::run_file): Remove use of _modal_dialog. (file_editor_tab::show_dialog): Add modal input setting. Remove use of _app_closing and _modal_dialog. (file_editor_tab::check_file_modified): Remove situational message for just one. If modified, call show_dialog with modal true, return QMessageBox::Cancel if anything cancelled, otherwise the user decision. (file_editor_tab::handle_file_modified_answer): Do not remove file editor tab in any case. If user cancelled, set _cancelled true. (file_editor_tab::save_file): Add "false" (non-modal) to show_dialog() call. (file_editor_tab::save_file_as): Add "false" (non-modal) to show_dialog() call. (file_editor_tab::conditional_close): Remove input argument and use of variable _app_closing. * file-editor-tab.h (file_editor_tab::conditional_close): Remove input argument. (file_editor_tab::reset_cancel): New member function declaration for managing cancellation of tab chain saves. (file_editor_tab::was_cancel): New member function for indicating any cancellation when saving modified files. (file_editor_tab::check_modified_file): New slot declaration for checking and saving file modifications. (file_editor_tab::show_dialog): Add modal option input argument. (file_editor_tab::_app_closing, file_editor_tab::_modal_dialog): Remove. (file_editor_tab::_cancelled): Add. * file-editor.cc (file_editor::file_editor): Remove _check_closing_done initialization. (file_editor::~file_editor): Remove use of _check_closing_done and check_closing(). (file_editor::check_closing): Clear cancellation history and check all files for modifications, without closing. Close all tabs and delete associated widgets if no cancellation. Remove use of _check_closing_done. (file_editor::request_close_file): Remove argument from conditional_close() function call. (file_editor::request_close_all_files): Ditto. (file_editor::request_close_other_files): Ditto. (file_editor::handle_tab_close_request): Ditto. (file_editor::handle_tab_remove_request): Add comment about deleting sender. (file_editor::add_file_editor_tab): Connect fetab_check_modified_file signal to check_modified_file slot. * file-editor.h (file_editor::fetab_check_modified_file): New signal. (file_editor::check_closing): Remove input argument. (file_editor::_check_closing_done): Remove. * main-window.cc (main_window::confirm_shutdown_octave): Rename of member function main_window::confirm_exit_octave(). Change return type to void. Set octave/qt link confirmation result then awake worker process. (main_window::exit_app): Rename of member function main_window::exit(). (main_window::closeEvent): Rather than post callback event, queue "exit" in the command buffer. (main_window::construct_octave_qt_link): Connect confirm_shutdown_signal to confirm_shutdown_octave slot. Connect exit_app_signal to exit_app slot. (main_window::exit_callback): Remove. (main_window::confirm_exit_octave): Renamed as confirm_shutdown_octave(). * main-window.h (main_window::confirm_shutdown_octave): Rename of slot confirm_exit_octave(). (main_window::exit): Renamed exit_app(). (main_window::exit_callback): Removed declaration. (main_window::confirm_exit_octave): Renamed confirm_shutdown_octave(). * octave-qt-link.cc (octave_qt_link::do_confirm_shutdown): New virtual function definition for initiating GUI shutdown and confirm exit. Worker process goes into sleep mode after issuing cross-thread signal. Return confirmation result. (octave_qt_link::do_exit): Change exit_signal to exit_app_signal. octave-qt-link.h (octave_qt_link::do_confirm_shutdown): New virtual function declaration for qt GUI. (octave_qt_link::mutex): Added. A QMutex for communicating with Qt GUI. (octave_qt_link::waitcondition): Added. For process wait. (octave_qt_link::shutdown_confirmation): Added. Store confirmation result. (octave_qt_link::_shutdown_confirm_result): Added. Confirmation result. (octave_qt_link::exit_signal): Signal renamed exit_app_signal. (octave_qt_link::confirm_shutdown_signal): Added. (octave_qt_link::exit_app_signal): Renamed of exit_signal. octave-link.h (octave_link::confirm_shutdown): Added. Access virtual function do_confirm_shutdown. (octave_link::do_confirm_shutdown): Added. Virtual function for GUI link. toplev.cc (clean_up_and_exit): Change 'retval' to 'status', as header file uses argument name 'status'. (quit): First initiate GUI shutdown via octave_link::confirm_shutdown() and if not confirmed, immediately return thereby avoiding exit sequence.
author Daniel J Sebald <daniel.sebald@ieee.org>
date Sat, 14 Feb 2015 11:27:10 -0600
parents c048358da712
children 3fa35defe495
comparison
equal deleted inserted replaced
19747:1a6fa5a523e4 19748:21015ca26566
775 ! settings->value ("terminal/print_debug_location", false).toBool (); 775 ! settings->value ("terminal/print_debug_location", false).toBool ();
776 776
777 resource_manager::update_network_settings (); 777 resource_manager::update_network_settings ();
778 } 778 }
779 779
780 void
781 main_window::confirm_shutdown_octave (void)
782 {
783 bool closenow = true;
784
785 QSettings *settings = resource_manager::get_settings ();
786
787 if (settings->value ("prompt_to_exit", false).toBool ())
788 {
789 int ans = QMessageBox::question (this, tr ("Octave"),
790 tr ("Are you sure you want to exit Octave?"),
791 QMessageBox::Ok | QMessageBox::Cancel, QMessageBox::Ok);
792
793 if (ans != QMessageBox::Ok)
794 closenow = false;
795 }
796
797 #ifdef HAVE_QSCINTILLA
798 if (closenow)
799 closenow = editor_window->check_closing ();
800 #endif
801
802 _octave_qt_link->shutdown_confirmation (closenow);
803
804 // Awake the worker thread so that it continues shutting down (or not).
805 _octave_qt_link->waitcondition.wakeAll ();
806 }
780 807
781 void 808 void
782 main_window::prepare_to_exit (void) 809 main_window::prepare_to_exit (void)
783 { 810 {
784 write_settings (); 811 write_settings ();
785 } 812 }
786 813
787 void 814 void
788 main_window::exit (int status) 815 main_window::exit_app (int status)
789 { 816 {
790 qApp->exit (status); 817 qApp->exit (status);
791 } 818 }
792 819
793 void 820 void
983 1010
984 void 1011 void
985 main_window::closeEvent (QCloseEvent *e) 1012 main_window::closeEvent (QCloseEvent *e)
986 { 1013 {
987 e->ignore (); 1014 e->ignore ();
988 if (confirm_exit_octave()) 1015 queue_command ("exit");
989 octave_link::post_event (this, &main_window::exit_callback);
990 } 1016 }
991 1017
992 void 1018 void
993 main_window::read_settings (void) 1019 main_window::read_settings (void)
994 { 1020 {
1433 void 1459 void
1434 main_window::construct_octave_qt_link (void) 1460 main_window::construct_octave_qt_link (void)
1435 { 1461 {
1436 _octave_qt_link = new octave_qt_link (this); 1462 _octave_qt_link = new octave_qt_link (this);
1437 1463
1438 connect (_octave_qt_link, SIGNAL (exit_signal (int)), 1464 connect (_octave_qt_link, SIGNAL (confirm_shutdown_signal ()),
1439 this, SLOT (exit (int))); 1465 this, SLOT (confirm_shutdown_octave ()));
1466
1467 connect (_octave_qt_link, SIGNAL (exit_app_signal (int)),
1468 this, SLOT (exit_app (int)));
1440 1469
1441 connect (_octave_qt_link, 1470 connect (_octave_qt_link,
1442 SIGNAL (set_workspace_signal 1471 SIGNAL (set_workspace_signal
1443 (bool, const QString&, const QStringList&, 1472 (bool, const QString&, const QStringList&,
1444 const QStringList&, const QStringList&, 1473 const QStringList&, const QStringList&,
2136 octave_link::post_event (this, &main_window::execute_debug_callback); 2165 octave_link::post_event (this, &main_window::execute_debug_callback);
2137 2166
2138 } 2167 }
2139 2168
2140 void 2169 void
2141 main_window::exit_callback (void)
2142 {
2143 Fquit ();
2144 }
2145
2146 void
2147 main_window::find_files (const QString &start_dir) 2170 main_window::find_files (const QString &start_dir)
2148 { 2171 {
2149 2172
2150 if (! find_files_dlg) 2173 if (! find_files_dlg)
2151 { 2174 {
2356 main_window::clear_clipboard () 2379 main_window::clear_clipboard ()
2357 { 2380 {
2358 _clipboard->clear (QClipboard::Clipboard); 2381 _clipboard->clear (QClipboard::Clipboard);
2359 } 2382 }
2360 2383
2361 bool
2362 main_window::confirm_exit_octave ()
2363 {
2364 bool closenow = true;
2365
2366 QSettings *settings = resource_manager::get_settings ();
2367
2368 if (settings->value ("prompt_to_exit", false).toBool ())
2369 {
2370 int ans = QMessageBox::question (this, tr ("Octave"),
2371 tr ("Are you sure you want to exit Octave?"),
2372 QMessageBox::Ok | QMessageBox::Cancel, QMessageBox::Ok);
2373
2374 if (ans != QMessageBox::Ok)
2375 return false;
2376
2377 }
2378
2379 #ifdef HAVE_QSCINTILLA
2380 closenow = editor_window->check_closing (1); // 1: exit request from gui
2381 #endif
2382
2383 return closenow;
2384 }
2385
2386