From: Jay Freeman (saurik) Date: Wed, 27 Dec 2017 09:38:22 +0000 (-0800) Subject: Require user to store streambufs for UnionFolders. X-Git-Tag: v2.1.0~21 X-Git-Url: https://git.saurik.com/ldid.git/commitdiff_plain/4e6d856ad85dcbc9b719edc0a459498fa3d4f8e2 Require user to store streambufs for UnionFolders. --- diff --git a/ldid.cpp b/ldid.cpp index 9027c67..4d97bb8 100644 --- a/ldid.cpp +++ b/ldid.cpp @@ -1978,19 +1978,20 @@ void UnionFolder::Open(const std::string &path, const Functorsecond); - auto &data(entry.first); + auto &data(*entry.data_); auto length(data.pubseekoff(0, std::ios::end, std::ios::in)); data.pubseekpos(0, std::ios::in); - code(data, length, entry.second); + code(data, length, entry.flag_); } void UnionFolder::Find(const std::string &path, const Functor &code, const Functor &)> &link) const { for (auto &reset : resets_) Map(path, code, reset.first, fun([&](const Functor &code) { auto &entry(reset.second); - auto length(entry.first.pubseekoff(0, std::ios::end, std::ios::in)); - entry.first.pubseekpos(0, std::ios::in); - code(entry.first, length, entry.second); + auto &data(*entry.data_); + auto length(data.pubseekoff(0, std::ios::end, std::ios::in)); + data.pubseekpos(0, std::ios::in); + code(data, length, entry.flag_); })); for (auto &remap : remaps_) diff --git a/ldid.hpp b/ldid.hpp index f2e465f..58bbc09 100644 --- a/ldid.hpp +++ b/ldid.hpp @@ -99,24 +99,16 @@ class UnionFolder : public Folder { private: - class StringBuffer : - public std::stringbuf - { - public: - StringBuffer() { - } - - StringBuffer(const StringBuffer &rhs) : - std::stringbuf(rhs.str()) - { - } + struct Reset { + const void *flag_; + std::streambuf *data_; }; Folder &parent_; std::set deletes_; std::map remaps_; - mutable std::map> resets_; + mutable std::map resets_; std::string Map(const std::string &path) const; void Map(const std::string &path, const Functor &code, const std::string &file, const Functor &)> &save) const; @@ -138,11 +130,11 @@ class UnionFolder : remaps_[to] = from; } - std::stringbuf &operator ()(const std::string &from, const void *flag) { + void operator ()(const std::string &from, const void *flag, std::streambuf &data) { operator ()(from); auto &reset(resets_[from]); - reset.second = flag; - return reset.first; + reset.flag_ = flag; + reset.data_ = &data; } };