From 5d00c2f6e25c15a7699167f4f135257281c4b218 Mon Sep 17 00:00:00 2001 From: Carl Hetherington Date: Wed, 24 May 2017 12:23:29 +0100 Subject: [PATCH] Keep model up to date when reordering KDMs. --- src/lib/dkdm_wrapper.cc | 12 ++++++++++-- src/lib/dkdm_wrapper.h | 2 +- src/tools/dcpomatic_kdm.cc | 6 +++--- 3 files changed, 14 insertions(+), 6 deletions(-) diff --git a/src/lib/dkdm_wrapper.cc b/src/lib/dkdm_wrapper.cc index 809739e06..76f9217aa 100644 --- a/src/lib/dkdm_wrapper.cc +++ b/src/lib/dkdm_wrapper.cc @@ -71,10 +71,18 @@ DKDMGroup::as_xml (xmlpp::Element* node) const } void -DKDMGroup::add (shared_ptr child) +DKDMGroup::add (shared_ptr child, shared_ptr previous) { DCPOMATIC_ASSERT (child); - _children.push_back (child); + if (previous) { + list >::iterator i = find (_children.begin(), _children.end(), previous); + if (i != _children.end ()) { + ++i; + } + _children.insert (i, child); + } else { + _children.push_back (child); + } child->set_parent (dynamic_pointer_cast (shared_from_this ())); } diff --git a/src/lib/dkdm_wrapper.h b/src/lib/dkdm_wrapper.h index d3ee2a095..9c65dd172 100644 --- a/src/lib/dkdm_wrapper.h +++ b/src/lib/dkdm_wrapper.h @@ -83,7 +83,7 @@ public: return _children; } - void add (boost::shared_ptr child); + void add (boost::shared_ptr child, boost::shared_ptr previous = boost::shared_ptr ()); void remove (boost::shared_ptr child); private: diff --git a/src/tools/dcpomatic_kdm.cc b/src/tools/dcpomatic_kdm.cc index 0ee8a0786..35bad5958 100644 --- a/src/tools/dcpomatic_kdm.cc +++ b/src/tools/dcpomatic_kdm.cc @@ -391,7 +391,7 @@ private: DCPOMATIC_ASSERT (from->second->parent ()); from->second->parent()->remove (from->second); - add_dkdm_model (from->second, group); + add_dkdm_model (from->second, group, dynamic_pointer_cast(to->second)); _dkdm->Delete (from->first); _dkdm_id.erase (from->first); @@ -472,9 +472,9 @@ private: } /** @param group Group to add dkdm to */ - void add_dkdm_model (shared_ptr dkdm, shared_ptr group) + void add_dkdm_model (shared_ptr dkdm, shared_ptr group, shared_ptr previous = shared_ptr ()) { - group->add (dkdm); + group->add (dkdm, previous); /* We're messing with a Config-owned object here, so tell it that something has changed. This isn't nice. */ -- 2.30.2