X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fardour_ui_dependents.cc;h=c55942b4bda74ec78c39f4dfaca75425f6948b45;hb=c40437430acf4b65d8acb8b084eae8cd2f6f5402;hp=725180e0abf7d6748dea8234aa5897e2e8323c1a;hpb=8dc95efe31405293ef0b76dcc1e286a3899b60cb;p=ardour.git diff --git a/gtk2_ardour/ardour_ui_dependents.cc b/gtk2_ardour/ardour_ui_dependents.cc index 725180e0ab..c55942b4bd 100644 --- a/gtk2_ardour/ardour_ui_dependents.cc +++ b/gtk2_ardour/ardour_ui_dependents.cc @@ -1,5 +1,5 @@ /* - Copyright (C) 2000 Paul Davis + Copyright (C) 2000 Paul Davis This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -17,24 +17,29 @@ */ +#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. */ #include -#include +#include "pbd/error.h" -#include +#include "ardour/session.h" #include "ardour_ui.h" #include "public_editor.h" #include "mixer_ui.h" #include "keyboard.h" +#include "splash.h" #include "route_params_ui.h" +#include "opts.h" #include "i18n.h" -using namespace sigc; using namespace Gtk; using namespace PBD; @@ -43,82 +48,128 @@ namespace ARDOUR { class Route; } +using namespace ARDOUR; + void ARDOUR_UI::shutdown () { - if (session) { - delete session; - session = 0; + if (ui_config->dirty()) { + ui_config->save_state(); } - } void ARDOUR_UI::we_have_dependents () -{ - setup_keybindings (); - editor->UpdateAllTransportClocks.connect (mem_fun (*this, &ARDOUR_UI::update_transport_clocks)); -} - -static void -accel_map_changed (GtkAccelMap* map, - gchar* path, - guint key, - GdkModifierType mod, - gpointer arg) -{ - static_cast(arg)->save_keybindings (); -} - -void -ARDOUR_UI::setup_keybindings () { install_actions (); ProcessorBox::register_actions (); - - cerr << "loading bindings from " << keybindings_path << endl; - - try { - AccelMap::load (keybindings_path); - } catch (...) { - error << string_compose (_("Ardour key bindings file not found at \"%1\" or contains errors."), keybindings_path) - << endmsg; - } - - /* catch changes */ - - GtkAccelMap* accelmap = gtk_accel_map_get(); - g_signal_connect (accelmap, "changed", (GCallback) accel_map_changed, this); - - + 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 ARDOUR_UI::connect_dependents_to_session (ARDOUR::Session *s) { - editor->connect_to_session (s); - mixer->connect_to_session (s); + BootMessage (_("Setup Editor")); + editor->set_session (s); + BootMessage (_("Setup Mixer")); + mixer->set_session (s); /* its safe to do this now */ - + + BootMessage (_("Reload Session History")); s->restore_history (""); } +static bool +_hide_splash (gpointer arg) +{ + ((ARDOUR_UI*)arg)->hide_splash(); + return false; +} + void ARDOUR_UI::goto_editor_window () { + if (splash && splash->is_visible()) { + // in 2 seconds, hide the splash screen + Glib::signal_timeout().connect (sigc::bind (sigc::ptr_fun (_hide_splash), this), 2000); + } + editor->show_window (); + editor->present (); + flush_pending (); } + void ARDOUR_UI::goto_mixer_window () { mixer->show_window (); + mixer->present (); + flush_pending (); } +void +ARDOUR_UI::toggle_mixer_window () +{ + Glib::RefPtr act = ActionManager::get_action (X_("Common"), X_("toggle-mixer")); + if (!act) { + return; + } + + Glib::RefPtr tact = Glib::RefPtr::cast_dynamic (act); + + if (tact->get_active()) { + goto_mixer_window (); + } else { + mixer->hide (); + } +} + +void +ARDOUR_UI::toggle_mixer_on_top () +{ + Glib::RefPtr act = ActionManager::get_action (X_("Common"), X_("toggle-mixer-on-top")); + if (!act) { + return; + } + + Glib::RefPtr tact = Glib::RefPtr::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::cast_dynamic (act); + + if (!tact->get_active()) { + tact->set_active (); + } + } + + goto_mixer_window (); + } else { + goto_editor_window (); + } +} + +/** The main editor window has been closed */ gint -ARDOUR_UI::exit_on_main_window_close (GdkEventAny *ev) +ARDOUR_UI::exit_on_main_window_close (GdkEventAny * /*ev*/) { +#ifdef TOP_MENUBAR + /* just hide the window, and return - the top menu stays up */ + editor->hide (); + return TRUE; +#else + /* time to get out of here */ finish(); return TRUE; +#endif } +