X-Git-Url: https://sigrok.org/gitweb/?p=pulseview.git;a=blobdiff_plain;f=pv%2Fstoresession.cpp;h=809dba3e6694e37da736e6799e2deaa946e69d18;hp=ed0b0defaaac41034bdf843e5858cae89f40fe19;hb=HEAD;hpb=7697cd83435e88689936b14c952b8a34d5258b69 diff --git a/pv/storesession.cpp b/pv/storesession.cpp index ed0b0def..5eb6a8ad 100644 --- a/pv/storesession.cpp +++ b/pv/storesession.cpp @@ -184,6 +184,9 @@ bool StoreSession::start() {{ConfigKey::SAMPLERATE, Glib::Variant::create( any_segment->samplerate())}}); output_->receive(meta); + + auto header = context->create_header_packet(session_.get_acquisition_start_time()); + output_->receive(header); } catch (Error& error) { error_ = tr("Error while saving: ") + error.what(); return false; @@ -301,10 +304,14 @@ void StoreSession::store_proc(vector< shared_ptr > achannel_li units_stored_ = unit_count_ - (sample_count_ >> progress_scale); } - auto dfend = context->create_end_packet(); - const string ldata_str = output_->receive(dfend); - if (output_stream_.is_open()) - output_stream_ << ldata_str; + try { + auto dfend = context->create_end_packet(); + const string ldata_str = output_->receive(dfend); + if (output_stream_.is_open()) + output_stream_ << ldata_str; + } catch (Error& error) { + error_ = tr("Error while saving: ") + error.what(); + } // Zeroing the progress variables indicates completion units_stored_ = unit_count_ = 0;