summaryrefslogtreecommitdiff
path: root/libs/ardour/pannable.cc
diff options
context:
space:
mode:
authorTim Mayberry <mojofunk@gmail.com>2016-08-26 09:20:35 +1000
committerTim Mayberry <mojofunk@gmail.com>2017-04-19 09:36:49 +1000
commitbe309b913d081093b5d5d6c4c166dd9b11ee85d3 (patch)
treec2fe47be2af2646ac42733e259aa013463f2eb34 /libs/ardour/pannable.cc
parentf2fb8523d89aa4fac24355767097d4e65bd4c9ea (diff)
Use XMLNode::get_property API in ARDOUR::Pannable class
Used for float conversions from old state versions, necessary to be able to remove LocaleGuard
Diffstat (limited to 'libs/ardour/pannable.cc')
-rw-r--r--libs/ardour/pannable.cc43
1 files changed, 18 insertions, 25 deletions
diff --git a/libs/ardour/pannable.cc b/libs/ardour/pannable.cc
index abfb9d66c2..e91eb43429 100644
--- a/libs/ardour/pannable.cc
+++ b/libs/ardour/pannable.cc
@@ -18,7 +18,6 @@
*/
#include "pbd/error.h"
-#include "pbd/convert.h"
#include "pbd/compose.h"
#include "ardour/boost_debug.h"
@@ -220,21 +219,21 @@ Pannable::set_state (const XMLNode& root, int version)
for (niter = nlist.begin(); niter != nlist.end(); ++niter) {
if ((*niter)->name() == Controllable::xml_node_name) {
- XMLProperty const * prop = (*niter)->property (X_("name"));
+ std::string control_name;
- if (!prop) {
+ if (!(*niter)->get_property (X_("name"), control_name)) {
continue;
}
- if (prop->value() == pan_azimuth_control->name()) {
+ if (control_name == pan_azimuth_control->name()) {
pan_azimuth_control->set_state (**niter, version);
- } else if (prop->value() == pan_width_control->name()) {
+ } else if (control_name == pan_width_control->name()) {
pan_width_control->set_state (**niter, version);
- } else if (prop->value() == pan_elevation_control->name()) {
+ } else if (control_name == pan_elevation_control->name()) {
pan_elevation_control->set_state (**niter, version);
- } else if (prop->value() == pan_frontback_control->name()) {
+ } else if (control_name == pan_frontback_control->name()) {
pan_frontback_control->set_state (**niter, version);
- } else if (prop->value() == pan_lfe_control->name()) {
+ } else if (control_name == pan_lfe_control->name()) {
pan_lfe_control->set_state (**niter, version);
}
@@ -242,34 +241,28 @@ Pannable::set_state (const XMLNode& root, int version)
set_automation_xml_state (**niter, PanAzimuthAutomation);
} else {
- XMLProperty const * prop;
-
/* old school (alpha1-6) XML info */
+ float val;
if ((*niter)->name() == X_("azimuth")) {
- prop = (*niter)->property (X_("value"));
- if (prop) {
- pan_azimuth_control->set_value (atof (prop->value()), Controllable::NoGroup);
+ if ((*niter)->get_property (X_("value"), val)) {
+ pan_azimuth_control->set_value (val, 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);
+ if ((*niter)->get_property (X_("value"), val)) {
+ pan_width_control->set_value (val, 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);
+ if ((*niter)->get_property (X_("value"), val)) {
+ pan_elevation_control->set_value (val, 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);
+ if ((*niter)->get_property (X_("value"), val)) {
+ pan_frontback_control->set_value (val, 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);
+ if ((*niter)->get_property (X_("value"), val)) {
+ pan_lfe_control->set_value (val, Controllable::NoGroup);
}
}
}