FileMap pack_files;
pack->collect_files(pack_files, filter);
+ files.insert(pack_files.begin(), pack_files.end());
for(FileMap::const_iterator i=pack_files.begin(); i!=pack_files.end(); ++i)
i->second->collect_objects(objects);
}
+list<PackSource::FileInfo> PackSource::list_files() const
+{
+ list<FileInfo> result;
+ for(FileMap::const_iterator i=files.begin(); i!=files.end(); ++i)
+ result.push_back(i->second->get_info());
+ return result;
+}
+
bool PackSource::is_loadable(const CollectionItemTypeBase &type, const string &name) const
{
ObjectMap::const_iterator i = objects.find(name);
type.load_item(coll, parser, name);
}
+IO::Seekable *PackSource::open(const string &fn) const
+{
+ FileMap::const_iterator i = files.find(fn);
+ if(i!=files.end())
+ return i->second->open().release();
+
+ return 0;
+}
+
PackSource::Pack::Pack(const string &fn):
filename(fn),
loaded(false)
{ }
-RefPtr<IO::Base> PackSource::File::open() const
+RefPtr<IO::Seekable> PackSource::File::open() const
{
IO::BufferedFile *io_file = new IO::BufferedFile(pack.get_filename());
IO::Slice *io_slice = new IO::Slice(*io_file, pack.get_base_offset()+offset, length);
return io_slice;
}
+PackSource::FileInfo PackSource::File::get_info() const
+{
+ FileInfo info;
+ info.name = filename;
+ info.size = length;
+ return info;
+}
+
string PackSource::File::get_full_name() const
{
return format("%s/%s", pack.get_filename(), filename);