]> sigrok.org Git - pulseview.git/blobdiff - pv/data/decode/rowdata.hpp
DecodeTrace: Add "%c" to the format string
[pulseview.git] / pv / data / decode / rowdata.hpp
index f0e3534f7e2507cb54899a581b05d1d3b63f39c0..01ea94f4586c7390601c28ea61e68c76a5ca960d 100644 (file)
 
 #include <vector>
 
-#include "annotation.hpp"
+#include <libsigrokdecode/libsigrokdecode.h>
+
+#include <pv/data/decode/annotation.hpp>
+
+using std::deque;
+using std::vector;
 
 namespace pv {
 namespace data {
 namespace decode {
 
+class Row;
+
 class RowData
 {
 public:
-       RowData();
+       RowData(Row* row);
 
-public:
        uint64_t get_max_sample() const;
 
+       uint64_t get_annotation_count() const;
+
        /**
-        * Extracts sorted annotations between two period into a vector.
+        * Extracts annotations between the given sample range into a vector.
+        * Note: The annotations are unsorted and only annotations that fully
+        * fit into the sample range are considered.
         */
-       void get_annotation_subset(
-               std::vector<pv::data::decode::Annotation> &dest,
+       void get_annotation_subset(deque<const pv::data::decode::Annotation*> &dest,
                uint64_t start_sample, uint64_t end_sample) const;
 
-       void push_annotation(const Annotation &a);
+       void emplace_annotation(srd_proto_data *pdata);
 
 private:
-       std::vector<Annotation> annotations_;
+       deque<Annotation> annotations_;
+       Row* row_;
+       uint64_t prev_ann_start_sample_;
 };
 
-}
-} // data
-} // pv
+}  // namespace decode
+}  // namespace data
+}  // namespace pv
 
 #endif // PULSEVIEW_PV_DATA_DECODE_ROWDATA_HPP