notably modify the design and logic of the startup dialog, so that we can handle...
[ardour.git] / gtk2_ardour / selection.h
index ad257e084875af5f43f08005ca3042b7cbab4f06..e30ca612eafde66f1a3cbf05018e3770b30ba159 100644 (file)
 
 #include <vector>
 #include <boost/shared_ptr.hpp>
+#include <boost/noncopyable.hpp>
 
 #include <sigc++/signal.h>
 
-#include "pbd/scoped_connections.h"
+#include "pbd/signals.h"
 
 #include "time_selection.h"
 #include "region_selection.h"
@@ -42,6 +43,9 @@ class RegionView;
 class Selectable;
 class PublicEditor;
 class MidiRegionView;
+class AutomationLine;
+class ControlPoint;
+
 
 namespace ARDOUR {
        class Region;
@@ -82,11 +86,11 @@ class Selection : public sigc::trackable, public PBD::ScopedConnectionList
        PointSelection       points;
        MarkerSelection      markers;
        MidiRegionSelection  midi_regions;
+
+       /** only used when this class is used as a cut buffer */
        MidiNoteSelection    midi_notes;
 
-       Selection (PublicEditor const * e) : tracks (e), editor (e), next_time_id (0) {
-               clear();
-       }
+       Selection (PublicEditor const * e);
 
        // Selection& operator= (const Selection& other);
 
@@ -100,6 +104,8 @@ class Selection : public sigc::trackable, public PBD::ScopedConnectionList
        sigc::signal<void> MidiNotesChanged;
        sigc::signal<void> MidiRegionsChanged;
 
+       void block_tracks_changed (bool);
+
        void clear ();
        bool empty (bool internal_selection = false);
 
@@ -108,10 +114,11 @@ class Selection : public sigc::trackable, public PBD::ScopedConnectionList
        bool selected (TimeAxisView*);
        bool selected (RegionView*);
        bool selected (Marker*);
+       bool selected (ControlPoint*);
 
-       void set (std::list<Selectable*>&);
-       void add (std::list<Selectable*>&);
-       void toggle (std::list<Selectable*>&);
+       void set (std::list<Selectable*> const &);
+       void add (std::list<Selectable*> const &);
+       void toggle (std::list<Selectable*> const &);
 
        void set (TimeAxisView*);
        void set (const TrackViewList&);
@@ -119,11 +126,12 @@ class Selection : public sigc::trackable, public PBD::ScopedConnectionList
        void set (RegionView*, bool also_clear_tracks = true);
        void set (MidiRegionView*);
        void set (std::vector<RegionView*>&);
-       long set (nframes_t, nframes_t);
+       long set (framepos_t, framepos_t);
+       void set_preserving_all_ranges (framepos_t, framepos_t);
        void set (boost::shared_ptr<Evoral::ControlList>);
        void set (boost::shared_ptr<ARDOUR::Playlist>);
        void set (const std::list<boost::shared_ptr<ARDOUR::Playlist> >&);
-       void set (AutomationSelectable*);
+       void set (ControlPoint *);
        void set (Marker*);
        void set (const RegionSelection&);
 
@@ -134,11 +142,12 @@ class Selection : public sigc::trackable, public PBD::ScopedConnectionList
        void toggle (MidiRegionView*);
        void toggle (MidiCutBuffer*);
        void toggle (std::vector<RegionView*>&);
-       long toggle (nframes_t, nframes_t);
+       long toggle (framepos_t, framepos_t);
        void toggle (ARDOUR::AutomationList*);
        void toggle (boost::shared_ptr<ARDOUR::Playlist>);
        void toggle (const std::list<boost::shared_ptr<ARDOUR::Playlist> >&);
-       void toggle (const std::vector<AutomationSelectable*>&);
+       void toggle (ControlPoint *);
+       void toggle (std::vector<ControlPoint*> const &);
        void toggle (Marker*);
 
        void add (TimeAxisView*);
@@ -148,13 +157,16 @@ class Selection : public sigc::trackable, public PBD::ScopedConnectionList
        void add (MidiRegionView*);
        void add (MidiCutBuffer*);
        void add (std::vector<RegionView*>&);
-       long add (nframes_t, nframes_t);
+       long add (framepos_t, framepos_t);
        void add (boost::shared_ptr<Evoral::ControlList>);
        void add (boost::shared_ptr<ARDOUR::Playlist>);
        void add (const std::list<boost::shared_ptr<ARDOUR::Playlist> >&);
+       void add (ControlPoint *);
+       void add (std::vector<ControlPoint*> const &);
        void add (Marker*);
        void add (const std::list<Marker*>&);
        void add (const RegionSelection&);
+       void add (const PointSelection&);
        void remove (TimeAxisView*);
        void remove (const TrackViewList&);
        void remove (const MidiNoteSelection&);
@@ -162,14 +174,17 @@ class Selection : public sigc::trackable, public PBD::ScopedConnectionList
        void remove (MidiRegionView*);
        void remove (MidiCutBuffer*);
        void remove (uint32_t selection_id);
-       void remove (nframes_t, nframes_t);
+       void remove (framepos_t, framepos_t);
        void remove (boost::shared_ptr<ARDOUR::AutomationList>);
        void remove (boost::shared_ptr<ARDOUR::Playlist>);
        void remove (const std::list<boost::shared_ptr<ARDOUR::Playlist> >&);
        void remove (const std::list<Selectable*>&);
        void remove (Marker*);
+       void remove (ControlPoint *);
 
-       void replace (uint32_t time_index, nframes_t start, nframes_t end);
+       void remove_regions (TimeAxisView *);
+
+       void replace (uint32_t time_index, framepos_t start, framepos_t end);
 
        void clear_regions();
        void clear_tracks ();
@@ -186,12 +201,13 @@ class Selection : public sigc::trackable, public PBD::ScopedConnectionList
        void foreach_midi_regionview (void (MidiRegionView::*method)(void));
        template<class A> void foreach_region (void (ARDOUR::Region::*method)(A), A arg);
 
+       XMLNode& get_state () const;
+       int set_state (XMLNode const &, int);
+
   private:
-       Selection (const Selection& other) : tracks (other.tracks) {}
        PublicEditor const * editor;
        uint32_t next_time_id;
-       
-       void add (std::vector<AutomationSelectable*>&);
+       bool _no_tracks_changed;
 };
 
 bool operator==(const Selection& a, const Selection& b);