update drobilla's fascistic dir-locals.el to force emacs users into whitespace submis...
[ardour.git] / gtk2_ardour / ardour_ui_dependents.cc
index e1d00548914b21754a08a1dae1d6f9e73cde052e..f7e6a89eb0d7e5b58d95f13527b7eb69b90db984 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.
 */
@@ -58,6 +62,7 @@ ARDOUR_UI::we_have_dependents ()
        install_actions ();
        ProcessorBox::register_actions ();
        keyboard->setup_keybindings ();
+       editor->setup_tooltips ();
        editor->UpdateAllTransportClocks.connect (sigc::mem_fun (*this, &ARDOUR_UI::update_transport_clocks));
 }
 
@@ -92,7 +97,6 @@ ARDOUR_UI::goto_editor_window ()
 
        editor->show_window ();
        editor->present ();
-       _mixer_on_top = false;
        flush_pending ();
 }
 
@@ -101,17 +105,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 ();
        }
 }
 
@@ -129,3 +167,4 @@ ARDOUR_UI::exit_on_main_window_close (GdkEventAny * /*ev*/)
        return TRUE;
 #endif
 }
+