#include <cerrno>
#include <glib.h>
-#include <glib/gstdio.h>
+#include "pbd/gstdio_compat.h"
#include <glibmm/fileutils.h>
#include <glibmm/miscutils.h>
#include "ardour/export_failed.h"
#include "ardour/directory_names.h"
#include "ardour/filename_extensions.h"
+#include "ardour/profile.h"
#include "ardour/route.h"
#include "ardour/session.h"
#include "ardour/broadcast_info.h"
ExportProfileManager::~ExportProfileManager ()
{
- XMLNode * instant_xml (new XMLNode (xml_node_name));
- serialize_profile (*instant_xml);
- session.add_instant_xml (*instant_xml, false);
+ XMLNode * extra_xml (new XMLNode (xml_node_name));
+ serialize_profile (*extra_xml);
+ session.add_extra_xml (*extra_xml);
}
void
ExportProfileManager::load_profile ()
{
- XMLNode * instant_node = session.instant_xml (xml_node_name);
- if (instant_node) {
- set_state (*instant_node);
+ XMLNode * extra_node = session.extra_xml (xml_node_name);
+ /* Legacy sessions used Session instant.xml for this */
+ if (!extra_node) {
+ extra_node = session.instant_xml (xml_node_name);
+ }
+
+ if (extra_node) {
+ set_state (*extra_node);
} else {
XMLNode empty_node (xml_node_name);
set_state (empty_node);
if (!preset) { return false; }
XMLNode const * state;
+ /* local state is saved in instant.xml and contains timespan
+ * and channel config for per session.
+ * It may not be present for a given preset/session combination
+ * and is never preset for system-wide presets, but that's OK.
+ */
if ((state = preset->get_local_state())) {
set_local_state (*state);
- } else { ok = false; }
+ }
if ((state = preset->get_global_state())) {
if (!set_global_state (*state)) {
{
vector<std::string> found;
- Glib::PatternSpec pattern_spec (pattern);
- find_matching_files_in_search_path (search_path, pattern_spec, found);
+ find_files_matching_pattern (found, search_path, pattern);
return found;
}
timespans.push_back (state);
// Add session as default selection
- Location * session_range = session.locations()->session_range_location();
+ Location * session_range;
+
+ if (Profile->get_trx()) {
+ session_range = (session.get_play_loop () ? session.locations()->auto_loop_location () : session.locations()->session_range_location());
+ } else {
+ session_range = session.locations()->session_range_location();
+ }
+
if (!session_range) { return false; }
ExportTimespanPtr timespan = handler->add_timespan();
return;
}
- /* Session */
- Location * session_range = session.locations()->session_range_location();
- if (session_range) {
- ranges->push_back (session_range);
+ /* Loop */
+ if (session.locations()->auto_loop_location ()) {
+ ranges->push_back (session.locations()->auto_loop_location ());
+ }
+
+ /* Session */
+ if (session.locations()->session_range_location()) {
+ ranges->push_back (session.locations()->session_range_location());
}
/* Selection */
ExportProfileManager::FormatStatePtr
ExportProfileManager::deserialize_format (XMLNode & root)
{
- XMLProperty * prop;
+ XMLProperty const * prop;
PBD::UUID id;
if ((prop = root.property ("id"))) {
ExportProfileManager::get_sample_filename_for_format (ExportFilenamePtr filename, ExportFormatSpecPtr format)
{
assert (format);
-
+
if (channel_configs.empty()) { return ""; }
std::list<string> filenames;
if (!channel_configs.empty ()) {
channel_config_state = channel_configs.front();
}
-
+
TimespanStatePtr timespan_state = timespans.front();
/*** Check "global" config ***/
check_config (warnings, timespan_state, channel_config_state, *format_it, *filename_it);
}
}
-
+
return warnings;
}