X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=libs%2Fardour%2Fardour%2Faudioplaylist.h;h=253329b38e7ab79e4a103fb03bc9e07033a0c296;hb=cdfbec0eb1289c17159f3263c1e6256afdee67dc;hp=ce7c8aa33557defe0bfd48a374d86224f452da5f;hpb=3c00a7ca2ae34cb65c8d3394d9a012f20c69ee77;p=ardour.git diff --git a/libs/ardour/ardour/audioplaylist.h b/libs/ardour/ardour/audioplaylist.h index ce7c8aa335..253329b38e 100644 --- a/libs/ardour/ardour/audioplaylist.h +++ b/libs/ardour/ardour/audioplaylist.h @@ -33,12 +33,42 @@ class Region; class AudioRegion; class Source; +namespace Properties { + /* fake the type, since crossfades are handled by SequenceProperty which doesn't + care about such things. + */ + extern PBD::PropertyDescriptor crossfades; +} + +class AudioPlaylist; + +class CrossfadeListProperty : public PBD::SequenceProperty > > +{ +public: + CrossfadeListProperty (AudioPlaylist &); + + void get_content_as_xml (boost::shared_ptr, XMLNode &) const; + boost::shared_ptr get_content_from_xml (XMLNode const &) const; + +private: + CrossfadeListProperty* clone () const; + CrossfadeListProperty* create () const; + + /* copy construction only by ourselves */ + CrossfadeListProperty (CrossfadeListProperty const & p); + + friend class AudioPlaylist; + /* we live and die with our playlist, no lifetime management needed */ + AudioPlaylist& _playlist; +}; + + class AudioPlaylist : public ARDOUR::Playlist { - public: +public: typedef std::list > Crossfades; + static void make_property_quarks (); - public: AudioPlaylist (Session&, const XMLNode&, bool hidden = false); AudioPlaylist (Session&, std::string name, bool hidden = false); AudioPlaylist (boost::shared_ptr, std::string name, bool hidden = false); @@ -48,7 +78,7 @@ class AudioPlaylist : public ARDOUR::Playlist void clear (bool with_signals=true); - nframes_t read (Sample *dst, Sample *mixdown, float *gain_buffer, nframes_t start, nframes_t cnt, uint32_t chan_n=0); + framecnt_t read (Sample *dst, Sample *mixdown, float *gain_buffer, framepos_t start, framecnt_t cnt, uint32_t chan_n=0); int set_state (const XMLNode&, int version); @@ -59,11 +89,15 @@ class AudioPlaylist : public ARDOUR::Playlist bool destroy_region (boost::shared_ptr); + void update (const CrossfadeListProperty::ChangeRecord &); + + boost::shared_ptr find_crossfade (const PBD::ID &) const; + protected: /* playlist "callbacks" */ void notify_crossfade_added (boost::shared_ptr); - void flush_notifications (); + void flush_notifications (bool); void finalize_split_region (boost::shared_ptr orig, boost::shared_ptr left, boost::shared_ptr right); @@ -72,15 +106,15 @@ class AudioPlaylist : public ARDOUR::Playlist void remove_dependents (boost::shared_ptr region); private: - Crossfades _crossfades; + CrossfadeListProperty _crossfades; Crossfades _pending_xfade_adds; void crossfade_invalidated (boost::shared_ptr); XMLNode& state (bool full_state); void dump () const; - bool region_changed (PBD::Change, boost::shared_ptr); - void crossfade_changed (PBD::Change); + bool region_changed (const PBD::PropertyChange&, boost::shared_ptr); + void crossfade_changed (const PBD::PropertyChange&); void add_crossfade (boost::shared_ptr); void source_offset_changed (boost::shared_ptr region);