27 using std::dynamic_pointer_cast;
33 using std::shared_ptr;
34 using std::static_pointer_cast;
45 vector< std::shared_ptr<TraceTreeItem> >
48 vector< shared_ptr<TraceTreeItem> > items;
50 assert(dynamic_pointer_cast<TraceTreeItem>(i));
51 const shared_ptr<TraceTreeItem> t(
52 static_pointer_cast<TraceTreeItem>(i));
62 assert(t->owner() ==
this);
63 t->set_owner(
nullptr);
70 assert(!item->owner());
71 item->set_owner(
this);
79 assert(item->owner() ==
this);
80 item->set_owner(
nullptr);
81 auto iter = std::find(
items_.begin(),
items_.end(), item);
82 assert(iter !=
items_.end());
90 pair<int, int> extents(INT_MAX, INT_MIN);
97 const int child_offset = t->layout_v_offset();
98 const pair<int, int> child_extents = t->v_extents();
99 extents.first = min(child_extents.first + child_offset,
101 extents.second = max(child_extents.second + child_offset,
113 sort(items.begin(), items.end(),
114 [](
const shared_ptr<TraceTreeItem> a,
const shared_ptr<TraceTreeItem> b) {
115 return a->layout_v_offset() > b->layout_v_offset(); });
117 for (
const shared_ptr<TraceTreeItem> item : items) {
118 item->set_bgcolour_state(next_bgcolour_state);
119 next_bgcolour_state = !next_bgcolour_state;
122 return next_bgcolour_state;
std::vector< std::shared_ptr< ViewItem > > item_list
std::vector< std::shared_ptr< TraceTreeItem > > trace_tree_child_items() const
std::pair< int, int > v_extents() const
virtual void restack_items()
virtual void extents_changed(bool horz, bool vert)=0
virtual const item_list & child_items() const
void add_child_item(std::shared_ptr< TraceTreeItem > item)
void remove_child_item(std::shared_ptr< TraceTreeItem > item)
bool reassign_bgcolour_states(bool next_bgcolour_state)