mirror of
https://github.com/subsurface/subsurface.git
synced 2025-02-19 22:16:15 +00:00
fix copy/paste of dive-site
The copy/pasting of dive-sites was fundamentally broken in at least two ways: 1) The dive-site pointer in struct dive was simply overwritten, which breaks internal consistency. Also, no dive-site changed signals where sent. 2) The copied dive-site was stored as a pointer in a struct dive. Thus, the user could copy a dive, then delete the dive-site and paste. This would lead to a dangling pointer and ultimately crash the application. Fix this by storing the UUID of the dive-site, not a pointer. To do that, don't store a copy of the dive, but collect all the data in a `dive_paste_data` structure. If the dive site has been deleted on paste, do nothing. Send the appropriate signals on pasting. The mobile version had an additional bug: It kept a pointer to the dive to be copied, which might become stale by undo. Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
This commit is contained in:
parent
48b4308a7d
commit
152e6966c9
17 changed files with 359 additions and 425 deletions
12
core/range.h
12
core/range.h
|
|
@ -181,13 +181,23 @@ bool range_contains(const Range &v, const Element &item)
|
|||
|
||||
// Insert into an already sorted range
|
||||
template<typename Range, typename Element, typename Comp>
|
||||
void range_insert_sorted(Range &v, Element &item, Comp &comp)
|
||||
void range_insert_sorted(Range &v, Element &item, Comp comp)
|
||||
{
|
||||
auto it = std::lower_bound(std::begin(v), std::end(v), item,
|
||||
[&comp](auto &a, auto &b) { return comp(a, b) < 0; });
|
||||
v.insert(it, std::move(item));
|
||||
}
|
||||
|
||||
// Insert into an already sorted range, but don't add an item twice
|
||||
template<typename Range, typename Element, typename Comp>
|
||||
void range_insert_sorted_unique(Range &v, Element &item, Comp comp)
|
||||
{
|
||||
auto it = std::lower_bound(std::begin(v), std::end(v), item,
|
||||
[&comp](auto &a, auto &b) { return comp(a, b) < 0; });
|
||||
if (it == std::end(v) || comp(item, *it) != 0)
|
||||
v.insert(it, std::move(item));
|
||||
}
|
||||
|
||||
template<typename Range, typename Element>
|
||||
void range_remove(Range &v, const Element &item)
|
||||
{
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue