]> sigrok.org Git - pulseview.git/blame - pv/view/tracetreeitemowner.cpp
Don't use redundant void argument.
[pulseview.git] / pv / view / tracetreeitemowner.cpp
CommitLineData
18f7104f
JH
1/*
2 * This file is part of the PulseView project.
3 *
4 * Copyright (C) 2014 Joel Holdsworth <joel@airwebreathe.org.uk>
5 *
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
10 *
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
efdec55a 17 * along with this program; if not, see <http://www.gnu.org/licenses/>.
18f7104f
JH
18 */
19
68b21a71
JH
20#include <cassert>
21
af503b10
JH
22#include "tracetreeitem.hpp"
23#include "tracetreeitemowner.hpp"
6046c19d 24#include "trace.hpp"
68b21a71 25
6046c19d 26using std::dynamic_pointer_cast;
a5d93c27
JH
27using std::max;
28using std::make_pair;
29using std::min;
30using std::pair;
873cbed0 31using std::set;
68b21a71 32using std::shared_ptr;
c373f828 33using std::static_pointer_cast;
68b21a71
JH
34using std::vector;
35
36namespace pv {
f4e57597
SA
37namespace views {
38namespace TraceView {
68b21a71 39
a8743cd9 40const ViewItemOwner::item_list& TraceTreeItemOwner::child_items() const
68b21a71 41{
8dbbc7f0 42 return items_;
68b21a71
JH
43}
44
c373f828
JH
45vector< std::shared_ptr<TraceTreeItem> >
46TraceTreeItemOwner::trace_tree_child_items() const
68b21a71 47{
c373f828 48 vector< shared_ptr<TraceTreeItem> > items;
8dbbc7f0 49 for (auto &i : items_) {
c373f828
JH
50 assert(dynamic_pointer_cast<TraceTreeItem>(i));
51 const shared_ptr<TraceTreeItem> t(
52 static_pointer_cast<TraceTreeItem>(i));
53 items.push_back(t);
54 }
55
56 return items;
57}
58
59void TraceTreeItemOwner::clear_child_items()
60{
61 for (auto &t : trace_tree_child_items()) {
62 assert(t->owner() == this);
63 t->set_owner(nullptr);
68b21a71 64 }
8dbbc7f0 65 items_.clear();
68b21a71
JH
66}
67
af503b10 68void TraceTreeItemOwner::add_child_item(std::shared_ptr<TraceTreeItem> item)
68b21a71
JH
69{
70 assert(!item->owner());
71 item->set_owner(this);
8dbbc7f0 72 items_.push_back(item);
32218d3e
JH
73
74 extents_changed(true, true);
68b21a71
JH
75}
76
af503b10 77void TraceTreeItemOwner::remove_child_item(std::shared_ptr<TraceTreeItem> item)
68b21a71
JH
78{
79 assert(item->owner() == this);
80 item->set_owner(nullptr);
8dbbc7f0
JH
81 auto iter = std::find(items_.begin(), items_.end(), item);
82 assert(iter != items_.end());
83 items_.erase(iter);
32218d3e
JH
84
85 extents_changed(true, true);
68b21a71
JH
86}
87
af503b10 88pair<int, int> TraceTreeItemOwner::v_extents() const
a5d93c27 89{
d9177e6c 90 bool has_children = false;
82ba380c 91
d9177e6c 92 pair<int, int> extents(INT_MAX, INT_MIN);
c373f828
JH
93 for (const shared_ptr<TraceTreeItem> t : trace_tree_child_items()) {
94 assert(t);
95 if (!t->enabled())
a5d93c27
JH
96 continue;
97
d9177e6c
SA
98 has_children = true;
99
c373f828
JH
100 const int child_offset = t->layout_v_offset();
101 const pair<int, int> child_extents = t->v_extents();
a5d93c27
JH
102 extents.first = min(child_extents.first + child_offset,
103 extents.first);
104 extents.second = max(child_extents.second + child_offset,
105 extents.second);
106 }
107
d9177e6c
SA
108 if (!has_children)
109 extents = make_pair(0, 0);
110
a5d93c27
JH
111 return extents;
112}
113
ac0708fb
SA
114bool TraceTreeItemOwner::reassign_bgcolour_states(bool next_bgcolour_state)
115{
116 vector< shared_ptr<TraceTreeItem> > items = trace_tree_child_items();
117
118 // Sort items according to vertical position
119 sort(items.begin(), items.end(),
120 [](const shared_ptr<TraceTreeItem> a, const shared_ptr<TraceTreeItem> b) {
121 return a->layout_v_offset() > b->layout_v_offset(); });
122
123 for (const shared_ptr<TraceTreeItem> item : items) {
124 item->set_bgcolour_state(next_bgcolour_state);
125 next_bgcolour_state = !next_bgcolour_state;
126 }
127
128 return next_bgcolour_state;
129}
130
af503b10 131void TraceTreeItemOwner::restack_items()
7ff0145f
JH
132{
133}
134
f4e57597
SA
135} // namespace TraceView
136} // namespace views
137} // namespace pv