sources.push_back(&s);
}
-IO::Seekable *Collection::open_from_sources(const string &name)
+IO::Seekable *Collection::open_raw(const string &name) const
{
for(SourceList::const_iterator i=sources.begin(); i!=sources.end(); ++i)
if(IO::Seekable *io = (*i)->open(name))
std::list<std::string> available_names = (*i)->get_names(type);
for(std::list<std::string>::iterator j=available_names.begin(); j!=available_names.end(); ++j)
if(!items.count(*j))
- (*i)->load(*this, type, *j);
+ {
+ bool loaded = false;
+ if(type.can_create())
+ {
+ type.create_item(*this, *j);
+ loaded = items.count(*j);
+ }
+ if(!loaded)
+ (*i)->load(*this, type, *j);
+ }
}
}