set a theme color for VCA axes in the editor
[ardour.git] / gtk2_ardour / selection.h
index 7585c0ae5685eb9b20a63191e09cbfd5a8d1227f..c9f5eddb4fd9e07e60b40278be5dd48edb6f1b55 100644 (file)
@@ -107,13 +107,18 @@ class Selection : public sigc::trackable, public PBD::ScopedConnectionList
        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 (ArdourMarker*);
        bool selected (ControlPoint*);
 
        void set (std::list<Selectable*> const &);
@@ -132,7 +137,7 @@ class Selection : public sigc::trackable, public PBD::ScopedConnectionList
        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*);
@@ -148,7 +153,7 @@ class Selection : public sigc::trackable, public PBD::ScopedConnectionList
        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&);
@@ -163,8 +168,8 @@ class Selection : public sigc::trackable, public PBD::ScopedConnectionList
        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*);
@@ -179,7 +184,7 @@ class Selection : public sigc::trackable, public PBD::ScopedConnectionList
        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 *);
@@ -200,18 +205,18 @@ class Selection : public sigc::trackable, public PBD::ScopedConnectionList
 
        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,8 +226,6 @@ 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<boost::shared_ptr<Evoral::Note<Evoral::Beats> > > > > pending_midi_note_selection;
 
   private: