summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJay Freeman (saurik) <saurik@saurik.com>2017-12-27 01:38:22 -0800
committerJay Freeman (saurik) <saurik@saurik.com>2017-12-27 01:38:22 -0800
commit4e6d856ad85dcbc9b719edc0a459498fa3d4f8e2 (patch)
tree4f1ec05ec0d52e35bfad15413741bd1ef28e27af
parentf74652ab3bfc5026ef954a35aeb137a18f55bf67 (diff)
downloadldid-4e6d856ad85dcbc9b719edc0a459498fa3d4f8e2.tar.gz
ldid-4e6d856ad85dcbc9b719edc0a459498fa3d4f8e2.tar.zst
ldid-4e6d856ad85dcbc9b719edc0a459498fa3d4f8e2.zip
Require user to store streambufs for UnionFolders.
-rw-r--r--ldid.cpp11
-rw-r--r--ldid.hpp22
2 files changed, 13 insertions, 20 deletions
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 Functor<void (std::streamb
return parent_.Open(Map(path), code);
auto &entry(file->second);
- 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<void (const std::string &)> &code, const Functor<void (const std::string &, const Functor<std::string ()> &)> &link) const {
for (auto &reset : resets_)
Map(path, code, reset.first, fun([&](const Functor<void (std::streambuf &, size_t, const void *)> &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<std::string> deletes_;
std::map<std::string, std::string> remaps_;
- mutable std::map<std::string, std::pair<StringBuffer, const void *>> resets_;
+ mutable std::map<std::string, Reset> resets_;
std::string Map(const std::string &path) const;
void Map(const std::string &path, const Functor<void (const std::string &)> &code, const std::string &file, const Functor<void (const Functor<void (std::streambuf &, size_t, const void *)> &)> &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;
}
};