along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
- $Id$
*/
#include <algorithm>
#include <sigc++/bind.h>
#include <pbd/error.h>
+#include <pbd/stacktrace.h>
#include <ardour/playlist.h>
#include "selection_templates.h"
#include "time_axis_view.h"
#include "automation_time_axis.h"
+#include "public_editor.h"
#include "i18n.h"
a.time.group == b.time.group &&
a.time == b.time &&
a.lines == b.lines &&
- a.playlists == b.playlists &&
- a.redirects == b.redirects;
+ a.playlists == b.playlists;
}
+/** Clear everything from the Selection */
void
Selection::clear ()
{
clear_lines();
clear_time ();
clear_playlists ();
- clear_redirects ();
}
void
}
-void
-Selection::clear_redirects ()
-{
- if (!redirects.empty()) {
- redirects.clear ();
- RedirectsChanged ();
- }
-}
-
void
Selection::clear_regions ()
{
/* Selections own their playlists */
for (PlaylistSelection::iterator i = playlists.begin(); i != playlists.end(); ++i) {
+ /* selections own their own regions, which are copies of the "originals". make them go away */
+ (*i)->drop_regions ();
(*i)->release ();
}
}
void
-Selection::toggle (boost::shared_ptr<Redirect> r)
+Selection::clear_markers ()
{
- RedirectSelection::iterator i;
-
- if ((i = find (redirects.begin(), redirects.end(), r)) == redirects.end()) {
- redirects.push_back (r);
- } else {
- redirects.erase (i);
+ if (!markers.empty()) {
+ markers.clear ();
+ MarkersChanged();
}
- RedirectsChanged();
-
}
void
return next_time_id - 1;
}
-
-void
-Selection::add (boost::shared_ptr<Redirect> r)
-{
- if (find (redirects.begin(), redirects.end(), r) == redirects.end()) {
- redirects.push_back (r);
- RedirectsChanged();
- }
-}
-
void
Selection::add (boost::shared_ptr<Playlist> pl)
{
}
void
-Selection::add (RegionView* r)
+Selection::add (vector<RegionView*>& v)
{
- if (find (regions.begin(), regions.end(), r) == regions.end()) {
- regions.add (r);
- add (&r->get_trackview());
+ /* XXX This method or the add (const RegionSelection&) needs to go
+ */
+
+ bool changed = false;
+
+ for (vector<RegionView*>::iterator i = v.begin(); i != v.end(); ++i) {
+ if (find (regions.begin(), regions.end(), (*i)) == regions.end()) {
+ changed = regions.add ((*i));
+ if (Config->get_link_region_and_track_selection() && changed) {
+ add (&(*i)->get_trackview());
+ }
+ }
+ }
+
+ if (changed) {
RegionsChanged ();
}
}
void
-Selection::add (vector<RegionView*>& v)
+Selection::add (const RegionSelection& rs)
{
- bool changed = false;
+ /* XXX This method or the add (const vector<RegionView*>&) needs to go
+ */
- for (vector<RegionView*>::iterator i = v.begin(); i != v.end(); ++i) {
+ bool changed = false;
+
+ for (RegionSelection::const_iterator i = rs.begin(); i != rs.end(); ++i) {
if (find (regions.begin(), regions.end(), (*i)) == regions.end()) {
changed = regions.add ((*i));
- if (changed) {
+ if (Config->get_link_region_and_track_selection() && changed) {
add (&(*i)->get_trackview());
}
}
}
-
+
if (changed) {
+ select_edit_group_regions ();
+ RegionsChanged ();
+ }
+}
+
+void
+Selection::add (RegionView* r)
+{
+ if (find (regions.begin(), regions.end(), r) == regions.end()) {
+ regions.add (r);
+ if (Config->get_link_region_and_track_selection()) {
+ add (&r->get_trackview());
+ }
RegionsChanged ();
}
}
}
void
-Selection::add (AutomationList* ac)
+Selection::add (boost::shared_ptr<Evoral::ControlList> cl)
{
- if (find (lines.begin(), lines.end(), ac) == lines.end()) {
- lines.push_back (ac);
- LinesChanged();
+ boost::shared_ptr<ARDOUR::AutomationList> al
+ = boost::dynamic_pointer_cast<ARDOUR::AutomationList>(cl);
+ if (!al) {
+ warning << "Programming error: Selected list is not an ARDOUR::AutomationList" << endmsg;
+ return;
+ return;
}
-}
-
-void
-Selection::remove (boost::shared_ptr<Redirect> r)
-{
- RedirectSelection::iterator i;
- if ((i = find (redirects.begin(), redirects.end(), r)) != redirects.end()) {
- redirects.erase (i);
- RedirectsChanged ();
+ if (find (lines.begin(), lines.end(), al) == lines.end()) {
+ lines.push_back (al);
+ LinesChanged();
}
}
RegionsChanged ();
}
- if (!regions.involves (r->get_trackview())) {
+ if (Config->get_link_region_and_track_selection() && !regions.involves (r->get_trackview())) {
remove (&r->get_trackview());
}
}
}
void
-Selection::remove (AutomationList *ac)
+Selection::remove (boost::shared_ptr<ARDOUR::AutomationList> ac)
{
- list<AutomationList*>::iterator i;
+ AutomationSelection::iterator i;
if ((i = find (lines.begin(), lines.end(), ac)) != lines.end()) {
lines.erase (i);
LinesChanged();
}
}
-void
-Selection::set (boost::shared_ptr<Redirect> r)
-{
- clear_redirects ();
- add (r);
-}
-
void
Selection::set (TimeAxisView* track)
{
}
void
-Selection::set (RegionView* r)
+Selection::set (const RegionSelection& rs)
+{
+ clear_regions();
+ regions = rs;
+ RegionsChanged(); /* EMIT SIGNAL */
+}
+
+void
+Selection::set (RegionView* r, bool also_clear_tracks)
{
clear_regions ();
- clear_tracks ();
+ if (also_clear_tracks) {
+ clear_tracks ();
+ }
add (r);
}
void
Selection::set (vector<RegionView*>& v)
{
- clear_tracks ();
clear_regions ();
- // make sure to deselect any automation selections
- clear_points();
+ if (Config->get_link_region_and_track_selection()) {
+ clear_tracks ();
+ // make sure to deselect any automation selections
+ clear_points();
+ }
add (v);
}
}
void
-Selection::set (AutomationList *ac)
+Selection::set (boost::shared_ptr<Evoral::ControlList> ac)
{
lines.clear();
add (ac);
}
+bool
+Selection::selected (Marker* m)
+{
+ return find (markers.begin(), markers.end(), m) != markers.end();
+}
+
bool
Selection::selected (TimeAxisView* tv)
{
lines.empty () &&
time.empty () &&
playlists.empty () &&
- redirects.empty ()
+ markers.empty()
;
}
Selection::toggle (const vector<AutomationSelectable*>& autos)
{
for (vector<AutomationSelectable*>::const_iterator x = autos.begin(); x != autos.end(); ++x) {
- (*x)->set_selected (!(*x)->get_selected());
+ if ((*x)->get_selected()) {
+ points.remove (**x);
+ } else {
+ points.push_back (**x);
+ }
+
+ delete *x;
}
+
+ PointsChanged (); /* EMIT SIGNAL */
}
void
{
for (vector<AutomationSelectable*>::iterator i = autos.begin(); i != autos.end(); ++i) {
points.push_back (**i);
- delete *i;
}
PointsChanged ();
}
+
+void
+Selection::select_edit_group_regions ()
+{
+ std::set<RegionView*> regions_to_add;
+
+ for (RegionSelection::iterator i = regions.begin(); i != regions.end(); ++i) {
+ vector<RegionView*> e;
+ editor->get_equivalent_regions (*i, e);
+ for (vector<RegionView*>::iterator j = e.begin(); j != e.end(); ++j) {
+ regions_to_add.insert(*j);
+ }
+ }
+
+ for (std::set<RegionView*>::iterator i = regions_to_add.begin(); i != regions_to_add.end(); ++i) {
+ add (*i);
+ }
+}
+
+void
+Selection::set (Marker* m)
+{
+ clear_markers ();
+ add (m);
+}
+
+void
+Selection::toggle (Marker* m)
+{
+ MarkerSelection::iterator i;
+
+ if ((i = find (markers.begin(), markers.end(), m)) == markers.end()) {
+ add (m);
+ } else {
+ remove (m);
+ }
+}
+
+void
+Selection::remove (Marker* m)
+{
+ MarkerSelection::iterator i;
+
+ if ((i = find (markers.begin(), markers.end(), m)) != markers.end()) {
+ markers.erase (i);
+ MarkersChanged();
+ }
+}
+
+void
+Selection::add (Marker* m)
+{
+ if (find (markers.begin(), markers.end(), m) == markers.end()) {
+
+ /* disambiguate which remove() for the compiler */
+
+ void (Selection::*pmf)(Marker*) = &Selection::remove;
+
+ m->GoingAway.connect (bind (mem_fun (*this, pmf), m));
+
+ markers.push_back (m);
+ MarkersChanged();
+ }
+}
+
+void
+Selection::add (const list<Marker*>& m)
+{
+ markers.insert (markers.end(), m.begin(), m.end());
+ MarkersChanged ();
+}
+
+void
+MarkerSelection::range (nframes64_t& s, nframes64_t& e)
+{
+ s = max_frames;
+ e = 0;
+
+ for (MarkerSelection::iterator i = begin(); i != end(); ++i) {
+
+ if ((*i)->position() < s) {
+ s = (*i)->position();
+ }
+
+ if ((*i)->position() > e) {
+ e = (*i)->position();
+ }
+ }
+
+ s = std::min (s, e);
+ e = std::max (s, e);
+}