- } else if (obj_T == "Playlist" || obj_T == "AudioPlaylist") {
- if (Playlist *pl = playlist_by_name(child->property("name")->value()))
- return new MementoCommand<Playlist>(*pl, before, after);
- } else if (obj_T == "Route") { // includes AudioTrack
- return new MementoCommand<Route>(*route_by_id(id), before, after);
- } else if (obj_T == "Curve") {
- if (curves.count(id))
- return new MementoCommand<Curve>(*curves[id], before, after);
- } else if (obj_T == "AutomationList") {
- if (automation_lists.count(id))
- return new MementoCommand<AutomationList>(*automation_lists[id], before, after);
- } else if (registry.count(id)) { // For Editor and AutomationLine which are off-limits here
- return new MementoCommand<StatefulDestructible>(*registry[id], before, after);
+
+ } else if (obj_T == "ARDOUR::Playlist" || obj_T == "ARDOUR::AudioPlaylist" || obj_T == "ARDOUR::MidiPlaylist") {
+ if (boost::shared_ptr<Playlist> pl = playlists->by_name(child->property("name")->value())) {
+ return new MementoCommand<Playlist>(*(pl.get()), before, after);
+ }
+
+ } else if (obj_T == "ARDOUR::Route" || obj_T == "ARDOUR::AudioTrack" || obj_T == "ARDOUR::MidiTrack") {
+ if (boost::shared_ptr<Route> r = route_by_id(id)) {
+ return new MementoCommand<Route>(*r, before, after);
+ } else {
+ error << string_compose (X_("Route %1 not found in session"), id) << endmsg;
+ }
+
+ } else if (obj_T == "Evoral::Curve" || obj_T == "ARDOUR::AutomationList") {
+ if (have_id) {
+ std::map<PBD::ID, AutomationList*>::iterator i = automation_lists.find(id);
+ if (i != automation_lists.end()) {
+ return new MementoCommand<AutomationList>(*i->second, before, after);
+ }
+ } else {
+ return new MementoCommand<AutomationList> (
+ new MidiAutomationListBinder (n, sources),
+ before, after
+ );
+ }
+
+ std::cerr << "Alist " << id << " not found\n";
+
+ } else if (registry.count(id)) { // For Editor and AutomationLine which are off-limits herea
+ return new MementoCommand<PBD::StatefulDestructible>(*registry[id], before, after);