]> sigrok.org Git - pulseview.git/blame - pv/data/decode/annotation.cpp
Minor decode refactorizations
[pulseview.git] / pv / data / decode / annotation.cpp
CommitLineData
06e810f2
JH
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
efdec55a 17 * along with this program; if not, see <http://www.gnu.org/licenses/>.
06e810f2
JH
18 */
19
20extern "C" {
21#include <libsigrokdecode/libsigrokdecode.h>
22}
23
943edd76 24#include <cassert>
7c2838bd
JH
25#include <vector>
26
6a26fc44 27#include <pv/data/decode/annotation.hpp>
06e810f2 28
6f925ba9
UH
29using std::vector;
30
06e810f2
JH
31namespace pv {
32namespace data {
33namespace decode {
34
5a914348 35Annotation::Annotation(const srd_proto_data *const pdata, const Row *row) :
8dbbc7f0 36 start_sample_(pdata->start_sample),
5a914348
SA
37 end_sample_(pdata->end_sample),
38 row_(row)
06e810f2
JH
39{
40 assert(pdata);
41 const srd_proto_data_annotation *const pda =
42 (const srd_proto_data_annotation*)pdata->data;
43 assert(pda);
44
462941e2
SA
45 ann_class_id_ = (Class)(pda->ann_class);
46
47 annotations_ = new vector<QString>();
06e810f2
JH
48
49 const char *const *annotations = (char**)pda->ann_text;
f3290553 50 while (*annotations) {
462941e2 51 annotations_->push_back(QString::fromUtf8(*annotations));
06e810f2
JH
52 annotations++;
53 }
6a26fc44 54
462941e2
SA
55 annotations_->shrink_to_fit();
56}
57
58Annotation::Annotation(Annotation&& a) :
59 start_sample_(a.start_sample_),
60 end_sample_(a.end_sample_),
61 annotations_(a.annotations_),
62 row_(a.row_),
63 ann_class_id_(a.ann_class_id_)
64{
65 a.annotations_ = nullptr;
66}
67
68Annotation& Annotation::operator=(Annotation&& a)
69{
70 if (&a != this) {
71 if (annotations_)
72 delete annotations_;
73
74 start_sample_ = a.start_sample_;
75 end_sample_ = a.end_sample_;
76 annotations_ = a.annotations_;
77 row_ = a.row_;
78 ann_class_id_ = a.ann_class_id_;
79
80 a.annotations_ = nullptr;
81 }
82
83 return *this;
84}
85
86Annotation::~Annotation()
87{
88 if (annotations_)
89 delete annotations_;
06e810f2
JH
90}
91
92uint64_t Annotation::start_sample() const
93{
8dbbc7f0 94 return start_sample_;
06e810f2
JH
95}
96
97uint64_t Annotation::end_sample() const
98{
8dbbc7f0 99 return end_sample_;
06e810f2
JH
100}
101
462941e2 102Annotation::Class Annotation::ann_class_id() const
06e810f2 103{
462941e2 104 return ann_class_id_;
06e810f2
JH
105}
106
462941e2 107const vector<QString>* Annotation::annotations() const
06e810f2 108{
8dbbc7f0 109 return annotations_;
06e810f2
JH
110}
111
5a914348
SA
112const Row* Annotation::row() const
113{
114 return row_;
115}
116
117bool Annotation::operator<(const Annotation &other) const
118{
119 return (start_sample_ < other.start_sample_);
120}
121
06e810f2
JH
122} // namespace decode
123} // namespace data
124} // namespace pv