X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/c45a236d5837894e3e9b9ae68d675c8dbc863eb7..336a8849b0b57d576c5772a217ad13d0b8c9cc42:/src/mc/ChunkedData.hpp diff --git a/src/mc/ChunkedData.hpp b/src/mc/ChunkedData.hpp index 05ef275b5b..bd35e3b5e5 100644 --- a/src/mc/ChunkedData.hpp +++ b/src/mc/ChunkedData.hpp @@ -19,18 +19,14 @@ namespace simgrid { namespace mc { +/** A byte-string represented as a sequence of chunks from a PageStor */ class ChunkedData { - PageStore* store_; + PageStore* store_ = nullptr; + /** Indices of the chunks */ std::vector pagenos_; public: - ChunkedData() : store_(nullptr) {} - ChunkedData(ChunkedData const& that) - { - store_ = that.store_; - pagenos_ = that.pagenos_; - for (std::size_t pageno : pagenos_) - store_->ref_page(pageno); - } + + ChunkedData() {} void clear() { for (std::size_t pageno : pagenos_) @@ -42,6 +38,14 @@ public: clear(); } + // Copy and move + ChunkedData(ChunkedData const& that) + { + store_ = that.store_; + pagenos_ = that.pagenos_; + for (std::size_t pageno : pagenos_) + store_->ref_page(pageno); + } ChunkedData(ChunkedData&& that) { store_ = that.store_; @@ -71,7 +75,6 @@ public: std::size_t page_count() const { return pagenos_.size(); } std::size_t pageno(std::size_t i) const { return pagenos_[i]; } const std::size_t* pagenos() const { return pagenos_.data(); } - std::size_t* pagenos() { return pagenos_.data(); } const void* page(std::size_t i) const {