]> sigrok.org Git - pulseview.git/blobdiff - pv/storesession.hpp
Introduce pv::data::SignalBase
[pulseview.git] / pv / storesession.hpp
index 9f31d59a7920c93d6252dba98acf0eee8fcef0d9..07d3c2fa94270497f334dd58ccba98ec9f71e54d 100644 (file)
@@ -45,6 +45,8 @@ namespace pv {
 class Session;
 
 namespace data {
+class SignalBase;
+class AnalogSegment;
 class LogicSegment;
 }
 
@@ -59,6 +61,7 @@ public:
        StoreSession(const std::string &file_name,
                const std::shared_ptr<sigrok::OutputFormat> &output_format,
                const std::map<std::string, Glib::VariantBase> &options,
+               const std::pair<uint64_t, uint64_t> sample_range,
                const Session &session);
 
        ~StoreSession();
@@ -74,7 +77,9 @@ public:
        void cancel();
 
 private:
-       void store_proc(std::shared_ptr<pv::data::LogicSegment> segment);
+       void store_proc(std::vector< std::shared_ptr<data::SignalBase> > achannel_list,
+               std::vector< std::shared_ptr<pv::data::AnalogSegment> > asegment_list,
+               std::shared_ptr<pv::data::LogicSegment> lsegment);
 
 Q_SIGNALS:
        void progress_updated();
@@ -83,6 +88,7 @@ private:
        const std::string file_name_;
        const std::shared_ptr<sigrok::OutputFormat> output_format_;
        const std::map<std::string, Glib::VariantBase> options_;
+       const std::pair<uint64_t, uint64_t> sample_range_;
        const Session &session_;
 
        std::shared_ptr<sigrok::Output> output_;
@@ -96,6 +102,8 @@ private:
 
        mutable std::mutex mutex_;
        QString error_;
+
+       uint64_t start_sample_, sample_count_;
 };
 
 } // pv