2 Copyright (C) 1999 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.
22 #include <cstdio> /* for snprintf, grrr */
28 #include <pbd/failed_constructor.h>
29 #include <pbd/xml++.h>
31 #include <ardour/ardour.h>
32 #include <ardour/configuration.h>
33 #include <ardour/diskstream.h>
34 #include <ardour/destructive_filesource.h>
38 using namespace ARDOUR;
41 /* this is global so that we do not have to indirect through an object pointer
46 float speed_quietning = 0.251189; // -12dB reduction for ffwd or rewind
49 Configuration::Configuration ()
52 user_configuration = false;
56 Configuration::~Configuration ()
61 Configuration::get_user_path()
63 return find_config_file ("ardour.rc");
67 Configuration::get_system_path()
69 return find_config_file ("ardour_system.rc");
73 Configuration::load_state ()
77 /* load system configuration first */
79 rcfile = get_system_path ();
81 if (rcfile.length()) {
85 if (!tree.read (rcfile.c_str())) {
86 error << string_compose(_("Ardour: cannot read system configuration file \"%1\""), rcfile) << endmsg;
90 if (set_state (*tree.root())) {
91 error << string_compose(_("Ardour: system configuration file \"%1\" not loaded successfully."), rcfile) << endmsg;
96 /* from this point on, all configuration changes are user driven */
98 user_configuration = true;
100 /* now load configuration file for user */
102 rcfile = get_user_path ();
104 if (rcfile.length()) {
108 if (!tree.read (rcfile)) {
109 error << string_compose(_("Ardour: cannot read configuration file \"%1\""), rcfile) << endmsg;
114 if (set_state (*tree.root())) {
115 error << string_compose(_("Ardour: configuration file \"%1\" not loaded successfully."), rcfile) << endmsg;
124 Configuration::save_state()
129 /* Note: this only writes the per-user file, and therefore
130 only saves variables marked as user-set or modified
133 rcfile = find_config_file("ardour.rc");
135 if (rcfile.length()) {
136 tree.set_root (&state (true));
137 if (!tree.write (rcfile.c_str())){
138 error << _("Config file not saved") << endmsg;
147 Configuration::get_state ()
149 return state (false);
153 Configuration::state (bool user_only)
155 XMLNode* root = new XMLNode("Ardour");
156 LocaleGuard lg (X_("POSIX"));
158 typedef map<string, MidiPortDescriptor*>::const_iterator CI;
159 for(CI m = midi_ports.begin(); m != midi_ports.end(); ++m){
160 root->add_child_nocopy(m->second->get_state());
163 XMLNode* node = new XMLNode("Config");
166 if (!user_only || minimum_disk_io_bytes_is_user) {
167 snprintf(buf, sizeof(buf), "%" PRIu32 , minimum_disk_io_bytes);
168 node->add_child_nocopy(option_node("minimum-disk-io-bytes", string(buf)));
170 if (!user_only || track_buffer_seconds_is_user) {
171 snprintf(buf, sizeof(buf), "%f", track_buffer_seconds);
172 node->add_child_nocopy(option_node("track-buffer-seconds", string(buf)));
174 if (!user_only || disk_choice_space_threshold_is_user) {
175 snprintf(buf, sizeof(buf), "%" PRIu32, disk_choice_space_threshold);
176 node->add_child_nocopy(option_node("disk-choice-space-threshold", string(buf)));
179 if (!user_only || midi_feedback_interval_ms_is_user) {
180 snprintf(buf, sizeof(buf), "%" PRIu32, midi_feedback_interval_ms);
181 node->add_child_nocopy(option_node("midi-feedback-interval-ms", string(buf)));
184 if (!user_only || mute_affects_pre_fader_is_user) {
185 node->add_child_nocopy(option_node("mute-affects-pre-fader", mute_affects_pre_fader?"yes":"no"));
187 if (!user_only || mute_affects_post_fader_is_user) {
188 node->add_child_nocopy(option_node("mute-affects-post-fader", mute_affects_post_fader?"yes":"no"));
190 if (!user_only || mute_affects_control_outs_is_user) {
191 node->add_child_nocopy(option_node("mute-affects-control-outs", mute_affects_control_outs?"yes":"no"));
193 if (!user_only || mute_affects_main_outs_is_user) {
194 node->add_child_nocopy(option_node("mute-affects-main-outs", mute_affects_main_outs?"yes":"no"));
196 if (!user_only || solo_latch_is_user) {
197 node->add_child_nocopy(option_node("solo-latch", solo_latch?"yes":"no"));
199 if (!user_only || raid_path_is_user) {
200 node->add_child_nocopy(option_node("raid-path", orig_raid_path));
202 if (!user_only || mtc_port_name_is_user) {
203 node->add_child_nocopy(option_node("mtc-port", mtc_port_name));
205 if (!user_only || mmc_port_name_is_user) {
206 node->add_child_nocopy(option_node("mmc-port", mmc_port_name));
208 if (!user_only || midi_port_name_is_user) {
209 node->add_child_nocopy(option_node("midi-port", midi_port_name));
211 if (!user_only || use_hardware_monitoring_is_user) {
212 node->add_child_nocopy(option_node("hardware-monitoring", use_hardware_monitoring?"yes":"no"));
214 if (!user_only || be_jack_time_master_is_user) {
215 node->add_child_nocopy(option_node("jack-time-master", be_jack_time_master?"yes":"no"));
217 if (!user_only || native_format_is_bwf_is_user) {
218 node->add_child_nocopy(option_node("native-format-bwf", native_format_is_bwf?"yes":"no"));
220 if (!user_only || trace_midi_input_is_user) {
221 node->add_child_nocopy(option_node("trace-midi-input", trace_midi_input?"yes":"no"));
223 if (!user_only || trace_midi_output_is_user) {
224 node->add_child_nocopy(option_node("trace-midi-output", trace_midi_output?"yes":"no"));
226 if (!user_only || plugins_stop_with_transport_is_user) {
227 node->add_child_nocopy(option_node("plugins-stop-with-transport", plugins_stop_with_transport?"yes":"no"));
229 if (!user_only || use_sw_monitoring_is_user) {
230 node->add_child_nocopy(option_node("use-sw-monitoring", use_sw_monitoring?"yes":"no"));
232 if (!user_only || stop_recording_on_xrun_is_user) {
233 node->add_child_nocopy(option_node("stop-recording-on-xrun", stop_recording_on_xrun?"yes":"no"));
235 if (!user_only || verify_remove_last_capture_is_user) {
236 node->add_child_nocopy(option_node("verify-remove-last-capture", verify_remove_last_capture?"yes":"no"));
238 if (!user_only || stop_at_session_end_is_user) {
239 node->add_child_nocopy(option_node("stop-at-session-end", stop_at_session_end?"yes":"no"));
241 if (!user_only || seamless_looping_is_user) {
242 node->add_child_nocopy(option_node("seamless-loop", seamless_looping?"yes":"no"));
244 if (!user_only || auto_xfade_is_user) {
245 node->add_child_nocopy(option_node("auto-xfade", auto_xfade?"yes":"no"));
247 if (!user_only || no_new_session_dialog_is_user) {
248 node->add_child_nocopy(option_node("no-new-session-dialog", no_new_session_dialog?"yes":"no"));
250 if (!user_only || timecode_source_is_synced_is_user) {
251 node->add_child_nocopy(option_node("timecode-source-is-synced", timecode_source_is_synced?"yes":"no"));
253 if (!user_only || auditioner_output_left_is_user) {
254 node->add_child_nocopy(option_node("auditioner-left-out", auditioner_output_left));
256 if (!user_only || auditioner_output_right_is_user) {
257 node->add_child_nocopy(option_node("auditioner-right-out", auditioner_output_right));
259 if (!user_only || quieten_at_speed_is_user) {
260 snprintf (buf, sizeof (buf), "%f", speed_quietning);
261 node->add_child_nocopy(option_node("quieten-at-speed", buf));
263 if (!user_only || latched_record_enable_is_user) {
264 node->add_child_nocopy(option_node("latched-record-enable", latched_record_enable?"yes":"no"));
266 if (!user_only || destructive_xfade_msecs_is_user) {
267 snprintf(buf, sizeof(buf), "%" PRIu32, destructive_xfade_msecs);
268 node->add_child_nocopy(option_node("destructive_xfade_msecs", string(buf)));
271 /* use-vst is always per-user */
272 node->add_child_nocopy (option_node ("use-vst", use_vst?"yes":"no"));
274 root->add_child_nocopy (*node);
277 root->add_child_copy (*key_node);
281 root->add_child_copy (*_extra_xml);
288 Configuration::set_state (const XMLNode& root)
290 if (root.name() != "Ardour") {
294 XMLNodeList nlist = root.children();
295 XMLNodeConstIterator niter;
299 for (niter = nlist.begin(); niter != nlist.end(); ++niter) {
303 if (node->name() == "MIDI-port") {
306 pair<string,MidiPortDescriptor*> newpair;
307 newpair.second = new MidiPortDescriptor (*node);
308 newpair.first = newpair.second->tag;
309 midi_ports.insert (newpair);
312 catch (failed_constructor& err) {
313 warning << _("ill-formed MIDI port specification in ardour rcfile (ignored)") << endmsg;
316 } else if (node->name() == "Config") {
318 XMLNodeList option_list = node->children();
319 XMLNodeConstIterator option_iter;
320 XMLNode *option_node;
325 for (option_iter = option_list.begin(); option_iter != option_list.end(); ++option_iter) {
327 option_node = *option_iter;
329 if (option_node->name() != "Option") {
333 if ((prop = option_node->property ("name")) != 0) {
334 option_name = prop->value();
336 throw failed_constructor ();
339 if ((prop = option_node->property ("value")) != 0) {
340 option_value = prop->value();
342 throw failed_constructor ();
345 if (option_name == "minimum-disk-io-bytes") {
346 set_minimum_disk_io (atoi (option_value.c_str()));
347 } else if (option_name == "track-buffer-seconds") {
348 set_track_buffer (atof (option_value.c_str()));
349 } else if (option_name == "raid-path") {
350 set_raid_path (option_value);
351 } else if (option_name == "hiding-groups-deactivates-groups") {
352 set_hiding_groups_deactivates_groups (option_value == "yes");
353 } else if (option_name == "mute-affects-pre-fader") {
354 set_mute_affects_pre_fader (option_value == "yes");
355 } else if (option_name == "mute-affects-post-fader") {
356 set_mute_affects_post_fader (option_value == "yes");
357 } else if (option_name == "mute-affects-control-outs") {
358 set_mute_affects_control_outs (option_value == "yes");
359 } else if (option_name == "mute-affects-main-outs") {
360 set_mute_affects_main_outs (option_value == "yes");
361 } else if (option_name == "solo-latch") {
362 set_solo_latch (option_value == "yes");
363 } else if (option_name == "mtc-port") {
364 set_mtc_port_name (option_value);
365 } else if (option_name == "mmc-port") {
366 set_mmc_port_name (option_value);
367 } else if (option_name == "midi-port") {
368 set_midi_port_name (option_value);
369 } else if (option_name == "hardware-monitoring") {
370 set_use_hardware_monitoring (option_value == "yes");
371 } else if (option_name == "jack-time-master") {
372 set_jack_time_master (option_value == "yes");
373 } else if (option_name == "trace-midi-input") {
374 set_trace_midi_input (option_value == "yes");
375 } else if (option_name == "trace-midi-output") {
376 set_trace_midi_output (option_value == "yes");
377 } else if (option_name == "plugins-stop-with-transport") {
378 set_plugins_stop_with_transport (option_value == "yes");
379 } else if (option_name == "use-sw-monitoring") {
380 set_use_sw_monitoring (option_value == "yes");
381 } else if (option_name == "no-sw-monitoring") { /* DEPRECATED */
382 set_use_sw_monitoring (option_value != "yes");
383 } else if (option_name == "stop-recording-on-xrun") {
384 set_stop_recording_on_xrun (option_value == "yes");
385 } else if (option_name == "verify-remove-last-capture") {
386 set_verify_remove_last_capture (option_value == "yes");
387 } else if (option_name == "stop-at-session-end") {
388 set_stop_at_session_end (option_value == "yes");
389 } else if (option_name == "seamless-loop") {
390 set_seamless_looping (option_value == "yes");
391 } else if (option_name == "auto-xfade") {
392 set_auto_xfade (option_value == "yes");
393 } else if (option_name == "no-new-session-dialog") {
394 set_no_new_session_dialog (option_value == "yes");
395 } else if (option_name == "timecode-source-is-synced") {
396 set_timecode_source_is_synced (option_value == "yes");
397 } else if (option_name == "auditioner-left-out") {
398 set_auditioner_output_left (option_value);
399 } else if (option_name == "auditioner-right-out") {
400 set_auditioner_output_right (option_value);
401 } else if (option_name == "use-vst") {
402 set_use_vst (option_value == "yes");
403 } else if (option_name == "quieten-at-speed") {
405 if (sscanf (option_value.c_str(), "%f", &v) == 1) {
406 set_quieten_at_speed (v);
408 } else if (option_name == "midi-feedback-interval-ms") {
409 set_midi_feedback_interval_ms (atoi (option_value.c_str()));
410 } else if (option_name == "latched-record-enable") {
411 set_latched_record_enable (option_value == "yes");
412 } else if (option_name == "destructive_xfade_msecs") {
414 if (sscanf (option_value.c_str(), "%u", &v) == 1) {
415 set_destructive_xfade_msecs (v);
420 } else if (node->name() == "Keys") {
421 /* defer handling of this for UI objects */
422 key_node = new XMLNode (*node);
423 } else if (node->name() == "extra") {
424 _extra_xml = new XMLNode (*node);
428 DiskStream::set_disk_io_chunk_frames (minimum_disk_io_bytes / sizeof (Sample));
434 Configuration::set_defaults ()
437 orig_raid_path = raid_path;
439 mtc_port_name = N_("default");
440 mmc_port_name = N_("default");
441 midi_port_name = N_("default");
443 auditioner_output_left = N_("coreaudio:Built-in Audio:in1");
444 auditioner_output_right = N_("coreaudio:Built-in Audio:in2");
446 auditioner_output_left = N_("alsa_pcm:playback_1");
447 auditioner_output_right = N_("alsa_pcm:playback_2");
449 minimum_disk_io_bytes = 1024 * 256;
450 track_buffer_seconds = 5.0;
451 hiding_groups_deactivates_groups = true;
452 mute_affects_pre_fader = 1;
453 mute_affects_post_fader = 1;
454 mute_affects_control_outs = 1;
455 mute_affects_main_outs = 1;
457 use_hardware_monitoring = true;
458 be_jack_time_master = true;
459 native_format_is_bwf = true;
460 trace_midi_input = false;
461 trace_midi_output = false;
462 plugins_stop_with_transport = false;
463 use_sw_monitoring = true;
464 stop_recording_on_xrun = false;
465 verify_remove_last_capture = true;
466 stop_at_session_end = true;
467 seamless_looping = true;
469 no_new_session_dialog = false;
470 timecode_source_is_synced = true;
471 use_vst = true; /* if we build with VST_SUPPORT, otherwise no effect */
472 quieten_at_speed = true;
473 destructive_xfade_msecs = 2;
475 midi_feedback_interval_ms = 100;
477 // this is about 5 minutes at 48kHz, 4 bytes/sample
478 disk_choice_space_threshold = 57600000;
480 /* at this point, no variables from from the user */
482 raid_path_is_user = false;
483 minimum_disk_io_bytes_is_user = false;
484 track_buffer_seconds_is_user = false;
485 hiding_groups_deactivates_groups_is_user = false;
486 auditioner_output_left_is_user = false;
487 auditioner_output_right_is_user = false;
488 mute_affects_pre_fader_is_user = false;
489 mute_affects_post_fader_is_user = false;
490 mute_affects_control_outs_is_user = false;
491 mute_affects_main_outs_is_user = false;
492 solo_latch_is_user = false;
493 disk_choice_space_threshold_is_user = false;
494 mtc_port_name_is_user = false;
495 mmc_port_name_is_user = false;
496 midi_port_name_is_user = false;
497 use_hardware_monitoring_is_user = false;
498 be_jack_time_master_is_user = false;
499 native_format_is_bwf_is_user = false;
500 trace_midi_input_is_user = false;
501 trace_midi_output_is_user = false;
502 plugins_stop_with_transport_is_user = false;
503 use_sw_monitoring_is_user = false;
504 stop_recording_on_xrun_is_user = false;
505 verify_remove_last_capture_is_user = false;
506 stop_at_session_end_is_user = false;
507 seamless_looping_is_user = false;
508 auto_xfade_is_user = false;
509 no_new_session_dialog_is_user = false;
510 timecode_source_is_synced_is_user = false;
511 quieten_at_speed_is_user = false;
512 midi_feedback_interval_ms_is_user = false;
513 latched_record_enable_is_user = false;
514 destructive_xfade_msecs_is_user = false;
517 Configuration::MidiPortDescriptor::MidiPortDescriptor (const XMLNode& node)
519 const XMLProperty *prop;
520 bool have_tag = false;
521 bool have_device = false;
522 bool have_type = false;
523 bool have_mode = false;
525 if ((prop = node.property ("tag")) != 0) {
530 if ((prop = node.property ("device")) != 0) {
531 device = prop->value();
535 if ((prop = node.property ("type")) != 0) {
536 type = prop->value();
540 if ((prop = node.property ("mode")) != 0) {
541 mode = prop->value();
545 if (!have_tag || !have_device || !have_type || !have_mode) {
546 throw failed_constructor();
551 Configuration::MidiPortDescriptor::get_state()
553 XMLNode* root = new XMLNode("MIDI-port");
555 root->add_property("tag", tag);
556 root->add_property("device", device);
557 root->add_property("type", type);
558 root->add_property("mode", mode);
564 Configuration::option_node(const string & name, const string & value)
566 XMLNode* root = new XMLNode("Option");
568 root->add_property("name", name);
569 root->add_property("value", value);
575 Configuration::get_raid_path()
581 Configuration::set_raid_path(string path)
584 /* Handle tilde and environment variable expansion in session path */
586 switch (wordexp (path.c_str(), &expansion, WRDE_NOCMD|WRDE_UNDEF)) {
590 error << _("illegal or badly-formed string used for RAID path") << endmsg;
594 if (expansion.we_wordc > 1) {
595 error << _("RAID search path is ambiguous") << endmsg;
599 raid_path = expansion.we_wordv[0];
600 orig_raid_path = path;
601 wordfree (&expansion);
603 raid_path = orig_raid_path = path;
606 if (user_configuration) {
607 raid_path_is_user = true;
612 Configuration::get_minimum_disk_io()
614 return minimum_disk_io_bytes;
618 Configuration::set_minimum_disk_io(uint32_t min)
620 minimum_disk_io_bytes = min;
621 if (user_configuration) {
622 minimum_disk_io_bytes_is_user = true;
627 Configuration::get_track_buffer()
629 return track_buffer_seconds;
633 Configuration::set_track_buffer(float buffer)
635 track_buffer_seconds = buffer;
636 if (user_configuration) {
637 track_buffer_seconds_is_user = true;
642 Configuration::does_hiding_groups_deactivates_groups()
644 return hiding_groups_deactivates_groups;
648 Configuration::set_hiding_groups_deactivates_groups(bool hiding)
650 hiding_groups_deactivates_groups = hiding;
651 if (user_configuration) {
652 hiding_groups_deactivates_groups_is_user = true;
657 Configuration::get_auditioner_output_left ()
659 return auditioner_output_left;
663 Configuration::set_auditioner_output_left (string str)
665 auditioner_output_left = str;
666 if (user_configuration) {
667 auditioner_output_left_is_user = true;
672 Configuration::get_auditioner_output_right ()
674 return auditioner_output_right;
678 Configuration::set_auditioner_output_right (string str)
680 auditioner_output_right = str;
681 if (user_configuration) {
682 auditioner_output_right_is_user = true;
687 Configuration::get_mute_affects_pre_fader()
689 return mute_affects_pre_fader;
693 Configuration::set_mute_affects_pre_fader (bool affects)
695 mute_affects_pre_fader = affects;
696 if (user_configuration) {
697 mute_affects_pre_fader_is_user = true;
702 Configuration::get_mute_affects_post_fader()
704 return mute_affects_post_fader;
708 Configuration::set_mute_affects_post_fader (bool affects)
710 mute_affects_post_fader = affects;
711 if (user_configuration) {
712 mute_affects_post_fader_is_user = true;
717 Configuration::get_mute_affects_control_outs()
719 return mute_affects_control_outs;
723 Configuration::set_mute_affects_control_outs (bool affects)
725 mute_affects_control_outs = affects;
726 if (user_configuration) {
727 mute_affects_control_outs_is_user = true;
732 Configuration::get_mute_affects_main_outs()
734 return mute_affects_main_outs;
738 Configuration::set_mute_affects_main_outs (bool affects)
740 mute_affects_main_outs = affects;
741 if (user_configuration) {
742 mute_affects_main_outs_is_user = true;
747 Configuration::get_solo_latch()
753 Configuration::set_solo_latch (bool latch)
756 if (user_configuration) {
757 solo_latch_is_user = true;
762 Configuration::get_keys () const
768 Configuration::set_keys (XMLNode* keys)
774 Configuration::get_disk_choice_space_threshold ()
776 return disk_choice_space_threshold;
780 Configuration::set_disk_choice_space_threshold (uint32_t val)
782 disk_choice_space_threshold = val;
783 if (user_configuration) {
784 disk_choice_space_threshold_is_user = true;
789 Configuration::get_mmc_port_name ()
791 return mmc_port_name;
795 Configuration::set_mmc_port_name (string name)
797 mmc_port_name = name;
798 if (user_configuration) {
799 mmc_port_name_is_user = true;
804 Configuration::get_mtc_port_name ()
806 return mtc_port_name;
810 Configuration::set_mtc_port_name (string name)
812 mtc_port_name = name;
813 if (user_configuration) {
814 mtc_port_name_is_user = true;
819 Configuration::get_midi_port_name ()
821 return midi_port_name;
825 Configuration::set_midi_port_name (string name)
827 midi_port_name = name;
828 if (user_configuration) {
829 midi_port_name_is_user = true;
834 Configuration::get_midi_feedback_interval_ms ()
836 return midi_feedback_interval_ms;
840 Configuration::set_midi_feedback_interval_ms (uint32_t val)
842 midi_feedback_interval_ms = val;
843 if (user_configuration) {
844 midi_feedback_interval_ms_is_user = true;
849 Configuration::get_use_hardware_monitoring()
851 return use_hardware_monitoring;
855 Configuration::set_use_hardware_monitoring(bool yn)
857 use_hardware_monitoring = yn;
858 if (user_configuration) {
859 use_hardware_monitoring_is_user = true;
864 Configuration::get_jack_time_master()
866 return be_jack_time_master;
870 Configuration::set_jack_time_master(bool yn)
872 be_jack_time_master = yn;
873 if (user_configuration) {
874 be_jack_time_master_is_user = true;
879 Configuration::get_native_format_is_bwf()
881 return native_format_is_bwf;
885 Configuration::set_native_format_is_bwf(bool yn)
887 native_format_is_bwf = yn;
888 if (user_configuration) {
889 native_format_is_bwf_is_user = true;
894 Configuration::get_trace_midi_input ()
896 return trace_midi_input;
900 Configuration::set_trace_midi_input (bool yn)
902 trace_midi_input = yn;
903 if (user_configuration) {
904 trace_midi_input_is_user = true;
909 Configuration::get_trace_midi_output ()
911 return trace_midi_output;
915 Configuration::set_trace_midi_output (bool yn)
917 trace_midi_output = yn;
918 if (user_configuration) {
919 trace_midi_output_is_user = true;
924 Configuration::get_plugins_stop_with_transport ()
926 return plugins_stop_with_transport;
930 Configuration::set_plugins_stop_with_transport (bool yn)
932 plugins_stop_with_transport = yn;
933 if (user_configuration) {
934 plugins_stop_with_transport_is_user = true;
939 Configuration::get_use_sw_monitoring ()
941 return use_sw_monitoring;
945 Configuration::set_use_sw_monitoring (bool yn)
947 use_sw_monitoring = yn;
948 if (user_configuration) {
949 use_sw_monitoring_is_user = true;
954 Configuration::get_stop_recording_on_xrun ()
956 return stop_recording_on_xrun;
960 Configuration::set_stop_recording_on_xrun (bool yn)
962 stop_recording_on_xrun = yn;
963 if (user_configuration) {
964 stop_recording_on_xrun_is_user = true;
969 Configuration::get_verify_remove_last_capture ()
971 return verify_remove_last_capture;
975 Configuration::set_verify_remove_last_capture (bool yn)
977 verify_remove_last_capture = yn;
978 if (user_configuration) {
979 verify_remove_last_capture_is_user = true;
984 Configuration::get_stop_at_session_end ()
986 return stop_at_session_end;
990 Configuration::set_stop_at_session_end (bool yn)
992 stop_at_session_end = yn;
993 if (user_configuration) {
994 stop_at_session_end_is_user = true;
999 Configuration::get_seamless_looping ()
1001 return seamless_looping;
1005 Configuration::set_seamless_looping (bool yn)
1007 seamless_looping = yn;
1008 if (user_configuration) {
1009 seamless_looping_is_user = true;
1014 Configuration::get_auto_xfade ()
1020 Configuration::set_auto_xfade (bool yn)
1023 if (user_configuration) {
1024 auto_xfade_is_user = true;
1029 Configuration::get_no_new_session_dialog()
1031 return no_new_session_dialog;
1035 Configuration::set_no_new_session_dialog(bool yn)
1037 no_new_session_dialog = yn;
1038 if (user_configuration) {
1039 no_new_session_dialog_is_user = true;
1044 Configuration::get_timecode_source_is_synced()
1046 return timecode_source_is_synced;
1050 Configuration::set_timecode_source_is_synced (bool yn)
1052 timecode_source_is_synced = yn;
1053 if (user_configuration) {
1054 timecode_source_is_synced_is_user = true;
1059 Configuration::get_use_vst ()
1065 Configuration::set_use_vst (bool yn)
1071 Configuration::get_quieten_at_speed()
1073 return speed_quietning;
1077 Configuration::set_quieten_at_speed (float gain_coefficient)
1079 speed_quietning = gain_coefficient;
1080 if (user_configuration) {
1081 quieten_at_speed_is_user = true;
1086 Configuration::set_latched_record_enable (bool yn)
1088 latched_record_enable = yn;
1089 if (user_configuration) {
1090 latched_record_enable_is_user = true;
1095 Configuration::get_latched_record_enable ()
1097 return latched_record_enable;
1101 Configuration::get_destructive_xfade_msecs ()
1103 return destructive_xfade_msecs;
1107 Configuration::set_destructive_xfade_msecs (uint32_t msecs, jack_nframes_t rate)
1109 destructive_xfade_msecs = msecs;
1111 DestructiveFileSource::setup_standard_crossfades (rate);