restore ability to create TOC and CUE files during export. this is an option in a...
[ardour.git] / libs / ardour / ardour / export_format_specification.h
1 /*
2     Copyright (C) 2008 Paul Davis
3     Author: Sakari Bergen
4
5     This program is free software; you can redistribute it and/or modify
6     it under the terms of the GNU General Public License as published by
7     the Free Software Foundation; either version 2 of the License, or
8     (at your option) any later version.
9
10     This program is distributed in the hope that it will be useful,
11     but WITHOUT ANY WARRANTY; without even the implied warranty of
12     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13     GNU General Public License for more details.
14
15     You should have received a copy of the GNU General Public License
16     along with this program; if not, write to the Free Software
17     Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
18
19 */
20
21 #ifndef __ardour_export_format_specification_h__
22 #define __ardour_export_format_specification_h__
23
24 #include <string>
25
26 #include "pbd/uuid.h"
27
28 #include "ardour/types.h"
29 #include "ardour/export_format_base.h"
30
31 class XMLNode;
32
33 namespace ARDOUR
34 {
35
36 class ExportFormat;
37 class ExportFormatCompatibility;
38 class Session;
39
40 class ExportFormatSpecification : public ExportFormatBase {
41
42   private:
43
44         /* Time struct for keeping time formats as close as possible to what was requested */
45
46         struct Time : public AnyTime {
47                 Time (Session & session) : AnyTime (), session (session) {}
48                 Time & operator= (AnyTime const & other);
49
50                 framecnt_t get_frames_at (framepos_t position, framecnt_t target_rate) const;
51
52                 /* Serialization */
53
54                 XMLNode & get_state ();
55                 int set_state (const XMLNode & node);
56
57           private:
58                 Session & session;
59         };
60
61   private:
62         friend class ExportElementFactory;
63         explicit ExportFormatSpecification (Session & s);
64         ExportFormatSpecification (Session & s, XMLNode const & state);
65
66   public:
67         ExportFormatSpecification (ExportFormatSpecification const & other);
68         ~ExportFormatSpecification ();
69
70         /* compatibility */
71
72         bool is_compatible_with (ExportFormatCompatibility const & compatibility) const;
73         bool is_complete () const;
74
75         /* Modifying functions */
76
77         void set_format (boost::shared_ptr<ExportFormat> format);
78
79         void set_name (std::string const & name) { _name = name; }
80
81         void set_type (Type type) { _type = type; }
82         void set_format_id (FormatId value) { format_ids.clear(); format_ids.insert (value); }
83         void set_endianness (Endianness value) { endiannesses.clear(); endiannesses.insert (value); }
84         void set_sample_format (SampleFormat value) { sample_formats.clear(); sample_formats.insert (value); }
85         void set_sample_rate (SampleRate value) { sample_rates.clear(); sample_rates.insert (value); }
86         void set_quality (Quality value) { qualities.clear(); qualities.insert (value); }
87
88         void set_dither_type (DitherType value) { _dither_type = value; }
89         void set_src_quality (SRCQuality value) { _src_quality = value; }
90         void set_trim_beginning (bool value) { _trim_beginning = value; }
91         void set_trim_end (bool value) { _trim_end = value; }
92         void set_normalize (bool value) { _normalize = value; }
93         void set_normalize_target (float value) { _normalize_target = value; }
94
95         void set_tag (bool tag_it) { _tag = tag_it; }
96         void set_with_cue (bool yn) { _with_cue = yn; }
97         void set_with_toc (bool yn) { _with_toc = yn; }
98
99         void set_silence_beginning (AnyTime const & value) { _silence_beginning = value; }
100         void set_silence_end (AnyTime const & value) { _silence_end = value; }
101
102         /* Accessing functions */
103
104         PBD::UUID const & id () { return _id; }
105         std::string const & name () const { return _name; }
106         std::string description ();
107
108         bool has_broadcast_info () const { return _has_broadcast_info; }
109         uint32_t channel_limit () const { return _channel_limit; }
110         std::string format_name () const { return _format_name; }
111
112         Type type () const { return _type; }
113         FormatId format_id () const { return *format_ids.begin(); }
114         Endianness endianness () const { return *endiannesses.begin(); }
115         SampleFormat sample_format () const { return *sample_formats.begin(); }
116         SampleRate sample_rate () const { return *sample_rates.begin(); }
117         Quality quality () const { return *qualities.begin(); }
118
119         DitherType dither_type () const { return _dither_type; }
120         SRCQuality src_quality () const { return _src_quality; }
121         bool trim_beginning () const { return _trim_beginning; }
122         bool trim_end () const { return _trim_end; }
123         bool normalize () const { return _normalize; }
124         float normalize_target () const { return _normalize_target; }
125         bool with_toc() const { return _with_toc; }
126         bool with_cue() const { return _with_cue; }
127
128         bool tag () const { return _tag && supports_tagging; }
129
130         framecnt_t silence_beginning_at (framepos_t position, framecnt_t samplerate) const
131                 { return _silence_beginning.get_frames_at (position, samplerate); }
132         framecnt_t silence_end_at (framepos_t position, framecnt_t samplerate) const
133                 { return _silence_end.get_frames_at (position, samplerate); }
134
135         AnyTime silence_beginning_time () const { return _silence_beginning; }
136         AnyTime silence_end_time () const { return _silence_end; }
137
138         /* Serialization */
139
140         XMLNode & get_state ();
141         int set_state (const XMLNode & root);
142
143
144   private:
145
146         Session &        session;
147
148         /* The variables below do not have setters (usually set via set_format) */
149
150         std::string  _format_name;
151         bool            has_sample_format;
152         bool            supports_tagging;
153         bool           _has_broadcast_info;
154         uint32_t       _channel_limit;
155
156         /* The variables below have getters and setters */
157
158         std::string   _name;
159         PBD::UUID       _id;
160
161         Type            _type;
162         DitherType      _dither_type;
163         SRCQuality      _src_quality;
164
165         bool            _tag;
166
167         bool            _trim_beginning;
168         Time            _silence_beginning;
169         bool            _trim_end;
170         Time            _silence_end;
171
172         bool            _normalize;
173         float           _normalize_target;
174         bool            _with_toc;
175         bool            _with_cue;
176
177         /* serialization helpers */
178
179         void add_option (XMLNode * node, std::string const & name, std::string const & value);
180         std::string get_option (XMLNode const * node, std::string const & name);
181
182 };
183
184 } // namespace ARDOUR
185
186 #endif /* __ardour_export_format_specification_h__ */