]> sigrok.org Git - pulseview.git/blame_incremental - pv/view/tracetreeitemowner.cpp
Added ViewItemOwner
[pulseview.git] / pv / view / tracetreeitemowner.cpp
... / ...
CommitLineData
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
17 * along with this program; if not, write to the Free Software
18 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
19 */
20
21#include <cassert>
22
23#include "tracetreeitem.hpp"
24#include "tracetreeitemowner.hpp"
25#include "trace.hpp"
26
27using std::dynamic_pointer_cast;
28using std::max;
29using std::make_pair;
30using std::min;
31using std::pair;
32using std::set;
33using std::shared_ptr;
34using std::static_pointer_cast;
35using std::vector;
36
37namespace pv {
38namespace view {
39
40vector< shared_ptr<ViewItem> >& TraceTreeItemOwner::child_items()
41{
42 return items_;
43}
44
45const vector< shared_ptr<ViewItem> >& TraceTreeItemOwner::child_items() const
46{
47 return items_;
48}
49
50vector< std::shared_ptr<TraceTreeItem> >
51TraceTreeItemOwner::trace_tree_child_items() const
52{
53 vector< shared_ptr<TraceTreeItem> > items;
54 for (auto &i : items_) {
55 assert(dynamic_pointer_cast<TraceTreeItem>(i));
56 const shared_ptr<TraceTreeItem> t(
57 static_pointer_cast<TraceTreeItem>(i));
58 items.push_back(t);
59 }
60
61 return items;
62}
63
64void TraceTreeItemOwner::clear_child_items()
65{
66 for (auto &t : trace_tree_child_items()) {
67 assert(t->owner() == this);
68 t->set_owner(nullptr);
69 }
70 items_.clear();
71}
72
73void TraceTreeItemOwner::add_child_item(std::shared_ptr<TraceTreeItem> item)
74{
75 assert(!item->owner());
76 item->set_owner(this);
77 items_.push_back(item);
78
79 extents_changed(true, true);
80}
81
82void TraceTreeItemOwner::remove_child_item(std::shared_ptr<TraceTreeItem> item)
83{
84 assert(item->owner() == this);
85 item->set_owner(nullptr);
86 auto iter = std::find(items_.begin(), items_.end(), item);
87 assert(iter != items_.end());
88 items_.erase(iter);
89
90 extents_changed(true, true);
91}
92
93pair<int, int> TraceTreeItemOwner::v_extents() const
94{
95 pair<int, int> extents(INT_MAX, INT_MIN);
96
97 for (const shared_ptr<TraceTreeItem> t : trace_tree_child_items()) {
98 assert(t);
99 if (!t->enabled())
100 continue;
101
102 const int child_offset = t->layout_v_offset();
103 const pair<int, int> child_extents = t->v_extents();
104 extents.first = min(child_extents.first + child_offset,
105 extents.first);
106 extents.second = max(child_extents.second + child_offset,
107 extents.second);
108 }
109
110 return extents;
111}
112
113void TraceTreeItemOwner::restack_items()
114{
115}
116
117} // view
118} // pv