diff options
Diffstat (limited to 'gtk2_ardour/route_group_menu.cc')
-rw-r--r-- | gtk2_ardour/route_group_menu.cc | 21 |
1 files changed, 20 insertions, 1 deletions
diff --git a/gtk2_ardour/route_group_menu.cc b/gtk2_ardour/route_group_menu.cc index 7e05c26fe3..c8ef0a260b 100644 --- a/gtk2_ardour/route_group_menu.cc +++ b/gtk2_ardour/route_group_menu.cc @@ -31,6 +31,8 @@ using namespace ARDOUR; RouteGroupMenu::RouteGroupMenu (Session* s, RouteGroup::Property p) : SessionHandlePtr (s) , _default_properties (p) + , _inhibit_group_selected (false) + , _selected_route_group (0) { rebuild (0); } @@ -40,6 +42,10 @@ RouteGroupMenu::rebuild (RouteGroup* curr) { using namespace Menu_Helpers; + _selected_route_group = curr; + + _inhibit_group_selected = true; + items().clear (); items().push_back (MenuElem (_("New group..."), sigc::mem_fun (*this, &RouteGroupMenu::new_group))); @@ -55,6 +61,8 @@ RouteGroupMenu::rebuild (RouteGroup* curr) if (_session) { _session->foreach_route_group (sigc::bind (sigc::mem_fun (*this, &RouteGroupMenu::add_item), curr, &group)); } + + _inhibit_group_selected = false; } void @@ -72,7 +80,18 @@ RouteGroupMenu::add_item (RouteGroup* rg, RouteGroup* curr, RadioMenuItem::Group void RouteGroupMenu::set_group (RouteGroup* g) { - GroupSelected (g); + if (g == _selected_route_group) { + /* cut off the signal_toggled that GTK emits for an option that is being un-selected + when a new option is being selected instead + */ + return; + } + + if (!_inhibit_group_selected) { + GroupSelected (g); + } + + _selected_route_group = g; } void |