followup to the previous tempo-dragging commit: use argument to Drag::aborted() to...
[ardour.git] / gtk2_ardour / ardour_ui_dependents.cc
index 6f48bee04ba4952655f80e0be935f14d094e5743..c55942b4bda74ec78c39f4dfaca75425f6948b45 100644 (file)
 
 */
 
+#ifdef WAF_BUILD
+#include "gtk2ardour-config.h"
+#endif
+
 /* this file exists solely to break compilation dependencies that
    would connect changes to the mixer or editor objects.
 */
@@ -49,7 +53,9 @@ using namespace ARDOUR;
 void
 ARDOUR_UI::shutdown ()
 {
-       ui_config->save_state();
+       if (ui_config->dirty()) {
+               ui_config->save_state();
+       }
 }
 
 void
@@ -60,6 +66,9 @@ ARDOUR_UI::we_have_dependents ()
        keyboard->setup_keybindings ();
        editor->setup_tooltips ();
        editor->UpdateAllTransportClocks.connect (sigc::mem_fun (*this, &ARDOUR_UI::update_transport_clocks));
+
+       editor->track_mixer_selection ();
+       mixer->track_editor_selection ();
 }
 
 void
@@ -93,7 +102,6 @@ ARDOUR_UI::goto_editor_window ()
 
        editor->show_window ();
        editor->present ();
-       _mixer_on_top = false;
        flush_pending ();
 }
 
@@ -102,17 +110,51 @@ ARDOUR_UI::goto_mixer_window ()
 {
        mixer->show_window ();
        mixer->present ();
-       _mixer_on_top = true;
        flush_pending ();
 }
 
 void
-ARDOUR_UI::toggle_editor_mixer_on_top ()
+ARDOUR_UI::toggle_mixer_window ()
 {
-       if (_mixer_on_top) {
-               goto_editor_window ();
+       Glib::RefPtr<Action> act = ActionManager::get_action (X_("Common"), X_("toggle-mixer"));
+       if (!act) {
+               return;
+       }
+
+       Glib::RefPtr<ToggleAction> tact = Glib::RefPtr<ToggleAction>::cast_dynamic (act);
+
+       if (tact->get_active()) {
+               goto_mixer_window ();
        } else {
+               mixer->hide ();
+       }
+}
+
+void
+ARDOUR_UI::toggle_mixer_on_top ()
+{
+       Glib::RefPtr<Action> act = ActionManager::get_action (X_("Common"), X_("toggle-mixer-on-top"));
+       if (!act) {
+               return;
+       }
+
+       Glib::RefPtr<ToggleAction> tact = Glib::RefPtr<ToggleAction>::cast_dynamic (act);
+
+       if (tact->get_active()) {
+
+               /* Toggle the mixer to `visible' if required */
+               act = ActionManager::get_action (X_("Common"), X_("toggle-mixer"));
+               if (act) {
+                       tact = Glib::RefPtr<ToggleAction>::cast_dynamic (act);
+
+                       if (!tact->get_active()) {
+                               tact->set_active ();
+                       }
+               }
+
                goto_mixer_window ();
+       } else {
+               goto_editor_window ();
        }
 }
 
@@ -130,3 +172,4 @@ ARDOUR_UI::exit_on_main_window_close (GdkEventAny * /*ev*/)
        return TRUE;
 #endif
 }
+