summaryrefslogtreecommitdiff
path: root/libs/ardour/processor.cc
diff options
context:
space:
mode:
authorPaul Davis <paul@linuxaudiosystems.com>2012-03-13 20:14:55 +0000
committerPaul Davis <paul@linuxaudiosystems.com>2012-03-13 20:14:55 +0000
commitd46acb86eaa3a94fb2dc673964271ecfe0f004dd (patch)
treee6e24673cff96baf335a2aa3583a8d8a8857d2a1 /libs/ardour/processor.cc
parentb557061ec444cdac8b23d6e433a6fe26c1e176a1 (diff)
redesign how XML state, bitslots and names get propagated during copying a send/port insert/return
git-svn-id: svn://localhost/ardour2/branches/3.0@11669 d708f5d6-7413-0410-9779-e7cbd77b26cf
Diffstat (limited to 'libs/ardour/processor.cc')
-rw-r--r--libs/ardour/processor.cc27
1 files changed, 15 insertions, 12 deletions
diff --git a/libs/ardour/processor.cc b/libs/ardour/processor.cc
index 4be545126b..79384c701e 100644
--- a/libs/ardour/processor.cc
+++ b/libs/ardour/processor.cc
@@ -141,15 +141,15 @@ Processor::set_state_2X (const XMLNode & node, int /*version*/)
XMLProperty const * prop;
XMLNodeList children = node.children ();
-
+
for (XMLNodeIterator i = children.begin(); i != children.end(); ++i) {
if ((*i)->name() == X_("IO")) {
-
+
if ((prop = (*i)->property ("name")) != 0) {
set_name (prop->value ());
}
-
+
set_id (**i);
if ((prop = (*i)->property ("active")) != 0) {
@@ -177,17 +177,20 @@ Processor::set_state (const XMLNode& node, int version)
const XMLProperty *prop;
const XMLProperty *legacy_active = 0;
-
- // may not exist for legacy 3.0 sessions
- if ((prop = node.property ("name")) != 0) {
- /* don't let derived classes have a crack at set_name,
- as some (like Send) will screw with the one we suggest.
- */
- Processor::set_name (prop->value());
+ bool leave_name_alone = (node.property ("ignore-name") != 0);
+
+ if (!leave_name_alone) {
+ // may not exist for legacy 3.0 sessions
+ if ((prop = node.property ("name")) != 0) {
+ /* don't let derived classes have a crack at set_name,
+ as some (like Send) will screw with the one we suggest.
+ */
+ Processor::set_name (prop->value());
+ }
+
+ set_id (node);
}
- set_id (node);
-
XMLNodeList nlist = node.children();
XMLNodeIterator niter;