]> sigrok.org Git - pulseview.git/blame_incremental - pv/data/decode/annotation.cpp
TabularDecView: Make the model/view work
[pulseview.git] / pv / data / decode / annotation.cpp
... / ...
CommitLineData
1/*
2 * This file is part of the PulseView project.
3 *
4 * Copyright (C) 2012 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, see <http://www.gnu.org/licenses/>.
18 */
19
20extern "C" {
21#include <libsigrokdecode/libsigrokdecode.h>
22}
23
24#include <cassert>
25#include <vector>
26
27#include <pv/data/decode/annotation.hpp>
28#include <pv/data/decode/decoder.hpp>
29
30using std::vector;
31
32namespace pv {
33namespace data {
34namespace decode {
35
36Annotation::Annotation(const srd_proto_data *const pdata, const Row *row) :
37 start_sample_(pdata->start_sample),
38 end_sample_(pdata->end_sample),
39 row_(row)
40{
41 assert(pdata);
42 const srd_proto_data_annotation *const pda =
43 (const srd_proto_data_annotation*)pdata->data;
44 assert(pda);
45
46 ann_class_id_ = (Class)(pda->ann_class);
47
48 annotations_ = new vector<QString>();
49
50 const char *const *annotations = (char**)pda->ann_text;
51 while (*annotations) {
52 annotations_->push_back(QString::fromUtf8(*annotations));
53 annotations++;
54 }
55
56 annotations_->shrink_to_fit();
57}
58
59Annotation::Annotation(Annotation&& a) :
60 start_sample_(a.start_sample_),
61 end_sample_(a.end_sample_),
62 annotations_(a.annotations_),
63 row_(a.row_),
64 ann_class_id_(a.ann_class_id_)
65{
66 a.annotations_ = nullptr;
67}
68
69Annotation& Annotation::operator=(Annotation&& a)
70{
71 if (&a != this) {
72 if (annotations_)
73 delete annotations_;
74
75 start_sample_ = a.start_sample_;
76 end_sample_ = a.end_sample_;
77 annotations_ = a.annotations_;
78 row_ = a.row_;
79 ann_class_id_ = a.ann_class_id_;
80
81 a.annotations_ = nullptr;
82 }
83
84 return *this;
85}
86
87Annotation::~Annotation()
88{
89 delete annotations_;
90}
91
92uint64_t Annotation::start_sample() const
93{
94 return start_sample_;
95}
96
97uint64_t Annotation::end_sample() const
98{
99 return end_sample_;
100}
101
102Annotation::Class Annotation::ann_class_id() const
103{
104 return ann_class_id_;
105}
106
107const QString Annotation::ann_class_name() const
108{
109 const AnnotationClass* ann_class =
110 row_->decoder()->get_ann_class_by_id(ann_class_id_);
111
112 return QString(ann_class->name);
113}
114
115const vector<QString>* Annotation::annotations() const
116{
117 return annotations_;
118}
119
120const QString Annotation::longest_annotation() const
121{
122 return annotations_->front();
123}
124
125const Row* Annotation::row() const
126{
127 return row_;
128}
129
130bool Annotation::operator<(const Annotation &other) const
131{
132 return (start_sample_ < other.start_sample_);
133}
134
135} // namespace decode
136} // namespace data
137} // namespace pv