X-Git-Url: https://sigrok.org/gitweb/?p=pulseview.git;a=blobdiff_plain;f=pv%2Fview%2Ftracetreeitemowner.cpp;h=af11ad2688b8d6f61c670d5398fd60ed470a4cf0;hp=93b966b4aad99517cb5e13b4e3f206968263e719;hb=c373f82810ad9c5376a7370118de9dd587ee0e43;hpb=21d5f19c7992046c7a1735096364138eb6de50cf diff --git a/pv/view/tracetreeitemowner.cpp b/pv/view/tracetreeitemowner.cpp index 93b966b4..af11ad26 100644 --- a/pv/view/tracetreeitemowner.cpp +++ b/pv/view/tracetreeitemowner.cpp @@ -31,26 +31,41 @@ using std::min; using std::pair; using std::set; using std::shared_ptr; +using std::static_pointer_cast; using std::vector; namespace pv { namespace view { -vector< shared_ptr >& TraceTreeItemOwner::child_items() +vector< shared_ptr >& TraceTreeItemOwner::child_items() { return items_; } -const vector< shared_ptr >& TraceTreeItemOwner::child_items() const +const vector< shared_ptr >& TraceTreeItemOwner::child_items() const { return items_; } -void TraceTreeItemOwner::clear_child_items() +vector< std::shared_ptr > +TraceTreeItemOwner::trace_tree_child_items() const { + vector< shared_ptr > items; for (auto &i : items_) { - assert(i->owner() == this); - i->set_owner(nullptr); + assert(dynamic_pointer_cast(i)); + const shared_ptr t( + static_pointer_cast(i)); + items.push_back(t); + } + + return items; +} + +void TraceTreeItemOwner::clear_child_items() +{ + for (auto &t : trace_tree_child_items()) { + assert(t->owner() == this); + t->set_owner(nullptr); } items_.clear(); } @@ -75,37 +90,17 @@ void TraceTreeItemOwner::remove_child_item(std::shared_ptr item) extents_changed(true, true); } -TraceTreeItemOwner::iterator TraceTreeItemOwner::begin() -{ - return iterator(this, items_.begin()); -} - -TraceTreeItemOwner::iterator TraceTreeItemOwner::end() -{ - return iterator(this); -} - -TraceTreeItemOwner::const_iterator TraceTreeItemOwner::begin() const -{ - return const_iterator(this, items_.cbegin()); -} - -TraceTreeItemOwner::const_iterator TraceTreeItemOwner::end() const -{ - return const_iterator(this); -} - pair TraceTreeItemOwner::v_extents() const { pair extents(INT_MAX, INT_MIN); - for (const shared_ptr r : child_items()) { - assert(r); - if (!r->enabled()) + for (const shared_ptr t : trace_tree_child_items()) { + assert(t); + if (!t->enabled()) continue; - const int child_offset = r->layout_v_offset(); - const pair child_extents = r->v_extents(); + const int child_offset = t->layout_v_offset(); + const pair child_extents = t->v_extents(); extents.first = min(child_extents.first + child_offset, extents.first); extents.second = max(child_extents.second + child_offset,