X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=libs%2Fardour%2Fardour%2Faudiofilesource.h;h=6a3e2569cea7bde67973e532544fd269bf36c143;hb=777fe3c68fef42d8fee79432830787bcebdfcb59;hp=af5dabe38880fc3cf0abf871124fb74596a5b0c5;hpb=848e75aaeaa04a81883ed30bcd04abd862f9d1fd;p=ardour.git diff --git a/libs/ardour/ardour/audiofilesource.h b/libs/ardour/ardour/audiofilesource.h index af5dabe388..6a3e2569ce 100644 --- a/libs/ardour/ardour/audiofilesource.h +++ b/libs/ardour/ardour/audiofilesource.h @@ -27,7 +27,7 @@ namespace ARDOUR { -struct SoundFileInfo { +struct LIBARDOUR_API SoundFileInfo { float samplerate; uint16_t channels; int64_t length; @@ -35,21 +35,13 @@ struct SoundFileInfo { int64_t timecode; }; -class AudioFileSource : public AudioSource, public FileSource { +class LIBARDOUR_API AudioFileSource : public AudioSource, public FileSource { public: virtual ~AudioFileSource (); - bool set_name (const std::string& newname) { - return (set_source_name(newname, destructive()) == 0); - } - - std::string peak_path (std::string audio_path); - std::string find_broken_peakfile (std::string missing_peak_path, - std::string audio_path); - - static void set_peak_dir (std::string dir) { peak_dir = dir; } + std::string construct_peak_filepath (const std::string& audio_path, const bool in_session = false, const bool old_peak_name = false) const; - static bool get_soundfile_info (std::string path, SoundFileInfo& _info, std::string& error); + static bool get_soundfile_info (const std::string& path, SoundFileInfo& _info, std::string& error); bool safe_file_extension (const std::string& path) const { return safe_audio_file_extension(path); @@ -58,19 +50,20 @@ public: /* this block of methods do nothing for regular file sources, but are significant for files used in destructive recording. */ - virtual framepos_t last_capture_start_frame() const { return 0; } - virtual void mark_capture_start (framepos_t) {} + virtual samplepos_t last_capture_start_sample() const { return 0; } + virtual void mark_capture_start (samplepos_t) {} virtual void mark_capture_end () {} virtual void clear_capture_marks() {} virtual bool one_of_several_channels () const { return false; } virtual void flush () = 0; - virtual int update_header (framepos_t when, struct tm&, time_t) = 0; + virtual int update_header (samplepos_t when, struct tm&, time_t) = 0; virtual int flush_header () = 0; - void mark_streaming_write_completed (); + void mark_streaming_write_completed (const Lock& lock); int setup_peakfile (); + void set_gain (float g, bool temporarily = false); XMLNode& get_state (); int set_state (const XMLNode&, int version); @@ -83,7 +76,7 @@ public: static bool is_empty (Session&, std::string path); static void set_bwf_serial_number (int); - static void set_header_position_offset (framecnt_t offset); + static void set_header_position_offset (samplecnt_t offset); static PBD::Signal0 HeaderPositionOffsetChanged; @@ -98,6 +91,12 @@ protected: /** Constructor to be called for existing in-session files */ AudioFileSource (Session&, const XMLNode&, bool must_exist = true); + /** Constructor to be called for crash recovery. Final argument is not + * used but exists to differentiate from the external-to-session + * constructor above. + */ + AudioFileSource (Session&, const std::string& path, Source::Flag flags, bool); + int init (const std::string& idstr, bool must_exist); virtual void set_header_timeline_position () = 0; @@ -105,20 +104,14 @@ protected: int move_dependents_to_trash(); - static Sample* get_interleave_buffer (framecnt_t size); - - static std::string peak_dir; + static Sample* get_interleave_buffer (samplecnt_t size); static char bwf_country_code[3]; static char bwf_organization_code[4]; static char bwf_serial_number[13]; /** Kept up to date with the position of the session location start */ - static framecnt_t header_position_offset; - - private: - std::string old_peak_path (std::string audio_path); - std::string broken_peak_path (std::string audio_path); + static samplecnt_t header_position_offset; }; } // namespace ARDOUR