Mercurial > octave-nkf
diff libgui/src/main-window.cc @ 16485:8b783661e03f
improve exit sequence for GUI
* octave-link.h, octave-link.cc (octave_link::accepting_events):
Delete variable and all uses.
(octave_link::link_enabled): New data member.
(octave_link::octave_link): Don't set octave_exit. Initialize
link_enabled.
(octave_link::do_exit): Delete definition. Now pure virtual.
Return bool.
(octave_link::exit): Call instance->do_exit.
(octave_link::enabled): New function.
(ocave_link::process_events): New arg, disable. Optionally disable
event processing.
Use octave_link::enabled instead of instance_ok everywhere except for
octave_link::exit.
(octave_link::cleanup_instance): Delete.
* octave-qt-link.h, octave-qt-link.cc
(octave_qt_link::octave_qt_link): Accept thread as argument.
Don't connect main_thread::finished signal.
(octave_qt_link::~octave_qt_link): Don't delete main_thread.
(octave_qt_link::do_exit): Emit exit_signal and return true.
(octave_qt_link::exit_signal: New signal.
(octave_qt_link::void octave_thread_finished_signal): Delete.
* main-window.h, main-window.cc (main_window::_octave_main_thread):
New member variable.
(main_window::main_window): Initialize _octave_main_thread and
_octave_qt_link to 0.
(main_window::~main_window): Don't call octave_link::connect_link.
Delete _octave_main_thread.
(main_window::exit): Accept exit status as argument and call
QApplication::exit instead of quit.
(main_window::construct): Don't connect qApp::aboutToQuit to
main_window::prepare_to_exit.
(main_window::construct_octave_qt_link): Create _octave_main_thread
and pass to _octave_qt_link. Don't connect
_octave_qt_link::octave_thread_finished to main_window::exit.
Connect _octave_qt_link::exit_signal to main_window::exit.
* toplev.h, toplev.cc (main_loop): If quitting_gracefully, just return
exit status instead of calling clean_up_and_exit.
(do_octave_atexit): Now static. Call octave_link::process_events with
disable arg set to true.
(octave_atexit_functions): Now static.
(clean_up_and_exit): New argument, safe_to_return.
Call octave_link::exit and possibly return or wait for
octave_link::exit to terminate the process.
* octave.cc (octave_execute_interpreter): Don't alter return value
from main_loop. Pass safe_to_return = true to clean_up_and_exit.
Return retval instead of 0.
(octave_initialize_interpreter): Don't call atexit.
author | John W. Eaton <jwe@octave.org> |
---|---|
date | Tue, 09 Apr 2013 23:08:24 -0400 |
parents | fa842e78f491 |
children | 9ff3181e671c |
line wrap: on
line diff
--- a/libgui/src/main-window.cc Tue Apr 09 23:08:21 2013 -0400 +++ b/libgui/src/main-window.cc Tue Apr 09 23:08:24 2013 -0400 @@ -70,7 +70,9 @@ file_browser_window (new files_dock_widget (this)), doc_browser_window (new documentation_dock_widget (this)), editor_window (create_default_editor (this)), - workspace_window (new workspace_view (this)) + workspace_window (new workspace_view (this)), + _octave_main_thread (0), + _octave_qt_link (0) { // We have to set up all our windows, before we finally launch octave. construct (); @@ -78,23 +80,18 @@ main_window::~main_window (void) { -+ // Destroy the terminal first so that STDERR stream is redirected back -+ // to its original pipe to capture error messages at exit. + // Destroy the terminal first so that STDERR stream is redirected back + // to its original pipe to capture error messages at exit. delete command_window; - delete _workspace_model; - delete status_bar; - delete history_window; - delete file_browser_window; - delete doc_browser_window; + delete workspace_window; delete editor_window; - delete workspace_window; - - // Clean up all dynamically created objects to ensure they are - // deleted before this main_window is. Otherwise, some will be - // attached to a non-existent parent. - - octave_link::connect_link (0); + delete doc_browser_window; + delete file_browser_window; + delete history_window; + delete status_bar; + delete _workspace_model; + delete _octave_main_thread; delete _octave_qt_link; } @@ -266,9 +263,9 @@ } void -main_window::exit (void) +main_window::exit (int status) { - qApp->quit (); + qApp->exit (status); } void @@ -545,9 +542,6 @@ construct_tool_bar (); - connect (qApp, SIGNAL (aboutToQuit ()), - this, SLOT (prepare_to_exit ())); - connect (this, SIGNAL (settings_changed (const QSettings *)), this, SLOT (notice_settings (const QSettings *))); @@ -592,10 +586,12 @@ void main_window::construct_octave_qt_link (void) { - _octave_qt_link = new octave_qt_link (); + _octave_main_thread = new octave_main_thread (); - connect (_octave_qt_link, SIGNAL (octave_thread_finished ()), - this, SLOT (exit ())); + _octave_qt_link = new octave_qt_link (_octave_main_thread); + + connect (_octave_qt_link, SIGNAL (exit_signal (int)), + this, SLOT (exit (int))); connect (_octave_qt_link, SIGNAL (set_workspace_signal