2 Copyright (C) 2006 Paul Davis
4 This program is free software; you can redistribute it and/or modify
5 it under the terms of the GNU General Public License as published by
6 the Free Software Foundation; either version 2 of the License, or
7 (at your option) any later version.
9 This program is distributed in the hope that it will be useful,
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 GNU General Public License for more details.
14 You should have received a copy of the GNU General Public License
15 along with this program; if not, write to the Free Software
16 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
20 #ifndef __sndfile_source_h__
21 #define __sndfile_source_h__
25 #include "ardour/audiofilesource.h"
26 #include "ardour/broadcast_info.h"
27 #include "ardour/progress.h"
31 class LIBARDOUR_API SndFileSource : public AudioFileSource {
33 /** Constructor to be called for existing external-to-session files */
34 SndFileSource (Session&, const std::string& path, int chn, Flag flags);
36 /* Constructor to be called for new in-session files */
37 SndFileSource (Session&, const std::string& path, const std::string& origin,
38 SampleFormat samp_format, HeaderFormat hdr_format, framecnt_t rate,
39 Flag flags = SndFileSource::default_writable_flags);
41 /* Constructor to be called for recovering files being used for
42 * capture. They are in-session, they already exist, they should not
43 * be writable. They are an odd hybrid (from a constructor point of
44 * view) of the previous two constructors.
46 SndFileSource (Session&, const std::string& path, int chn);
48 /** Constructor to be called for existing in-session files during
51 SndFileSource (Session&, const XMLNode&);
53 /** Constructor to losslessly compress existing source */
54 SndFileSource (Session& s, const AudioFileSource& other, const std::string& path, bool use16bits = false, Progress* p = NULL);
58 float sample_rate () const;
59 int update_header (framepos_t when, struct tm&, time_t);
63 framepos_t natural_position () const;
65 framepos_t last_capture_start_frame() const;
66 void mark_capture_start (framepos_t);
67 void mark_capture_end ();
68 void clear_capture_marks();
70 bool set_destructive (bool yn);
72 bool one_of_several_channels () const;
73 uint32_t channel_count () const { return _info.channels; }
75 bool clamped_at_unity () const;
77 static void setup_standard_crossfades (Session const &, framecnt_t sample_rate);
78 static const Source::Flag default_writable_flags;
80 static int get_soundfile_info (const std::string& path, SoundFileInfo& _info, std::string& error_msg);
85 void set_path (const std::string& p);
86 void set_header_timeline_position ();
88 framecnt_t read_unlocked (Sample *dst, framepos_t start, framecnt_t cnt) const;
89 framecnt_t write_unlocked (Sample *dst, framecnt_t cnt);
90 framecnt_t write_float (Sample* data, framepos_t pos, framecnt_t cnt);
95 BroadcastInfo *_broadcast_info;
99 int setup_broadcast_info (framepos_t when, struct tm&, time_t);
104 static framecnt_t xfade_frames;
105 static gain_t* out_coefficient;
106 static gain_t* in_coefficient;
110 framepos_t capture_start_frame;
111 framepos_t file_pos; // unit is frames
114 framecnt_t crossfade (Sample* data, framecnt_t cnt, int dir);
115 void set_timeline_position (framepos_t);
116 framecnt_t destructive_write_unlocked (Sample *dst, framecnt_t cnt);
117 framecnt_t nondestructive_write_unlocked (Sample *dst, framecnt_t cnt);
118 void handle_header_position_change ();
119 PBD::ScopedConnection header_position_connection;
122 } // namespace ARDOUR
124 #endif /* __sndfile_source_h__ */