summaryrefslogtreecommitdiff
path: root/gtk2_ardour/route_time_axis.cc
diff options
context:
space:
mode:
authorCarl Hetherington <carl@carlh.net>2010-05-25 14:50:45 +0000
committerCarl Hetherington <carl@carlh.net>2010-05-25 14:50:45 +0000
commitef94fbf11ca36fc088e58cfa5691cbca7c7a3390 (patch)
tree3937a4fae192b1405a8e5d4ac4ca252808739b68 /gtk2_ardour/route_time_axis.cc
parentd95d6ca7194d337f75e5497b3fb5523607fabdbc (diff)
Remove some dead code. Clean up storage of automation axis menu
items. Fixes #3174. git-svn-id: svn://localhost/ardour2/branches/3.0@7157 d708f5d6-7413-0410-9779-e7cbd77b26cf
Diffstat (limited to 'gtk2_ardour/route_time_axis.cc')
-rw-r--r--gtk2_ardour/route_time_axis.cc123
1 files changed, 53 insertions, 70 deletions
diff --git a/gtk2_ardour/route_time_axis.cc b/gtk2_ardour/route_time_axis.cc
index e77063c893..873eb171d2 100644
--- a/gtk2_ardour/route_time_axis.cc
+++ b/gtk2_ardour/route_time_axis.cc
@@ -253,10 +253,6 @@ RouteTimeAxisView::~RouteTimeAxisView ()
delete _view;
_view = 0;
- for (AutomationTracks::iterator i = _automation_tracks.begin(); i != _automation_tracks.end(); ++i) {
- delete i->second;
- }
-
_automation_tracks.clear ();
delete route_group_menu;
@@ -1212,34 +1208,6 @@ RouteTimeAxisView::get_inverted_selectables (Selection& sel, list<Selectable*>&
return;
}
-bool
-RouteTimeAxisView::show_automation(Evoral::Parameter param)
-{
- return (_show_automation.find(param) != _show_automation.end());
-}
-
-/** Retuns 0 if track for \a param doesn't exist.
- */
-RouteTimeAxisView::RouteAutomationNode*
-RouteTimeAxisView::automation_track (Evoral::Parameter param)
-{
- map<Evoral::Parameter, RouteAutomationNode*>::iterator i = _automation_tracks.find (param);
-
- if (i != _automation_tracks.end()) {
- return i->second;
- } else {
- return 0;
- }
-}
-
-/** Shorthand for GainAutomation, etc.
- */
-RouteTimeAxisView::RouteAutomationNode*
-RouteTimeAxisView::automation_track (AutomationType type)
-{
- return automation_track (Evoral::Parameter(type));
-}
-
RouteGroup*
RouteTimeAxisView::route_group () const
{
@@ -1613,14 +1581,16 @@ RouteTimeAxisView::color_handler ()
void
RouteTimeAxisView::toggle_automation_track (const Evoral::Parameter& param)
{
- RouteAutomationNode* node = automation_track(param);
+ boost::shared_ptr<AutomationTimeAxisView> track = automation_child (param);
+ Gtk::CheckMenuItem* menu = automation_child_menu_item (param);
- if (!node) {
+ if (!track) {
/* it doesn't exist yet, so we don't care about the button state: just add it */
create_automation_child (param, true);
} else {
- bool yn = node->menu_item->get_active();
- if (node->track->set_visibility (node->menu_item->get_active()) && yn) {
+ assert (menu);
+ bool yn = menu->get_active();
+ if (track->set_visibility (menu->get_active()) && yn) {
/* we made it visible, now trigger a redisplay. if it was hidden, then automation_track_hidden()
will have done that for us.
@@ -1636,19 +1606,20 @@ RouteTimeAxisView::toggle_automation_track (const Evoral::Parameter& param)
void
RouteTimeAxisView::automation_track_hidden (Evoral::Parameter param)
{
- RouteAutomationNode* ran = automation_track(param);
+ boost::shared_ptr<AutomationTimeAxisView> track = automation_child (param);
- if (!ran) {
+ if (!track) {
return;
}
+ Gtk::CheckMenuItem* menu = automation_child_menu_item (param);
+
// if Evoral::Parameter::operator< doesn't obey strict weak ordering, we may crash here....
- _show_automation.erase (param);
- ran->track->get_state_node()->add_property (X_("shown"), X_("no"));
+ track->get_state_node()->add_property (X_("shown"), X_("no"));
- if (ran->menu_item && !_hidden) {
+ if (menu && !_hidden) {
ignore_toggle = true;
- ran->menu_item->set_active (false);
+ menu->set_active (false);
ignore_toggle = false;
}
@@ -1665,13 +1636,15 @@ RouteTimeAxisView::show_all_automation ()
/* Show our automation */
- map<Evoral::Parameter, RouteAutomationNode*>::iterator i;
- for (i = _automation_tracks.begin(); i != _automation_tracks.end(); ++i) {
- i->second->track->set_marked_for_display (true);
- i->second->track->canvas_display()->show();
- i->second->track->get_state_node()->add_property ("shown", X_("yes"));
- if (i->second->menu_item) {
- i->second->menu_item->set_active(true);
+ for (AutomationTracks::iterator i = _automation_tracks.begin(); i != _automation_tracks.end(); ++i) {
+ i->second->set_marked_for_display (true);
+ i->second->canvas_display()->show();
+ i->second->get_state_node()->add_property ("shown", X_("yes"));
+
+ Gtk::CheckMenuItem* menu = automation_child_menu_item (i->first);
+
+ if (menu) {
+ menu->set_active(true);
}
}
@@ -1702,13 +1675,15 @@ RouteTimeAxisView::show_existing_automation ()
/* Show our automation */
- map<Evoral::Parameter, RouteAutomationNode*>::iterator i;
- for (i = _automation_tracks.begin(); i != _automation_tracks.end(); ++i) {
- if (i->second->track->line() && i->second->track->line()->npoints() > 0) {
- i->second->track->set_marked_for_display (true);
- i->second->track->canvas_display()->show();
- i->second->track->get_state_node()->add_property ("shown", X_("yes"));
- i->second->menu_item->set_active(true);
+ for (AutomationTracks::iterator i = _automation_tracks.begin(); i != _automation_tracks.end(); ++i) {
+ if (i->second->line() && i->second->line()->npoints() > 0) {
+ i->second->set_marked_for_display (true);
+ i->second->canvas_display()->show();
+ i->second->get_state_node()->add_property ("shown", X_("yes"));
+
+ Gtk::CheckMenuItem* menu = automation_child_menu_item (i->first);
+ assert (menu);
+ menu->set_active(true);
}
}
@@ -1735,12 +1710,15 @@ RouteTimeAxisView::hide_all_automation ()
/* Hide our automation */
- for (map<Evoral::Parameter, RouteAutomationNode*>::iterator i = _automation_tracks.begin(); i != _automation_tracks.end(); ++i) {
- i->second->track->set_marked_for_display (false);
- i->second->track->hide ();
- i->second->track->get_state_node()->add_property ("shown", X_("no"));
- if (i->second->menu_item) {
- i->second->menu_item->set_active (false);
+ for (AutomationTracks::iterator i = _automation_tracks.begin(); i != _automation_tracks.end(); ++i) {
+ i->second->set_marked_for_display (false);
+ i->second->hide ();
+ i->second->get_state_node()->add_property ("shown", X_("no"));
+
+ Gtk::CheckMenuItem* menu = automation_child_menu_item (i->first);
+
+ if (menu) {
+ menu->set_active (false);
}
}
@@ -1752,8 +1730,6 @@ RouteTimeAxisView::hide_all_automation ()
}
}
- _show_automation.clear();
-
no_redraw = false;
_route->gui_changed ("track_height", (void *) 0); /* EMIT_SIGNAL */
}
@@ -1947,14 +1923,10 @@ RouteTimeAxisView::add_automation_child (Evoral::Parameter param, boost::shared_
}
}
- _automation_tracks.insert (std::make_pair (param, new RouteAutomationNode(param, NULL, track)));
+ _automation_tracks[param] = track;
track->set_visibility (!hideit);
- if (!hideit) {
- _show_automation.insert (param);
- }
-
if (!no_redraw) {
_route->gui_changed ("track_height", (void *) 0); /* EMIT_SIGNAL */
}
@@ -2196,7 +2168,7 @@ RouteTimeAxisView::automation_child(Evoral::Parameter param)
{
AutomationTracks::iterator i = _automation_tracks.find(param);
if (i != _automation_tracks.end()) {
- return i->second->track;
+ return i->second;
} else {
return boost::shared_ptr<AutomationTimeAxisView>();
}
@@ -2388,3 +2360,14 @@ RouteTimeAxisView::set_button_names ()
}
mute_button_label.set_text (_("m"));
}
+
+Gtk::CheckMenuItem*
+RouteTimeAxisView::automation_child_menu_item (Evoral::Parameter param)
+{
+ ParameterMenuMap::iterator i = _parameter_menu_map.find (param);
+ if (i == _parameter_menu_map.end()) {
+ return 0;
+ }
+
+ return i->second;
+}