add note onset detection to the ferret, c/o the aubio-based Onset VAMP plugin (REQUIR...
[ardour.git] / gtk2_ardour / streamview.h
index 5a0e10974f9a8c3f472c9123629c24ca403aad99..da44a7a2f082c2509bb2d16abfb5570e70c692c5 100644 (file)
@@ -27,7 +27,6 @@
 #include "enums.h"
 #include "simplerect.h"
 #include "canvas.h"
-#include "color.h"
 
 namespace Gdk {
        class Color;
@@ -44,8 +43,8 @@ namespace ARDOUR {
 
 struct RecBoxInfo {
        ArdourCanvas::SimpleRect* rectangle;
-       jack_nframes_t            start;
-       jack_nframes_t            length;
+       nframes_t            start;
+       nframes_t            length;
 };
 
 class PublicEditor;
@@ -83,14 +82,14 @@ public:
        Gdk::Color get_region_color () const { return region_color; }
        void       apply_color (Gdk::Color&, ColorTarget t);
 
-       RegionView*  find_view (const ARDOUR::Region&);
+       RegionView*  find_view (boost::shared_ptr<const ARDOUR::Region>);
        void         foreach_regionview (sigc::slot<void,RegionView*> slot);
 
        void set_selected_regionviews (RegionSelection&);
-       void get_selectables (jack_nframes_t start, jack_nframes_t end, list<Selectable* >&);
+       void get_selectables (nframes_t start, nframes_t end, list<Selectable* >&);
        void get_inverted_selectables (Selection&, list<Selectable* >& results);
 
-       void add_region_view (ARDOUR::Region*);
+       void add_region_view (boost::shared_ptr<ARDOUR::Region>);
        void region_layered (RegionView*);
        
        sigc::signal<void,RegionView*> RegionViewAdded;
@@ -101,26 +100,26 @@ protected:
 //private: (FIXME?)
 
        void         transport_changed();
+       void         transport_looped();
        void         rec_enable_changed();
        void         sess_rec_enable_changed();
        virtual void setup_rec_box () = 0;
        void         update_rec_box ();
        virtual void update_rec_regions () = 0;
        
-       virtual void add_region_view_internal (ARDOUR::Region*, bool wait_for_waves) = 0;
-       virtual void remove_region_view (ARDOUR::Region* );
-       void         remove_rec_region (ARDOUR::Region*);
+       virtual void add_region_view_internal (boost::shared_ptr<ARDOUR::Region>, bool wait_for_waves, bool recording = false) = 0;
+       virtual void remove_region_view (boost::weak_ptr<ARDOUR::Region> );
+       //void         remove_rec_region (boost::shared_ptr<ARDOUR::Region>); (unused)
 
-       void         display_diskstream (ARDOUR::Diskstream* );
+       void         display_diskstream (boost::weak_ptr<ARDOUR::Diskstream>);
        virtual void undisplay_diskstream ();
        virtual void redisplay_diskstream () = 0;
        void         diskstream_changed ();
        
-       void         playlist_state_changed (ARDOUR::Change);
-       virtual void playlist_changed (ARDOUR::Diskstream* );
+       virtual void playlist_changed (boost::weak_ptr<ARDOUR::Diskstream>);
        virtual void playlist_modified ();
        
-       virtual void color_handler (ColorID, uint32_t) = 0;
+       virtual void color_handler () = 0;
 
 
        RouteTimeAxisView&        _trackview;
@@ -134,7 +133,7 @@ protected:
 
        sigc::connection       screen_update_connection;
        vector<RecBoxInfo>     rec_rects;
-       list<ARDOUR::Region* > rec_regions;
+       list<boost::shared_ptr<ARDOUR::Region> > rec_regions;
        bool                   rec_updating;
        bool                   rec_active;
        bool                   use_rec_regions;