]> sigrok.org Git - pulseview.git/blobdiff - pv/data/logic.hpp
Session: Fix issue #67 by improving error handling
[pulseview.git] / pv / data / logic.hpp
index c80f0151f8957122d8a87687a75c535b083d196f..07f8222c1946cc699828c6ac3cdc6c3d761eb67d 100644 (file)
@@ -21,6 +21,7 @@
 #define PULSEVIEW_PV_DATA_LOGIC_HPP
 
 #include "signaldata.hpp"
+#include "segment.hpp"
 
 #include <deque>
 
@@ -35,7 +36,7 @@ namespace data {
 
 class LogicSegment;
 
-class Logic : public QObject, public SignalData
+class Logic : public SignalData
 {
        Q_OBJECT
 
@@ -47,23 +48,34 @@ public:
        void push_segment(shared_ptr<LogicSegment> &segment);
 
        const deque< shared_ptr<LogicSegment> >& logic_segments() const;
+       deque< shared_ptr<LogicSegment> >& logic_segments();
 
        vector< shared_ptr<Segment> > segments() const;
 
+       uint32_t get_segment_count() const;
+
        void clear();
 
+       void set_samplerate(double value);
+
+       double get_samplerate() const;
+
        uint64_t max_sample_count() const;
 
-       void notify_samples_added(QObject* segment, uint64_t start_sample,
+       void notify_samples_added(shared_ptr<Segment> segment, uint64_t start_sample,
                uint64_t end_sample);
 
 Q_SIGNALS:
        void samples_cleared();
 
-       void samples_added(QObject* segment, uint64_t start_sample,
+       void samples_added(SharedPtrToSegment segment, uint64_t start_sample,
                uint64_t end_sample);
 
+private Q_SLOTS:
+       void on_segment_completed();
+
 private:
+       double samplerate_;
        const unsigned int num_channels_;
        deque< shared_ptr<LogicSegment> > segments_;
 };