diff --git a/apps/openmw/mwscript/miscextensions.cpp b/apps/openmw/mwscript/miscextensions.cpp index 234f67d8c..77dc1deb0 100644 --- a/apps/openmw/mwscript/miscextensions.cpp +++ b/apps/openmw/mwscript/miscextensions.cpp @@ -1,6 +1,8 @@ #include "miscextensions.hpp" +#include + #include #include @@ -317,10 +319,15 @@ namespace MWScript { MWWorld::Ptr ptr = R()(runtime); - int key = runtime[0].mInteger; + std::string effect = runtime.getStringLiteral(runtime[0].mInteger); runtime.pop(); - runtime.push (MWWorld::Class::get(ptr).getCreatureStats (ptr).getMagicEffects ().get ( + char *end; + long key = strtol(effect.c_str(), &end, 10); + if(key < 0 || key > 32767 || *end != '\0') + key = ESM::MagicEffect::effectStringToId(effect); + + runtime.push(MWWorld::Class::get(ptr).getCreatureStats(ptr).getMagicEffects().get( MWMechanics::EffectKey(key)).mMagnitude > 0); } }; diff --git a/components/compiler/extensions0.cpp b/components/compiler/extensions0.cpp index 692b50052..9e0c36825 100644 --- a/components/compiler/extensions0.cpp +++ b/components/compiler/extensions0.cpp @@ -238,7 +238,7 @@ namespace Compiler extensions.registerInstruction ("wakeuppc", "", opcodeWakeUpPc); extensions.registerInstruction ("playbink", "Sl", opcodePlayBink); extensions.registerFunction ("getlocked", 'l', "", opcodeGetLocked, opcodeGetLockedExplicit); - extensions.registerFunction ("geteffect", 'l', "l", opcodeGetEffect, opcodeGetEffectExplicit); + extensions.registerFunction ("geteffect", 'l', "S", opcodeGetEffect, opcodeGetEffectExplicit); extensions.registerInstruction ("addsoulgem", "cc", opcodeAddSoulGem, opcodeAddSoulGemExplicit); extensions.registerInstruction ("removesoulgem", "c", opcodeRemoveSoulGem, opcodeRemoveSoulGemExplicit); extensions.registerInstruction ("drop", "cl", opcodeDrop, opcodeDropExplicit); diff --git a/components/esm/loadmgef.cpp b/components/esm/loadmgef.cpp index 4aef97838..060645b5f 100644 --- a/components/esm/loadmgef.cpp +++ b/components/esm/loadmgef.cpp @@ -83,7 +83,8 @@ void MagicEffect::save(ESMWriter &esm) esm.writeHNOString("DESC", mDescription); } -std::string MagicEffect::effectIdToString(short effectID) + +static std::map genNameMap() { // Map effect ID to GMST name // http://www.uesp.net/morrow/hints/mweffects.shtml @@ -235,10 +236,43 @@ std::string MagicEffect::effectIdToString(short effectID) // tribunal names[137] ="sEffectSummonFabricant"; - if (names.find(effectID) == names.end()) - throw std::runtime_error( std::string("Unimplemented effect ID ") + boost::lexical_cast(effectID)); + return names; +} +const std::map MagicEffect::sNames = genNameMap(); + +const std::string &MagicEffect::effectIdToString(short effectID) +{ + std::map::const_iterator name = sNames.find(effectID); + if(name == sNames.end()) + throw std::runtime_error(std::string("Unimplemented effect ID ")+boost::lexical_cast(effectID)); + + return name->second; +} + +class FindSecond { + const std::string &mName; - return names[effectID]; +public: + FindSecond(const std::string &name) : mName(name) { } + + bool operator()(const std::pair &item) const + { + if(Misc::StringUtils::ciEqual(item.second, mName)) + return true; + return false; + } +}; + +short MagicEffect::effectStringToId(const std::string &effect) +{ + std::map::const_iterator name; + + name = std::find_if(sNames.begin(), sNames.end(), FindSecond(effect)); + if(name == sNames.end()) + throw std::runtime_error(std::string("Unimplemented effect ")+effect); + + return name->first; } + } diff --git a/components/esm/loadmgef.hpp b/components/esm/loadmgef.hpp index 7efc17aec..b74efb466 100644 --- a/components/esm/loadmgef.hpp +++ b/components/esm/loadmgef.hpp @@ -2,6 +2,7 @@ #define OPENMW_ESM_MGEF_H #include +#include namespace ESM { @@ -42,7 +43,10 @@ struct MagicEffect float mSpeed, mSize, mSizeCap; }; // 36 bytes - static std::string effectIdToString(short effectID); + static const std::map sNames; + + static const std::string &effectIdToString(short effectID); + static short effectStringToId(const std::string &effect); MEDTstruct mData;