Add API to run automation only (emit Changed signal).
[ardour.git] / libs / ardour / track.cc
index c84d9a1868499a88c225f125743d6d74e71170a4..d7d9a0a9d14686b04ba78f8aba3521367b4d36e1 100644 (file)
@@ -35,6 +35,7 @@
 #include "ardour/session.h"
 #include "ardour/session_playlists.h"
 #include "ardour/track.h"
+#include "ardour/types_convert.h"
 #include "ardour/utils.h"
 
 #include "pbd/i18n.h"
@@ -64,7 +65,7 @@ Track::init ()
                 return -1;
         }
 
-       boost::shared_ptr<Route> rp (shared_from_this());
+        boost::shared_ptr<Route> rp (boost::dynamic_pointer_cast<Route> (shared_from_this()));
        boost::shared_ptr<Track> rt = boost::dynamic_pointer_cast<Track> (rp);
 
        _record_enable_control.reset (new RecordEnableControl (_session, EventTypeMap::instance().to_symbol (RecEnableAutomation), *this));
@@ -112,7 +113,7 @@ Track::state (bool full)
        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.set_property (X_("saved-meter-point"), _saved_meter_point);
        root.add_child_nocopy (_diskstream->get_state ());
 
        return root;
@@ -147,28 +148,32 @@ Track::set_state (const XMLNode& node, int version)
        for (XMLNodeConstIterator niter = nlist.begin(); niter != nlist.end(); ++niter) {
                child = *niter;
 
-               XMLProperty const * prop;
-
                if (child->name() == Controllable::xml_node_name) {
-                       if ((prop = child->property ("name")) == 0) {
+                       std::string name;
+                       if (!child->get_property ("name", name)) {
                                continue;
                        }
 
-                       if (prop->value() == _record_enable_control->name()) {
+                       if (name == _record_enable_control->name()) {
                                _record_enable_control->set_state (*child, version);
-                       } else if (prop->value() == _record_safe_control->name()) {
+                       } else if (name == _record_safe_control->name()) {
                                _record_safe_control->set_state (*child, version);
-                       } else if (prop->value() == _monitoring_control->name()) {
+                       } else if (name == _monitoring_control->name()) {
                                _monitoring_control->set_state (*child, version);
                        }
                }
        }
 
-       XMLProperty const * prop;
+       /* convert old 3001 state */
+       MonitorChoice monitoring;
+       if (node.get_property (X_("monitoring"), monitoring)) {
+               XMLNode mon_node ("backwardscompat");
+               mon_node.set_property (X_("monitoring"), monitoring);
+               mon_node.set_property (X_("value"), (int) monitoring);
+               _monitoring_control->set_state (mon_node, version);
+       }
 
-       if ((prop = node.property (X_("saved-meter-point"))) != 0) {
-               _saved_meter_point = MeterPoint (string_2_enum (prop->value(), _saved_meter_point));
-       } else {
+       if (!node.get_property (X_("saved-meter-point"), _saved_meter_point)) {
                _saved_meter_point = _meter_point;
        }
 
@@ -294,8 +299,12 @@ Track::set_name (const string& str)
 {
        bool ret;
 
-       if (_record_enable_control->get_value() && _session.actively_recording()) {
-               /* this messes things up if done while recording */
+       if (str.empty ()) {
+               return false;
+       }
+
+       if (_record_enable_control->get_value()) {
+               /* when re-arm'ed the file (named after the track) is already ready to rolll */
                return false;
        }