diff options
| author | Carl Hetherington <cth@carlh.net> | 2017-05-24 12:23:29 +0100 |
|---|---|---|
| committer | Carl Hetherington <cth@carlh.net> | 2017-05-24 12:23:59 +0100 |
| commit | 5d00c2f6e25c15a7699167f4f135257281c4b218 (patch) | |
| tree | 67e9b194a166342f57792ea2da052fc66191c730 /src/lib/dkdm_wrapper.cc | |
| parent | e6874d3e34a919917fa19025cafdb0c64cb855a9 (diff) | |
Keep model up to date when reordering KDMs.
Diffstat (limited to 'src/lib/dkdm_wrapper.cc')
| -rw-r--r-- | src/lib/dkdm_wrapper.cc | 12 |
1 files changed, 10 insertions, 2 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<DKDMBase> child) +DKDMGroup::add (shared_ptr<DKDMBase> child, shared_ptr<DKDM> previous) { DCPOMATIC_ASSERT (child); - _children.push_back (child); + if (previous) { + list<shared_ptr<DKDMBase> >::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<DKDMGroup> (shared_from_this ())); } |
