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