#include <algorithm>
#include <sigc++/bind.h>
-#include <pbd/error.h>
-#include <pbd/stacktrace.h>
+#include "pbd/error.h"
+#include "pbd/stacktrace.h"
-#include <ardour/playlist.h>
+#include "ardour/playlist.h"
+#include "ardour/rc_configuration.h"
#include "region_view.h"
#include "selection.h"
#include "selection_templates.h"
#include "time_axis_view.h"
#include "automation_time_axis.h"
+#include "public_editor.h"
#include "i18n.h"
+using namespace std;
using namespace ARDOUR;
using namespace PBD;
using namespace sigc;
tracks = other.tracks;
time = other.time;
lines = other.lines;
+ midi = other.midi;
}
return *this;
}
a.time == b.time &&
a.lines == b.lines &&
a.playlists == b.playlists &&
- a.redirects == b.redirects;
+ a.midi == b.midi;
}
+/** Clear everything from the Selection */
void
Selection::clear ()
{
clear_lines();
clear_time ();
clear_playlists ();
- clear_redirects ();
+ clear_midi ();
}
void
}
-void
-Selection::clear_redirects ()
-{
- if (!redirects.empty()) {
- redirects.clear ();
- RedirectsChanged ();
- }
-}
-
void
Selection::clear_regions ()
{
}
}
+void
+Selection::clear_midi ()
+{
+ if (!midi.empty()) {
+ midi.clear ();
+ MidiChanged ();
+ }
+}
+
void
Selection::clear_time ()
{
}
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
RegionsChanged ();
}
+void
+Selection::toggle (MidiRegionView* mrv)
+{
+ MidiSelection::iterator i;
+
+ if ((i = find (midi.begin(), midi.end(), mrv)) == midi.end()) {
+ add (mrv);
+ } else {
+ midi.erase (i);
+ }
+
+ MidiChanged ();
+}
+
void
Selection::toggle (vector<RegionView*>& r)
{
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 (const list<TimeAxisView*>& track_list)
{
- bool changed = false;
+ list<TimeAxisView*> added = tracks.add (track_list);
- for (list<TimeAxisView*>::const_iterator i = track_list.begin(); i != track_list.end(); ++i) {
- if (find (tracks.begin(), tracks.end(), (*i)) == tracks.end()) {
- void (Selection::*pmf)(TimeAxisView*) = &Selection::remove;
- (*i)->GoingAway.connect (sigc::bind (mem_fun (*this, pmf), (*i)));
- tracks.push_back (*i);
- changed = true;
- }
+ for (list<TimeAxisView*>::const_iterator i = added.begin(); i != added.end(); ++i) {
+ void (Selection::*pmf)(TimeAxisView*) = &Selection::remove;
+ (*i)->GoingAway.connect (sigc::bind (mem_fun (*this, pmf), (*i)));
}
- if (changed) {
+ if (!added.empty()) {
TracksChanged ();
}
}
}
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) {
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 (MidiRegionView* mrv)
+{
+ if (find (midi.begin(), midi.end(), mrv) == midi.end()) {
+ midi.push_back (mrv);
+ /* XXX should we do this? */
+#if 0
+ if (Config->get_link_region_and_track_selection()) {
+ add (&mrv->get_trackview());
+ }
+#endif
+ MidiChanged ();
+ }
+}
+
long
Selection::add (nframes_t start, nframes_t end)
{
}
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 (MidiRegionView* mrv)
+{
+ MidiSelection::iterator x;
+
+ if ((x = find (midi.begin(), midi.end(), mrv)) != midi.end()) {
+ midi.erase (x);
+ MidiChanged ();
+ }
+
+#if 0
+ /* XXX fix this up ? */
+ if (Config->get_link_region_and_track_selection() && !regions.involves (r->get_trackview())) {
+ remove (&r->get_trackview());
+ }
+#endif
+}
+
void
Selection::remove (uint32_t selection_id)
}
void
-Selection::remove (nframes_t start, nframes_t end)
+Selection::remove (nframes_t /*start*/, nframes_t /*end*/)
{
}
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 (MidiRegionView* mrv)
+{
+ clear_midi ();
+ add (mrv);
+}
+
+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);
}
if (track) {
time.track = track;
- time.group = track->edit_group();
+ time.group = track->route_group();
} else {
time.track = 0;
time.group = 0;
}
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()
;
}
PointsChanged ();
}
+
+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);
+}