]> sigrok.org Git - pulseview.git/blame - pv/data/analog.cpp
Device: add support for list of discrete values for probe factor
[pulseview.git] / pv / data / analog.cpp
CommitLineData
aba1dd16
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
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
3b68d03d
JH
21#include <cassert>
22
2acdb232 23#include "analog.hpp"
f3d66e52 24#include "analogsegment.hpp"
aba1dd16 25
819f4c25
JH
26using std::deque;
27using std::max;
f9abf97e 28using std::shared_ptr;
99503171 29using std::vector;
aba1dd16
JH
30
31namespace pv {
1b1ec774 32namespace data {
aba1dd16 33
b087ba7f
JH
34Analog::Analog() :
35 SignalData()
aba1dd16
JH
36{
37}
38
f3d66e52 39void Analog::push_segment(shared_ptr<AnalogSegment> &segment)
aba1dd16 40{
f3d66e52 41 segments_.push_front(segment);
aba1dd16
JH
42}
43
f3d66e52 44const deque< shared_ptr<AnalogSegment> >& Analog::analog_segments() const
aba1dd16 45{
f3d66e52 46 return segments_;
aba1dd16
JH
47}
48
f3d66e52 49vector< shared_ptr<Segment> > Analog::segments() const
99503171 50{
f3d66e52
JH
51 return vector< shared_ptr<Segment> >(
52 segments_.begin(), segments_.end());
99503171
JH
53}
54
caabb84c 55void Analog::clear()
b087ba7f 56{
f3d66e52 57 segments_.clear();
b087ba7f
JH
58}
59
e45b13b5 60uint64_t Analog::max_sample_count() const
a007f5ad
JH
61{
62 uint64_t l = 0;
f3d66e52 63 for (const std::shared_ptr<AnalogSegment> s : segments_) {
a007f5ad
JH
64 assert(s);
65 l = max(l, s->get_sample_count());
66 }
67 return l;
68}
69
1b1ec774 70} // namespace data
aba1dd16 71} // namespace pv