X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fpacksource.h;h=35ec8b87a72eb54572057c04328a329e3d364dad;hb=HEAD;hp=f552d2ab479ed952c47a04619b76d75bdde29e83;hpb=835fcd2f79e8848fa0d92be667c0e02952e23436;p=libs%2Fdatafile.git diff --git a/source/packsource.h b/source/packsource.h index f552d2a..d2194e0 100644 --- a/source/packsource.h +++ b/source/packsource.h @@ -1,6 +1,7 @@ #ifndef MSP_DATAFILE_PACKSOURCE_H_ #define MSP_DATAFILE_PACKSOURCE_H_ +#include #include #include "collectionsource.h" #include "objectloader.h" @@ -21,9 +22,16 @@ in is loaded. */ class PackSource: public CollectionSource { +public: + struct FileInfo + { + std::string name; + IO::SeekOffset size = 0; + }; + private: class File; - struct Object; + class Object; typedef std::map FileMap; typedef std::map ObjectMap; @@ -41,16 +49,20 @@ private: private: std::string filename; - unsigned base_offset; + IO::Seekable *io = nullptr; + IO::SeekOffset base_offset = 0; std::list files; public: - Pack(const std::string &); + Pack(IO::Seekable *, const std::string &); + Pack(const Pack &); const std::string &get_filename() const { return filename; } - unsigned get_base_offset() const { return base_offset; } + IO::Seekable *get_io() const { return io; } + IO::SeekOffset get_base_offset() const { return base_offset; } void collect_files(FileMap &, const std::string &) const; + void translate_files(FileMap &, const Pack &) const; }; class File @@ -61,51 +73,59 @@ private: public: Loader(File &); private: - virtual void finish(); + void finish() override; void object(const std::string &, const std::string &); }; private: const Pack &pack; std::string filename; - unsigned offset; - unsigned length; - bool collection; + IO::SeekOffset offset = 0; + IO::SeekOffset length = 0; + bool collection = false; std::list objects; - bool loaded; public: File(const Pack &, const std::string &); + File(const File &, const Pack &); - RefPtr open() const; + RefPtr open() const; const std::string &get_filename() const { return filename; } + FileInfo get_info() const; std::string get_full_name() const; bool is_collection() const { return collection; } - void set_loaded(); - bool is_loaded() const { return loaded; } - void collect_objects(ObjectMap &) const; + void translate_objects(ObjectMap &, const File &) const; }; class Object { private: - File &file; + const File &file; std::string name; std::string keyword; public: - Object(File &, const std::string &, const std::string &); + Object(const File &, const std::string &, const std::string &); + Object(const Object &, const File &); - File &get_file() const { return file; } + const File &get_file() const { return file; } const std::string &get_name() const { return name; } const std::string &get_keyword() const { return keyword; } }; std::list packs; + FileMap files; ObjectMap objects; +public: + PackSource() = default; + PackSource(const PackSource &); + PackSource &operator=(const PackSource &); +private: + void translate_maps(const PackSource &); + public: /// Adds a pack file to load objects from. The index is read immediately. void add_pack_file(const std::string &); @@ -114,9 +134,26 @@ public: read on the first call; subsequent calls will use cached data. */ void add_pack_file(const std::string &, const std::string &); - virtual bool is_loadable(const CollectionItemTypeBase &, const std::string &) const; - virtual NameList get_names(const CollectionItemTypeBase &) const; - virtual void load(Collection &, const CollectionItemTypeBase &, const std::string &) const; + /** Adds a pack from an existing seekable I/O object. The same object is + used for all accesses to the pack, so it must not be deleted before the + PackSource. */ + void add_pack_io(IO::Seekable &, const std::string & = std::string()); + + /** Adds a pack from an I/O object with a regex to filter logical files. + Multiple filters for the same I/O object can be added with repeated calls. */ + void add_pack_io(IO::Seekable &, const std::string &, const std::string &); + +private: + void add_pack(IO::Seekable *, const std::string &, const std::string &); + +public: + /// Returns information about the files in the pack. + std::list list_files() const; + + bool is_loadable(const CollectionItemTypeBase &, const std::string &) const override; + NameList get_names(const CollectionItemTypeBase &) const override; + void load(Collection &, const CollectionItemTypeBase &, const std::string &) const override; + IO::Seekable *open(const std::string &) const override; }; } // namespace DataFile