Set session of PluginPinWidget created after ::set_session()
[ardour.git] / gtk2_ardour / selection.h
index fe2be2e6e4fe0025c3698a5fa377cbfbe56e4f96..38e2e77591b3b57f1d11236acfdde751de3003b0 100644 (file)
@@ -65,7 +65,7 @@ namespace Evoral {
 
 class Selection : public sigc::trackable, public PBD::ScopedConnectionList
 {
-  public:
+public:
        enum SelectionType {
                Object = 0x1,
                Range = 0x2
@@ -90,12 +90,12 @@ class Selection : public sigc::trackable, public PBD::ScopedConnectionList
        /** only used when this class is used as a cut buffer */
        MidiNoteSelection    midi_notes;
 
-       Selection (PublicEditor const * e);
+       Selection (PublicEditor const * e, bool manage_libardour_selection);
 
        // Selection& operator= (const Selection& other);
 
-       sigc::signal<void> RegionsChanged;
        sigc::signal<void> TracksChanged;
+       sigc::signal<void> RegionsChanged;
        sigc::signal<void> TimeChanged;
        sigc::signal<void> LinesChanged;
        sigc::signal<void> PlaylistsChanged;
@@ -104,17 +104,20 @@ class Selection : public sigc::trackable, public PBD::ScopedConnectionList
        sigc::signal<void> MidiNotesChanged;
        sigc::signal<void> MidiRegionsChanged;
 
-       void block_tracks_changed (bool);
-
        void clear ();
+
+       /** check if all selections are empty
+        * @param internal_selection also check object internals (e.g midi notes, automation points), when false only check objects.
+        * @return true if nothing is selected.
+        */
        bool empty (bool internal_selection = false);
 
        void dump_region_layers();
 
-       bool selected (TimeAxisView*);
-       bool selected (RegionView*);
-       bool selected (Marker*);
-       bool selected (ControlPoint*);
+       bool selected (TimeAxisView*) const;
+       bool selected (RegionView*) const;
+       bool selected (ArdourMarker*) const;
+       bool selected (ControlPoint*) const;
 
        void set (std::list<Selectable*> const &);
        void add (std::list<Selectable*> const &);
@@ -126,13 +129,13 @@ 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 (framepos_t, framepos_t);
-       void set_preserving_all_ranges (framepos_t, framepos_t);
+       long set (samplepos_t, samplepos_t);
+       void set_preserving_all_ranges (samplepos_t, samplepos_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 (ControlPoint *);
-       void set (Marker*);
+       void set (ArdourMarker*);
        void set (const RegionSelection&);
 
        void toggle (TimeAxisView*);
@@ -142,13 +145,13 @@ class Selection : public sigc::trackable, public PBD::ScopedConnectionList
        void toggle (MidiRegionView*);
        void toggle (MidiCutBuffer*);
        void toggle (std::vector<RegionView*>&);
-       long toggle (framepos_t, framepos_t);
+       long toggle (samplepos_t, samplepos_t);
        void toggle (ARDOUR::AutomationList*);
        void toggle (boost::shared_ptr<ARDOUR::Playlist>);
        void toggle (const std::list<boost::shared_ptr<ARDOUR::Playlist> >&);
        void toggle (ControlPoint *);
        void toggle (std::vector<ControlPoint*> const &);
-       void toggle (Marker*);
+       void toggle (ArdourMarker*);
 
        void add (TimeAxisView*);
        void add (const TrackViewList&);
@@ -157,14 +160,14 @@ class Selection : public sigc::trackable, public PBD::ScopedConnectionList
        void add (MidiRegionView*);
        void add (MidiCutBuffer*);
        void add (std::vector<RegionView*>&);
-       long add (framepos_t, framepos_t);
+       long add (samplepos_t, samplepos_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 (ArdourMarker*);
+       void add (const std::list<ArdourMarker*>&);
        void add (const RegionSelection&);
        void add (const PointSelection&);
        void remove (TimeAxisView*);
@@ -174,44 +177,44 @@ class Selection : public sigc::trackable, public PBD::ScopedConnectionList
        void remove (MidiRegionView*);
        void remove (MidiCutBuffer*);
        void remove (uint32_t selection_id);
-       void remove (framepos_t, framepos_t);
+       void remove (samplepos_t, samplepos_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 (ArdourMarker*);
        void remove (ControlPoint *);
 
        void remove_regions (TimeAxisView *);
 
-        void move_time (framecnt_t);
+       void move_time (samplecnt_t);
 
-       void replace (uint32_t time_index, framepos_t start, framepos_t end);
+       void replace (uint32_t time_index, samplepos_t start, samplepos_t end);
 
-/*
- * A note about items in an editing Selection:
- * At a high level, selections can include Tracks, Objects, or Time Ranges
- * Range and Object selections are mutually exclusive.
- * Selecting a Range will deselect all Objects, and vice versa.
- * This is done to avoid confusion over what will happen in an operation such as Delete
- * Tracks are somewhat orthogonal b/c editing operations don't apply to tracks.
- * The Track selection isn't affected when ranges or objects are added.
- */
+       /*
       * A note about items in an editing Selection:
       * At a high level, selections can include Tracks, Objects, or Time Ranges
       * Range and Object selections are mutually exclusive.
       * Selecting a Range will deselect all Objects, and vice versa.
       * This is done to avoid confusion over what will happen in an operation such as Delete
       * Tracks are somewhat orthogonal b/c editing operations don't apply to tracks.
       * The Track selection isn't affected when ranges or objects are added.
       */
 
        void clear_all() { clear_time(); clear_tracks(); clear_objects(); }
 
-       void clear_time();  //clears any time selection  ( i.e. Range )
-       void clear_tracks ();  //clears the track header selections
-       void clear_objects();  //clears the items listed below
+       void clear_time(bool with_signal = true);  //clears any time selection  ( i.e. Range )
+       void clear_tracks (bool with_signal = true);  //clears the track header selections
+       void clear_objects(bool with_signal = true);  //clears the items listed below
 
        // these items get cleared wholesale in clear_objects
-       void clear_regions();
-       void clear_lines ();
-       void clear_playlists ();
-       void clear_points ();
-       void clear_markers ();
-       void clear_midi_notes ();
-       void clear_midi_regions ();
+       void clear_regions(bool with_signal = true);
+       void clear_lines (bool with_signal = true);
+       void clear_playlists (bool with_signal = true);
+       void clear_points (bool with_signal = true);
+       void clear_markers (bool with_signal = true);
+       void clear_midi_notes (bool with_signal = true);
+       void clear_midi_regions (bool with_signal = true);
 
        void foreach_region (void (ARDOUR::Region::*method)(void));
        void foreach_regionview (void (RegionView::*method)(void));
@@ -221,12 +224,16 @@ class Selection : public sigc::trackable, public PBD::ScopedConnectionList
        XMLNode& get_state () const;
        int set_state (XMLNode const &, int);
 
-       PBD::Signal0<void> ClearMidiNoteSelection;
+       std::list<std::pair<PBD::ID const, std::list<Evoral::event_id_t> > > pending_midi_note_selection;
+
+       void core_selection_changed (PBD::PropertyChange const & pc);
 
-  private:
+private:
        PublicEditor const * editor;
        uint32_t next_time_id;
-       bool _no_tracks_changed;
+       bool     manage_libardour_selection;
+
+       TrackViewList add_grouped_tracks (TrackViewList const & t);
 };
 
 bool operator==(const Selection& a, const Selection& b);