summaryrefslogtreecommitdiff
path: root/libs/ardour/track.cc
diff options
context:
space:
mode:
authorPaul Davis <paul@linuxaudiosystems.com>2016-07-19 18:56:31 -0400
committerPaul Davis <paul@linuxaudiosystems.com>2016-07-19 18:56:37 -0400
commit8338c1ccf5bada18e46c077546f38a114593eb5d (patch)
tree34d0cb03e21ff98f8e41bb41e74c39d83ded0f27 /libs/ardour/track.cc
parent0fd2d82a6d0fe796ff6216fbe112931cc79cadd3 (diff)
save/restore track monitoring, rec-enable and rec-safe states
Diffstat (limited to 'libs/ardour/track.cc')
-rw-r--r--libs/ardour/track.cc18
1 files changed, 16 insertions, 2 deletions
diff --git a/libs/ardour/track.cc b/libs/ardour/track.cc
index 062f1601c4..02c44eddf7 100644
--- a/libs/ardour/track.cc
+++ b/libs/ardour/track.cc
@@ -105,6 +105,11 @@ XMLNode&
Track::state (bool full)
{
XMLNode& root (Route::state (full));
+
+ root.add_child_nocopy (_monitoring_control->get_state ());
+ root.add_child_nocopy (_record_safe_control->get_state ());
+ root.add_child_nocopy (_record_enable_control->get_state ());
+
root.add_property (X_("saved-meter-point"), enum_2_string (_saved_meter_point));
root.add_child_nocopy (_diskstream->get_state ());
@@ -141,9 +146,18 @@ Track::set_state (const XMLNode& node, int version)
child = *niter;
XMLProperty const * prop;
- if (child->name() == Controllable::xml_node_name && (prop = child->property ("name")) != 0) {
- if (prop->value() == X_("recenable")) {
+
+ if (child->name() == Controllable::xml_node_name) {
+ if ((prop = child->property ("name")) == 0) {
+ continue;
+ }
+
+ if (prop->value() == _record_enable_control->name()) {
_record_enable_control->set_state (*child, version);
+ } else if (prop->value() == _record_safe_control->name()) {
+ _record_safe_control->set_state (*child, version);
+ } else if (prop->value() == _monitoring_control->name()) {
+ _monitoring_control->set_state (*child, version);
}
}
}