diff options
author | Paul Davis <paul@linuxaudiosystems.com> | 2015-05-06 11:51:04 -0400 |
---|---|---|
committer | Paul Davis <paul@linuxaudiosystems.com> | 2015-06-29 14:16:43 -0400 |
commit | 2363fb71e3ec69d14695207bf13820720679c2d8 (patch) | |
tree | b19a1f270eef539e9f4bb4fc8e1ed7da5fb2f502 /libs/gtkmm2ext/actions.cc | |
parent | 7e097c5efcf10f17434c0497d404e6353f087a40 (diff) |
hand-merge libs/gtkmm2ext part of f49d31a82 from Tracks; provides a way to disable/re-enable OS X main menu
Diffstat (limited to 'libs/gtkmm2ext/actions.cc')
-rw-r--r-- | libs/gtkmm2ext/actions.cc | 102 |
1 files changed, 55 insertions, 47 deletions
diff --git a/libs/gtkmm2ext/actions.cc b/libs/gtkmm2ext/actions.cc index 666ac29c5c..60ca2f0910 100644 --- a/libs/gtkmm2ext/actions.cc +++ b/libs/gtkmm2ext/actions.cc @@ -139,11 +139,11 @@ ActionManager::lookup_entry (const ustring accel_path, Gtk::AccelKey& key) } struct SortActionsByLabel { - bool operator() (Glib::RefPtr<Gtk::Action> a, Glib::RefPtr<Gtk::Action> b) { - ustring astr = a->get_accel_path(); - ustring bstr = b->get_accel_path(); - return astr < bstr; - } + bool operator() (Glib::RefPtr<Gtk::Action> a, Glib::RefPtr<Gtk::Action> b) { + ustring astr = a->get_accel_path(); + ustring bstr = b->get_accel_path(); + return astr < bstr; + } }; void @@ -289,71 +289,63 @@ struct ActionState { typedef std::vector<ActionState> ActionStates; -static std::stack<boost::shared_ptr<ActionStates> > state_stack; +static ActionStates action_states_to_restore; +static bool actions_disabled = false; -static boost::shared_ptr<ActionStates> -get_action_state () +void +ActionManager::save_action_states () { - boost::shared_ptr<ActionStates> state = boost::shared_ptr<ActionStates>(new ActionStates); - /* the C++ API for functions used here appears to be broken in gtkmm2.6, so we fall back to the C level. */ - GList* list = gtk_ui_manager_get_action_groups (ActionManager::ui_manager->gobj()); GList* node; GList* acts; for (node = list; node; node = g_list_next (node)) { - + GtkActionGroup* group = (GtkActionGroup*) node->data; - - /* first pass: collect them all */ - - typedef std::list<Glib::RefPtr<Gtk::Action> > action_list; - action_list the_acts; - + for (acts = gtk_action_group_list_actions (group); acts; acts = g_list_next (acts)) { GtkAction* action = (GtkAction*) acts->data; - - state->push_back (ActionState (action, gtk_action_get_sensitive (action))); + action_states_to_restore.push_back (ActionState (action, gtk_action_get_sensitive (action))); } } - - return state; } void -ActionManager::push_action_state () +ActionManager::enable_active_actions () { - state_stack.push (get_action_state()); -} - -void -ActionManager::pop_action_state () -{ - if (state_stack.empty()) { - warning << string_compose (_("programming error: %1"), X_("ActionManager::pop_action_state called with empty stack")) << endmsg; - return; + if (!actions_disabled) { + return ; } - boost::shared_ptr<ActionStates> as = state_stack.top (); - state_stack.pop (); - - for (ActionStates::iterator i = as->begin(); i != as->end(); ++i) { - gtk_action_set_sensitive ((*i).action, (*i).sensitive); + for (ActionStates::iterator i = action_states_to_restore.begin(); i != action_states_to_restore.end(); ++i) { + if ((*i).action && (*i).sensitive) { + gtk_action_set_sensitive ((*i).action, true); + } } + + action_states_to_restore.clear (); + actions_disabled = false; } void -ActionManager::disable_all_actions () +ActionManager::disable_active_actions () { - push_action_state (); - boost::shared_ptr<ActionStates> as = state_stack.top (); + if (actions_disabled == true ) { + return ; + } + // save all action's states to action_states_to_restore + save_action_states (); - for (ActionStates::iterator i = as->begin(); i != as->end(); ++i) { - gtk_action_set_sensitive ((*i).action, false); + // set all action's states disabled + for (ActionStates::iterator i = action_states_to_restore.begin(); i != action_states_to_restore.end(); ++i) { + if ((*i).sensitive) { + gtk_action_set_sensitive ((*i).action, false); + } } + actions_disabled = true; } void @@ -464,8 +456,24 @@ ActionManager::get_action_from_name (const char* name) void ActionManager::set_sensitive (vector<RefPtr<Action> >& actions, bool state) { - for (vector<RefPtr<Action> >::iterator i = actions.begin(); i != actions.end(); ++i) { - (*i)->set_sensitive (state); + // if actions weren't disabled + if (!actions_disabled) { + for (vector<RefPtr<Action> >::iterator i = actions.begin(); i != actions.end(); ++i) { + (*i)->set_sensitive (state); + } + } + else { + // actions were disabled + // so we should just set necessary action's states in action_states_to_restore + for (vector<RefPtr<Action> >::iterator i = actions.begin(); i != actions.end(); ++i) { + // go through action_states_to_restore and set state of actions + for (ActionStates::iterator j = action_states_to_restore.begin(); j != action_states_to_restore.end(); ++j) { + // all actions should have their individual name, so we can use it for comparison + if (gtk_action_get_name ((*j).action) == (*i)->get_name ()) { + (*j).sensitive = state; + } + } + } } } @@ -503,10 +511,10 @@ ActionManager::set_toggleaction_state (string n, bool s) const char* action_name = last_slash + 1; - RefPtr<Action> act = get_action (group_name, action_name); + RefPtr<Action> act = get_action (group_name, action_name); if (act) { - RefPtr<ToggleAction> tact = RefPtr<ToggleAction>::cast_dynamic(act); - tact->set_active (s); + RefPtr<ToggleAction> tact = RefPtr<ToggleAction>::cast_dynamic(act); + tact->set_active (s); } else { error << string_compose (_("Unknown action name: %1"), name) << endmsg; } |