X-Git-Url: https://sigrok.org/gitweb/?p=pulseview.git;a=blobdiff_plain;f=pv%2Fview%2Frowitemowner.cpp;h=49e6e1a59afca5b796252f44c26e93b90450b2c1;hp=d6150f89a90e5db497bf6f2eae4e5a09e7b69e80;hb=dbf74f26f6bd9fd5277f090fea8e4f5506c19911;hpb=68b21a71797051fb48ed272bc2a6b4893bdbf517 diff --git a/pv/view/rowitemowner.cpp b/pv/view/rowitemowner.cpp index d6150f89..49e6e1a5 100644 --- a/pv/view/rowitemowner.cpp +++ b/pv/view/rowitemowner.cpp @@ -20,43 +20,126 @@ #include -#include "rowitem.h" -#include "rowitemowner.h" +#include "rowitem.hpp" +#include "rowitemowner.hpp" +#include "trace.hpp" +using std::dynamic_pointer_cast; +using std::max; +using std::make_pair; +using std::min; +using std::pair; +using std::set; using std::shared_ptr; using std::vector; namespace pv { namespace view { +vector< shared_ptr >& RowItemOwner::child_items() +{ + return items_; +} + const vector< shared_ptr >& RowItemOwner::child_items() const { - return _items; + return items_; } void RowItemOwner::clear_child_items() { - for (auto &i : _items) { + for (auto &i : items_) { assert(i->owner() == this); i->set_owner(nullptr); } - _items.clear(); + items_.clear(); } void RowItemOwner::add_child_item(std::shared_ptr item) { assert(!item->owner()); item->set_owner(this); - _items.push_back(item); + items_.push_back(item); + + extents_changed(true, true); } void RowItemOwner::remove_child_item(std::shared_ptr item) { assert(item->owner() == this); item->set_owner(nullptr); - auto iter = std::find(_items.begin(), _items.end(), item); - assert(iter != _items.end()); - _items.erase(iter); + auto iter = std::find(items_.begin(), items_.end(), item); + assert(iter != items_.end()); + items_.erase(iter); + + extents_changed(true, true); +} + +RowItemOwner::iterator RowItemOwner::begin() +{ + return iterator(this, items_.begin()); +} + +RowItemOwner::iterator RowItemOwner::end() +{ + return iterator(this); +} + +RowItemOwner::const_iterator RowItemOwner::begin() const +{ + return const_iterator(this, items_.cbegin()); +} + +RowItemOwner::const_iterator RowItemOwner::end() const +{ + return const_iterator(this); +} + +set< RowItemOwner* > RowItemOwner::list_row_item_owners() +{ + set< RowItemOwner* > owners; + for (const auto &r : *this) + owners.insert(r->owner()); + return owners; +} + +template +set< shared_ptr > RowItemOwner::list_by_type() +{ + set< shared_ptr > items; + for (const auto &r : *this) { + shared_ptr p = dynamic_pointer_cast(r); + if (p) + items.insert(p); + } + + return items; +} + +template set< shared_ptr > RowItemOwner::list_by_type(); + +pair RowItemOwner::v_extents() const +{ + pair extents(INT_MAX, INT_MIN); + + for (const shared_ptr r : child_items()) { + assert(r); + if (!r->enabled()) + continue; + + const int child_offset = r->layout_v_offset(); + const pair child_extents = r->v_extents(); + extents.first = min(child_extents.first + child_offset, + extents.first); + extents.second = max(child_extents.second + child_offset, + extents.second); + } + + return extents; +} + +void RowItemOwner::restack_items() +{ } } // view