void Logic::push_segment(shared_ptr<LogicSegment> &segment)
{
segments_.push_back(segment);
+
+ if ((samplerate_ == 1) && (segment->samplerate() > 1))
+ samplerate_ = segment->samplerate();
+
+ connect(segment.get(), SIGNAL(completed()), this, SLOT(on_segment_completed()));
}
const deque< shared_ptr<LogicSegment> >& Logic::logic_segments() const
return segments_;
}
+deque< shared_ptr<LogicSegment> >& Logic::logic_segments()
+{
+ return segments_;
+}
+
vector< shared_ptr<Segment> > Logic::segments() const
{
return vector< shared_ptr<Segment> >(segments_.begin(), segments_.end());
void Logic::clear()
{
- segments_.clear();
+ if (!segments_.empty()) {
+ segments_.clear();
- samples_cleared();
+ samples_cleared();
+ }
}
void Logic::set_samplerate(double value)
return l;
}
-void Logic::notify_samples_added(QObject* segment, uint64_t start_sample,
+void Logic::notify_samples_added(shared_ptr<Segment> segment, uint64_t start_sample,
uint64_t end_sample)
{
samples_added(segment, start_sample, end_sample);
}
+void Logic::on_segment_completed()
+{
+ segment_completed();
+}
+
} // namespace data
} // namespace pv