/* Copyright (C) 2005 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 the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. $Id$ */ #include #include #include #include #include "actions.h" using namespace std; using namespace Gtk; using namespace Glib; using namespace sigc; using namespace ActionManager; vector > ActionManager::session_sensitive_actions; vector > ActionManager::region_list_selection_sensitive_actions; vector > ActionManager::region_selection_sensitive_actions; vector > ActionManager::track_selection_sensitive_actions; vector > ActionManager::plugin_selection_sensitive_actions; vector > ActionManager::range_sensitive_actions; vector > ActionManager::jack_sensitive_actions; string ActionManager::unbound_string = "--"; static vector > ui_managers; void register_ui_manager (RefPtr uim) { ui_managers.push_back (uim); } RefPtr register_action (RefPtr group, string name, string label, slot sl, guint key, Gdk::ModifierType mods) { RefPtr act = register_action (group, name, label, sl); AccelMap::add_entry (act->get_accel_path(), key, mods); return act; } RefPtr register_action (RefPtr group, string name, string label, slot sl) { RefPtr act = register_action (group, name, label); group->add (act, sl); return act; } RefPtr register_action (RefPtr group, string name, string label) { RefPtr act; act = Action::create (name, label); group->add (act); return act; } RefPtr register_radio_action (RefPtr group, RadioAction::Group rgroup, string name, string label, slot sl, guint key, Gdk::ModifierType mods) { RefPtr act = register_radio_action (group, rgroup, name, label, sl); AccelMap::add_entry (act->get_accel_path(), key, mods); return act; } RefPtr register_radio_action (RefPtr group, RadioAction::Group rgroup, string name, string label, slot sl) { RefPtr act; act = RadioAction::create (rgroup, name, label); group->add (act, sl); return act; } RefPtr register_toggle_action (RefPtr group, string name, string label, slot sl, guint key, Gdk::ModifierType mods) { RefPtr act = register_toggle_action (group,name, label, sl); AccelMap::add_entry (act->get_accel_path(), key, mods); return act; } RefPtr register_toggle_action (RefPtr group, string name, string label, slot sl) { RefPtr act; act = ToggleAction::create (name, label); group->add (act, sl); return act; } bool lookup_entry (const ustring accel_path, Gtk::AccelKey& key) { GtkAccelKey gkey; bool known = gtk_accel_map_lookup_entry (accel_path.c_str(), &gkey); if (known) { key = AccelKey (gkey.accel_key, Gdk::ModifierType (gkey.accel_mods)); } else { key = AccelKey (GDK_VoidSymbol, Gdk::ModifierType (0)); } return known; } void merge_actions (RefPtr dst, const RefPtr src) { ListHandle > group_actions = src->get_actions(); for (ListHandle >::iterator a = group_actions.begin(); a != group_actions.end(); ++a) { RefPtr act = Action::create ((*a)->get_name(), (*a)->property_label()); dst->add (act); } } void get_all_actions (vector& names, vector& paths, vector& keys, vector& bindings) { for (vector >::iterator u = ui_managers.begin(); u != ui_managers.end(); ++u) { ListHandle > uim_groups = (*u)->get_action_groups (); for (ListHandle >::iterator g = uim_groups.begin(); g != uim_groups.end(); ++g) { ListHandle > group_actions = (*g)->get_actions(); for (ListHandle >::iterator a = group_actions.begin(); a != group_actions.end(); ++a) { ustring accel_path; accel_path = (*a)->get_accel_path(); names.push_back ((*a)->get_name()); paths.push_back (accel_path); AccelKey key; bool known = lookup_entry (accel_path, key); if (known) { keys.push_back ((*u)->get_accel_group()->name (key.get_key(), Gdk::ModifierType (key.get_mod()))); } else { keys.push_back (unbound_string); } bindings.push_back (AccelKey (key.get_key(), Gdk::ModifierType (key.get_mod()))); } } } }