- const XMLProperty *prop;
-
- nlist = root.children();
-
- for (niter = nlist.begin(); niter != nlist.end(); ++niter) {
- if ((*niter)->name() == X_("azimuth")) {
- prop = (*niter)->property (X_("value"));
- if (prop) {
- pan_azimuth_control->set_value (atof (prop->value()));
- }
- } else if ((*niter)->name() == X_("width")) {
- prop = (*niter)->property (X_("value"));
- if (prop) {
- pan_width_control->set_value (atof (prop->value()));
- }
- } else if ((*niter)->name() == X_("elevation")) {
- prop = (*niter)->property (X_("value"));
- if (prop) {
- pan_elevation_control->set_value (atof (prop->value()));
- }
- } else if ((*niter)->name() == X_("azimuth")) {
- prop = (*niter)->property (X_("value"));
- if (prop) {
- pan_frontback_control->set_value (atof (prop->value()));
- }
- } else if ((*niter)->name() == X_("lfe")) {
- prop = (*niter)->property (X_("value"));
- if (prop) {
- pan_lfe_control->set_value (atof (prop->value()));
- }
- } else if ((*niter)->name() == Automatable::xml_node_name) {
- set_automation_xml_state (**niter, PanAzimuthAutomation);
- }
- }
-
- _has_state = true;
-
- return 0;
+
+ for (niter = nlist.begin(); niter != nlist.end(); ++niter) {
+ if ((*niter)->name() == Controllable::xml_node_name) {
+ const XMLProperty* prop = (*niter)->property (X_("name"));
+
+ if (!prop) {
+ continue;
+ }
+
+ if (prop->value() == pan_azimuth_control->name()) {
+ pan_azimuth_control->set_state (**niter, version);
+ } else if (prop->value() == pan_width_control->name()) {
+ pan_width_control->set_state (**niter, version);
+ } else if (prop->value() == pan_elevation_control->name()) {
+ pan_elevation_control->set_state (**niter, version);
+ } else if (prop->value() == pan_frontback_control->name()) {
+ pan_frontback_control->set_state (**niter, version);
+ } else if (prop->value() == pan_lfe_control->name()) {
+ pan_lfe_control->set_state (**niter, version);
+ }
+
+ } else if ((*niter)->name() == Automatable::xml_node_name) {
+ set_automation_xml_state (**niter, PanAzimuthAutomation);
+
+ } else {
+ const XMLProperty* prop;
+
+ /* old school (alpha1-6) XML info */
+
+ if ((*niter)->name() == X_("azimuth")) {
+ prop = (*niter)->property (X_("value"));
+ if (prop) {
+ pan_azimuth_control->set_value (atof (prop->value()), Controllable::NoGroup);
+ }
+ } else if ((*niter)->name() == X_("width")) {
+ prop = (*niter)->property (X_("value"));
+ if (prop) {
+ pan_width_control->set_value (atof (prop->value()), Controllable::NoGroup);
+ }
+ } else if ((*niter)->name() == X_("elevation")) {
+ prop = (*niter)->property (X_("value"));
+ if (prop) {
+ pan_elevation_control->set_value (atof (prop->value()), Controllable::NoGroup);
+ }
+ } else if ((*niter)->name() == X_("frontback")) {
+ prop = (*niter)->property (X_("value"));
+ if (prop) {
+ pan_frontback_control->set_value (atof (prop->value()), Controllable::NoGroup);
+ }
+ } else if ((*niter)->name() == X_("lfe")) {
+ prop = (*niter)->property (X_("value"));
+ if (prop) {
+ pan_lfe_control->set_value (atof (prop->value()), Controllable::NoGroup);
+ }
+ }
+ }
+ }
+
+ _has_state = true;
+
+ return 0;