X-Git-Url: http://sigrok.org/gitweb/?a=blobdiff_plain;f=pv%2Fdata%2Flogic.hpp;h=e45ff2f69e99463ac6492f9fdfa997f6a44ca836;hb=1f3033cb3e63de7cfe98dab537460443917fece3;hp=6e5749a31ee86daac20bf38f2b963a66ed69ebb3;hpb=efdec55aec1a137460fa362a381ed1904182bfed;p=pulseview.git diff --git a/pv/data/logic.hpp b/pv/data/logic.hpp index 6e5749a3..e45ff2f6 100644 --- a/pv/data/logic.hpp +++ b/pv/data/logic.hpp @@ -24,6 +24,12 @@ #include +#include + +using std::deque; +using std::shared_ptr; +using std::vector; + namespace pv { namespace data { @@ -31,26 +37,43 @@ class LogicSegment; class Logic : public SignalData { + Q_OBJECT + public: Logic(unsigned int num_channels); unsigned int num_channels() const; - void push_segment( - std::shared_ptr &segment); + void push_segment(shared_ptr &segment); - const std::deque< std::shared_ptr >& - logic_segments() const; + const deque< shared_ptr >& logic_segments() const; + deque< shared_ptr >& logic_segments(); - std::vector< std::shared_ptr > segments() const; + vector< shared_ptr > 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(shared_ptr segment, uint64_t start_sample, + uint64_t end_sample); + +Q_SIGNALS: + void samples_cleared(); + + void samples_added(shared_ptr segment, uint64_t start_sample, + uint64_t end_sample); + private: + double samplerate_; const unsigned int num_channels_; - std::deque< std::shared_ptr > segments_; + deque< shared_ptr > segments_; }; } // namespace data