X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=libs%2Fardour%2Fardour%2Fsource_factory.h;h=b1ee6438f5088041ebe3b76c522e91b2a7c09342;hb=470255effaab8f691b74a717857dc1ff71f32af3;hp=c59dab92234625e110f27d1473b5ed0bb9f99266;hpb=66a9112d48b5726f61eec7ce4cfc4bd15b9420d0;p=ardour.git diff --git a/libs/ardour/ardour/source_factory.h b/libs/ardour/ardour/source_factory.h index c59dab9223..b1ee6438f5 100644 --- a/libs/ardour/ardour/source_factory.h +++ b/libs/ardour/ardour/source_factory.h @@ -24,6 +24,8 @@ #include #include +#include + #include "ardour/source.h" class XMLNode; @@ -32,8 +34,9 @@ namespace ARDOUR { class Session; class AudioSource; +class Playlist; -class SourceFactory { +class LIBARDOUR_API SourceFactory { public: static void init (); @@ -41,20 +44,31 @@ class SourceFactory { static boost::shared_ptr create (Session&, const XMLNode& node, bool async = false); static boost::shared_ptr createSilent (Session&, const XMLNode& node, - framecnt_t nframes, float sample_rate); + framecnt_t nframes, float sample_rate); + + static boost::shared_ptr createExternal + (DataType type, Session&, + const std::string& path, + int chn, Source::Flag flags, bool announce = true, bool async = false); + + static boost::shared_ptr createWritable + (DataType type, Session&, + const std::string& path, + bool destructive, framecnt_t rate, bool announce = true, bool async = false); + - static boost::shared_ptr createReadable (DataType type, Session&, - const std::string& path, - int chn, Source::Flag flags, bool announce = true, bool async = false); + static boost::shared_ptr createForRecovery + (DataType type, Session&, const std::string& path, int chn); - static boost::shared_ptr createWritable (DataType type, Session&, - const std::string& path, const std::string& origin, - bool destructive, nframes_t rate, bool announce = true, bool async = false); + static boost::shared_ptr createFromPlaylist + (DataType type, Session& s, boost::shared_ptr p, const PBD::ID& orig, const std::string& name, + uint32_t chn, frameoffset_t start, framecnt_t len, bool copy, bool defer_peaks); - static Glib::Cond* PeaksToBuild; - static Glib::StaticMutex peak_building_lock; + static Glib::Threads::Cond PeaksToBuild; + static Glib::Threads::Mutex peak_building_lock; static std::list< boost::weak_ptr > files_with_peaks; + static int peak_work_queue_length (); static int setup_peakfile (boost::shared_ptr, bool async); };