add a SndFileSource c'tor to create .flac encoded file for archiving
[ardour.git] / libs / ardour / ardour / sndfilesource.h
1 /*
2     Copyright (C) 2006 Paul Davis
3
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.
8
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.
13
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.
17
18 */
19
20 #ifndef __sndfile_source_h__
21 #define __sndfile_source_h__
22
23 #include <sndfile.h>
24
25 #include "ardour/audiofilesource.h"
26 #include "ardour/broadcast_info.h"
27 #include "ardour/progress.h"
28
29 namespace ARDOUR {
30
31 class LIBARDOUR_API SndFileSource : public AudioFileSource {
32   public:
33         /** Constructor to be called for existing external-to-session files */
34         SndFileSource (Session&, const std::string& path, int chn, Flag flags);
35
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);
40
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.
45          */
46         SndFileSource (Session&, const std::string& path, int chn);
47
48         /** Constructor to be called for existing in-session files during
49          * session loading
50          */
51         SndFileSource (Session&, const XMLNode&);
52
53         /** Constructor to losslessly compress existing source */
54         SndFileSource (Session& s, const AudioFileSource& other, const std::string& path, bool use16bits = false, Progress* p = NULL);
55
56         ~SndFileSource ();
57
58         float sample_rate () const;
59         int update_header (framepos_t when, struct tm&, time_t);
60         int flush_header ();
61         void flush ();
62
63         framepos_t natural_position () const;
64
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();
69
70         bool set_destructive (bool yn);
71
72         bool one_of_several_channels () const;
73     uint32_t channel_count () const { return _info.channels; }
74
75         bool clamped_at_unity () const;
76
77         static void setup_standard_crossfades (Session const &, framecnt_t sample_rate);
78         static const Source::Flag default_writable_flags;
79
80         static int get_soundfile_info (const std::string& path, SoundFileInfo& _info, std::string& error_msg);
81
82   protected:
83         void close ();
84
85         void set_path (const std::string& p);
86         void set_header_timeline_position ();
87
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);
91
92   private:
93         SNDFILE* _sndfile;
94         SF_INFO _info;
95         BroadcastInfo *_broadcast_info;
96
97         void init_sndfile ();
98         int open();
99         int setup_broadcast_info (framepos_t when, struct tm&, time_t);
100         void file_closed ();
101
102         /* destructive */
103
104         static framecnt_t xfade_frames;
105         static gain_t* out_coefficient;
106         static gain_t* in_coefficient;
107
108         bool          _capture_start;
109         bool          _capture_end;
110         framepos_t     capture_start_frame;
111         framepos_t     file_pos; // unit is frames
112         Sample*        xfade_buf;
113
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;
120 };
121
122 } // namespace ARDOUR
123
124 #endif /* __sndfile_source_h__ */
125