mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-26 22:26:37 +00:00 
			
		
		
		
	Merge remote branch 'greye/master'
This commit is contained in:
		
						commit
						e1bb98e71f
					
				
					 10 changed files with 462 additions and 138 deletions
				
			
		|  | @ -47,24 +47,24 @@ namespace MWClass | |||
|             MWWorld::LiveCellRef<ESM::Creature> *ref = ptr.get<ESM::Creature>(); | ||||
| 
 | ||||
|             // creature stats
 | ||||
|             data->mCreatureStats.mAttributes[0].set (ref->base->data.strength); | ||||
|             data->mCreatureStats.mAttributes[1].set (ref->base->data.intelligence); | ||||
|             data->mCreatureStats.mAttributes[2].set (ref->base->data.willpower); | ||||
|             data->mCreatureStats.mAttributes[3].set (ref->base->data.agility); | ||||
|             data->mCreatureStats.mAttributes[4].set (ref->base->data.speed); | ||||
|             data->mCreatureStats.mAttributes[5].set (ref->base->data.endurance); | ||||
|             data->mCreatureStats.mAttributes[6].set (ref->base->data.personality); | ||||
|             data->mCreatureStats.mAttributes[7].set (ref->base->data.luck); | ||||
|             data->mCreatureStats.mDynamic[0].set (ref->base->data.health); | ||||
|             data->mCreatureStats.mDynamic[1].set (ref->base->data.mana); | ||||
|             data->mCreatureStats.mDynamic[2].set (ref->base->data.fatigue); | ||||
|             data->mCreatureStats.getAttribute(0).set (ref->base->data.strength); | ||||
|             data->mCreatureStats.getAttribute(1).set (ref->base->data.intelligence); | ||||
|             data->mCreatureStats.getAttribute(2).set (ref->base->data.willpower); | ||||
|             data->mCreatureStats.getAttribute(3).set (ref->base->data.agility); | ||||
|             data->mCreatureStats.getAttribute(4).set (ref->base->data.speed); | ||||
|             data->mCreatureStats.getAttribute(5).set (ref->base->data.endurance); | ||||
|             data->mCreatureStats.getAttribute(6).set (ref->base->data.personality); | ||||
|             data->mCreatureStats.getAttribute(7).set (ref->base->data.luck); | ||||
|             data->mCreatureStats.getHealth().set (ref->base->data.health); | ||||
|             data->mCreatureStats.getMagicka().set (ref->base->data.mana); | ||||
|             data->mCreatureStats.getFatigue().set (ref->base->data.fatigue); | ||||
| 
 | ||||
|             data->mCreatureStats.mLevel = ref->base->data.level; | ||||
|             data->mCreatureStats.setLevel(ref->base->data.level); | ||||
| 
 | ||||
|             data->mCreatureStats.mHello = ref->base->AI.hello; | ||||
|             data->mCreatureStats.mFight = ref->base->AI.fight; | ||||
|             data->mCreatureStats.mFlee = ref->base->AI.flee; | ||||
|             data->mCreatureStats.mAlarm = ref->base->AI.alarm; | ||||
|             data->mCreatureStats.setHello(ref->base->AI.hello); | ||||
|             data->mCreatureStats.setFight(ref->base->AI.fight); | ||||
|             data->mCreatureStats.setFlee(ref->base->AI.flee); | ||||
|             data->mCreatureStats.setAlarm(ref->base->AI.alarm); | ||||
| 
 | ||||
|             // store
 | ||||
|             ptr.getRefData().setCustomData (data.release()); | ||||
|  | @ -169,7 +169,7 @@ namespace MWClass | |||
|     float Creature::getCapacity (const MWWorld::Ptr& ptr) const | ||||
|     { | ||||
|         const MWMechanics::CreatureStats& stats = getCreatureStats (ptr); | ||||
|         return stats.mAttributes[0].getModified()*5; | ||||
|         return stats.getAttribute(0).getModified()*5; | ||||
|     } | ||||
| 
 | ||||
|     float Creature::getEncumbrance (const MWWorld::Ptr& ptr) const | ||||
|  | @ -178,9 +178,9 @@ namespace MWClass | |||
| 
 | ||||
|         const MWMechanics::CreatureStats& stats = getCreatureStats (ptr); | ||||
| 
 | ||||
|         weight -= stats.mMagicEffects.get (MWMechanics::EffectKey (8)).mMagnitude; // feather
 | ||||
|         weight -= stats.getMagicEffects().get (MWMechanics::EffectKey (8)).mMagnitude; // feather
 | ||||
| 
 | ||||
|         weight += stats.mMagicEffects.get (MWMechanics::EffectKey (7)).mMagnitude; // burden
 | ||||
|         weight += stats.getMagicEffects().get (MWMechanics::EffectKey (7)).mMagnitude; // burden
 | ||||
| 
 | ||||
|         if (weight<0) | ||||
|             weight = 0; | ||||
|  |  | |||
|  | @ -81,29 +81,29 @@ namespace MWClass | |||
|                 for (int i=0; i<27; ++i) | ||||
|                     data->mNpcStats.getSkill (i).setBase (ref->base->npdt52.skills[i]); | ||||
| 
 | ||||
|                 data->mCreatureStats.mAttributes[0].set (ref->base->npdt52.strength); | ||||
|                 data->mCreatureStats.mAttributes[1].set (ref->base->npdt52.intelligence); | ||||
|                 data->mCreatureStats.mAttributes[2].set (ref->base->npdt52.willpower); | ||||
|                 data->mCreatureStats.mAttributes[3].set (ref->base->npdt52.agility); | ||||
|                 data->mCreatureStats.mAttributes[4].set (ref->base->npdt52.speed); | ||||
|                 data->mCreatureStats.mAttributes[5].set (ref->base->npdt52.endurance); | ||||
|                 data->mCreatureStats.mAttributes[6].set (ref->base->npdt52.personality); | ||||
|                 data->mCreatureStats.mAttributes[7].set (ref->base->npdt52.luck); | ||||
|                 data->mCreatureStats.mDynamic[0].set (ref->base->npdt52.health); | ||||
|                 data->mCreatureStats.mDynamic[1].set (ref->base->npdt52.mana); | ||||
|                 data->mCreatureStats.mDynamic[2].set (ref->base->npdt52.fatigue); | ||||
|                 data->mCreatureStats.getAttribute(0).set (ref->base->npdt52.strength); | ||||
|                 data->mCreatureStats.getAttribute(1).set (ref->base->npdt52.intelligence); | ||||
|                 data->mCreatureStats.getAttribute(2).set (ref->base->npdt52.willpower); | ||||
|                 data->mCreatureStats.getAttribute(3).set (ref->base->npdt52.agility); | ||||
|                 data->mCreatureStats.getAttribute(4).set (ref->base->npdt52.speed); | ||||
|                 data->mCreatureStats.getAttribute(5).set (ref->base->npdt52.endurance); | ||||
|                 data->mCreatureStats.getAttribute(6).set (ref->base->npdt52.personality); | ||||
|                 data->mCreatureStats.getAttribute(7).set (ref->base->npdt52.luck); | ||||
|                 data->mCreatureStats.getHealth().set (ref->base->npdt52.health); | ||||
|                 data->mCreatureStats.getMagicka().set (ref->base->npdt52.mana); | ||||
|                 data->mCreatureStats.getFatigue().set (ref->base->npdt52.fatigue); | ||||
| 
 | ||||
|                 data->mCreatureStats.mLevel = ref->base->npdt52.level; | ||||
|                 data->mCreatureStats.setLevel(ref->base->npdt52.level); | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 /// \todo do something with npdt12 maybe:p
 | ||||
|             } | ||||
| 
 | ||||
|             data->mCreatureStats.mHello = ref->base->AI.hello; | ||||
|             data->mCreatureStats.mFight = ref->base->AI.fight; | ||||
|             data->mCreatureStats.mFlee = ref->base->AI.flee; | ||||
|             data->mCreatureStats.mAlarm = ref->base->AI.alarm; | ||||
|             data->mCreatureStats.setHello(ref->base->AI.hello); | ||||
|             data->mCreatureStats.setFight(ref->base->AI.fight); | ||||
|             data->mCreatureStats.setFlee(ref->base->AI.flee); | ||||
|             data->mCreatureStats.setAlarm(ref->base->AI.alarm); | ||||
| 
 | ||||
|             // store
 | ||||
|             ptr.getRefData().setCustomData (data.release()); | ||||
|  | @ -330,7 +330,7 @@ namespace MWClass | |||
|     float Npc::getCapacity (const MWWorld::Ptr& ptr) const | ||||
|     { | ||||
|         const MWMechanics::CreatureStats& stats = getCreatureStats (ptr); | ||||
|         return stats.mAttributes[0].getModified()*5; | ||||
|         return stats.getAttribute(0).getModified()*5; | ||||
|     } | ||||
| 
 | ||||
|     float Npc::getEncumbrance (const MWWorld::Ptr& ptr) const | ||||
|  | @ -339,9 +339,9 @@ namespace MWClass | |||
| 
 | ||||
|         const MWMechanics::CreatureStats& stats = getCreatureStats (ptr); | ||||
| 
 | ||||
|         weight -= stats.mMagicEffects.get (MWMechanics::EffectKey (8)).mMagnitude; // feather
 | ||||
|         weight -= stats.getMagicEffects().get (MWMechanics::EffectKey (8)).mMagnitude; // feather
 | ||||
| 
 | ||||
|         weight += stats.mMagicEffects.get (MWMechanics::EffectKey (7)).mMagnitude; // burden
 | ||||
|         weight += stats.getMagicEffects().get (MWMechanics::EffectKey (7)).mMagnitude; // burden
 | ||||
| 
 | ||||
|         if (weight<0) | ||||
|             weight = 0; | ||||
|  | @ -356,7 +356,7 @@ namespace MWClass | |||
| 
 | ||||
|         /// \todo consider instant effects
 | ||||
| 
 | ||||
|         return stats.mActiveSpells.addSpell (id); | ||||
|         return stats.getActiveSpells().addSpell (id); | ||||
|     } | ||||
| 
 | ||||
|     void Npc::skillUsageSucceeded (const MWWorld::Ptr& ptr, int skill, int usageType) const | ||||
|  |  | |||
|  | @ -81,7 +81,7 @@ namespace MWGui | |||
|         MWWorld::Ptr player = MWBase::Environment::get().getWorld()->getPlayer().getPlayer(); | ||||
|         MWWorld::InventoryStore& store = MWWorld::Class::get(player).getInventoryStore(player); | ||||
|         MWMechanics::CreatureStats& stats = MWWorld::Class::get(player).getCreatureStats(player); | ||||
|         MWMechanics::Spells& spells = stats.mSpells; | ||||
|         MWMechanics::Spells& spells = stats.getSpells(); | ||||
| 
 | ||||
|         // the following code switches between selected enchanted item and selected spell (only one of these
 | ||||
|         // can be active at a time)
 | ||||
|  | @ -333,7 +333,7 @@ namespace MWGui | |||
|         MWWorld::Ptr player = MWBase::Environment::get().getWorld()->getPlayer().getPlayer(); | ||||
|         MWMechanics::CreatureStats& stats = MWWorld::Class::get(player).getCreatureStats(player); | ||||
|         MWWorld::InventoryStore& store = MWWorld::Class::get(player).getInventoryStore(player); | ||||
|         MWMechanics::Spells& spells = stats.mSpells; | ||||
|         MWMechanics::Spells& spells = stats.getSpells(); | ||||
|         MWWorld::Ptr item = *_sender->getUserData<MWWorld::Ptr>(); | ||||
| 
 | ||||
|         // retrieve ContainerStoreIterator to the item
 | ||||
|  | @ -397,7 +397,7 @@ namespace MWGui | |||
|         MWWorld::Ptr player = MWBase::Environment::get().getWorld()->getPlayer().getPlayer(); | ||||
|         MWMechanics::CreatureStats& stats = MWWorld::Class::get(player).getCreatureStats(player); | ||||
|         MWWorld::InventoryStore& store = MWWorld::Class::get(player).getInventoryStore(player); | ||||
|         MWMechanics::Spells& spells = stats.mSpells; | ||||
|         MWMechanics::Spells& spells = stats.getSpells(); | ||||
| 
 | ||||
|         if (MyGUI::InputManager::getInstance().isShiftPressed()) | ||||
|         { | ||||
|  | @ -451,7 +451,7 @@ namespace MWGui | |||
|     { | ||||
|         MWWorld::Ptr player = MWBase::Environment::get().getWorld()->getPlayer().getPlayer(); | ||||
|         MWMechanics::CreatureStats& stats = MWWorld::Class::get(player).getCreatureStats(player); | ||||
|         MWMechanics::Spells& spells = stats.mSpells; | ||||
|         MWMechanics::Spells& spells = stats.getSpells(); | ||||
| 
 | ||||
|         if (spells.getSelectedSpell() == mSpellToDelete) | ||||
|         { | ||||
|  |  | |||
|  | @ -33,7 +33,7 @@ namespace MWMechanics | |||
|     { | ||||
|         CreatureStats& creatureStats =  MWWorld::Class::get (creature).getCreatureStats (creature); | ||||
| 
 | ||||
|         MagicEffects now = creatureStats.mSpells.getMagicEffects(); | ||||
|         MagicEffects now = creatureStats.getSpells().getMagicEffects(); | ||||
| 
 | ||||
|         if (creature.getTypeName()==typeid (ESM::NPC).name()) | ||||
|         { | ||||
|  | @ -41,11 +41,11 @@ namespace MWMechanics | |||
|             now += store.getMagicEffects(); | ||||
|         } | ||||
| 
 | ||||
|         now += creatureStats.mActiveSpells.getMagicEffects(); | ||||
|         now += creatureStats.getActiveSpells().getMagicEffects(); | ||||
| 
 | ||||
|         MagicEffects diff = MagicEffects::diff (creatureStats.mMagicEffects, now); | ||||
|         MagicEffects diff = MagicEffects::diff (creatureStats.getMagicEffects(), now); | ||||
| 
 | ||||
|         creatureStats.mMagicEffects = now; | ||||
|         creatureStats.setMagicEffects(now); | ||||
| 
 | ||||
|         // TODO apply diff to other stats
 | ||||
|     } | ||||
|  | @ -54,18 +54,22 @@ namespace MWMechanics | |||
|     { | ||||
|         CreatureStats& creatureStats = MWWorld::Class::get (ptr).getCreatureStats (ptr); | ||||
| 
 | ||||
|         int strength = creatureStats.mAttributes[0].getBase(); | ||||
|         int intelligence = creatureStats.mAttributes[1].getBase(); | ||||
|         int willpower = creatureStats.mAttributes[2].getBase(); | ||||
|         int agility = creatureStats.mAttributes[3].getBase(); | ||||
|         int endurance = creatureStats.mAttributes[5].getBase(); | ||||
|         int strength        = creatureStats.getAttribute(0).getBase(); | ||||
|         int intelligence    = creatureStats.getAttribute(1).getBase(); | ||||
|         int willpower       = creatureStats.getAttribute(2).getBase(); | ||||
|         int agility         = creatureStats.getAttribute(3).getBase(); | ||||
|         int endurance       = creatureStats.getAttribute(5).getBase(); | ||||
| 
 | ||||
|         double magickaFactor = creatureStats.mMagicEffects.get (EffectKey (84)).mMagnitude*0.1 + 0.5; | ||||
|         double magickaFactor = | ||||
|             creatureStats.getMagicEffects().get (EffectKey (84)).mMagnitude * 0.1 + 0.5; | ||||
| 
 | ||||
|         creatureStats.mDynamic[0].setBase (static_cast<int> (0.5 * (strength + endurance))); | ||||
|         creatureStats.mDynamic[1].setBase (static_cast<int> (intelligence + | ||||
|             magickaFactor * intelligence)); | ||||
|         creatureStats.mDynamic[2].setBase (strength+willpower+agility+endurance); | ||||
|         creatureStats.getHealth().setBase( | ||||
|             static_cast<int> (0.5 * (strength + endurance))); | ||||
| 
 | ||||
|         creatureStats.getMagicka().setBase( | ||||
|             static_cast<int> (intelligence + magickaFactor * intelligence)); | ||||
| 
 | ||||
|         creatureStats.getFatigue().setBase(strength+willpower+agility+endurance); | ||||
|     } | ||||
| 
 | ||||
|     void Actors::calculateCreatureStatModifiers (const MWWorld::Ptr& ptr) | ||||
|  | @ -75,20 +79,24 @@ namespace MWMechanics | |||
|         // attributes
 | ||||
|         for (int i=0; i<5; ++i) | ||||
|         { | ||||
|             int modifier = creatureStats.mMagicEffects.get (EffectKey (79, i)).mMagnitude | ||||
|                 - creatureStats.mMagicEffects.get (EffectKey (17, i)).mMagnitude; | ||||
|             int modifier = | ||||
|                 creatureStats.getMagicEffects().get (EffectKey (79, i)).mMagnitude; | ||||
| 
 | ||||
|             creatureStats.mAttributes[i].setModifier (modifier); | ||||
|             modifier -= creatureStats.getMagicEffects().get (EffectKey (17, i)).mMagnitude; | ||||
| 
 | ||||
|             creatureStats.getAttribute(i).setModifier (modifier); | ||||
|         } | ||||
| 
 | ||||
|         // dynamic stats
 | ||||
|         for (int i=0; i<3; ++i) | ||||
|         { | ||||
|             int modifier = creatureStats.mMagicEffects.get (EffectKey (80+i)).mMagnitude | ||||
|                 - creatureStats.mMagicEffects.get (EffectKey (18+i)).mMagnitude; | ||||
|         MagicEffects effects = creatureStats.getMagicEffects(); | ||||
|         creatureStats.getHealth().setModifier( | ||||
|             effects.get(EffectKey(80)).mMagnitude - effects.get(EffectKey(18)).mMagnitude); | ||||
| 
 | ||||
|             creatureStats.mDynamic[i].setModifier (modifier); | ||||
|         } | ||||
|         creatureStats.getMagicka().setModifier( | ||||
|             effects.get(EffectKey(81)).mMagnitude - effects.get(EffectKey(19)).mMagnitude); | ||||
| 
 | ||||
|         creatureStats.getFatigue().setModifier( | ||||
|             effects.get(EffectKey(82)).mMagnitude - effects.get(EffectKey(20)).mMagnitude); | ||||
|     } | ||||
| 
 | ||||
|     Actors::Actors() : mDuration (0) {} | ||||
|  |  | |||
							
								
								
									
										48
									
								
								apps/openmw/mwmechanics/creaturestats.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										48
									
								
								apps/openmw/mwmechanics/creaturestats.cpp
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,48 @@ | |||
| #include "creaturestats.hpp" | ||||
| 
 | ||||
| namespace MWMechanics | ||||
| { | ||||
|     CreatureStats::CreatureStats() | ||||
|     {} | ||||
|      | ||||
|     // Can't use all benefits of members initialization because of
 | ||||
|     // lack of copy constructors
 | ||||
|     CreatureStats::CreatureStats(const CreatureStats &orig) | ||||
|       : mLevel(orig.mLevel), mHello(orig.mHello), mFight(orig.mFight), | ||||
|       mFlee(orig.mFlee), mAlarm(orig.mAlarm) | ||||
|     { | ||||
|         for (int i = 0; i < 8; ++i) { | ||||
|             mAttributes[i] = orig.mAttributes[i]; | ||||
|         } | ||||
|         for (int i = 0; i < 3; ++i) { | ||||
|             mDynamic[i] = orig.mDynamic[i]; | ||||
|         } | ||||
|         mSpells = orig.mSpells; | ||||
|         mActiveSpells = orig.mActiveSpells; | ||||
|         mMagicEffects = orig.mMagicEffects; | ||||
|     } | ||||
| 
 | ||||
|     CreatureStats::~CreatureStats() | ||||
|     {} | ||||
| 
 | ||||
|     const CreatureStats & | ||||
|     CreatureStats::operator=(const CreatureStats &orig) | ||||
|     { | ||||
|         for (int i = 0; i < 8; ++i) { | ||||
|             mAttributes[i] = orig.mAttributes[i]; | ||||
|         } | ||||
|         for (int i = 0; i < 3; ++i) { | ||||
|             mDynamic[i] = orig.mDynamic[i]; | ||||
|         } | ||||
|         mLevel = orig.mLevel; | ||||
|         mSpells = orig.mSpells; | ||||
|         mActiveSpells = orig.mActiveSpells; | ||||
|         mMagicEffects = orig.mMagicEffects; | ||||
|         mHello = orig.mHello; | ||||
|         mFight = orig.mFight; | ||||
|         mFlee = orig.mFlee; | ||||
|         mAlarm = orig.mAlarm; | ||||
| 
 | ||||
|         return *this; | ||||
|     } | ||||
| } | ||||
|  | @ -3,6 +3,7 @@ | |||
| 
 | ||||
| #include <set> | ||||
| #include <string> | ||||
| #include <stdexcept> | ||||
| 
 | ||||
| #include "stat.hpp" | ||||
| #include "magiceffects.hpp" | ||||
|  | @ -11,7 +12,10 @@ | |||
| 
 | ||||
| namespace MWMechanics | ||||
| { | ||||
|     struct CreatureStats | ||||
|     /// \brief Common creature stats
 | ||||
|     ///
 | ||||
|     ///
 | ||||
|     class CreatureStats | ||||
|     { | ||||
|         Stat<int> mAttributes[8]; | ||||
|         DynamicStat<int> mDynamic[3]; // health, magicka, fatigue
 | ||||
|  | @ -23,7 +27,258 @@ namespace MWMechanics | |||
|         int mFight; | ||||
|         int mFlee; | ||||
|         int mAlarm; | ||||
| 
 | ||||
|     public: | ||||
|         CreatureStats(); | ||||
|         CreatureStats(const CreatureStats &); | ||||
|         virtual ~CreatureStats(); | ||||
| 
 | ||||
|         const CreatureStats & operator=(const CreatureStats &); | ||||
| 
 | ||||
|         const Stat<int> & getAttribute(int index) const; | ||||
| 
 | ||||
|         const DynamicStat<int> & getHealth() const; | ||||
| 
 | ||||
|         const DynamicStat<int> & getMagicka() const; | ||||
| 
 | ||||
|         const DynamicStat<int> & getFatigue() const; | ||||
| 
 | ||||
|         const Spells & getSpells() const; | ||||
| 
 | ||||
|         const ActiveSpells & getActiveSpells() const; | ||||
| 
 | ||||
|         const MagicEffects & getMagicEffects() const; | ||||
| 
 | ||||
|         int getLevel() const; | ||||
| 
 | ||||
|         int getHello() const; | ||||
| 
 | ||||
|         int getFight() const; | ||||
| 
 | ||||
|         int getFlee() const; | ||||
| 
 | ||||
|         int getAlarm() const; | ||||
| 
 | ||||
| 
 | ||||
|         Stat<int> & getAttribute(int index); | ||||
| 
 | ||||
|         DynamicStat<int> & getHealth(); | ||||
| 
 | ||||
|         DynamicStat<int> & getMagicka(); | ||||
| 
 | ||||
|         DynamicStat<int> & getFatigue(); | ||||
| 
 | ||||
|         DynamicStat<int> & getDynamic(int index); | ||||
| 
 | ||||
|         Spells & getSpells(); | ||||
| 
 | ||||
|         ActiveSpells & getActiveSpells(); | ||||
| 
 | ||||
|         MagicEffects & getMagicEffects(); | ||||
| 
 | ||||
| 
 | ||||
|         void setAttribute(int index, const Stat<int> &value); | ||||
| 
 | ||||
|         void setHealth(const DynamicStat<int> &value); | ||||
| 
 | ||||
|         void setMagicka(const DynamicStat<int> &value); | ||||
| 
 | ||||
|         void setFatigue(const DynamicStat<int> &value); | ||||
| 
 | ||||
|         void setSpells(const Spells &spells); | ||||
| 
 | ||||
|         void setActiveSpells(const ActiveSpells &active); | ||||
| 
 | ||||
|         void setMagicEffects(const MagicEffects &effects); | ||||
| 
 | ||||
|         void setLevel(int level); | ||||
| 
 | ||||
|         void setHello(int value); | ||||
| 
 | ||||
|         void setFight(int value); | ||||
| 
 | ||||
|         void setFlee(int value); | ||||
| 
 | ||||
|         void setAlarm(int value); | ||||
|     }; | ||||
| 
 | ||||
|     // Inline const getters
 | ||||
| 
 | ||||
|     inline const Stat<int> & | ||||
|     CreatureStats::getAttribute(int index) const { | ||||
|         if (index < 0 || index > 7) { | ||||
|             throw std::runtime_error("attribute index is out of range"); | ||||
|         } | ||||
|         return mAttributes[index]; | ||||
|     } | ||||
| 
 | ||||
|     inline const DynamicStat<int> & | ||||
|     CreatureStats::getHealth() const { | ||||
|         return mDynamic[0]; | ||||
|     } | ||||
| 
 | ||||
|     inline const DynamicStat<int> & | ||||
|     CreatureStats::getMagicka() const { | ||||
|         return mDynamic[1]; | ||||
|     } | ||||
| 
 | ||||
|     inline const DynamicStat<int> & | ||||
|     CreatureStats::getFatigue() const { | ||||
|         return mDynamic[2]; | ||||
|     } | ||||
| 
 | ||||
|     inline const Spells & | ||||
|     CreatureStats::getSpells() const { | ||||
|         return mSpells; | ||||
|     } | ||||
| 
 | ||||
|     inline const ActiveSpells &  | ||||
|     CreatureStats::getActiveSpells() const { | ||||
|         return mActiveSpells; | ||||
|     } | ||||
| 
 | ||||
|     inline const MagicEffects &  | ||||
|     CreatureStats::getMagicEffects() const { | ||||
|         return mMagicEffects; | ||||
|     } | ||||
| 
 | ||||
|     inline int | ||||
|     CreatureStats::getLevel() const { | ||||
|         return mLevel; | ||||
|     } | ||||
|     | ||||
|     inline int | ||||
|     CreatureStats::getHello() const { | ||||
|         return mHello; | ||||
|     } | ||||
| 
 | ||||
|     inline int | ||||
|     CreatureStats::getFight() const { | ||||
|         return mFight; | ||||
|     } | ||||
| 
 | ||||
|     inline int | ||||
|     CreatureStats::getFlee() const { | ||||
|         return mFlee; | ||||
|     } | ||||
| 
 | ||||
|     inline int | ||||
|     CreatureStats::getAlarm() const { | ||||
|         return mAlarm; | ||||
|     } | ||||
| 
 | ||||
|     // Inline non-const getters
 | ||||
| 
 | ||||
|     inline Stat<int> & | ||||
|     CreatureStats::getAttribute(int index) { | ||||
|         if (index < 0 || index > 7) { | ||||
|             throw std::runtime_error("attribute index is out of range"); | ||||
|         } | ||||
|         return mAttributes[index]; | ||||
|     } | ||||
| 
 | ||||
|     inline DynamicStat<int> & | ||||
|     CreatureStats::getHealth() { | ||||
|         return mDynamic[0]; | ||||
|     } | ||||
| 
 | ||||
|     inline DynamicStat<int> & | ||||
|     CreatureStats::getMagicka() { | ||||
|         return mDynamic[1]; | ||||
|     } | ||||
| 
 | ||||
|     inline DynamicStat<int> & | ||||
|     CreatureStats::getFatigue() { | ||||
|         return mDynamic[2]; | ||||
|     } | ||||
| 
 | ||||
|     inline DynamicStat<int> & | ||||
|     CreatureStats::getDynamic(int index) { | ||||
|         if (index < 0 || index > 2) { | ||||
|             throw std::runtime_error("dynamic stat index is out of range"); | ||||
|         } | ||||
|         return mDynamic[index]; | ||||
|     } | ||||
| 
 | ||||
|     inline Spells &  | ||||
|     CreatureStats::getSpells() { | ||||
|         return mSpells; | ||||
|     } | ||||
| 
 | ||||
|     inline void  | ||||
|     CreatureStats::setSpells(const Spells &spells) { | ||||
|         mSpells = spells; | ||||
|     } | ||||
| 
 | ||||
|     inline ActiveSpells &  | ||||
|     CreatureStats::getActiveSpells() { | ||||
|         return mActiveSpells; | ||||
|     } | ||||
| 
 | ||||
|     inline MagicEffects &  | ||||
|     CreatureStats::getMagicEffects() { | ||||
|         return mMagicEffects; | ||||
|     } | ||||
| 
 | ||||
|     // Inline setters
 | ||||
| 
 | ||||
|     inline void | ||||
|     CreatureStats::setAttribute(int index, const Stat<int> &value) { | ||||
|         if (index < 0 || index > 7) { | ||||
|             throw std::runtime_error("attribute index is out of range"); | ||||
|         } | ||||
|         mAttributes[index] = value; | ||||
|     } | ||||
| 
 | ||||
|     inline void | ||||
|     CreatureStats::setHealth(const DynamicStat<int> &value) { | ||||
|         mDynamic[0] = value; | ||||
|     } | ||||
| 
 | ||||
|     inline void | ||||
|     CreatureStats::setMagicka(const DynamicStat<int> &value) { | ||||
|         mDynamic[1] = value; | ||||
|     } | ||||
| 
 | ||||
|     inline void | ||||
|     CreatureStats::setFatigue(const DynamicStat<int> &value) { | ||||
|         mDynamic[2] = value; | ||||
|     } | ||||
| 
 | ||||
|     inline void | ||||
|     CreatureStats::setLevel(int level) { | ||||
|         mLevel = level; | ||||
|     } | ||||
| 
 | ||||
|     inline void  | ||||
|     CreatureStats::setActiveSpells(const ActiveSpells &active) { | ||||
|         mActiveSpells = active; | ||||
|     } | ||||
| 
 | ||||
|     inline void  | ||||
|     CreatureStats::setMagicEffects(const MagicEffects &effects) { | ||||
|         mMagicEffects = effects; | ||||
|     } | ||||
| 
 | ||||
|     inline void | ||||
|     CreatureStats::setHello(int value) { | ||||
|         mHello = value; | ||||
|     } | ||||
| 
 | ||||
|     inline void | ||||
|     CreatureStats::setFight(int value) { | ||||
|         mFight = value; | ||||
|     } | ||||
| 
 | ||||
|     inline void | ||||
|     CreatureStats::setFlee(int value) { | ||||
|         mFlee = value; | ||||
|     } | ||||
| 
 | ||||
|     inline void | ||||
|     CreatureStats::setAlarm(int value) { | ||||
|         mAlarm = value; | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| #endif | ||||
|  |  | |||
|  | @ -23,21 +23,21 @@ namespace MWMechanics | |||
|         const ESM::NPC *player = ptr.get<ESM::NPC>()->base; | ||||
| 
 | ||||
|         // reset
 | ||||
|         creatureStats.mLevel = player->npdt52.level; | ||||
|         creatureStats.mSpells.clear(); | ||||
|         creatureStats.mMagicEffects = MagicEffects(); | ||||
|         creatureStats.setLevel(player->npdt52.level); | ||||
|         creatureStats.getSpells().clear(); | ||||
|         creatureStats.setMagicEffects(MagicEffects()); | ||||
| 
 | ||||
|         for (int i=0; i<27; ++i) | ||||
|             npcStats.getSkill (i).setBase (player->npdt52.skills[i]); | ||||
| 
 | ||||
|         creatureStats.mAttributes[0].setBase (player->npdt52.strength); | ||||
|         creatureStats.mAttributes[1].setBase (player->npdt52.intelligence); | ||||
|         creatureStats.mAttributes[2].setBase (player->npdt52.willpower); | ||||
|         creatureStats.mAttributes[3].setBase (player->npdt52.agility); | ||||
|         creatureStats.mAttributes[4].setBase (player->npdt52.speed); | ||||
|         creatureStats.mAttributes[5].setBase (player->npdt52.endurance); | ||||
|         creatureStats.mAttributes[6].setBase (player->npdt52.personality); | ||||
|         creatureStats.mAttributes[7].setBase (player->npdt52.luck); | ||||
|         creatureStats.getAttribute(0).setBase (player->npdt52.strength); | ||||
|         creatureStats.getAttribute(1).setBase (player->npdt52.intelligence); | ||||
|         creatureStats.getAttribute(2).setBase (player->npdt52.willpower); | ||||
|         creatureStats.getAttribute(3).setBase (player->npdt52.agility); | ||||
|         creatureStats.getAttribute(4).setBase (player->npdt52.speed); | ||||
|         creatureStats.getAttribute(5).setBase (player->npdt52.endurance); | ||||
|         creatureStats.getAttribute(6).setBase (player->npdt52.personality); | ||||
|         creatureStats.getAttribute(7).setBase (player->npdt52.luck); | ||||
| 
 | ||||
|         // race
 | ||||
|         if (mRaceSelected) | ||||
|  | @ -63,7 +63,7 @@ namespace MWMechanics | |||
|                     case 7: attribute = &race->data.luck; break; | ||||
|                 } | ||||
| 
 | ||||
|                 creatureStats.mAttributes[i].setBase ( | ||||
|                 creatureStats.getAttribute(i).setBase ( | ||||
|                     static_cast<int> (male ? attribute->male : attribute->female)); | ||||
|             } | ||||
| 
 | ||||
|  | @ -81,7 +81,7 @@ namespace MWMechanics | |||
|             for (std::vector<std::string>::const_iterator iter (race->powers.list.begin()); | ||||
|                 iter!=race->powers.list.end(); ++iter) | ||||
|             { | ||||
|                 creatureStats.mSpells.add (*iter); | ||||
|                 creatureStats.getSpells().add (*iter); | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|  | @ -95,7 +95,7 @@ namespace MWMechanics | |||
|             for (std::vector<std::string>::const_iterator iter (sign->powers.list.begin()); | ||||
|                 iter!=sign->powers.list.end(); ++iter) | ||||
|             { | ||||
|                 creatureStats.mSpells.add (*iter); | ||||
|                 creatureStats.getSpells().add (*iter); | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|  | @ -109,8 +109,8 @@ namespace MWMechanics | |||
|                 int attribute = class_.data.attribute[i]; | ||||
|                 if (attribute>=0 && attribute<8) | ||||
|                 { | ||||
|                     creatureStats.mAttributes[attribute].setBase ( | ||||
|                         creatureStats.mAttributes[attribute].getBase() + 10); | ||||
|                     creatureStats.getAttribute(attribute).setBase ( | ||||
|                         creatureStats.getAttribute(attribute).getBase() + 10); | ||||
|                 } | ||||
|             } | ||||
| 
 | ||||
|  | @ -151,8 +151,9 @@ namespace MWMechanics | |||
|         // forced update and current value adjustments
 | ||||
|         mActors.updateActor (ptr, 0); | ||||
| 
 | ||||
|         for (int i=0; i<3; ++i) | ||||
|             creatureStats.mDynamic[i].setCurrent (creatureStats.mDynamic[i].getModified()); | ||||
|         creatureStats.getHealth().setCurrent(creatureStats.getHealth().getModified()); | ||||
|         creatureStats.getMagicka().setCurrent(creatureStats.getMagicka().getModified()); | ||||
|         creatureStats.getFatigue().setCurrent(creatureStats.getFatigue().getModified()); | ||||
|     } | ||||
| 
 | ||||
| 
 | ||||
|  | @ -213,22 +214,25 @@ namespace MWMechanics | |||
| 
 | ||||
|             for (int i=0; i<8; ++i) | ||||
|             { | ||||
|                 if (stats.mAttributes[i]!=mWatchedCreature.mAttributes[i]) | ||||
|                 if (stats.getAttribute(i)!=mWatchedCreature.getAttribute(i)) | ||||
|                 { | ||||
|                     mWatchedCreature.mAttributes[i] = stats.mAttributes[i]; | ||||
|                     mWatchedCreature.setAttribute(i, stats.getAttribute(i)); | ||||
| 
 | ||||
|                     MWBase::Environment::get().getWindowManager()->setValue (attributeNames[i], stats.mAttributes[i]); | ||||
|                     MWBase::Environment::get().getWindowManager()->setValue (attributeNames[i], stats.getAttribute(i)); | ||||
|                 } | ||||
|             } | ||||
| 
 | ||||
|             for (int i=0; i<3; ++i) | ||||
|             { | ||||
|                 if (stats.mDynamic[i]!=mWatchedCreature.mDynamic[i]) | ||||
|                 { | ||||
|                     mWatchedCreature.mDynamic[i] = stats.mDynamic[i]; | ||||
| 
 | ||||
|                     MWBase::Environment::get().getWindowManager()->setValue (dynamicNames[i], stats.mDynamic[i]); | ||||
|                 } | ||||
|             if (stats.getHealth() != mWatchedCreature.getHealth()) { | ||||
|                 mWatchedCreature.setHealth(stats.getHealth()); | ||||
|                 MWBase::Environment::get().getWindowManager()->setValue(dynamicNames[0], stats.getHealth()); | ||||
|             } | ||||
|             if (stats.getMagicka() != mWatchedCreature.getMagicka()) { | ||||
|                 mWatchedCreature.setMagicka(stats.getMagicka()); | ||||
|                 MWBase::Environment::get().getWindowManager()->setValue(dynamicNames[1], stats.getMagicka()); | ||||
|             } | ||||
|             if (stats.getFatigue() != mWatchedCreature.getFatigue()) { | ||||
|                 mWatchedCreature.setFatigue(stats.getFatigue()); | ||||
|                 MWBase::Environment::get().getWindowManager()->setValue(dynamicNames[2], stats.getFatigue()); | ||||
|             } | ||||
| 
 | ||||
|             bool update = false; | ||||
|  | @ -247,7 +251,7 @@ namespace MWMechanics | |||
|             if (update) | ||||
|                 MWBase::Environment::get().getWindowManager()->updateSkillArea(); | ||||
| 
 | ||||
|             MWBase::Environment::get().getWindowManager()->setValue ("level", stats.mLevel); | ||||
|             MWBase::Environment::get().getWindowManager()->setValue ("level", stats.getLevel()); | ||||
|         } | ||||
| 
 | ||||
|         if (mUpdatePlayer) | ||||
|  |  | |||
|  | @ -81,12 +81,12 @@ namespace MWMechanics | |||
|         int skillLevel = stats.getSkill (getSpellSchool(spellId, actor)).getModified(); | ||||
| 
 | ||||
|         // Sound magic effect (reduces spell casting chance)
 | ||||
|         int soundMagnitude = creatureStats.mMagicEffects.get (MWMechanics::EffectKey (48)).mMagnitude; | ||||
|         int soundMagnitude = creatureStats.getMagicEffects().get (MWMechanics::EffectKey (48)).mMagnitude; | ||||
| 
 | ||||
|         int willpower = creatureStats.mAttributes[ESM::Attribute::Willpower].getModified(); | ||||
|         int luck = creatureStats.mAttributes[ESM::Attribute::Luck].getModified(); | ||||
|         int currentFatigue = creatureStats.mDynamic[2].getCurrent(); | ||||
|         int maxFatigue = creatureStats.mDynamic[2].getModified(); | ||||
|         int willpower = creatureStats.getAttribute(ESM::Attribute::Willpower).getModified(); | ||||
|         int luck = creatureStats.getAttribute(ESM::Attribute::Luck).getModified(); | ||||
|         int currentFatigue = creatureStats.getFatigue().getCurrent(); | ||||
|         int maxFatigue = creatureStats.getFatigue().getModified(); | ||||
|         int spellCost = spell->data.cost; | ||||
| 
 | ||||
|         // There we go, all needed variables are there, lets go
 | ||||
|  |  | |||
|  | @ -130,7 +130,7 @@ namespace MWScript | |||
|                     Interpreter::Type_Integer value = runtime[0].mInteger; | ||||
|                     runtime.pop(); | ||||
| 
 | ||||
|                     MWWorld::Class::get (ptr).getCreatureStats (ptr).mHello = value; | ||||
|                     MWWorld::Class::get (ptr).getCreatureStats (ptr).setHello(value); | ||||
|                 } | ||||
|         }; | ||||
| 
 | ||||
|  | @ -146,7 +146,7 @@ namespace MWScript | |||
|                     Interpreter::Type_Integer value = runtime[0].mInteger; | ||||
|                     runtime.pop(); | ||||
| 
 | ||||
|                     MWWorld::Class::get (ptr).getCreatureStats (ptr).mFight = value; | ||||
|                     MWWorld::Class::get (ptr).getCreatureStats (ptr).setFight(value); | ||||
|                 } | ||||
|         }; | ||||
| 
 | ||||
|  | @ -162,7 +162,7 @@ namespace MWScript | |||
|                     Interpreter::Type_Integer value = runtime[0].mInteger; | ||||
|                     runtime.pop(); | ||||
| 
 | ||||
|                     MWWorld::Class::get (ptr).getCreatureStats (ptr).mFlee = value; | ||||
|                     MWWorld::Class::get (ptr).getCreatureStats (ptr).setFlee(value); | ||||
|                 } | ||||
|         }; | ||||
| 
 | ||||
|  | @ -178,7 +178,7 @@ namespace MWScript | |||
|                     Interpreter::Type_Integer value = runtime[0].mInteger; | ||||
|                     runtime.pop(); | ||||
| 
 | ||||
|                     MWWorld::Class::get (ptr).getCreatureStats (ptr).mAlarm = value; | ||||
|                     MWWorld::Class::get (ptr).getCreatureStats (ptr).setAlarm(value); | ||||
|                 } | ||||
|         }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -46,8 +46,10 @@ namespace MWScript | |||
|                     MWWorld::Ptr ptr = R()(runtime); | ||||
| 
 | ||||
|                     Interpreter::Type_Integer value = | ||||
|                         MWWorld::Class::get (ptr).getCreatureStats (ptr).mAttributes[mIndex]. | ||||
|                         getModified(); | ||||
|                         MWWorld::Class::get (ptr) | ||||
|                             .getCreatureStats (ptr) | ||||
|                             .getAttribute(mIndex) | ||||
|                             .getModified(); | ||||
| 
 | ||||
|                     runtime.push (value); | ||||
|                 } | ||||
|  | @ -69,8 +71,10 @@ namespace MWScript | |||
|                     Interpreter::Type_Integer value = runtime[0].mInteger; | ||||
|                     runtime.pop(); | ||||
| 
 | ||||
|                     MWWorld::Class::get (ptr).getCreatureStats (ptr).mAttributes[mIndex]. | ||||
|                         setModified (value, 0); | ||||
|                     MWWorld::Class::get(ptr) | ||||
|                         .getCreatureStats(ptr) | ||||
|                         .getAttribute(mIndex) | ||||
|                         .setModified (value, 0); | ||||
|                 } | ||||
|         }; | ||||
| 
 | ||||
|  | @ -90,11 +94,16 @@ namespace MWScript | |||
|                     Interpreter::Type_Integer value = runtime[0].mInteger; | ||||
|                     runtime.pop(); | ||||
| 
 | ||||
|                     value += MWWorld::Class::get (ptr).getCreatureStats (ptr).mAttributes[mIndex]. | ||||
|                         getModified(); | ||||
|                     value += | ||||
|                         MWWorld::Class::get(ptr) | ||||
|                             .getCreatureStats(ptr) | ||||
|                             .getAttribute(mIndex) | ||||
|                             .getModified(); | ||||
| 
 | ||||
|                     MWWorld::Class::get (ptr).getCreatureStats (ptr).mAttributes[mIndex]. | ||||
|                         setModified (value, 0, 100); | ||||
|                     MWWorld::Class::get(ptr) | ||||
|                         .getCreatureStats(ptr) | ||||
|                         .getAttribute(mIndex) | ||||
|                         .setModified (value, 0, 100); | ||||
|                 } | ||||
|         }; | ||||
| 
 | ||||
|  | @ -110,21 +119,19 @@ namespace MWScript | |||
|                 virtual void execute (Interpreter::Runtime& runtime) | ||||
|                 { | ||||
|                     MWWorld::Ptr ptr = R()(runtime); | ||||
|                     Interpreter::Type_Integer value; | ||||
| 
 | ||||
|                     if (mIndex==0 && MWWorld::Class::get (ptr).hasItemHealth (ptr)) | ||||
|                     { | ||||
|                         // health is a special case
 | ||||
|                         Interpreter::Type_Integer value = | ||||
|                             MWWorld::Class::get (ptr).getItemMaxHealth (ptr); | ||||
|                         runtime.push (value); | ||||
| 
 | ||||
|                         return; | ||||
|                         value = MWWorld::Class::get (ptr).getItemMaxHealth (ptr); | ||||
|                     } else { | ||||
|                         value = | ||||
|                             MWWorld::Class::get(ptr) | ||||
|                                 .getCreatureStats(ptr) | ||||
|                                 .getDynamic(mIndex) | ||||
|                                 .getCurrent(); | ||||
|                     } | ||||
| 
 | ||||
|                     Interpreter::Type_Integer value = | ||||
|                         MWWorld::Class::get (ptr).getCreatureStats (ptr).mDynamic[mIndex]. | ||||
|                         getCurrent(); | ||||
| 
 | ||||
|                     runtime.push (value); | ||||
|                 } | ||||
|         }; | ||||
|  | @ -145,8 +152,10 @@ namespace MWScript | |||
|                     Interpreter::Type_Integer value = runtime[0].mInteger; | ||||
|                     runtime.pop(); | ||||
| 
 | ||||
|                     MWWorld::Class::get (ptr).getCreatureStats (ptr).mDynamic[mIndex]. | ||||
|                         setModified (value, 0); | ||||
|                     MWWorld::Class::get(ptr) | ||||
|                         .getCreatureStats(ptr) | ||||
|                         .getDynamic(mIndex) | ||||
|                         .setModified(value, 0); | ||||
|                 } | ||||
|         }; | ||||
| 
 | ||||
|  | @ -168,12 +177,12 @@ namespace MWScript | |||
| 
 | ||||
|                     MWMechanics::CreatureStats& stats = MWWorld::Class::get (ptr).getCreatureStats (ptr); | ||||
| 
 | ||||
|                     Interpreter::Type_Integer current = stats.mDynamic[mIndex].getCurrent(); | ||||
|                     Interpreter::Type_Integer current = stats.getDynamic(mIndex).getCurrent(); | ||||
| 
 | ||||
|                     stats.mDynamic[mIndex].setModified ( | ||||
|                         diff + stats.mDynamic[mIndex].getModified(), 0); | ||||
|                     stats.getDynamic(mIndex).setModified( | ||||
|                         diff + stats.getDynamic(mIndex).getModified(), 0); | ||||
| 
 | ||||
|                     stats.mDynamic[mIndex].setCurrent (diff + current); | ||||
|                     stats.getDynamic(mIndex).setCurrent(diff + current); | ||||
|                 } | ||||
|         }; | ||||
| 
 | ||||
|  | @ -195,9 +204,9 @@ namespace MWScript | |||
| 
 | ||||
|                     MWMechanics::CreatureStats& stats = MWWorld::Class::get (ptr).getCreatureStats (ptr); | ||||
| 
 | ||||
|                     Interpreter::Type_Integer current = stats.mDynamic[mIndex].getCurrent(); | ||||
|                     Interpreter::Type_Integer current = stats.getDynamic(mIndex).getCurrent(); | ||||
| 
 | ||||
|                     stats.mDynamic[mIndex].setCurrent (diff + current); | ||||
|                     stats.getDynamic(mIndex).setCurrent (diff + current); | ||||
|                 } | ||||
|         }; | ||||
| 
 | ||||
|  | @ -218,10 +227,10 @@ namespace MWScript | |||
| 
 | ||||
|                     Interpreter::Type_Float value = 0; | ||||
| 
 | ||||
|                     Interpreter::Type_Float max = stats.mDynamic[mIndex].getModified(); | ||||
|                     Interpreter::Type_Float max = stats.getDynamic(mIndex).getModified(); | ||||
| 
 | ||||
|                     if (max>0) | ||||
|                         value = stats.mDynamic[mIndex].getCurrent() / max; | ||||
|                         value = stats.getDynamic(mIndex).getCurrent() / max; | ||||
| 
 | ||||
|                     runtime.push (value); | ||||
|                 } | ||||
|  | @ -335,7 +344,7 @@ namespace MWScript | |||
|                     // make sure a spell with this ID actually exists.
 | ||||
|                     MWBase::Environment::get().getWorld()->getStore().spells.find (id); | ||||
| 
 | ||||
|                     MWWorld::Class::get (ptr).getCreatureStats (ptr).mSpells.add (id); | ||||
|                     MWWorld::Class::get (ptr).getCreatureStats (ptr).getSpells().add (id); | ||||
|                 } | ||||
|         }; | ||||
| 
 | ||||
|  | @ -351,7 +360,7 @@ namespace MWScript | |||
|                     std::string id = runtime.getStringLiteral (runtime[0].mInteger); | ||||
|                     runtime.pop(); | ||||
| 
 | ||||
|                     MWWorld::Class::get (ptr).getCreatureStats (ptr).mSpells.remove (id); | ||||
|                     MWWorld::Class::get (ptr).getCreatureStats (ptr).getSpells().remove (id); | ||||
|                 } | ||||
|         }; | ||||
| 
 | ||||
|  | @ -371,8 +380,8 @@ namespace MWScript | |||
|                     Interpreter::Type_Integer value = 0; | ||||
| 
 | ||||
|                     for (MWMechanics::Spells::TIterator iter ( | ||||
|                         MWWorld::Class::get (ptr).getCreatureStats (ptr).mSpells.begin()); | ||||
|                         iter!=MWWorld::Class::get (ptr).getCreatureStats (ptr).mSpells.end(); ++iter) | ||||
|                         MWWorld::Class::get (ptr).getCreatureStats (ptr).getSpells().begin()); | ||||
|                         iter!=MWWorld::Class::get (ptr).getCreatureStats (ptr).getSpells().end(); ++iter) | ||||
|                         if (*iter==id) | ||||
|                         { | ||||
|                             value = 1; | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue