Improved ExportProfileManager error handling, and added some missing (?) initialization
[ardour.git] / libs / ardour / ardour / source_factory.h
index fb591216bfa91e465f9e348c76612c7ad8ab3b9d..7e9be451e8b11a0ce1e26b218a8dc4215fb6ce10 100644 (file)
@@ -36,16 +36,23 @@ class Session;
 
 class SourceFactory {
   public:
+       static void init ();
+
        static sigc::signal<void,boost::shared_ptr<Source> > SourceCreated;
 
-       static boost::shared_ptr<Source> create (Session&, const XMLNode& node);
+       static boost::shared_ptr<Source> create (Session&, const XMLNode& node, bool async = false);
        static boost::shared_ptr<Source> createSilent (Session&, const XMLNode& node, nframes_t nframes, float sample_rate);
 
-       static boost::shared_ptr<Source> createReadable (DataType type, Session&, std::string path, int chn, AudioFileSource::Flag flags, bool announce = true);
-       static boost::shared_ptr<Source> createWritable (DataType type, Session&, std::string name, bool destructive, nframes_t rate, bool announce = true);
+       static boost::shared_ptr<Source> createReadable (DataType type, Session&, std::string path, int chn, AudioFileSource::Flag flags,
+                                                        bool announce = true, bool async = false);
+       static boost::shared_ptr<Source> createWritable (DataType type, Session&, std::string name, bool destructive, nframes_t rate, 
+                                                        bool announce = true, bool async = false);
+
+       static Glib::Cond*                              PeaksToBuild;
+       static Glib::StaticMutex                        peak_building_lock;
+       static std::list<boost::weak_ptr<AudioSource> > files_with_peaks;
 
-  private:
-       static int setup_peakfile (boost::shared_ptr<Source>);
+       static int setup_peakfile (boost::shared_ptr<Source>, bool async);
 };
 
 }