]> sigrok.org Git - pulseview.git/blame_incremental - pv/data/decode/annotation.cpp
Backport recent changes from mainline.
[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 "annotation.hpp"
28
29using std::vector;
30
31namespace pv {
32namespace data {
33namespace decode {
34
35Annotation::Annotation(const srd_proto_data *const pdata, const Row *row) :
36 start_sample_(pdata->start_sample),
37 end_sample_(pdata->end_sample),
38 row_(row)
39{
40 assert(pdata);
41 const srd_proto_data_annotation *const pda =
42 (const srd_proto_data_annotation*)pdata->data;
43 assert(pda);
44
45 ann_class_ = (Class)(pda->ann_class);
46
47 const char *const *annotations = (char**)pda->ann_text;
48 while (*annotations) {
49 annotations_.push_back(QString::fromUtf8(*annotations));
50 annotations++;
51 }
52}
53
54uint64_t Annotation::start_sample() const
55{
56 return start_sample_;
57}
58
59uint64_t Annotation::end_sample() const
60{
61 return end_sample_;
62}
63
64Annotation::Class Annotation::ann_class() const
65{
66 return ann_class_;
67}
68
69const vector<QString>& Annotation::annotations() const
70{
71 return annotations_;
72}
73
74const Row* Annotation::row() const
75{
76 return row_;
77}
78
79bool Annotation::operator<(const Annotation &other) const
80{
81 return (start_sample_ < other.start_sample_);
82}
83
84} // namespace decode
85} // namespace data
86} // namespace pv