+uint32_t DecodeSignal::get_binary_data_chunk_count(uint32_t segment_id) const
+{
+ uint32_t count = 0;
+
+ try {
+ const DecodeSegment *segment = &(segments_.at(segment_id));
+ count = segment->binary_data.size();
+ } catch (out_of_range&) {
+ // Do nothing
+ }
+
+ return count;
+}
+
+void DecodeSignal::get_binary_data_chunk(uint32_t segment_id, uint32_t chunk_id,
+ const vector<uint8_t> **dest, uint64_t *size)
+{
+ try {
+ const DecodeSegment *segment = &(segments_.at(segment_id));
+ if (dest)
+ *dest = &(segment->binary_data.at(chunk_id).data);
+ if (size)
+ *size = segment->binary_data.at(chunk_id).data.size();
+ } catch (out_of_range&) {
+ // Do nothing
+ }
+}
+
+void DecodeSignal::get_binary_data_chunks_merged(uint32_t segment_id,
+ uint64_t start_sample, uint64_t end_sample, vector<uint8_t> *dest) const
+{
+ assert(dest != nullptr);
+
+ try {
+ const DecodeSegment *segment = &(segments_.at(segment_id));
+
+ // Determine overall size before copying to resize dest vector only once
+ uint64_t size = 0;
+ for (const DecodeBinaryData& d : segment->binary_data)
+ if ((d.sample >= start_sample) && (d.sample < end_sample))
+ size += d.data.size();
+ dest->reserve(size);
+
+ uint64_t index = 0;
+ for (const DecodeBinaryData& d : segment->binary_data)
+ if ((d.sample >= start_sample) && (d.sample < end_sample)) {
+ memcpy(dest->data() + index, d.data.data(), d.data.size());
+ index += d.data.size();
+ }
+ } catch (out_of_range&) {
+ // Do nothing
+ }
+}
+
+