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>
37 using namespace ARDOUR;
40 /* this is global so that we do not have to indirect through an object pointer
45 float speed_quietning = 0.251189; // -12dB reduction for ffwd or rewind
48 Configuration::Configuration ()
51 user_configuration = false;
55 Configuration::~Configuration ()
60 Configuration::get_user_path()
64 if ((envvar = getenv ("ARDOUR_RC")) != 0) {
68 return find_config_file ("ardour.rc");
72 Configuration::get_system_path()
76 if ((envvar = getenv ("ARDOUR_SYSTEM_RC")) != 0) {
80 return find_config_file ("ardour_system.rc");
84 Configuration::load_state ()
88 /* load system configuration first */
90 rcfile = get_system_path ();
92 if (rcfile.length()) {
96 cerr << "Loading system configuration file " << rcfile << endl;
98 if (!tree.read (rcfile.c_str())) {
99 error << string_compose(_("Ardour: cannot read system configuration file \"%1\""), rcfile) << endmsg;
103 if (set_state (*tree.root())) {
104 error << string_compose(_("Ardour: system configuration file \"%1\" not loaded successfully."), rcfile) << endmsg;
109 /* from this point on, all configuration changes are user driven */
111 user_configuration = true;
113 /* now load configuration file for user */
115 rcfile = get_user_path ();
117 if (rcfile.length()) {
121 cerr << "Loading user configuration file " << rcfile << endl;
123 if (!tree.read (rcfile)) {
124 error << string_compose(_("Ardour: cannot read configuration file \"%1\""), rcfile) << endmsg;
129 if (set_state (*tree.root())) {
130 error << string_compose(_("Ardour: configuration file \"%1\" not loaded successfully."), rcfile) << endmsg;
139 Configuration::save_state()
145 /* Note: this only writes the per-user file, and therefore
146 only saves variables marked as user-set or modified
149 if ((envvar = getenv ("ARDOUR_RC")) != 0) {
150 if (strlen (envvar) == 0) {
156 if ((envvar = getenv ("HOME")) == 0) {
159 if (strlen (envvar) == 0) {
163 rcfile += "/.ardour/ardour.rc";
166 if (rcfile.length()) {
167 tree.set_root (&state (true));
168 if (!tree.write (rcfile.c_str())){
169 error << _("Config file not saved") << endmsg;
178 Configuration::get_state ()
180 return state (false);
184 Configuration::state (bool user_only)
186 XMLNode* root = new XMLNode("Ardour");
187 LocaleGuard lg (X_("POSIX"));
189 typedef map<string, MidiPortDescriptor*>::const_iterator CI;
190 for(CI m = midi_ports.begin(); m != midi_ports.end(); ++m){
191 root->add_child_nocopy(m->second->get_state());
194 XMLNode* node = new XMLNode("Config");
197 if (!user_only || minimum_disk_io_bytes_is_user) {
198 snprintf(buf, sizeof(buf), "%" PRIu32 , minimum_disk_io_bytes);
199 node->add_child_nocopy(option_node("minimum-disk-io-bytes", string(buf)));
201 if (!user_only || track_buffer_seconds_is_user) {
202 snprintf(buf, sizeof(buf), "%f", track_buffer_seconds);
203 node->add_child_nocopy(option_node("track-buffer-seconds", string(buf)));
205 if (!user_only || disk_choice_space_threshold_is_user) {
206 snprintf(buf, sizeof(buf), "%" PRIu32, disk_choice_space_threshold);
207 node->add_child_nocopy(option_node("disk-choice-space-threshold", string(buf)));
210 if (!user_only || midi_feedback_interval_ms_is_user) {
211 snprintf(buf, sizeof(buf), "%" PRIu32, midi_feedback_interval_ms);
212 node->add_child_nocopy(option_node("midi-feedback-interval-ms", string(buf)));
215 if (!user_only || mute_affects_pre_fader_is_user) {
216 node->add_child_nocopy(option_node("mute-affects-pre-fader", mute_affects_pre_fader?"yes":"no"));
218 if (!user_only || mute_affects_post_fader_is_user) {
219 node->add_child_nocopy(option_node("mute-affects-post-fader", mute_affects_post_fader?"yes":"no"));
221 if (!user_only || mute_affects_control_outs_is_user) {
222 node->add_child_nocopy(option_node("mute-affects-control-outs", mute_affects_control_outs?"yes":"no"));
224 if (!user_only || mute_affects_main_outs_is_user) {
225 node->add_child_nocopy(option_node("mute-affects-main-outs", mute_affects_main_outs?"yes":"no"));
227 if (!user_only || solo_latch_is_user) {
228 node->add_child_nocopy(option_node("solo-latch", solo_latch?"yes":"no"));
230 if (!user_only || raid_path_is_user) {
231 node->add_child_nocopy(option_node("raid-path", orig_raid_path));
233 if (!user_only || mtc_port_name_is_user) {
234 node->add_child_nocopy(option_node("mtc-port", mtc_port_name));
236 if (!user_only || mmc_port_name_is_user) {
237 node->add_child_nocopy(option_node("mmc-port", mmc_port_name));
239 if (!user_only || midi_port_name_is_user) {
240 node->add_child_nocopy(option_node("midi-port", midi_port_name));
242 if (!user_only || use_hardware_monitoring_is_user) {
243 node->add_child_nocopy(option_node("hardware-monitoring", use_hardware_monitoring?"yes":"no"));
245 if (!user_only || be_jack_time_master_is_user) {
246 node->add_child_nocopy(option_node("jack-time-master", be_jack_time_master?"yes":"no"));
248 if (!user_only || native_format_is_bwf_is_user) {
249 node->add_child_nocopy(option_node("native-format-bwf", native_format_is_bwf?"yes":"no"));
251 if (!user_only || trace_midi_input_is_user) {
252 node->add_child_nocopy(option_node("trace-midi-input", trace_midi_input?"yes":"no"));
254 if (!user_only || trace_midi_output_is_user) {
255 node->add_child_nocopy(option_node("trace-midi-output", trace_midi_output?"yes":"no"));
257 if (!user_only || plugins_stop_with_transport_is_user) {
258 node->add_child_nocopy(option_node("plugins-stop-with-transport", plugins_stop_with_transport?"yes":"no"));
260 if (!user_only || use_sw_monitoring_is_user) {
261 node->add_child_nocopy(option_node("use-sw-monitoring", use_sw_monitoring?"yes":"no"));
263 if (!user_only || stop_recording_on_xrun_is_user) {
264 node->add_child_nocopy(option_node("stop-recording-on-xrun", stop_recording_on_xrun?"yes":"no"));
266 if (!user_only || verify_remove_last_capture_is_user) {
267 node->add_child_nocopy(option_node("verify-remove-last-capture", verify_remove_last_capture?"yes":"no"));
269 if (!user_only || stop_at_session_end_is_user) {
270 node->add_child_nocopy(option_node("stop-at-session-end", stop_at_session_end?"yes":"no"));
272 if (!user_only || seamless_looping_is_user) {
273 node->add_child_nocopy(option_node("seamless-loop", seamless_looping?"yes":"no"));
275 if (!user_only || auto_xfade_is_user) {
276 node->add_child_nocopy(option_node("auto-xfade", auto_xfade?"yes":"no"));
278 if (!user_only || no_new_session_dialog_is_user) {
279 node->add_child_nocopy(option_node("no-new-session-dialog", no_new_session_dialog?"yes":"no"));
281 if (!user_only || timecode_source_is_synced_is_user) {
282 node->add_child_nocopy(option_node("timecode-source-is-synced", timecode_source_is_synced?"yes":"no"));
284 if (!user_only || auditioner_output_left_is_user) {
285 node->add_child_nocopy(option_node("auditioner-left-out", auditioner_output_left));
287 if (!user_only || auditioner_output_right_is_user) {
288 node->add_child_nocopy(option_node("auditioner-right-out", auditioner_output_right));
290 if (!user_only || quieten_at_speed_is_user) {
291 snprintf (buf, sizeof (buf), "%f", speed_quietning);
292 node->add_child_nocopy(option_node("quieten-at-speed", buf));
295 /* use-vst is always per-user */
296 node->add_child_nocopy (option_node ("use-vst", use_vst?"yes":"no"));
298 root->add_child_nocopy (*node);
301 root->add_child_copy (*key_node);
305 root->add_child_copy (*_extra_xml);
312 Configuration::set_state (const XMLNode& root)
314 if (root.name() != "Ardour") {
318 XMLNodeList nlist = root.children();
319 XMLNodeConstIterator niter;
323 for (niter = nlist.begin(); niter != nlist.end(); ++niter) {
327 if (node->name() == "MIDI-port") {
330 pair<string,MidiPortDescriptor*> newpair;
331 newpair.second = new MidiPortDescriptor (*node);
332 newpair.first = newpair.second->tag;
333 midi_ports.insert (newpair);
336 catch (failed_constructor& err) {
337 warning << _("ill-formed MIDI port specification in ardour rcfile (ignored)") << endmsg;
340 } else if (node->name() == "Config") {
342 XMLNodeList option_list = node->children();
343 XMLNodeConstIterator option_iter;
344 XMLNode *option_node;
349 for (option_iter = option_list.begin(); option_iter != option_list.end(); ++option_iter) {
351 option_node = *option_iter;
353 if (option_node->name() != "Option") {
357 if ((prop = option_node->property ("name")) != 0) {
358 option_name = prop->value();
360 throw failed_constructor ();
363 if ((prop = option_node->property ("value")) != 0) {
364 option_value = prop->value();
366 throw failed_constructor ();
369 if (option_name == "minimum-disk-io-bytes") {
370 set_minimum_disk_io (atoi (option_value.c_str()));
371 } else if (option_name == "track-buffer-seconds") {
372 set_track_buffer (atof (option_value.c_str()));
373 } else if (option_name == "raid-path") {
374 set_raid_path (option_value);
375 } else if (option_name == "hiding-groups-deactivates-groups") {
376 set_hiding_groups_deactivates_groups (option_value == "yes");
377 } else if (option_name == "mute-affects-pre-fader") {
378 set_mute_affects_pre_fader (option_value == "yes");
379 } else if (option_name == "mute-affects-post-fader") {
380 set_mute_affects_post_fader (option_value == "yes");
381 } else if (option_name == "mute-affects-control-outs") {
382 set_mute_affects_control_outs (option_value == "yes");
383 } else if (option_name == "mute-affects-main-outs") {
384 set_mute_affects_main_outs (option_value == "yes");
385 } else if (option_name == "solo-latch") {
386 set_solo_latch (option_value == "yes");
387 } else if (option_name == "mtc-port") {
388 set_mtc_port_name (option_value);
389 } else if (option_name == "mmc-port") {
390 set_mmc_port_name (option_value);
391 } else if (option_name == "midi-port") {
392 set_midi_port_name (option_value);
393 } else if (option_name == "hardware-monitoring") {
394 set_use_hardware_monitoring (option_value == "yes");
395 } else if (option_name == "jack-time-master") {
396 set_jack_time_master (option_value == "yes");
397 } else if (option_name == "trace-midi-input") {
398 set_trace_midi_input (option_value == "yes");
399 } else if (option_name == "trace-midi-output") {
400 set_trace_midi_output (option_value == "yes");
401 } else if (option_name == "plugins-stop-with-transport") {
402 set_plugins_stop_with_transport (option_value == "yes");
403 } else if (option_name == "use-sw-monitoring") {
404 set_use_sw_monitoring (option_value == "yes");
405 } else if (option_name == "no-sw-monitoring") { /* DEPRECATED */
406 set_use_sw_monitoring (option_value != "yes");
407 } else if (option_name == "stop-recording-on-xrun") {
408 set_stop_recording_on_xrun (option_value == "yes");
409 } else if (option_name == "verify-remove-last-capture") {
410 set_verify_remove_last_capture (option_value == "yes");
411 } else if (option_name == "stop-at-session-end") {
412 set_stop_at_session_end (option_value == "yes");
413 } else if (option_name == "seamless-loop") {
414 set_seamless_looping (option_value == "yes");
415 } else if (option_name == "auto-xfade") {
416 set_auto_xfade (option_value == "yes");
417 } else if (option_name == "no-new-session-dialog") {
418 set_no_new_session_dialog (option_value == "yes");
419 } else if (option_name == "timecode-source-is-synced") {
420 set_timecode_source_is_synced (option_value == "yes");
421 } else if (option_name == "auditioner-left-out") {
422 set_auditioner_output_left (option_value);
423 } else if (option_name == "auditioner-right-out") {
424 set_auditioner_output_right (option_value);
425 } else if (option_name == "use-vst") {
426 set_use_vst (option_value == "yes");
427 } else if (option_name == "quieten-at-speed") {
429 if (sscanf (option_value.c_str(), "%f", &v) == 1) {
430 set_quieten_at_speed (v);
432 } else if (option_name == "midi-feedback-interval-ms") {
433 set_midi_feedback_interval_ms (atoi (option_value.c_str()));
437 } else if (node->name() == "Keys") {
438 /* defer handling of this for UI objects */
439 key_node = new XMLNode (*node);
440 } else if (node->name() == "extra") {
441 _extra_xml = new XMLNode (*node);
445 DiskStream::set_disk_io_chunk_frames (minimum_disk_io_bytes / sizeof (Sample));
451 Configuration::set_defaults ()
454 orig_raid_path = raid_path;
456 mtc_port_name = N_("default");
457 mmc_port_name = N_("default");
458 midi_port_name = N_("default");
460 auditioner_output_left = N_("coreaudio:Built-in Audio:in1");
461 auditioner_output_right = N_("coreaudio:Built-in Audio:in2");
463 auditioner_output_left = N_("alsa_pcm:playback_1");
464 auditioner_output_right = N_("alsa_pcm:playback_2");
466 minimum_disk_io_bytes = 1024 * 256;
467 track_buffer_seconds = 5.0;
468 hiding_groups_deactivates_groups = true;
469 mute_affects_pre_fader = 1;
470 mute_affects_post_fader = 1;
471 mute_affects_control_outs = 1;
472 mute_affects_main_outs = 1;
474 use_hardware_monitoring = true;
475 be_jack_time_master = true;
476 native_format_is_bwf = true;
477 trace_midi_input = false;
478 trace_midi_output = false;
479 plugins_stop_with_transport = false;
480 use_sw_monitoring = true;
481 stop_recording_on_xrun = false;
482 verify_remove_last_capture = true;
483 stop_at_session_end = true;
484 seamless_looping = true;
486 no_new_session_dialog = false;
487 timecode_source_is_synced = true;
488 use_vst = true; /* if we build with VST_SUPPORT, otherwise no effect */
489 quieten_at_speed = true;
491 midi_feedback_interval_ms = 100;
493 // this is about 5 minutes at 48kHz, 4 bytes/sample
494 disk_choice_space_threshold = 57600000;
496 /* at this point, no variables from from the user */
498 raid_path_is_user = false;
499 minimum_disk_io_bytes_is_user = false;
500 track_buffer_seconds_is_user = false;
501 hiding_groups_deactivates_groups_is_user = false;
502 auditioner_output_left_is_user = false;
503 auditioner_output_right_is_user = false;
504 mute_affects_pre_fader_is_user = false;
505 mute_affects_post_fader_is_user = false;
506 mute_affects_control_outs_is_user = false;
507 mute_affects_main_outs_is_user = false;
508 solo_latch_is_user = false;
509 disk_choice_space_threshold_is_user = false;
510 mtc_port_name_is_user = false;
511 mmc_port_name_is_user = false;
512 midi_port_name_is_user = false;
513 use_hardware_monitoring_is_user = false;
514 be_jack_time_master_is_user = false;
515 native_format_is_bwf_is_user = false;
516 trace_midi_input_is_user = false;
517 trace_midi_output_is_user = false;
518 plugins_stop_with_transport_is_user = false;
519 use_sw_monitoring_is_user = false;
520 stop_recording_on_xrun_is_user = false;
521 verify_remove_last_capture_is_user = false;
522 stop_at_session_end_is_user = false;
523 seamless_looping_is_user = false;
524 auto_xfade_is_user = false;
525 no_new_session_dialog_is_user = false;
526 timecode_source_is_synced_is_user = false;
527 quieten_at_speed_is_user = false;
528 midi_feedback_interval_ms_is_user = false;
531 Configuration::MidiPortDescriptor::MidiPortDescriptor (const XMLNode& node)
533 const XMLProperty *prop;
534 bool have_tag = false;
535 bool have_device = false;
536 bool have_type = false;
537 bool have_mode = false;
539 if ((prop = node.property ("tag")) != 0) {
544 if ((prop = node.property ("device")) != 0) {
545 device = prop->value();
549 if ((prop = node.property ("type")) != 0) {
550 type = prop->value();
554 if ((prop = node.property ("mode")) != 0) {
555 mode = prop->value();
559 if (!have_tag || !have_device || !have_type || !have_mode) {
560 throw failed_constructor();
565 Configuration::MidiPortDescriptor::get_state()
567 XMLNode* root = new XMLNode("MIDI-port");
569 root->add_property("tag", tag);
570 root->add_property("device", device);
571 root->add_property("type", type);
572 root->add_property("mode", mode);
578 Configuration::option_node(const string & name, const string & value)
580 XMLNode* root = new XMLNode("Option");
582 root->add_property("name", name);
583 root->add_property("value", value);
589 Configuration::get_raid_path()
595 Configuration::set_raid_path(string path)
598 /* Handle tilde and environment variable expansion in session path */
600 switch (wordexp (path.c_str(), &expansion, WRDE_NOCMD|WRDE_UNDEF)) {
604 error << _("illegal or badly-formed string used for RAID path") << endmsg;
608 if (expansion.we_wordc > 1) {
609 error << _("RAID search path is ambiguous") << endmsg;
613 raid_path = expansion.we_wordv[0];
614 orig_raid_path = path;
615 wordfree (&expansion);
617 raid_path = orig_raid_path = path;
620 if (user_configuration) {
621 raid_path_is_user = true;
626 Configuration::get_minimum_disk_io()
628 return minimum_disk_io_bytes;
632 Configuration::set_minimum_disk_io(uint32_t min)
634 minimum_disk_io_bytes = min;
635 if (user_configuration) {
636 minimum_disk_io_bytes_is_user = true;
641 Configuration::get_track_buffer()
643 return track_buffer_seconds;
647 Configuration::set_track_buffer(float buffer)
649 track_buffer_seconds = buffer;
650 if (user_configuration) {
651 track_buffer_seconds_is_user = true;
656 Configuration::does_hiding_groups_deactivates_groups()
658 return hiding_groups_deactivates_groups;
662 Configuration::set_hiding_groups_deactivates_groups(bool hiding)
664 hiding_groups_deactivates_groups = hiding;
665 if (user_configuration) {
666 hiding_groups_deactivates_groups_is_user = true;
671 Configuration::get_auditioner_output_left ()
673 return auditioner_output_left;
677 Configuration::set_auditioner_output_left (string str)
679 auditioner_output_left = str;
680 if (user_configuration) {
681 auditioner_output_left_is_user = true;
686 Configuration::get_auditioner_output_right ()
688 return auditioner_output_right;
692 Configuration::set_auditioner_output_right (string str)
694 auditioner_output_right = str;
695 if (user_configuration) {
696 auditioner_output_right_is_user = true;
701 Configuration::get_mute_affects_pre_fader()
703 return mute_affects_pre_fader;
707 Configuration::set_mute_affects_pre_fader (bool affects)
709 mute_affects_pre_fader = affects;
710 if (user_configuration) {
711 mute_affects_pre_fader_is_user = true;
716 Configuration::get_mute_affects_post_fader()
718 return mute_affects_post_fader;
722 Configuration::set_mute_affects_post_fader (bool affects)
724 mute_affects_post_fader = affects;
725 if (user_configuration) {
726 mute_affects_post_fader_is_user = true;
731 Configuration::get_mute_affects_control_outs()
733 return mute_affects_control_outs;
737 Configuration::set_mute_affects_control_outs (bool affects)
739 mute_affects_control_outs = affects;
740 if (user_configuration) {
741 mute_affects_control_outs_is_user = true;
746 Configuration::get_mute_affects_main_outs()
748 return mute_affects_main_outs;
752 Configuration::set_mute_affects_main_outs (bool affects)
754 mute_affects_main_outs = affects;
755 if (user_configuration) {
756 mute_affects_main_outs_is_user = true;
761 Configuration::get_solo_latch()
767 Configuration::set_solo_latch (bool latch)
770 if (user_configuration) {
771 solo_latch_is_user = true;
776 Configuration::get_keys () const
782 Configuration::set_keys (XMLNode* keys)
788 Configuration::get_disk_choice_space_threshold ()
790 return disk_choice_space_threshold;
794 Configuration::set_disk_choice_space_threshold (uint32_t val)
796 disk_choice_space_threshold = val;
797 if (user_configuration) {
798 disk_choice_space_threshold_is_user = true;
803 Configuration::get_mmc_port_name ()
805 return mmc_port_name;
809 Configuration::set_mmc_port_name (string name)
811 mmc_port_name = name;
812 if (user_configuration) {
813 mmc_port_name_is_user = true;
818 Configuration::get_mtc_port_name ()
820 return mtc_port_name;
824 Configuration::set_mtc_port_name (string name)
826 mtc_port_name = name;
827 if (user_configuration) {
828 mtc_port_name_is_user = true;
833 Configuration::get_midi_port_name ()
835 return midi_port_name;
839 Configuration::set_midi_port_name (string name)
841 midi_port_name = name;
842 if (user_configuration) {
843 midi_port_name_is_user = true;
848 Configuration::get_midi_feedback_interval_ms ()
850 return midi_feedback_interval_ms;
854 Configuration::set_midi_feedback_interval_ms (uint32_t val)
856 midi_feedback_interval_ms = val;
857 if (user_configuration) {
858 midi_feedback_interval_ms_is_user = true;
863 Configuration::get_use_hardware_monitoring()
865 return use_hardware_monitoring;
869 Configuration::set_use_hardware_monitoring(bool yn)
871 use_hardware_monitoring = yn;
872 if (user_configuration) {
873 use_hardware_monitoring_is_user = true;
878 Configuration::get_jack_time_master()
880 return be_jack_time_master;
884 Configuration::set_jack_time_master(bool yn)
886 be_jack_time_master = yn;
887 if (user_configuration) {
888 be_jack_time_master_is_user = true;
893 Configuration::get_native_format_is_bwf()
895 return native_format_is_bwf;
899 Configuration::set_native_format_is_bwf(bool yn)
901 native_format_is_bwf = yn;
902 if (user_configuration) {
903 native_format_is_bwf_is_user = true;
908 Configuration::get_trace_midi_input ()
910 return trace_midi_input;
914 Configuration::set_trace_midi_input (bool yn)
916 trace_midi_input = yn;
917 if (user_configuration) {
918 trace_midi_input_is_user = true;
923 Configuration::get_trace_midi_output ()
925 return trace_midi_output;
929 Configuration::set_trace_midi_output (bool yn)
931 trace_midi_output = yn;
932 if (user_configuration) {
933 trace_midi_output_is_user = true;
938 Configuration::get_plugins_stop_with_transport ()
940 return plugins_stop_with_transport;
944 Configuration::set_plugins_stop_with_transport (bool yn)
946 plugins_stop_with_transport = yn;
947 if (user_configuration) {
948 plugins_stop_with_transport_is_user = true;
953 Configuration::get_use_sw_monitoring ()
955 return use_sw_monitoring;
959 Configuration::set_use_sw_monitoring (bool yn)
961 use_sw_monitoring = yn;
962 if (user_configuration) {
963 use_sw_monitoring_is_user = true;
968 Configuration::get_stop_recording_on_xrun ()
970 return stop_recording_on_xrun;
974 Configuration::set_stop_recording_on_xrun (bool yn)
976 stop_recording_on_xrun = yn;
977 if (user_configuration) {
978 stop_recording_on_xrun_is_user = true;
983 Configuration::get_verify_remove_last_capture ()
985 return verify_remove_last_capture;
989 Configuration::set_verify_remove_last_capture (bool yn)
991 verify_remove_last_capture = yn;
992 if (user_configuration) {
993 verify_remove_last_capture_is_user = true;
998 Configuration::get_stop_at_session_end ()
1000 return stop_at_session_end;
1004 Configuration::set_stop_at_session_end (bool yn)
1006 stop_at_session_end = yn;
1007 if (user_configuration) {
1008 stop_at_session_end_is_user = true;
1013 Configuration::get_seamless_looping ()
1015 return seamless_looping;
1019 Configuration::set_seamless_looping (bool yn)
1021 seamless_looping = yn;
1022 if (user_configuration) {
1023 seamless_looping_is_user = true;
1028 Configuration::get_auto_xfade ()
1034 Configuration::set_auto_xfade (bool yn)
1037 if (user_configuration) {
1038 auto_xfade_is_user = true;
1043 Configuration::get_user_ardour_path ()
1048 if ((envvar = getenv ("HOME")) == 0 || strlen (envvar) == 0) {
1053 path += "/.ardour/";
1059 Configuration::get_system_ardour_path ()
1064 if ((envvar = getenv ("ARDOUR_DATA_PATH")) != 0) {
1066 if (path[path.length()-1] != ':') {
1078 Configuration::get_no_new_session_dialog()
1080 return no_new_session_dialog;
1084 Configuration::set_no_new_session_dialog(bool yn)
1086 no_new_session_dialog = yn;
1087 if (user_configuration) {
1088 no_new_session_dialog_is_user = true;
1093 Configuration::get_timecode_source_is_synced()
1095 return timecode_source_is_synced;
1099 Configuration::set_timecode_source_is_synced (bool yn)
1101 timecode_source_is_synced = yn;
1102 if (user_configuration) {
1103 timecode_source_is_synced_is_user = true;
1108 Configuration::get_use_vst ()
1114 Configuration::set_use_vst (bool yn)
1120 Configuration::get_quieten_at_speed()
1122 return speed_quietning;
1126 Configuration::set_quieten_at_speed (float gain_coefficient)
1128 speed_quietning = gain_coefficient;
1129 if (user_configuration) {
1130 quieten_at_speed_is_user = true;