1
0
Fork 1
mirror of https://github.com/TES3MP/openmw-tes3mp.git synced 2025-01-19 22:23:51 +00:00

fixed checks for allowing load/save and some general cleanup

This commit is contained in:
Marc Zinnschlag 2014-04-24 10:14:17 +02:00
parent 760c8c7214
commit 9db9ad410d

View file

@ -223,19 +223,23 @@ void MWState::StateManager::saveGame (const std::string& description, const Slot
slot->mPath.parent_path().filename().string()); slot->mPath.parent_path().filename().string());
} }
void MWState::StateManager::quickSave(std::string name) { void MWState::StateManager::quickSave (std::string name)
if(MWBase::Environment::get().getWorld()->getGlobalInt ("chargenstate")==-1) { //ensure you're not in character creation {
const MWState::Slot* slot = NULL; if (mState!=State_Running ||
MWState::Character* mCurrentCharacter = MWBase::Environment::get().getStateManager()->getCurrentCharacter(true); //Get current character MWBase::Environment::get().getWorld()->getGlobalInt ("chargenstate")!=-1) // char gen
return;
//Find quicksave slot const Slot* slot = NULL;
for (MWState::Character::SlotIterator it = mCurrentCharacter->begin(); it != mCurrentCharacter->end(); ++it) Character* mCurrentCharacter = getCurrentCharacter(true); //Get current character
{
if (it->mProfile.mDescription == name) //Find quicksave slot
slot = &*it; for (Character::SlotIterator it = mCurrentCharacter->begin(); it != mCurrentCharacter->end(); ++it)
} {
MWBase::Environment::get().getStateManager()->saveGame(name, slot); if (it->mProfile.mDescription == name)
slot = &*it;
} }
saveGame(name, slot);
} }
void MWState::StateManager::loadGame (const Character *character, const Slot *slot) void MWState::StateManager::loadGame (const Character *character, const Slot *slot)
@ -343,15 +347,11 @@ void MWState::StateManager::loadGame (const Character *character, const Slot *sl
} }
} }
void MWState::StateManager::quickLoad() { void MWState::StateManager::quickLoad()
if(MWBase::Environment::get().getWorld()->getGlobalInt ("chargenstate")==-1) { {
MWState::Character* mCurrentCharacter = MWBase::Environment::get().getStateManager()->getCurrentCharacter(false); //Get current character if (Character* mCurrentCharacter = getCurrentCharacter (false))
if(mCurrentCharacter) { //Ensure a current character exists if (const MWState::Slot* slot = &*mCurrentCharacter->begin()) //Get newest save
const MWState::Slot* slot = &*mCurrentCharacter->begin(); //Get newest save loadGame (mCurrentCharacter, slot);
if(slot) //Don't even try loading it if there's no prior save.
MWBase::Environment::get().getStateManager()->loadGame (mCurrentCharacter, slot); //load newest save. That was easy!
}
}
} }
MWState::Character *MWState::StateManager::getCurrentCharacter (bool create) MWState::Character *MWState::StateManager::getCurrentCharacter (bool create)