RegionExportChannelSelector::sync_with_manager ()
{
state = manager->get_channel_configs().front();
+
+ if (!state) { return; }
+
+ switch (state->config->region_processing_type()) {
+ case RegionExportChannelFactory::None:
+ // Do nothing
+ break;
+ case RegionExportChannelFactory::Raw:
+ raw_button.set_active (true);
+ break;
+ case RegionExportChannelFactory::Fades:
+ fades_button.set_active (true);
+ break;
+ case RegionExportChannelFactory::Processed:
+ processed_button.set_active (true);
+ break;
+ }
+
handle_selection ();
}
state->config->clear_channels ();
+ RegionExportChannelFactory::Type type = RegionExportChannelFactory::None;
if (raw_button.get_active ()) {
- factory.reset (new RegionExportChannelFactory (_session, region, track, RegionExportChannelFactory::Raw));
+ type = RegionExportChannelFactory::Raw;
} else if (fades_button.get_active ()) {
- factory.reset (new RegionExportChannelFactory (_session, region, track, RegionExportChannelFactory::Fades));
+ type = RegionExportChannelFactory::Fades;
} else if (processed_button.get_active ()) {
- factory.reset (new RegionExportChannelFactory(_session, region, track, RegionExportChannelFactory::Processed));
+ type = RegionExportChannelFactory::Processed;
} else {
CriticalSelectionChanged ();
return;
}
+ factory.reset (new RegionExportChannelFactory (_session, region, track, type));
+ state->config->set_region_processing_type (type);
+
for (size_t chan = 0; chan < region_chans; ++chan) {
state->config->register_channel (factory->create (chan));
}
{
public:
enum Type {
+ None,
Raw,
Fades,
Processed
void set_name (std::string name) { _name = name; }
void set_split (bool value) { split = value; }
+ RegionExportChannelFactory::Type region_processing_type() const { return region_type; }
+ void set_region_processing_type(RegionExportChannelFactory::Type type) { region_type = type; }
+
bool get_split () const { return split; }
uint32_t get_n_chans () const { return channels.size(); }
ChannelList channels;
bool split; // Split to mono files
std::string _name;
+ RegionExportChannelFactory::Type region_type;
};
} // namespace ARDOUR
#include "ardour/export_filename.h"
#include "ardour/export_format_base.h"
#include "ardour/export_profile_manager.h"
+#include "ardour/export_channel_configuration.h"
#include "ardour/io.h"
#include "ardour/location.h"
#include "ardour/midi_model.h"
ExportFormatBase::SampleRate _ExportFormatBase_SampleRate;
ExportFormatBase::SRCQuality _ExportFormatBase_SRCQuality;
ExportProfileManager::TimeFormat _ExportProfileManager_TimeFormat;
+ RegionExportChannelFactory::Type _RegionExportChannelFactory_Type;
Delivery::Role _Delivery_Role;
IO::Direction _IO_Direction;
MuteMaster::MutePoint _MuteMaster_MutePoint;
REGISTER_CLASS_ENUM (ExportProfileManager, Frames);
REGISTER (_ExportProfileManager_TimeFormat);
+ REGISTER_CLASS_ENUM (RegionExportChannelFactory, None);
+ REGISTER_CLASS_ENUM (RegionExportChannelFactory, Raw);
+ REGISTER_CLASS_ENUM (RegionExportChannelFactory, Fades);
+ REGISTER_CLASS_ENUM (RegionExportChannelFactory, Processed);
+ REGISTER (_RegionExportChannelFactory_Type);
+
REGISTER_CLASS_ENUM (Delivery, Insert);
REGISTER_CLASS_ENUM (Delivery, Send);
REGISTER_CLASS_ENUM (Delivery, Listen);
#include "ardour/audioengine.h"
#include "pbd/convert.h"
+#include "pbd/enumwriter.h"
#include "pbd/pthread_utils.h"
using namespace PBD;
/* ExportChannelConfiguration */
-ExportChannelConfiguration::ExportChannelConfiguration (Session & session) :
- session (session),
- split (false)
+ExportChannelConfiguration::ExportChannelConfiguration (Session & session)
+ : session (session)
+ , split (false)
+ , region_type (RegionExportChannelFactory::None)
{
}
root->add_property ("split", get_split() ? "true" : "false");
root->add_property ("channels", to_string (get_n_chans(), std::dec));
+ switch (region_type) {
+ case RegionExportChannelFactory::None:
+ // Do nothing
+ break;
+ default:
+ root->add_property ("region-processing", enum_2_string (region_type));
+ break;
+ }
+
uint32_t i = 1;
for (ExportChannelConfiguration::ChannelList::const_iterator c_it = channels.begin(); c_it != channels.end(); ++c_it) {
channel = root->add_child ("Channel");
set_split (!prop->value().compare ("true"));
}
+ if ((prop = root.property ("region-processing"))) {
+ set_region_processing_type ((RegionExportChannelFactory::Type)
+ string_2_enum (prop->value(), RegionExportChannelFactory::Type));
+ }
+
XMLNodeList channels = root.children ("Channel");
for (XMLNodeList::iterator it = channels.begin(); it != channels.end(); ++it) {
ExportChannelPtr channel (new PortExportChannel ());
ExportProfileManager::~ExportProfileManager ()
{
- if (single_range_mode) { return; }
-
XMLNode * instant_xml (new XMLNode (xml_node_name));
serialize_profile (*instant_xml);
session.add_instant_xml (*instant_xml, false);