+
+struct RegionSortByTrack {
+ bool operator() (const RegionView* a, const RegionView* b) const {
+
+ /* really, track and position */
+
+ if (a->get_trackview().order == b->get_trackview().order) {
+ return a->region()->position() < b->region()->position();
+ } else {
+ return a->get_trackview().order < b->get_trackview().order;
+ }
+ }
+};
+
+void
+RegionSelection::by_track (list<RegionView*>& foo) const
+{
+ list<RegionView*>::const_iterator i;
+ RegionSortByTrack sorter;
+
+ for (i = _bylayer.begin(); i != _bylayer.end(); ++i) {
+ foo.push_back (*i);
+ }
+
+ foo.sort (sorter);
+ return;
+}
+
+void
+RegionSelection::sort_by_position_and_track ()
+{
+ RegionSortByTrack sorter;
+ sort (sorter);
+}
+
+bool
+RegionSelection::involves (const TimeAxisView& tv) const
+{
+ for (RegionSelection::const_iterator i = begin(); i != end(); ++i) {
+ if (&(*i)->get_trackview() == &tv) {
+ return true;
+ }
+ }
+ return false;
+}
+