|
|
|
@ -57,11 +57,12 @@ namespace
|
|
|
|
|
|
|
|
|
|
return MWWorld::Ptr();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
template<typename T>
|
|
|
|
|
void getState (MWWorld::CellRefList<T>& collection, const ESM::ObjectState& state)
|
|
|
|
|
{
|
|
|
|
|
if (!MWWorld::LiveCellRef<T>::checkState (state))
|
|
|
|
|
template<typename T>
|
|
|
|
|
void MWWorld::ContainerStore::getState (CellRefList<T>& collection, const ESM::ObjectState& state)
|
|
|
|
|
{
|
|
|
|
|
if (!LiveCellRef<T>::checkState (state))
|
|
|
|
|
return; // not valid anymore with current content files -> skip
|
|
|
|
|
|
|
|
|
|
const T *record = MWBase::Environment::get().getWorld()->getStore().
|
|
|
|
@ -70,30 +71,30 @@ namespace
|
|
|
|
|
if (!record)
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
|
|
MWWorld::LiveCellRef<T> ref (record);
|
|
|
|
|
LiveCellRef<T> ref (record);
|
|
|
|
|
ref.load (state);
|
|
|
|
|
ref.mRef.mRefNum.mContentFile = -1;
|
|
|
|
|
collection.mList.push_back (ref);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
template<typename T>
|
|
|
|
|
void storeState (const MWWorld::LiveCellRef<T>& ref, ESM::ObjectState& state)
|
|
|
|
|
{
|
|
|
|
|
template<typename T>
|
|
|
|
|
void MWWorld::ContainerStore::storeState (const LiveCellRef<T>& ref, ESM::ObjectState& state)
|
|
|
|
|
const
|
|
|
|
|
{
|
|
|
|
|
ref.save (state);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
template<typename T>
|
|
|
|
|
void storeStates (const MWWorld::CellRefList<T>& collection,
|
|
|
|
|
std::vector<std::pair<ESM::ObjectState, std::pair<unsigned int, int> > >& states)
|
|
|
|
|
{
|
|
|
|
|
for (typename MWWorld::CellRefList<T>::List::const_iterator iter (collection.mList.begin());
|
|
|
|
|
template<typename T>
|
|
|
|
|
void MWWorld::ContainerStore::storeStates (const CellRefList<T>& collection,
|
|
|
|
|
std::vector<std::pair<ESM::ObjectState, std::pair<unsigned int, int> > >& states) const
|
|
|
|
|
{
|
|
|
|
|
for (typename CellRefList<T>::List::const_iterator iter (collection.mList.begin());
|
|
|
|
|
iter!=collection.mList.end(); ++iter)
|
|
|
|
|
{
|
|
|
|
|
ESM::ObjectState state;
|
|
|
|
|
storeState (*iter, state);
|
|
|
|
|
states.push_back (std::make_pair (state, std::make_pair (T::sRecordId, -1)));
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const std::string MWWorld::ContainerStore::sGoldId = "gold_001";
|
|
|
|
|