X-Git-Url: https://git.saurik.com/ldid.git/blobdiff_plain/fc01987cd0fec42019f804be48053840b49450da..f74652ab3bfc5026ef954a35aeb137a18f55bf67:/ldid.hpp diff --git a/ldid.hpp b/ldid.hpp index b3631bb..f2e465f 100644 --- a/ldid.hpp +++ b/ldid.hpp @@ -50,10 +50,10 @@ FunctorImpl fun(const Function_ &value) { class Folder { public: - virtual void Save(const std::string &path, const void *flag, const Functor &code) = 0; - virtual bool Look(const std::string &path) = 0; - virtual void Open(const std::string &path, const Functor &code) = 0; - virtual void Find(const std::string &path, const Functor &)> &)> &code, const Functor &)> &link) = 0; + virtual void Save(const std::string &path, bool edit, const void *flag, const Functor &code) = 0; + virtual bool Look(const std::string &path) const = 0; + virtual void Open(const std::string &path, const Functor &code) const = 0; + virtual void Find(const std::string &path, const Functor &code, const Functor &)> &link) const = 0; }; class DiskFolder : @@ -63,18 +63,20 @@ class DiskFolder : const std::string path_; std::map commit_; - std::string Path(const std::string &path); + protected: + std::string Path(const std::string &path) const; - void Find(const std::string &root, const std::string &base, const Functor &)> &)> &code, const Functor &)> &link); + private: + void Find(const std::string &root, const std::string &base, const Functor &code, const Functor &)> &link) const; public: DiskFolder(const std::string &path); ~DiskFolder(); - virtual void Save(const std::string &path, const void *flag, const Functor &code); - virtual bool Look(const std::string &path); - virtual void Open(const std::string &path, const Functor &code); - virtual void Find(const std::string &path, const Functor &)> &)> &code, const Functor &)> &link); + virtual void Save(const std::string &path, bool edit, const void *flag, const Functor &code); + virtual bool Look(const std::string &path) const; + virtual void Open(const std::string &path, const Functor &code) const; + virtual void Find(const std::string &path, const Functor &code, const Functor &)> &link) const; }; class SubFolder : @@ -87,10 +89,10 @@ class SubFolder : public: SubFolder(Folder &parent, const std::string &path); - virtual void Save(const std::string &path, const void *flag, const Functor &code); - virtual bool Look(const std::string &path); - virtual void Open(const std::string &path, const Functor &code); - virtual void Find(const std::string &path, const Functor &)> &)> &code, const Functor &)> &link); + virtual void Save(const std::string &path, bool edit, const void *flag, const Functor &code); + virtual bool Look(const std::string &path) const; + virtual void Open(const std::string &path, const Functor &code) const; + virtual void Find(const std::string &path, const Functor &code, const Functor &)> &link) const; }; class UnionFolder : @@ -114,18 +116,18 @@ class UnionFolder : std::set deletes_; std::map remaps_; - std::map> resets_; + mutable std::map> resets_; - std::string Map(const std::string &path); - void Map(const std::string &path, const Functor &)> &)> &code, const std::string &file, const Functor &)> &save); + 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; public: UnionFolder(Folder &parent); - virtual void Save(const std::string &path, const void *flag, const Functor &code); - virtual bool Look(const std::string &path); - virtual void Open(const std::string &path, const Functor &code); - virtual void Find(const std::string &path, const Functor &)> &)> &code, const Functor &)> &link); + virtual void Save(const std::string &path, bool edit, const void *flag, const Functor &code); + virtual bool Look(const std::string &path) const; + virtual void Open(const std::string &path, const Functor &code) const; + virtual void Find(const std::string &path, const Functor &code, const Functor &)> &link) const; void operator ()(const std::string &from) { deletes_.insert(from); @@ -144,17 +146,21 @@ class UnionFolder : } }; +struct Hash { + uint8_t sha1_[0x14]; + uint8_t sha256_[0x20]; +}; + struct Bundle { std::string path; - std::vector hash; + Hash hash; }; -Bundle Sign(const std::string &root, Folder &folder, const std::string &key, const std::string &entitlements, const std::string &requirement); +Bundle Sign(const std::string &root, Folder &folder, const std::string &key, const std::string &requirement, const Functor &alter, const Functor &progress, const Functor &percent); -typedef std::map> Slots; +typedef std::map Slots; -std::string Analyze(const void *data, size_t size); -std::vector Sign(const void *idata, size_t isize, std::streambuf &output, const std::string &identifier, const std::string &entitlements, const std::string &requirement, const std::string &key, const Slots &slots); +Hash Sign(const void *idata, size_t isize, std::streambuf &output, const std::string &identifier, const std::string &entitlements, const std::string &requirement, const std::string &key, const Slots &slots, const Functor &percent); }