#include "pbd/stacktrace.h"
#include "ardour/playlist.h"
+#include "ardour/rc_configuration.h"
#include "region_view.h"
#include "selection.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.group == b.time.group &&
a.time == b.time &&
a.lines == b.lines &&
- a.playlists == b.playlists;
+ a.playlists == b.playlists &&
+ a.midi == b.midi;
}
/** Clear everything from the Selection */
clear_lines();
clear_time ();
clear_playlists ();
+ clear_midi ();
}
void
}
}
+void
+Selection::clear_midi ()
+{
+ if (!midi.empty()) {
+ midi.clear ();
+ MidiChanged ();
+ }
+}
+
void
Selection::clear_time ()
{
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)
{
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 ();
}
}
}
if (changed) {
- select_edit_group_regions ();
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::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*/)
{
}
RegionsChanged(); /* EMIT SIGNAL */
}
+void
+Selection::set (MidiRegionView* mrv)
+{
+ clear_midi ();
+ add (mrv);
+}
+
void
Selection::set (RegionView* r, bool also_clear_tracks)
{
if (track) {
time.track = track;
- time.group = track->edit_group();
+ time.group = track->route_group();
} else {
time.track = 0;
time.group = 0;
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)
{