Merge branch 'master' into windows
[ardour.git] / gtk2_ardour / actions.cc
index 6d29737b8643bb633773529d92a999e4b9322610..3b0133b5355fb6e691c6d50151f401ae4ca4a018 100644 (file)
@@ -31,7 +31,6 @@
 #include "pbd/error.h"
 #include "pbd/file_utils.h"
 
-#include "ardour/ardour.h"
 #include "ardour/filesystem_paths.h"
 #include "ardour/rc_configuration.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;
@@ -65,23 +63,26 @@ vector<RefPtr<Gtk::Action> > ActionManager::jack_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 ()
+{
+       std::string ui_file;
 
-       find_file_in_search_path (spath, "ardour.menus", ui_file);
+       find_file_in_search_path (ardour_config_search_path(), "ardour.menus", 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;
@@ -92,7 +93,7 @@ ActionManager::init ()
 
        if (!loaded) {
                cerr << string_compose (_("%1 will not work without a valid ardour.menus file"), PROGRAM_NAME) << endl;
-                error << string_compose (_("%1 will not work without a valid ardour.menus file"), PROGRAM_NAME) << endmsg;
+               error << string_compose (_("%1 will not work without a valid ardour.menus file"), PROGRAM_NAME) << endmsg;
                exit(1);
        }
 }
@@ -160,11 +161,7 @@ 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";
        }
 }
 
@@ -186,16 +183,3 @@ ActionManager::map_some_state (const char* group, const char* action, sigc::slot
        }
 }
 
-string
-ActionManager::get_key_representation (const string& accel_path, AccelKey& key)
-{
-       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;
-}