2018-01-13 01:02:43 +00:00
|
|
|
#ifndef GAME_STATE_QUICKSAVEMANAGER_H
|
|
|
|
#define GAME_STATE_QUICKSAVEMANAGER_H
|
|
|
|
|
2018-01-13 01:02:43 +00:00
|
|
|
#include <string>
|
|
|
|
|
2018-01-13 01:02:43 +00:00
|
|
|
#include "character.hpp"
|
|
|
|
|
|
|
|
namespace MWState{
|
|
|
|
class QuickSaveManager{
|
2018-01-13 01:02:43 +00:00
|
|
|
std::string mSaveName;
|
2018-01-18 02:43:30 +00:00
|
|
|
unsigned int mMaxSaves;
|
|
|
|
unsigned int mSlotsVisited;
|
2018-01-13 01:02:43 +00:00
|
|
|
const Slot *mOldestSlotVisited;
|
2018-01-13 01:02:43 +00:00
|
|
|
private:
|
2021-03-29 17:44:23 +00:00
|
|
|
bool shouldCreateNewSlot() const;
|
|
|
|
bool isOldestSave(const Slot *compare) const;
|
2018-01-13 01:02:43 +00:00
|
|
|
public:
|
2018-01-18 02:43:30 +00:00
|
|
|
QuickSaveManager(std::string &saveName, unsigned int maxSaves);
|
2018-01-13 01:02:43 +00:00
|
|
|
///< A utility class to manage multiple quicksave slots
|
|
|
|
///
|
|
|
|
/// \param saveName The name of the save ("QuickSave", "AutoSave", etc)
|
2018-02-14 02:01:15 +00:00
|
|
|
/// \param maxSaves The maximum number of save slots to create before recycling old ones
|
2018-01-13 01:02:43 +00:00
|
|
|
|
|
|
|
void visitSave(const Slot *saveSlot);
|
|
|
|
///< Visits the given \a slot \a
|
|
|
|
|
|
|
|
const Slot *getNextQuickSaveSlot();
|
|
|
|
///< Get the slot that the next quicksave should use.
|
|
|
|
///
|
2018-10-09 06:21:12 +00:00
|
|
|
///\return Either the oldest quicksave slot visited, or nullptr if a new slot can be made
|
2018-01-13 01:02:43 +00:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|