merge hv v6, rework trace methods
[goodguy/history.git] / cinelerra-5.1 / cinelerra / edlsession.C
1
2 /*
3  * CINELERRA
4  * Copyright (C) 2008 Adam Williams <broadcast at earthling dot net>
5  *
6  * This program is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License as published by
8  * the Free Software Foundation; either version 2 of the License, or
9  * (at  your option) any later version.
10  *
11  * This program is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with this program; if not, write to the Free Software
18  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
19  *
20  */
21
22 #include "asset.h"
23 #include "assets.h"
24 #include "autoconf.h"
25 #include "awindowgui.h"
26 #include "bccmodels.h"
27 #include "bchash.h"
28 #include "clip.h"
29 #include "edl.h"
30 #include "edlsession.h"
31 #include "filexml.h"
32 #include "interlacemodes.h"
33 #include "overlayframe.inc"
34 #include "playbackconfig.h"
35 #include "recordconfig.h"
36 #include "tracks.h"
37 #include "workarounds.h"
38
39 int EDLSession::current_id = 0;
40
41 EDLSession::EDLSession(EDL *edl)
42 {
43         this->edl = edl;
44         for(int i = 0; i < MAXCHANNELS; i++)
45                 achannel_positions[i] = 0;
46         assetlist_format = ASSETS_ICONS;
47         for(int i = 0; i < ASSET_COLUMNS; i++)
48                 asset_columns[i] = 100;
49         auto_conf = new AutoConf;
50         awindow_folder = AW_MEDIA_FOLDER;
51         aspect_w = 4;  aspect_h = 3;
52         audio_channels = 2;
53         audio_tracks = 2;
54         autos_follow_edits = 1; // this is needed for predictability
55         auto_keyframes = 0;
56         brender_start = brender_end = 0.0;
57         clipboard_length = 0; // unused
58         color_model = BC_RGBA8888;
59         interlace_mode = ILACE_MODE_UNDETECTED;
60         crop_x1 = 0; crop_x2 = 320;
61         crop_y1 = 0; crop_y2 = 240;
62         eyedrop_radius = 0;
63         ruler_x1 = ruler_y1 = 0.0;
64         ruler_x2 = ruler_y2 = 0.0;
65         cursor_on_frames = 1;
66         typeless_keyframes = 0;
67         cwindow_dest = 0;
68         cwindow_mask = 0;
69         cwindow_meter = 0;
70         cwindow_operation = 0;
71         cwindow_scrollbars = 0;
72         cwindow_xscroll = cwindow_yscroll = 0;
73         cwindow_zoom = 1.0;
74         strcpy(default_atransition, "");
75         strcpy(default_vtransition, "");
76         default_transition_length = 1.0;
77         edit_handle_mode[0] = MOVE_ALL_EDITS;
78         edit_handle_mode[1] = MOVE_ONE_EDIT;
79         edit_handle_mode[2] = MOVE_NO_EDITS;
80         editing_mode = EDITING_IBEAM;
81         enable_duplex = 1;
82         folderlist_format = FOLDERS_ICONS;
83         frame_rate = 30000./1001;
84         frames_per_foot = 16;
85         highlighted_track = 0;
86         interpolation_type = CUBIC_CUBIC;
87         interpolate_raw = 1;
88         white_balance_raw = 1;
89         labels_follow_edits = 1;
90         mpeg4_deblock = 1;
91         plugins_follow_edits = 1;
92         single_standalone = 1;
93         meter_format = METER_DB;
94         min_meter_db = -85;
95         max_meter_db = 6;
96         output_w = 720;
97         output_h = 480;
98         playback_buffer = 4096;
99         playback_cursor_visible = 0;
100         playback_preload = 0;
101         decode_subtitles = 0;
102         subtitle_number = 0;
103         label_cells = 0;
104         program_no = 0;
105         playback_software_position = 0;
106 //      playback_strategy
107         real_time_playback = 0;
108         real_time_record = 0;
109         record_positioning = 1;
110         record_raw_stream = 0;
111         record_sync_drives = 0;
112         record_speed = frame_rate;
113         record_fragment_size = 2048;
114         record_write_length = 131072;
115         record_realtime_toc = 1;
116
117         safe_regions = 0;
118         sample_rate = 48000;
119         scrub_speed = 2.;
120         show_assets = 1;
121         show_titles = 1;
122         test_playback_edits = 1;
123         time_format = TIME_HMSF;
124         for(int i = 0; i < 4; i++)
125                 timecode_offset[i] = 0;
126         nudge_format = 1;
127         tool_window = 0;
128         for(int i = 0; i < MAXCHANNELS; i++) {
129                 vchannel_x[i] = 64*i;
130                 vchannel_y[i] = 0;
131         }
132         video_channels = 1;
133         aconfig_in = new AudioInConfig;
134         vconfig_in = new VideoInConfig;
135         recording_format = new Asset;
136         video_every_frame = 0;
137         video_asynchronous = 0;
138         video_tracks = 1;
139         video_write_length = 30;
140         view_follows_playback = 1;
141         vwindow_meter = 0;
142         vwindow_zoom = 1.;
143
144         playback_config = new PlaybackConfig;
145 }
146
147 EDLSession::~EDLSession()
148 {
149         delete aconfig_in;
150         delete auto_conf;
151         delete vconfig_in;
152         delete playback_config;
153         recording_format->Garbage::remove_user();
154 }
155
156
157 int EDLSession::need_rerender(EDLSession *ptr)
158 {
159         return ((playback_preload != ptr->playback_preload) ||
160                 (interpolation_type != ptr->interpolation_type) ||
161                 (video_every_frame != ptr->video_every_frame) ||
162                 (video_asynchronous != ptr->video_asynchronous) ||
163                 (real_time_playback != ptr->real_time_playback) ||
164                 (playback_software_position != ptr->playback_software_position) ||
165                 (test_playback_edits != ptr->test_playback_edits) ||
166                 (playback_buffer != ptr->playback_buffer) ||
167                 (decode_subtitles != ptr->decode_subtitles) ||
168                 (subtitle_number != ptr->subtitle_number) ||
169                 (interpolate_raw != ptr->interpolate_raw) ||
170                 (white_balance_raw != ptr->white_balance_raw));
171 }
172
173 void EDLSession::equivalent_output(EDLSession *session, double *result)
174 {
175         if(session->output_w != output_w ||
176                 session->output_h != output_h ||
177                 !EQUIV(session->frame_rate, frame_rate) ||
178                 session->color_model != color_model ||
179                 session->interpolation_type != interpolation_type ||
180                 session->interpolate_raw != interpolate_raw ||
181                 session->white_balance_raw != white_balance_raw ||
182                 session->mpeg4_deblock != mpeg4_deblock ||
183                 session->decode_subtitles != decode_subtitles ||
184                 session->subtitle_number != subtitle_number)
185                 *result = 0;
186
187 // If it's before the current brender_start, render extra data.
188 // If it's after brender_start, check brender map.
189         if(brender_start != session->brender_start &&
190                 (*result < 0 || *result > brender_start))
191                 *result = brender_start;
192 }
193
194
195 int EDLSession::load_defaults(BC_Hash *defaults)
196 {
197         char string[BCTEXTLEN];
198 // Default channel positions
199         for(int i = 0; i < MAXCHANNELS; i++)
200         {
201                 sprintf(string, "ACHANNEL_ANGLE_%d", i);
202                 int default_position = i * 30;
203
204                 if(i == 0) default_position = 180;
205                 else
206                 if(i == 1) default_position = 0;
207                 else
208                 if(default_position == 90) default_position = 300;
209                 else
210                 if(default_position == 0) default_position = 330;
211
212                 achannel_positions[i] = defaults->get(string, default_position);
213         }
214         aconfig_in->load_defaults(defaults);
215         assetlist_format = defaults->get("ASSETLIST_FORMAT", ASSETS_ICONS);
216         aspect_w = defaults->get("ASPECTW", aspect_w);
217         aspect_h = defaults->get("ASPECTH", aspect_h);
218         for(int i = 0; i < ASSET_COLUMNS; i++)
219         {
220                 sprintf(string, "ASSET_COLUMN%d", i);
221                 asset_columns[i] = defaults->get(string, 100);
222         }
223         audio_channels = defaults->get("ACHANNELS", audio_channels);
224         audio_tracks = defaults->get("ATRACKS", audio_tracks);
225         auto_conf->load_defaults(defaults);
226         autos_follow_edits = defaults->get("AUTOS_FOLLOW_EDITS", 1);
227         brender_start = defaults->get("BRENDER_START", brender_start);
228         brender_end = defaults->get("BRENDER_END", brender_end);
229         BC_CModels::to_text(string, BC_RGBA8888);
230         color_model = BC_CModels::from_text(defaults->get("COLOR_MODEL", string));
231         eyedrop_radius = defaults->get("EYEDROP_RADIUS", 0);
232         ilacemode_to_xmltext(string, interlace_mode);
233         const char *ilace_mode = defaults->get("INTERLACE_MODE",string);
234         interlace_mode = ilacemode_from_xmltext(ilace_mode, ILACE_MODE_NOTINTERLACED);
235         crop_x1 = defaults->get("CROP_X1", 0);
236         crop_x2 = defaults->get("CROP_X2", 320);
237         crop_y1 = defaults->get("CROP_Y1", 0);
238         crop_y2 = defaults->get("CROP_Y2", 240);
239         ruler_x1 = defaults->get("RULER_X1", 0.0);
240         ruler_x2 = defaults->get("RULER_X2", 0.0);
241         ruler_y1 = defaults->get("RULER_Y1", 0.0);
242         ruler_y2 = defaults->get("RULER_Y2", 0.0);
243         awindow_folder = defaults->get("AWINDOW_FOLDER", awindow_folder);
244         cursor_on_frames = defaults->get("CURSOR_ON_FRAMES", 1);
245         typeless_keyframes = defaults->get("TYPELESS_KEYFRAMES", 0);
246         cwindow_dest = defaults->get("CWINDOW_DEST", 0);
247         cwindow_mask = defaults->get("CWINDOW_MASK", 0);
248         cwindow_meter = defaults->get("CWINDOW_METER", 0);
249         cwindow_operation = defaults->get("CWINDOW_OPERATION", 0);
250         cwindow_scrollbars = defaults->get("CWINDOW_SCROLLBARS", 0);
251         cwindow_xscroll = defaults->get("CWINDOW_XSCROLL", 0);
252         cwindow_yscroll = defaults->get("CWINDOW_YSCROLL", 0);
253         cwindow_zoom = defaults->get("CWINDOW_ZOOM", (float)1);
254         sprintf(default_atransition, _("Crossfade"));
255         defaults->get("DEFAULT_ATRANSITION", default_atransition);
256         sprintf(default_vtransition, _("Dissolve"));
257         defaults->get("DEFAULT_VTRANSITION", default_vtransition);
258         default_transition_length = defaults->get("DEFAULT_TRANSITION_LENGTH", (double)1);
259         edit_handle_mode[0] = defaults->get("EDIT_HANDLE_MODE0", MOVE_ALL_EDITS);
260         edit_handle_mode[1] = defaults->get("EDIT_HANDLE_MODE1", MOVE_ONE_EDIT);
261         edit_handle_mode[2] = defaults->get("EDIT_HANDLE_MODE2", MOVE_NO_EDITS);
262         editing_mode = defaults->get("EDITING_MODE", EDITING_IBEAM);
263         enable_duplex = defaults->get("ENABLE_DUPLEX", 1);
264         folderlist_format = defaults->get("FOLDERLIST_FORMAT", FOLDERS_TEXT);
265         frame_rate = defaults->get("FRAMERATE", frame_rate);
266         frames_per_foot = defaults->get("FRAMES_PER_FOOT", (float)16);
267         interpolation_type = defaults->get("INTERPOLATION_TYPE", interpolation_type);
268         interpolate_raw = defaults->get("INTERPOLATE_RAW", interpolate_raw);
269         white_balance_raw = defaults->get("WHITE_BALANCE_RAW", white_balance_raw);
270         labels_follow_edits = defaults->get("LABELS_FOLLOW_EDITS", 1);
271         plugins_follow_edits = defaults->get("PLUGINS_FOLLOW_EDITS", 1);
272         single_standalone = defaults->get("SINGLE_STANDALONE", 1);
273         playback_preload = defaults->get("PLAYBACK_PRELOAD", 0);
274         auto_keyframes = defaults->get("AUTO_KEYFRAMES", 0);
275         meter_format = defaults->get("METER_FORMAT", METER_DB);
276         min_meter_db = defaults->get("MIN_METER_DB", -85);
277         max_meter_db = defaults->get("MAX_METER_DB", 6);
278         mpeg4_deblock = defaults->get("MPEG4_DEBLOCK", mpeg4_deblock);
279         output_w = defaults->get("OUTPUTW", output_w);
280         output_h = defaults->get("OUTPUTH", output_h);
281         playback_buffer = defaults->get("PLAYBACK_BUFFER", 4096);
282         playback_software_position = defaults->get("PLAYBACK_SOFTWARE_POSITION", 0);
283         delete playback_config;
284         playback_config = new PlaybackConfig;
285         playback_config->load_defaults(defaults);
286         real_time_playback = defaults->get("PLAYBACK_REALTIME", 0);
287         real_time_record = defaults->get("REALTIME_RECORD", 0);
288         record_positioning = defaults->get("RECORD_POSITIONING", 1);
289         record_raw_stream = defaults->get("RECORD_RAW_STREAM", 0);
290         record_sync_drives = defaults->get("RECORD_SYNC_DRIVES", 0);
291 //      record_speed = defaults->get("RECORD_SPEED", 24);
292         record_fragment_size = defaults->get("RECORD_FRAGMENT_SIZE", 2048);
293         record_write_length = defaults->get("RECORD_WRITE_LENGTH", 131072);
294
295 // set some defaults that work
296         recording_format->video_data = 1;
297         recording_format->audio_data = 1;
298         recording_format->format = FILE_FFMPEG;
299         strcpy(recording_format->acodec, "mp4.qt");
300         strcpy(recording_format->vcodec, "mp4.qt");
301         recording_format->channels = 2;
302         recording_format->sample_rate = 48000;
303         recording_format->bits = 16;
304         recording_format->dither = 0;
305
306         record_realtime_toc = defaults->get("RECORD_REALTIME_TOC", 1);
307         recording_format->load_defaults(defaults, "RECORD_", 1, 1, 1, 1, 1);
308
309         safe_regions = defaults->get("SAFE_REGIONS", 0);
310         sample_rate = defaults->get("SAMPLERATE", sample_rate);
311         scrub_speed = defaults->get("SCRUB_SPEED", (float)2);
312         si_useduration = defaults->get("SI_USEDURATION",1);
313         si_duration = defaults->get("SI_DURATION",3);
314
315         show_assets = defaults->get("SHOW_ASSETS", 1);
316         show_titles = defaults->get("SHOW_TITLES", 1);
317 //      test_playback_edits = defaults->get("TEST_PLAYBACK_EDITS", 1);
318         time_format = defaults->get("TIME_FORMAT", TIME_HMSF);
319         for(int i = 0; i < 4; i++) {
320                 sprintf(string, "TIMECODE_OFFSET_%d", i);
321                 timecode_offset[i] = defaults->get(string, 0);
322         }
323         nudge_format = defaults->get("NUDGE_FORMAT", 1);
324         tool_window = defaults->get("TOOL_WINDOW", 0);
325         vconfig_in->load_defaults(defaults);
326         for(int i = 0; i < MAXCHANNELS; i++) {
327                 int default_position = i * output_w;
328                 sprintf(string, "VCHANNEL_X_%d", i);
329                 vchannel_x[i] = defaults->get(string, default_position);
330                 sprintf(string, "VCHANNEL_Y_%d", i);
331                 vchannel_y[i] = defaults->get(string, 0);
332         }
333         video_channels = defaults->get("VCHANNELS", video_channels);
334         video_every_frame = defaults->get("VIDEO_EVERY_FRAME", 0);
335         video_asynchronous = defaults->get("VIDEO_ASYNCHRONOUS", 0);
336         video_tracks = defaults->get("VTRACKS", video_tracks);
337         video_write_length = defaults->get("VIDEO_WRITE_LENGTH", 30);
338         view_follows_playback = defaults->get("VIEW_FOLLOWS_PLAYBACK", 1);
339         vwindow_meter = defaults->get("VWINDOW_METER", 0);
340         vwindow_zoom = defaults->get("VWINDOW_ZOOM", (float)1);
341
342         decode_subtitles = defaults->get("DECODE_SUBTITLES", decode_subtitles);
343         subtitle_number = defaults->get("SUBTITLE_NUMBER", subtitle_number);
344         label_cells = defaults->get("LABEL_CELLS", label_cells);
345         program_no = defaults->get("PROGRAM_NO", program_no);
346
347         boundaries();
348
349         return 0;
350 }
351
352 int EDLSession::save_defaults(BC_Hash *defaults)
353 {
354         char string[BCTEXTLEN];
355
356 // Session
357         for(int i = 0; i < MAXCHANNELS; i++)
358         {
359                 sprintf(string, "ACHANNEL_ANGLE_%d", i);
360                 defaults->update(string, achannel_positions[i]);
361         }
362         defaults->update("ACHANNELS", audio_channels);
363         aconfig_in->save_defaults(defaults);
364         for(int i = 0; i < ASSET_COLUMNS; i++)
365         {
366                 sprintf(string, "ASSET_COLUMN%d", i);
367                 defaults->update(string, asset_columns[i]);
368         }
369         auto_conf->save_defaults(defaults);
370         defaults->update("ASSETLIST_FORMAT", assetlist_format);
371         defaults->update("ASPECTW", aspect_w);
372         defaults->update("ASPECTH", aspect_h);
373         defaults->update("ATRACKS", audio_tracks);
374         defaults->update("AUTOS_FOLLOW_EDITS", autos_follow_edits);
375         defaults->update("BRENDER_START", brender_start);
376         defaults->update("BRENDER_END", brender_end);
377         BC_CModels::to_text(string, color_model);
378         defaults->update("COLOR_MODEL", string);
379         ilacemode_to_xmltext(string, interlace_mode);
380         defaults->update("INTERLACE_MODE", string);
381         defaults->update("EYEDROP_RADIUS", eyedrop_radius);
382         defaults->update("CROP_X1", crop_x1);
383         defaults->update("CROP_X2", crop_x2);
384         defaults->update("CROP_Y1", crop_y1);
385         defaults->update("CROP_Y2", crop_y2);
386         defaults->update("RULER_X1", ruler_x1);
387         defaults->update("RULER_X2", ruler_x2);
388         defaults->update("RULER_Y1", ruler_y1);
389         defaults->update("RULER_Y2", ruler_y2);
390         defaults->update("AWINDOW_FOLDER", awindow_folder);
391         defaults->update("CURSOR_ON_FRAMES", cursor_on_frames);
392         defaults->update("TYPELESS_KEYFRAMES", typeless_keyframes);
393         defaults->update("CWINDOW_DEST", cwindow_dest);
394         defaults->update("CWINDOW_MASK", cwindow_mask);
395         defaults->update("CWINDOW_METER", cwindow_meter);
396         defaults->update("CWINDOW_OPERATION", cwindow_operation);
397         defaults->update("CWINDOW_SCROLLBARS", cwindow_scrollbars);
398         defaults->update("CWINDOW_XSCROLL", cwindow_xscroll);
399         defaults->update("CWINDOW_YSCROLL", cwindow_yscroll);
400         defaults->update("CWINDOW_ZOOM", cwindow_zoom);
401         defaults->update("DEFAULT_ATRANSITION", default_atransition);
402         defaults->update("DEFAULT_VTRANSITION", default_vtransition);
403         defaults->update("DEFAULT_TRANSITION_LENGTH", default_transition_length);
404         defaults->update("EDIT_HANDLE_MODE0", edit_handle_mode[0]);
405         defaults->update("EDIT_HANDLE_MODE1", edit_handle_mode[1]);
406         defaults->update("EDIT_HANDLE_MODE2", edit_handle_mode[2]);
407         defaults->update("EDITING_MODE", editing_mode);
408         defaults->update("ENABLE_DUPLEX", enable_duplex);
409         defaults->update("FOLDERLIST_FORMAT", folderlist_format);
410         defaults->update("FRAMERATE", frame_rate);
411         defaults->update("FRAMES_PER_FOOT", frames_per_foot);
412         defaults->update("HIGHLIGHTED_TRACK", highlighted_track);
413         defaults->update("INTERPOLATION_TYPE", interpolation_type);
414         defaults->update("INTERPOLATE_RAW", interpolate_raw);
415         defaults->update("WHITE_BALANCE_RAW", white_balance_raw);
416         defaults->update("LABELS_FOLLOW_EDITS", labels_follow_edits);
417         defaults->update("PLUGINS_FOLLOW_EDITS", plugins_follow_edits);
418         defaults->update("SINGLE_STANDALONE", single_standalone);
419         defaults->update("PLAYBACK_PRELOAD", playback_preload);
420         defaults->update("AUTO_KEYFRAMES", auto_keyframes);
421         defaults->update("METER_FORMAT", meter_format);
422         defaults->update("MIN_METER_DB", min_meter_db);
423         defaults->update("MAX_METER_DB", max_meter_db);
424         defaults->update("MPEG4_DEBLOCK", mpeg4_deblock);
425         defaults->update("OUTPUTW", output_w);
426         defaults->update("OUTPUTH", output_h);
427         defaults->update("PLAYBACK_BUFFER", playback_buffer);
428         defaults->update("PLAYBACK_SOFTWARE_POSITION", playback_software_position);
429         playback_config->save_defaults(defaults);
430         defaults->update("PLAYBACK_REALTIME", real_time_playback);
431         defaults->update("REALTIME_RECORD", real_time_record);
432         defaults->update("RECORD_POSITIONING", record_positioning);
433         defaults->update("RECORD_RAW_STREAM", record_raw_stream);
434         defaults->update("RECORD_SYNC_DRIVES", record_sync_drives);
435 //      defaults->update("RECORD_SPEED", record_speed);
436         defaults->update("RECORD_FRAGMENT_SIZE", record_fragment_size);
437         defaults->update("RECORD_WRITE_LENGTH", record_write_length); // Heroine kernel 2.2 scheduling sucks.
438         defaults->update("RECORD_REALTIME_TOC", record_realtime_toc);
439         recording_format->save_defaults(defaults,
440                 "RECORD_",
441                 1,
442                 1,
443                 1,
444                 1,
445                 1);
446         defaults->update("SAFE_REGIONS", safe_regions);
447         defaults->update("SAMPLERATE", sample_rate);
448         defaults->update("SCRUB_SPEED", scrub_speed);
449         defaults->update("SI_USEDURATION",si_useduration);
450         defaults->update("SI_DURATION",si_duration);
451         defaults->update("SHOW_ASSETS", show_assets);
452         defaults->update("SHOW_TITLES", show_titles);
453 //      defaults->update("TEST_PLAYBACK_EDITS", test_playback_edits);
454         defaults->update("TIME_FORMAT", time_format);
455         for(int i = 0; i < 4; i++) {
456                 sprintf(string, "TIMECODE_OFFSET_%d", i);
457                 defaults->update(string, timecode_offset[i]);
458         }
459         defaults->update("NUDGE_FORMAT", nudge_format);
460         defaults->update("TOOL_WINDOW", tool_window);
461         vconfig_in->save_defaults(defaults);
462         for(int i = 0; i < MAXCHANNELS; i++) {
463                 sprintf(string, "VCHANNEL_X_%d", i);
464                 defaults->update(string, vchannel_x[i]);
465                 sprintf(string, "VCHANNEL_Y_%d", i);
466                 defaults->update(string, vchannel_y[i]);
467         }
468         defaults->update("VCHANNELS", video_channels);
469         defaults->update("VIDEO_EVERY_FRAME", video_every_frame);
470         defaults->update("VIDEO_ASYNCHRONOUS", video_asynchronous);
471         defaults->update("VTRACKS", video_tracks);
472         defaults->update("VIDEO_WRITE_LENGTH", video_write_length);
473         defaults->update("VIEW_FOLLOWS_PLAYBACK", view_follows_playback);
474         defaults->update("VWINDOW_METER", vwindow_meter);
475         defaults->update("VWINDOW_ZOOM", vwindow_zoom);
476
477         defaults->update("DECODE_SUBTITLES", decode_subtitles);
478         defaults->update("SUBTITLE_NUMBER", subtitle_number);
479         defaults->update("LABEL_CELLS", label_cells);
480         defaults->update("PROGRAM_NO", program_no);
481
482         return 0;
483 }
484
485
486
487 // GCC 3.0 fails to compile
488 #define BC_INFINITY 65536
489
490
491 void EDLSession::boundaries()
492 {
493         Workarounds::clamp(audio_tracks, 0, (int)BC_INFINITY);
494         Workarounds::clamp(audio_channels, 1, MAXCHANNELS - 1);
495         Workarounds::clamp(sample_rate, 1, 1000000);
496         Workarounds::clamp(video_tracks, 0, (int)BC_INFINITY);
497         Workarounds::clamp(video_channels, 1, MAXCHANNELS - 1);
498         Workarounds::clamp(frame_rate, 1.0, (double)BC_INFINITY);
499         Workarounds::clamp(min_meter_db, -80, -20);
500         Workarounds::clamp(max_meter_db, 0, 10);
501         Workarounds::clamp(frames_per_foot, 1, 32);
502         Workarounds::clamp(output_w, 16, (int)BC_INFINITY);
503         Workarounds::clamp(output_h, 16, (int)BC_INFINITY);
504         Workarounds::clamp(video_write_length, 1, 1000);
505 //printf("EDLSession::boundaries 1\n");
506         output_w /= 2;
507         output_w *= 2;
508         output_h /= 2;
509         output_h *= 2;
510
511         Workarounds::clamp(eyedrop_radius, 0, 255);
512         Workarounds::clamp(crop_x1, 0, output_w);
513         Workarounds::clamp(crop_x2, 0, output_w);
514         Workarounds::clamp(crop_y1, 0, output_h);
515         Workarounds::clamp(crop_y2, 0, output_h);
516         Workarounds::clamp(ruler_x1, 0.0, output_w);
517         Workarounds::clamp(ruler_x2, 0.0, output_w);
518         Workarounds::clamp(ruler_y1, 0.0, output_h);
519         Workarounds::clamp(ruler_y2, 0.0, output_h);
520         if(brender_start < 0) brender_start = 0.0;
521         if(brender_end < 0) brender_end = 0.0;
522
523         Workarounds::clamp(subtitle_number, 0, 31);
524         Workarounds::clamp(awindow_folder, 0, AWINDOW_FOLDERS - 1);
525
526 // Correct framerates
527         frame_rate = Units::fix_framerate(frame_rate);
528 }
529
530
531
532 int EDLSession::load_video_config(FileXML *file, int append_mode, uint32_t load_flags)
533 {
534         char string[BCTEXTLEN];
535         if(append_mode) return 0;
536         interpolation_type = file->tag.get_property("INTERPOLATION_TYPE", interpolation_type);
537         interpolate_raw = file->tag.get_property("INTERPOLATE_RAW", interpolate_raw);
538         white_balance_raw = file->tag.get_property("WHITE_BALANCE_RAW", white_balance_raw);
539         BC_CModels::to_text(string, color_model);
540         color_model = BC_CModels::from_text(file->tag.get_property("COLORMODEL", string));
541         const char *ilace_mode = file->tag.get_property("INTERLACE_MODE");
542         interlace_mode = ilacemode_from_xmltext(ilace_mode, ILACE_MODE_NOTINTERLACED);
543         video_channels = file->tag.get_property("CHANNELS", video_channels);
544         for(int i = 0; i < video_channels; i++)
545         {
546                 int default_position = i * output_w;
547                 sprintf(string, "VCHANNEL_X_%d", i);
548                 vchannel_x[i] = file->tag.get_property(string, default_position);
549                 sprintf(string, "VCHANNEL_Y_%d", i);
550                 vchannel_y[i] = file->tag.get_property(string, 0);
551         }
552
553         frame_rate = file->tag.get_property("FRAMERATE", frame_rate);
554         frames_per_foot = file->tag.get_property("FRAMES_PER_FOOT", frames_per_foot);
555         output_w = file->tag.get_property("OUTPUTW", output_w);
556         output_h = file->tag.get_property("OUTPUTH", output_h);
557         aspect_w = file->tag.get_property("ASPECTW", aspect_w);
558         aspect_h = file->tag.get_property("ASPECTH", aspect_h);
559         return 0;
560 }
561
562 int EDLSession::load_audio_config(FileXML *file, int append_mode, uint32_t load_flags)
563 {
564         char string[32];
565 // load channels setting
566         if(append_mode) return 0;
567         audio_channels = file->tag.get_property("CHANNELS", (int64_t)audio_channels);
568
569
570         for(int i = 0; i < audio_channels; i++)
571         {
572                 sprintf(string, "ACHANNEL_ANGLE_%d", i);
573                 achannel_positions[i] = file->tag.get_property(string, achannel_positions[i]);
574 //printf("EDLSession::load_audio_config 1 %d %d\n", i, achannel_positions[i]);
575         }
576
577         sample_rate = file->tag.get_property("SAMPLERATE", (int64_t)sample_rate);
578         return 0;
579 }
580
581 int EDLSession::load_xml(FileXML *file,
582         int append_mode,
583         uint32_t load_flags)
584 {
585         char string[BCTEXTLEN];
586
587         if(append_mode)
588         {
589         }
590         else
591         {
592                 assetlist_format = file->tag.get_property("ASSETLIST_FORMAT", assetlist_format);
593                 for(int i = 0; i < ASSET_COLUMNS; i++) {
594                         sprintf(string, "ASSET_COLUMN%d", i);
595                         asset_columns[i] = file->tag.get_property(string, asset_columns[i]);
596                 }
597                 auto_conf->load_xml(file);
598                 auto_keyframes = file->tag.get_property("AUTO_KEYFRAMES", auto_keyframes);
599                 autos_follow_edits = file->tag.get_property("AUTOS_FOLLOW_EDITS", autos_follow_edits);
600                 brender_start = file->tag.get_property("BRENDER_START", brender_start);
601                 brender_end = file->tag.get_property("BRENDER_END", brender_end);
602                 eyedrop_radius = file->tag.get_property("EYEDROP_RADIUS", eyedrop_radius);
603                 crop_x1 = file->tag.get_property("CROP_X1", crop_x1);
604                 crop_y1 = file->tag.get_property("CROP_Y1", crop_y1);
605                 crop_x2 = file->tag.get_property("CROP_X2", crop_x2);
606                 crop_y2 = file->tag.get_property("CROP_Y2", crop_y2);
607                 ruler_x1 = file->tag.get_property("RULER_X1", ruler_x1);
608                 ruler_y1 = file->tag.get_property("RULER_Y1", ruler_y1);
609                 ruler_x2 = file->tag.get_property("RULER_X2", ruler_x2);
610                 ruler_y2 = file->tag.get_property("RULER_Y2", ruler_y2);
611                 string[0] = 0;
612                 file->tag.get_property("CURRENT_FOLDER", string);
613                 if( string[0] ) {
614                         awindow_folder = AWindowGUI::folder_number(string);
615                         if( awindow_folder < 0 ) awindow_folder = AW_MEDIA_FOLDER;
616                 }
617                 file->tag.get_property("AWINDOW_FOLDER", awindow_folder);
618                 cursor_on_frames = file->tag.get_property("CURSOR_ON_FRAMES", cursor_on_frames);
619                 typeless_keyframes = file->tag.get_property("TYPELESS_KEYFRAMES", typeless_keyframes);
620                 cwindow_dest = file->tag.get_property("CWINDOW_DEST", cwindow_dest);
621                 cwindow_mask = file->tag.get_property("CWINDOW_MASK", cwindow_mask);
622                 cwindow_meter = file->tag.get_property("CWINDOW_METER", cwindow_meter);
623                 cwindow_operation = file->tag.get_property("CWINDOW_OPERATION", cwindow_operation);
624                 cwindow_scrollbars = file->tag.get_property("CWINDOW_SCROLLBARS", cwindow_scrollbars);
625                 cwindow_xscroll = file->tag.get_property("CWINDOW_XSCROLL", cwindow_xscroll);
626                 cwindow_yscroll = file->tag.get_property("CWINDOW_YSCROLL", cwindow_yscroll);
627                 cwindow_zoom = file->tag.get_property("CWINDOW_ZOOM", cwindow_zoom);
628                 editing_mode = file->tag.get_property("EDITING_MODE", editing_mode);
629                 folderlist_format = file->tag.get_property("FOLDERLIST_FORMAT", folderlist_format);
630                 highlighted_track = file->tag.get_property("HIGHLIGHTED_TRACK", 0);
631                 labels_follow_edits = file->tag.get_property("LABELS_FOLLOW_EDITS", labels_follow_edits);
632                 mpeg4_deblock = file->tag.get_property("MPEG4_DEBLOCK", mpeg4_deblock);
633                 plugins_follow_edits = file->tag.get_property("PLUGINS_FOLLOW_EDITS", plugins_follow_edits);
634                 single_standalone = file->tag.get_property("SINGLE_STANDALONE", single_standalone);
635                 playback_preload = file->tag.get_property("PLAYBACK_PRELOAD", playback_preload);
636                 safe_regions = file->tag.get_property("SAFE_REGIONS", safe_regions);
637                 show_assets = file->tag.get_property("SHOW_ASSETS", 1);
638                 show_titles = file->tag.get_property("SHOW_TITLES", 1);
639 //              test_playback_edits = file->tag.get_property("TEST_PLAYBACK_EDITS", test_playback_edits);
640                 time_format = file->tag.get_property("TIME_FORMAT", time_format);
641                 for(int i = 0; i < 4; i++) {
642                         sprintf(string, "TIMECODE_OFFSET_%d", i);
643                         timecode_offset[i] = file->tag.get_property(string, timecode_offset[i]);
644                 }
645                 nudge_format = file->tag.get_property("NUDGE_FORMAT", nudge_format);
646                 tool_window = file->tag.get_property("TOOL_WINDOW", tool_window);
647                 vwindow_meter = file->tag.get_property("VWINDOW_METER", vwindow_meter);
648                 vwindow_zoom = file->tag.get_property("VWINDOW_ZOOM", vwindow_zoom);
649
650                 decode_subtitles = file->tag.get_property("DECODE_SUBTITLES", decode_subtitles);
651                 subtitle_number = file->tag.get_property("SUBTITLE_NUMBER", subtitle_number);
652                 label_cells = file->tag.get_property("LABEL_CELLS", label_cells);
653                 program_no = file->tag.get_property("PROGRAM_NO", program_no);
654
655                 boundaries();
656         }
657
658         return 0;
659 }
660
661 int EDLSession::save_xml(FileXML *file)
662 {
663 //printf("EDLSession::save_session 1\n");
664         char string[BCTEXTLEN];
665         file->tag.set_title("SESSION");
666         file->tag.set_property("ASSETLIST_FORMAT", assetlist_format);
667         for(int i = 0; i < ASSET_COLUMNS; i++) {
668                 sprintf(string, "ASSET_COLUMN%d", i);
669                 file->tag.set_property(string, asset_columns[i]);
670         }
671         auto_conf->save_xml(file);
672         file->tag.set_property("AUTO_KEYFRAMES", auto_keyframes);
673         file->tag.set_property("AUTOS_FOLLOW_EDITS", autos_follow_edits);
674         file->tag.set_property("BRENDER_START", brender_start);
675         file->tag.set_property("BRENDER_END", brender_end);
676         file->tag.set_property("EYEDROP_RADIUS", eyedrop_radius);
677         file->tag.set_property("CROP_X1", crop_x1);
678         file->tag.set_property("CROP_Y1", crop_y1);
679         file->tag.set_property("CROP_X2", crop_x2);
680         file->tag.set_property("CROP_Y2", crop_y2);
681         file->tag.set_property("RULER_X1", ruler_x1);
682         file->tag.set_property("RULER_Y1", ruler_y1);
683         file->tag.set_property("RULER_X2", ruler_x2);
684         file->tag.set_property("RULER_Y2", ruler_y2);
685         file->tag.set_property("AWINDOW_FOLDER", awindow_folder);
686         file->tag.set_property("CURSOR_ON_FRAMES", cursor_on_frames);
687         file->tag.set_property("TYPELESS_KEYFRAMES", typeless_keyframes);
688         file->tag.set_property("CWINDOW_DEST", cwindow_dest);
689         file->tag.set_property("CWINDOW_MASK", cwindow_mask);
690         file->tag.set_property("CWINDOW_METER", cwindow_meter);
691         file->tag.set_property("CWINDOW_OPERATION", cwindow_operation);
692         file->tag.set_property("CWINDOW_SCROLLBARS", cwindow_scrollbars);
693         file->tag.set_property("CWINDOW_XSCROLL", cwindow_xscroll);
694         file->tag.set_property("CWINDOW_YSCROLL", cwindow_yscroll);
695         file->tag.set_property("CWINDOW_ZOOM", cwindow_zoom);
696         file->tag.set_property("EDITING_MODE", editing_mode);
697         file->tag.set_property("FOLDERLIST_FORMAT", folderlist_format);
698         file->tag.set_property("HIGHLIGHTED_TRACK", highlighted_track);
699         file->tag.set_property("LABELS_FOLLOW_EDITS", labels_follow_edits);
700         file->tag.set_property("MPEG4_DEBLOCK", mpeg4_deblock);
701         file->tag.set_property("PLUGINS_FOLLOW_EDITS", plugins_follow_edits);
702         file->tag.set_property("SINGLE_STANDALONE", single_standalone);
703         file->tag.set_property("PLAYBACK_PRELOAD", playback_preload);
704         file->tag.set_property("SAFE_REGIONS", safe_regions);
705         file->tag.set_property("SHOW_ASSETS", show_assets);
706         file->tag.set_property("SHOW_TITLES", show_titles);
707         file->tag.set_property("TEST_PLAYBACK_EDITS", test_playback_edits);
708         file->tag.set_property("TIME_FORMAT", time_format);
709         for(int i = 0; i < 4; i++) {
710                 sprintf(string, "TIMECODE_OFFSET_%d", i);
711                 file->tag.set_property(string, timecode_offset[i]);
712         }
713         file->tag.set_property("NUDGE_FORMAT", nudge_format);
714         file->tag.set_property("TOOL_WINDOW", tool_window);
715         file->tag.set_property("VWINDOW_METER", vwindow_meter);
716         file->tag.set_property("VWINDOW_ZOOM", vwindow_zoom);
717
718         file->tag.set_property("DECODE_SUBTITLES", decode_subtitles);
719         file->tag.set_property("SUBTITLE_NUMBER", subtitle_number);
720
721         file->append_tag();
722         file->tag.set_title("/SESSION");
723         file->append_tag();
724         file->append_newline();
725         file->append_newline();
726 //printf("EDLSession::save_session 3\n");
727         return 0;
728 }
729
730 int EDLSession::save_video_config(FileXML *file)
731 {
732         char string[BCTEXTLEN];
733         file->tag.set_title("VIDEO");
734         file->tag.set_property("INTERPOLATION_TYPE", interpolation_type);
735         file->tag.set_property("INTERPOLATE_RAW", interpolate_raw);
736         file->tag.set_property("WHITE_BALANCE_RAW", white_balance_raw);
737         BC_CModels::to_text(string, color_model);
738         file->tag.set_property("COLORMODEL", string);
739         ilacemode_to_xmltext(string, interlace_mode);
740         file->tag.set_property("INTERLACE_MODE",string);
741     file->tag.set_property("CHANNELS", video_channels);
742         for(int i = 0; i < video_channels; i++)
743         {
744                 sprintf(string, "VCHANNEL_X_%d", i);
745                 file->tag.set_property(string, vchannel_x[i]);
746                 sprintf(string, "VCHANNEL_Y_%d", i);
747                 file->tag.set_property(string, vchannel_y[i]);
748         }
749
750         file->tag.set_property("FRAMERATE", frame_rate);
751         file->tag.set_property("FRAMES_PER_FOOT", frames_per_foot);
752         file->tag.set_property("OUTPUTW", output_w);
753         file->tag.set_property("OUTPUTH", output_h);
754         file->tag.set_property("ASPECTW", aspect_w);
755         file->tag.set_property("ASPECTH", aspect_h);
756         file->append_tag();
757         file->tag.set_title("/VIDEO");
758         file->append_tag();
759         file->append_newline();
760         file->append_newline();
761         return 0;
762 }
763
764 int EDLSession::save_audio_config(FileXML *file)
765 {
766         char string[1024];
767         file->tag.set_title("AUDIO");
768         file->tag.set_property("SAMPLERATE", (int64_t)sample_rate);
769         file->tag.set_property("CHANNELS", (int64_t)audio_channels);
770
771         for(int i = 0; i < audio_channels; i++)
772         {
773                 sprintf(string, "ACHANNEL_ANGLE_%d", i);
774                 file->tag.set_property(string, achannel_positions[i]);
775         }
776
777         file->append_tag();
778         file->tag.set_title("/AUDIO");
779         file->append_tag();
780         file->append_newline();
781         file->append_newline();
782         return 0;
783 }
784
785 int EDLSession::copy(EDLSession *session)
786 {
787 // Audio channel positions
788         for(int i = 0; i < MAXCHANNELS; i++)
789         {
790                 achannel_positions[i] = session->achannel_positions[i];
791         }
792         aconfig_in->copy_from(session->aconfig_in);
793         for(int i = 0; i < ASSET_COLUMNS; i++)
794         {
795                 asset_columns[i] = session->asset_columns[i];
796         }
797         assetlist_format = session->assetlist_format;
798         auto_conf->copy_from(session->auto_conf);
799         aspect_w = session->aspect_w;
800         aspect_h = session->aspect_h;
801         audio_channels = session->audio_channels;
802         audio_tracks = session->audio_tracks;
803         autos_follow_edits = session->autos_follow_edits;
804         brender_start = session->brender_start;
805         brender_end = session->brender_end;
806         color_model = session->color_model;
807         interlace_mode = session->interlace_mode;
808         eyedrop_radius = session->eyedrop_radius;
809         crop_x1 = session->crop_x1;
810         crop_y1 = session->crop_y1;
811         crop_x2 = session->crop_x2;
812         crop_y2 = session->crop_y2;
813         ruler_x1 = session->ruler_x1;
814         ruler_y1 = session->ruler_y1;
815         ruler_x2 = session->ruler_x2;
816         ruler_y2 = session->ruler_y2;
817         awindow_folder = session->awindow_folder;
818         cursor_on_frames = session->cursor_on_frames;
819         typeless_keyframes = session->typeless_keyframes;
820         cwindow_dest = session->cwindow_dest;
821         cwindow_mask = session->cwindow_mask;
822         cwindow_meter = session->cwindow_meter;
823         cwindow_operation = session->cwindow_operation;
824         cwindow_scrollbars = session->cwindow_scrollbars;
825         cwindow_xscroll = session->cwindow_xscroll;
826         cwindow_yscroll = session->cwindow_yscroll;
827         cwindow_zoom = session->cwindow_zoom;
828         strcpy(default_atransition, session->default_atransition);
829         strcpy(default_vtransition, session->default_vtransition);
830         default_transition_length = session->default_transition_length;
831         edit_handle_mode[0] = session->edit_handle_mode[0];
832         edit_handle_mode[1] = session->edit_handle_mode[1];
833         edit_handle_mode[2] = session->edit_handle_mode[2];
834         editing_mode = session->editing_mode;
835         enable_duplex = session->enable_duplex;
836         folderlist_format = session->folderlist_format;
837         frame_rate = session->frame_rate;
838         frames_per_foot = session->frames_per_foot;
839         highlighted_track = session->highlighted_track;
840         interpolation_type = session->interpolation_type;
841         interpolate_raw = session->interpolate_raw;
842         white_balance_raw = session->white_balance_raw;
843         labels_follow_edits = session->labels_follow_edits;
844         plugins_follow_edits = session->plugins_follow_edits;
845         single_standalone = session->single_standalone;
846         auto_keyframes = session->auto_keyframes;
847 //      last_playback_position = session->last_playback_position;
848         meter_format = session->meter_format;
849         min_meter_db = session->min_meter_db;
850         max_meter_db = session->max_meter_db;
851         mpeg4_deblock = session->mpeg4_deblock;
852         output_w = session->output_w;
853         output_h = session->output_h;
854         playback_buffer = session->playback_buffer;
855         delete playback_config;
856         playback_config = new PlaybackConfig;
857         playback_config->copy_from(session->playback_config);
858         playback_cursor_visible = session->playback_cursor_visible;
859         playback_software_position = session->playback_software_position;
860         real_time_playback = session->real_time_playback;
861         real_time_record = session->real_time_record;
862         record_positioning = session->record_positioning;
863         record_raw_stream = session->record_raw_stream;
864         record_speed = session->record_speed;
865         record_sync_drives = session->record_sync_drives;
866         record_fragment_size = session->record_fragment_size;
867         record_write_length = session->record_write_length;
868         record_realtime_toc = session->record_realtime_toc;
869         recording_format->copy_from(session->recording_format, 0);
870         safe_regions = session->safe_regions;
871         sample_rate = session->sample_rate;
872         scrub_speed = session->scrub_speed;
873         si_useduration = session->si_useduration;
874         si_duration = session->si_duration;
875         show_assets = session->show_assets;
876         show_titles = session->show_titles;
877         test_playback_edits = session->test_playback_edits;
878         time_format = session->time_format;
879         for(int i = 0; i < 4; i++) {
880                 timecode_offset[i] = session->timecode_offset[i];
881         }
882         nudge_format = session->nudge_format;
883         tool_window = session->tool_window;
884         for(int i = 0; i < MAXCHANNELS; i++) {
885                 vchannel_x[i] = session->vchannel_x[i];
886                 vchannel_y[i] = session->vchannel_y[i];
887         }
888         video_channels = session->video_channels;
889         *vconfig_in = *session->vconfig_in;
890         video_every_frame = session->video_every_frame;
891         video_asynchronous = session->video_asynchronous;
892         video_tracks = session->video_tracks;
893         video_write_length = session->video_write_length;
894         view_follows_playback = session->view_follows_playback;
895         vwindow_meter = session->vwindow_meter;
896         vwindow_zoom = session->vwindow_zoom;
897
898         subtitle_number = session->subtitle_number;
899         decode_subtitles = session->decode_subtitles;
900         label_cells = session->label_cells;
901         program_no = session->program_no;
902
903         return 0;
904 }
905
906 int64_t EDLSession::get_frame_offset()
907 {
908         return int64_t((timecode_offset[3] * 3600 + timecode_offset[2] * 60 +
909                 timecode_offset[1]) * frame_rate + timecode_offset[0]);
910 }
911
912 void EDLSession::dump()
913 {
914         printf("EDLSession::dump\n");
915         printf("    audio_tracks=%d audio_channels=%d sample_rate=%jd\n"
916                 "    video_tracks=%d frame_rate=%f output_w=%d output_h=%d aspect_w=%f aspect_h=%f\n"
917                 "    decode subtitles=%d subtitle_number=%d label_cells=%d program_no=%d\n",
918                 audio_tracks, audio_channels, sample_rate, video_tracks,
919                 frame_rate, output_w, output_h, aspect_w, aspect_h,
920                 decode_subtitles, subtitle_number, label_cells, program_no);
921 }
922