waf build works on OS X ; new bindings file and processing system in place for mnemon...
[ardour.git] / gtk2_ardour / selection.cc
index 910cebc7fe718007954d67c23c8253a8afa89f48..cbe5975e87babae9ef2052abee340c235c56053c 100644 (file)
 
 #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"
@@ -33,6 +34,7 @@
 
 #include "i18n.h"
 
+using namespace std;
 using namespace ARDOUR;
 using namespace PBD;
 using namespace sigc;
@@ -268,18 +270,14 @@ Selection::add (const list<boost::shared_ptr<Playlist> >& pllist)
 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 ();
        }
 }
@@ -335,7 +333,6 @@ Selection::add (const RegionSelection& rs)
        }
        
        if (changed) {
-               select_edit_group_regions ();
                RegionsChanged ();
        }
 }
@@ -389,10 +386,17 @@ Selection::replace (uint32_t sid, 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);
+       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;
+       }
+       if (find (lines.begin(), lines.end(), al) == lines.end()) {
+               lines.push_back (al);
                LinesChanged();
        }
 }
@@ -488,14 +492,14 @@ 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();
@@ -581,7 +585,7 @@ Selection::set (TimeAxisView* track, nframes_t start, nframes_t end)
 
        if (track) {
                time.track = track;
-               time.group = track->edit_group();
+               time.group = track->route_group();
        } else {
                time.track = 0;
                time.group = 0;
@@ -595,12 +599,18 @@ Selection::set (TimeAxisView* track, nframes_t start, nframes_t end)
 }
 
 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)
 {
@@ -731,24 +741,6 @@ Selection::add (vector<AutomationSelectable*>& autos)
        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)
 {
@@ -794,3 +786,31 @@ Selection::add (Marker* 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);
+}