move all (G)UI related configuration parameters into UIConfiguration, not RCConfiguration
[ardour.git] / gtk2_ardour / actions.cc
index 5836a4c2011579671494d4f47d566aba6b880f86..43d2eb83c9cd84fe2c2c22664b912171bffc0525 100644 (file)
 #include "pbd/error.h"
 #include "pbd/file_utils.h"
 
-#include "ardour/ardour.h"
 #include "ardour/filesystem_paths.h"
 #include "ardour/rc_configuration.h"
 
 #include "gtkmm2ext/actions.h"
 
-#include "utils.h"
+#include "ardour_ui.h"
 #include "actions.h"
 #include "i18n.h"
 
@@ -51,7 +50,6 @@ vector<RefPtr<Gtk::Action> > ActionManager::session_sensitive_actions;
 vector<RefPtr<Gtk::Action> > ActionManager::write_sensitive_actions;
 vector<RefPtr<Gtk::Action> > ActionManager::region_list_selection_sensitive_actions;
 vector<RefPtr<Gtk::Action> > ActionManager::plugin_selection_sensitive_actions;
-vector<RefPtr<Gtk::Action> > ActionManager::region_selection_sensitive_actions;
 vector<RefPtr<Gtk::Action> > ActionManager::track_selection_sensitive_actions;
 vector<RefPtr<Gtk::Action> > ActionManager::point_selection_sensitive_actions;
 vector<RefPtr<Gtk::Action> > ActionManager::time_selection_sensitive_actions;
@@ -60,39 +58,42 @@ vector<RefPtr<Gtk::Action> > ActionManager::playlist_selection_sensitive_actions
 vector<RefPtr<Gtk::Action> > ActionManager::mouse_edit_point_requires_canvas_actions;
 
 vector<RefPtr<Gtk::Action> > ActionManager::range_sensitive_actions;
-vector<RefPtr<Gtk::Action> > ActionManager::jack_sensitive_actions;
-vector<RefPtr<Gtk::Action> > ActionManager::jack_opposite_sensitive_actions;
+vector<RefPtr<Gtk::Action> > ActionManager::engine_sensitive_actions;
+vector<RefPtr<Gtk::Action> > ActionManager::engine_opposite_sensitive_actions;
 vector<RefPtr<Gtk::Action> > ActionManager::transport_sensitive_actions;
 vector<RefPtr<Gtk::Action> > ActionManager::edit_point_in_region_sensitive_actions;
 
+static Glib::RefPtr<UIManager> ui_manager;
 
 void
 ActionManager::init ()
 {
        ui_manager = UIManager::create ();
+}
 
-       sys::path ui_file;
-
-       SearchPath spath = ardour_search_path() + user_config_directory() + system_config_search_path();
+void
+ActionManager::load_menus (const string& menus_file)
+{
+       std::string ui_file;
 
-       find_file_in_search_path (spath, "ardour.menus", ui_file);
+       find_file (ardour_config_search_path(), menus_file, ui_file);
 
        bool loaded = false;
 
        try {
-               ui_manager->add_ui_from_file (ui_file.to_string());
-               info << string_compose (_("Loading menus from %1"), ui_file.to_string()) << endmsg;
+               ui_manager->add_ui_from_file (ui_file);
+               info << string_compose (_("Loading menus from %1"), ui_file) << endmsg;
                loaded = true;
        } catch (Glib::MarkupError& err) {
-               error << string_compose (_("badly formatted UI definition file: %1"), err.what()) << endmsg;
-               cerr << string_compose (_("badly formatted UI definition file: %1"), err.what()) << endl;
+               error << string_compose (_("badly formatted menu definition file: %1"), err.what()) << endmsg;
+               cerr << string_compose (_("badly formatted menu definition file: %1"), err.what()) << endl;
        } catch (...) {
-               error << _("Ardour menu definition file not found") << endmsg;
+               error << string_compose (_("%1 menu definition file not found"), PROGRAM_NAME) << endmsg;
        }
 
        if (!loaded) {
-               cerr << _("ardour will not work without a valid ardour.menus file") << endl;
-               error << _("ardour will not work without a valid ardour.menus file") << endmsg;
+               cerr << string_compose (_("%1 will not work without a valid menu definition file"), PROGRAM_NAME) << endl;
+               error << string_compose (_("%1 will not work without a valid menu definition file"), PROGRAM_NAME) << endmsg;
                exit(1);
        }
 }
@@ -122,6 +123,31 @@ ActionManager::toggle_config_state (const char* group, const char* action, bool
        }
 }
 
+/** Examine the state of a Configuration setting and a toggle action, and toggle the Configuration
+ * setting if its state doesn't match the toggle action.
+ * @param group Action group.
+ * @param action Action name.
+ * @param Method to set the state of the Configuration setting.
+ * @param Method to get the state of the Configuration setting.
+ */
+void
+ActionManager::toggle_config_state (const char* group, const char* action, bool (UIConfiguration::*set)(bool), bool (UIConfiguration::*get)(void) const)
+{
+       Glib::RefPtr<Action> act = ActionManager::get_action (group, action);
+
+       if (act) {
+               Glib::RefPtr<ToggleAction> tact = Glib::RefPtr<ToggleAction>::cast_dynamic(act);
+
+               if (tact) {
+                       bool x = (ARDOUR_UI::config()->*get)();
+
+                       if (x != tact->get_active()) {
+                               (ARDOUR_UI::config()->*set) (!x);
+                       }
+               }
+       }
+}
+
 void
 ActionManager::toggle_config_state_foo (const char* group, const char* action, sigc::slot<bool, bool> set, sigc::slot<bool> get)
 {
@@ -160,16 +186,17 @@ ActionManager::map_some_state (const char* group, const char* action, bool (RCCo
                        if (tact->get_active() != x) {
                                tact->set_active (x);
                        }
-               } else {
-                       cerr << group << ':' << action << " is not a toggle\n";
                }
-       } else {
-               cerr << group << ':' << action << " not an action\n";
        }
 }
 
+/** Set the state of a ToggleAction using a particular Configuration get() method
+ * @param group Action group.
+ * @param action Action name.
+ * @param get Method to obtain the state that the ToggleAction should have.
+ */
 void
-ActionManager::map_some_state (const char* group, const char* action, sigc::slot<bool> get)
+ActionManager::map_some_state (const char* group, const char* action, bool (UIConfiguration::*get)() const)
 {
        Glib::RefPtr<Action> act = ActionManager::get_action (group, action);
        if (act) {
@@ -177,7 +204,7 @@ ActionManager::map_some_state (const char* group, const char* action, sigc::slot
 
                if (tact) {
 
-                       bool const x = get ();
+                       bool x = (ARDOUR_UI::config()->*get)();
 
                        if (tact->get_active() != x) {
                                tact->set_active (x);
@@ -186,16 +213,21 @@ ActionManager::map_some_state (const char* group, const char* action, sigc::slot
        }
 }
 
-string
-ActionManager::get_key_representation (const string& accel_path, AccelKey& key)
+void
+ActionManager::map_some_state (const char* group, const char* action, sigc::slot<bool> get)
 {
-       bool known = lookup_entry (accel_path, key);
-       
-       if (known) {
-               uint32_t k = possibly_translate_legal_accelerator_to_real_key (key.get_key());
-               key = AccelKey (k, Gdk::ModifierType (key.get_mod()));
-               return ui_manager->get_accel_group()->name (key.get_key(), Gdk::ModifierType (key.get_mod()));
-       } 
-       
-       return unbound_string;
+       Glib::RefPtr<Action> act = ActionManager::get_action (group, action);
+       if (act) {
+               Glib::RefPtr<ToggleAction> tact = Glib::RefPtr<ToggleAction>::cast_dynamic(act);
+
+               if (tact) {
+
+                       bool const x = get ();
+
+                       if (tact->get_active() != x) {
+                               tact->set_active (x);
+                       }
+               }
+       }
 }
+