more MTC debugging
[ardour.git] / libs / ardour / user_bundle.cc
index 2dee0af01eeaa74836d7b1becaae1dc9d7cdb49b..4c39c5f5fff21ca5e73822e9670ae6a252b3248d 100644 (file)
@@ -1,7 +1,7 @@
 #include <cassert>
-#include <pbd/failed_constructor.h>
-#include <pbd/compose.h>
-#include <pbd/xml++.h>
+#include "pbd/failed_constructor.h"
+#include "pbd/compose.h"
+#include "pbd/xml++.h"
 #include "ardour/user_bundle.h"
 #include "ardour/port_set.h"
 #include "ardour/io.h"
@@ -15,19 +15,19 @@ ARDOUR::UserBundle::UserBundle (std::string const & n)
 
 }
 
-ARDOUR::UserBundle::UserBundle (XMLNode const & x, bool i)
+ARDOUR::UserBundle::UserBundle (XMLNode const & node, bool i)
        : Bundle (i)
 {
-       if (set_state (x)) {
+       if (set_state (node, Stateful::loading_state_version)) {
                throw failed_constructor ();
        }
 }
 
 int
-ARDOUR::UserBundle::set_state (XMLNode const & node)
+ARDOUR::UserBundle::set_state (XMLNode const & node, int /*version*/)
 {
        XMLProperty const * name;
-       
+
        if ((name = node.property ("name")) == 0) {
                PBD::error << _("Node for Bundle has no \"name\" property") << endmsg;
                return -1;
@@ -45,7 +45,12 @@ ARDOUR::UserBundle::set_state (XMLNode const & node)
                        return -1;
                }
 
-               add_channel ("XXX");
+               if ((name = (*i)->property ("name")) == 0) {
+                       PBD::error << _("Node for Channel has no \"name\" property") << endmsg;
+                       return -1;
+               }
+
+               add_channel (name->value ());
 
                XMLNodeList const ports = (*i)->children ();
 
@@ -58,8 +63,8 @@ ARDOUR::UserBundle::set_state (XMLNode const & node)
                        if ((name = (*j)->property ("name")) == 0) {
                                PBD::error << _("Node for Port has no \"name\" property") << endmsg;
                                return -1;
-                       } 
-                       
+                       }
+
                        add_port_to_channel (n, name->value ());
                }
 
@@ -73,7 +78,7 @@ XMLNode&
 ARDOUR::UserBundle::get_state ()
 {
        XMLNode *node;
-       
+
        if (ports_are_inputs ()) {
                node = new XMLNode ("InputBundle");
        } else {
@@ -88,13 +93,13 @@ ARDOUR::UserBundle::get_state ()
                for (std::vector<Channel>::iterator i = _channel.begin(); i != _channel.end(); ++i) {
                        XMLNode* c = new XMLNode ("Channel");
                        c->add_property ("name", i->name);
-                       
+
                        for (PortList::iterator j = i->ports.begin(); j != i->ports.end(); ++j) {
                                XMLNode* p = new XMLNode ("Port");
                                p->add_property ("name", *j);
                                c->add_child_nocopy (*p);
                        }
-                       
+
                        node->add_child_nocopy (*c);
                }
        }