Improved ExportProfileManager error handling, and added some missing (?) initialization
[ardour.git] / libs / ardour / ardour / export_profile_manager.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_profile_manager_h__
22 #define __ardour_export_profile_manager_h__
23
24 #include <list>
25 #include <vector>
26 #include <map>
27 #include <set>
28 #include <stdexcept>
29
30 #include <boost/shared_ptr.hpp>
31 #include <boost/weak_ptr.hpp>
32 #include <sigc++/signal.h>
33 #include <glibmm/ustring.h>
34
35 #include <pbd/uuid.h>
36 #include <pbd/file_utils.h>
37 #include <pbd/xml++.h>
38
39 #include <ardour/filesystem_paths.h>
40 #include <ardour/location.h>
41 #include <ardour/types.h>
42
43 using std::string;
44 using std::list;
45 using std::set;
46
47 namespace ARDOUR
48 {
49
50 class ExportHandler;
51 class ExportTimespan;
52 class ExportChannelConfiguration;
53 class ExportFormatSpecification;
54 class ExportFilename;
55 class ExportPreset;
56 class Location;
57 class Session;
58
59 /// Manages (de)serialization of export profiles and related classes
60 class ExportProfileManager
61 {
62   public:
63
64         ExportProfileManager (Session & s);
65         ~ExportProfileManager ();
66
67         void load_profile ();
68         void prepare_for_export ();
69         
70         typedef boost::shared_ptr<ExportPreset> PresetPtr;
71         typedef std::list<PresetPtr> PresetList;
72         
73         PresetList const & get_presets () { return preset_list; }
74         bool load_preset (PresetPtr preset);
75         PresetPtr save_preset (string const & name);
76         void remove_preset ();
77
78   private:
79         typedef boost::shared_ptr<ExportHandler> HandlerPtr;
80
81         typedef std::pair<PBD::UUID, PBD::sys::path> FilePair;
82         typedef std::map<PBD::UUID, PBD::sys::path> FileMap;
83         
84         HandlerPtr  handler;
85         Session &   session;
86         
87         void load_presets ();
88         void load_preset_from_disk (PBD::sys::path const & path);
89         
90         bool set_state (XMLNode const & root);
91         bool set_global_state (XMLNode const & root);
92         bool set_local_state (XMLNode const & root);
93         
94         void serialize_profile (XMLNode & root);
95         void serialize_global_profile (XMLNode & root);
96         void serialize_local_profile (XMLNode & root);
97         
98         PresetList preset_list;
99         PresetPtr  current_preset;
100         FileMap    preset_file_map;
101         
102         std::vector<PBD::sys::path> find_file (std::string const & pattern);
103         
104         PBD::sys::path  export_config_dir;
105         PBD::SearchPath search_path;
106
107 /* Timespans */
108   public:
109
110         typedef boost::shared_ptr<ExportTimespan> TimespanPtr;
111         typedef std::list<TimespanPtr> TimespanList;
112         typedef boost::shared_ptr<TimespanList> TimespanListPtr;
113         typedef std::list<Location *> LocationList;
114
115         enum TimeFormat {
116                 SMPTE,
117                 BBT,
118                 MinSec,
119                 Frames,
120                 Off
121         };
122
123         struct TimespanState {
124                 TimespanListPtr timespans;
125                 TimeFormat      time_format;
126                 
127                 boost::shared_ptr<Location> session_range;
128                 boost::shared_ptr<Location> selection_range;
129                 boost::shared_ptr<LocationList> ranges;
130                 
131                 TimespanState (boost::shared_ptr<Location> session_range,
132                                boost::shared_ptr<Location> selection_range,
133                                boost::shared_ptr<LocationList> ranges) :
134                   timespans (new TimespanList ()),
135                   time_format (SMPTE),
136                 
137                   session_range (session_range),
138                   selection_range (selection_range),
139                   ranges (ranges)
140                 {}
141         };
142         
143         typedef boost::shared_ptr<TimespanState> TimespanStatePtr;
144         typedef std::list<TimespanStatePtr> TimespanStateList;
145         
146         void set_selection_range (nframes_t start = 0, nframes_t end = 0);
147         TimespanStateList const & get_timespans () { return check_list (timespans); }
148         
149   private:
150
151         TimespanStateList timespans;
152
153         bool init_timespans (XMLNodeList nodes);
154         
155         TimespanStatePtr deserialize_timespan (XMLNode & root);
156         XMLNode & serialize_timespan (TimespanStatePtr state);
157         
158         /* Locations */
159         
160         void update_ranges ();
161         
162         boost::shared_ptr<Location>     session_range;
163         boost::shared_ptr<Location>     selection_range;
164         boost::shared_ptr<LocationList> ranges;
165
166 /* Channel Configs */
167   public:
168
169         typedef boost::shared_ptr<ExportChannelConfiguration> ChannelConfigPtr;
170
171         struct ChannelConfigState {
172                 ChannelConfigPtr config;
173                 
174                 ChannelConfigState (ChannelConfigPtr ptr) : config (ptr) {}
175         };
176         typedef boost::shared_ptr<ChannelConfigState> ChannelConfigStatePtr;
177         typedef std::list<ChannelConfigStatePtr> ChannelConfigStateList;
178         
179         ChannelConfigStateList const & get_channel_configs () { return check_list (channel_configs); }
180
181   private:
182
183         ChannelConfigStateList channel_configs;
184
185         bool init_channel_configs (XMLNodeList nodes);
186
187 /* Formats */
188   public:
189
190         typedef boost::shared_ptr<ExportFormatSpecification> FormatPtr;
191         typedef std::list<FormatPtr> FormatList;
192
193         struct FormatState {
194                 boost::shared_ptr<FormatList const> list;
195                 FormatPtr                           format;
196                 
197                 FormatState (boost::shared_ptr<FormatList const> list, FormatPtr format) :
198                   list (list), format (format) {}
199         };
200         typedef boost::shared_ptr<FormatState> FormatStatePtr;
201         typedef std::list<FormatStatePtr> FormatStateList;
202         
203         FormatStateList const & get_formats () { return check_list (formats); }
204         FormatStatePtr duplicate_format_state (FormatStatePtr state);
205         void remove_format_state (FormatStatePtr state);
206         
207         PBD::sys::path save_format_to_disk (FormatPtr format);
208         void remove_format_profile (FormatPtr format);
209         FormatPtr get_new_format (FormatPtr original);
210         
211         sigc::signal<void> FormatListChanged;
212
213   private:
214
215         FormatStateList formats;
216
217         bool init_formats (XMLNodeList nodes);
218         FormatStatePtr deserialize_format (XMLNode & root);
219         XMLNode & serialize_format (FormatStatePtr state);
220
221         void load_formats ();
222         
223         FormatPtr load_format (XMLNode & node);
224         void load_format_from_disk (PBD::sys::path const & path);
225
226         boost::shared_ptr<FormatList> format_list;
227         FileMap                       format_file_map;
228         
229 /* Filenames */
230   public:
231         
232         typedef boost::shared_ptr<ExportFilename> FilenamePtr;
233         
234         struct FilenameState {
235                 FilenamePtr  filename;
236                 
237                 FilenameState (FilenamePtr ptr) : filename (ptr) {}
238         };
239         typedef boost::shared_ptr<FilenameState> FilenameStatePtr;
240         typedef std::list<FilenameStatePtr> FilenameStateList;
241         
242         FilenameStateList const & get_filenames () { return check_list (filenames); }
243         FilenameStatePtr duplicate_filename_state (FilenameStatePtr state);
244         void remove_filename_state (FilenameStatePtr state);
245
246   private:
247
248         FilenameStateList filenames;
249         
250         bool init_filenames (XMLNodeList nodes);
251         FilenamePtr load_filename (XMLNode & node);
252
253 /* Warnings */
254   public:
255         struct Warnings {
256                 std::list<Glib::ustring> errors;
257                 std::list<Glib::ustring> warnings;
258                 std::list<Glib::ustring> conflicting_filenames;
259         };
260         
261         boost::shared_ptr<Warnings> get_warnings ();
262         
263   private:
264         void check_config (boost::shared_ptr<Warnings> warnings,
265                            TimespanStatePtr timespan_state,
266                            ChannelConfigStatePtr channel_config_state,
267                            FormatStatePtr format_state,
268                            FilenameStatePtr filename_state);
269
270  /* Utilities */
271
272         /* Element state lists should never be empty, this is used to check them */
273         template<typename T>
274         std::list<T> const &
275         check_list (std::list<T> const & list)
276         {
277                 if (list.empty()) {
278                         throw std::runtime_error ("Programming error: Uninitialized list in ExportProfileManager");
279                 }
280                 return list;
281         }
282
283 };
284
285
286 } // namespace ARDOUR
287
288 #endif /* __ardour_export_profile_manager_h__ */