1
0
mirror of https://gitlab.com/OpenMW/openmw.git synced 2025-01-26 18:35:20 +00:00

124 lines
4.0 KiB
C++
Raw Normal View History

2012-09-29 10:02:46 +02:00
#ifndef GAME_MWMECHANICS_ALCHEMY_H
#define GAME_MWMECHANICS_ALCHEMY_H
#include <vector>
#include <set>
#include <components/esm/effectlist.hpp>
2012-09-29 10:02:46 +02:00
#include "../mwworld/ptr.hpp"
2014-02-23 20:11:05 +01:00
namespace ESM
{
struct Potion;
}
2012-09-29 10:02:46 +02:00
namespace MWMechanics
{
struct EffectKey;
/// \brief Potion creation via alchemy skill
2012-09-29 10:02:46 +02:00
class Alchemy
{
public:
2014-02-23 20:11:05 +01:00
typedef std::vector<MWWorld::Ptr> TToolsContainer;
typedef TToolsContainer::const_iterator TToolsIterator;
2014-02-23 20:11:05 +01:00
typedef std::vector<MWWorld::Ptr> TIngredientsContainer;
typedef TIngredientsContainer::const_iterator TIngredientsIterator;
typedef std::vector<ESM::ENAMstruct> TEffectsContainer;
typedef TEffectsContainer::const_iterator TEffectsIterator;
2014-02-23 20:11:05 +01:00
enum Result
{
Result_Success,
2014-02-23 20:11:05 +01:00
Result_NoMortarAndPestle,
Result_LessThanTwoIngredients,
Result_NoName,
Result_NoEffects,
Result_RandomFailure
};
2014-02-23 20:11:05 +01:00
private:
2014-02-23 20:11:05 +01:00
MWWorld::Ptr mAlchemist;
TToolsContainer mTools;
TIngredientsContainer mIngredients;
TEffectsContainer mEffects;
2012-10-18 15:33:27 +02:00
int mValue;
2012-09-29 10:02:46 +02:00
std::set<EffectKey> listEffects() const;
2012-10-28 14:07:36 +01:00
///< List all effects shared by at least two ingredients.
void applyTools (int flags, float& value) const;
void updateEffects();
2014-02-23 20:11:05 +01:00
const ESM::Potion *getRecord() const;
///< Return existing recrod for created potion (may return 0)
2014-02-23 20:11:05 +01:00
void removeIngredients();
///< Remove selected ingredients from alchemist's inventory, cleanup selected ingredients and
/// update effect list accordingly.
void addPotion (const std::string& name);
///< Add a potion to the alchemist's inventory.
2014-02-23 20:11:05 +01:00
void increaseSkill();
///< Increase alchemist's skill.
2014-02-23 20:11:05 +01:00
float getChance() const;
///< Return chance of success.
2014-02-23 20:11:05 +01:00
int countIngredients() const;
2014-02-23 20:11:05 +01:00
2012-09-29 10:02:46 +02:00
public:
2014-02-23 20:11:05 +01:00
2012-09-29 10:02:46 +02:00
void setAlchemist (const MWWorld::Ptr& npc);
///< Set alchemist and configure alchemy setup accordingly. \a npc may be empty to indicate that
/// there is no alchemist (alchemy session has ended).
2014-02-23 20:11:05 +01:00
TToolsIterator beginTools() const;
///< \attention Iterates over tool slots, not over tools. Some of the slots may be empty.
2014-02-23 20:11:05 +01:00
TToolsIterator endTools() const;
2014-02-23 20:11:05 +01:00
TIngredientsIterator beginIngredients() const;
///< \attention Iterates over ingredient slots, not over ingredients. Some of the slots may be empty.
2014-02-23 20:11:05 +01:00
TIngredientsIterator endIngredients() const;
2014-02-23 20:11:05 +01:00
void clear();
///< Remove alchemist, tools and ingredients.
2014-02-23 20:11:05 +01:00
int addIngredient (const MWWorld::Ptr& ingredient);
///< Add ingredient into the next free slot.
///
/// \return Slot index or -1, if adding failed because of no free slot or the ingredient type being
/// listed already.
2014-02-23 20:11:05 +01:00
void removeIngredient (int index);
///< Remove ingredient from slot (calling this function on an empty slot is a no-op).
2014-02-23 20:11:05 +01:00
TEffectsIterator beginEffects() const;
2014-02-23 20:11:05 +01:00
TEffectsIterator endEffects() const;
2014-02-23 20:11:05 +01:00
std::string getPotionName() const;
///< Return the name of the potion that would be created when calling create (if a record for such
/// a potion already exists) or return an empty string.
2014-02-23 20:11:05 +01:00
Result create (const std::string& name);
///< Try to create a potion from the ingredients, place it in the inventory of the alchemist and
/// adjust the skills of the alchemist accordingly.
/// \param name must not be an empty string, unless there is already a potion record (
/// getPotionName() does not return an empty string).
2012-09-29 10:02:46 +02:00
};
}
#endif