forked from mirror/openmw-tes3mp
added set/get/mod instructions for skills
This commit is contained in:
parent
6fe6f3d282
commit
a8c974d2e7
2 changed files with 203 additions and 1 deletions
|
@ -95,4 +95,10 @@ op 0x2000085-0x200008b: Disable Controls
|
||||||
op 0x200008c: Unlock
|
op 0x200008c: Unlock
|
||||||
op 0x200008d: Unlock, explicit reference
|
op 0x200008d: Unlock, explicit reference
|
||||||
op 0x200008e: COE
|
op 0x200008e: COE
|
||||||
opcodes 0x200008f-0x3ffffff unused
|
op 0x200008e-0x20000a8: GetSkill
|
||||||
|
op 0x20000a9-0x20000c3: GetSkill, explicit reference
|
||||||
|
op 0x20000c4-0x20000de: SetSkill
|
||||||
|
op 0x20000df-0x20000f9: SetSkill, explicit reference
|
||||||
|
op 0x20000fa-0x2000114: ModSkill
|
||||||
|
op 0x2000115-0x200012f: ModSKill, explicit reference
|
||||||
|
opcodes 0x2000130-0x3ffffff unused
|
||||||
|
|
|
@ -468,6 +468,160 @@ namespace MWScript
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
class OpGetSkill : public Interpreter::Opcode0
|
||||||
|
{
|
||||||
|
int mIndex;
|
||||||
|
|
||||||
|
public:
|
||||||
|
|
||||||
|
OpGetSkill (int index) : mIndex (index) {}
|
||||||
|
|
||||||
|
virtual void execute (Interpreter::Runtime& runtime)
|
||||||
|
{
|
||||||
|
MWScript::InterpreterContext& context
|
||||||
|
= static_cast<MWScript::InterpreterContext&> (runtime.getContext());
|
||||||
|
|
||||||
|
MWWorld::Ptr ptr = context.getReference();
|
||||||
|
|
||||||
|
Interpreter::Type_Integer value =
|
||||||
|
MWWorld::Class::get (ptr).getNpcStats (ptr).mSkill[mIndex].
|
||||||
|
getModified();
|
||||||
|
|
||||||
|
runtime.push (value);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
class OpGetSkillExplicit : public Interpreter::Opcode0
|
||||||
|
{
|
||||||
|
int mIndex;
|
||||||
|
|
||||||
|
public:
|
||||||
|
|
||||||
|
OpGetSkillExplicit (int index) : mIndex (index) {}
|
||||||
|
|
||||||
|
virtual void execute (Interpreter::Runtime& runtime)
|
||||||
|
{
|
||||||
|
MWScript::InterpreterContext& context
|
||||||
|
= static_cast<MWScript::InterpreterContext&> (runtime.getContext());
|
||||||
|
|
||||||
|
std::string id = runtime.getStringLiteral (runtime[0].mInteger);
|
||||||
|
runtime.pop();
|
||||||
|
|
||||||
|
MWWorld::Ptr ptr = context.getWorld().getPtr (id, false);
|
||||||
|
|
||||||
|
Interpreter::Type_Integer value =
|
||||||
|
MWWorld::Class::get (ptr).getNpcStats (ptr).mSkill[mIndex].
|
||||||
|
getModified();
|
||||||
|
|
||||||
|
runtime.push (value);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
class OpSetSkill : public Interpreter::Opcode0
|
||||||
|
{
|
||||||
|
int mIndex;
|
||||||
|
|
||||||
|
public:
|
||||||
|
|
||||||
|
OpSetSkill (int index) : mIndex (index) {}
|
||||||
|
|
||||||
|
virtual void execute (Interpreter::Runtime& runtime)
|
||||||
|
{
|
||||||
|
MWScript::InterpreterContext& context
|
||||||
|
= static_cast<MWScript::InterpreterContext&> (runtime.getContext());
|
||||||
|
|
||||||
|
Interpreter::Type_Integer value = runtime[0].mInteger;
|
||||||
|
runtime.pop();
|
||||||
|
|
||||||
|
MWWorld::Ptr ptr = context.getReference();
|
||||||
|
|
||||||
|
MWWorld::Class::get (ptr).getNpcStats (ptr).mSkill[mIndex].
|
||||||
|
setModified (value, 0);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
class OpSetSkillExplicit : public Interpreter::Opcode0
|
||||||
|
{
|
||||||
|
int mIndex;
|
||||||
|
|
||||||
|
public:
|
||||||
|
|
||||||
|
OpSetSkillExplicit (int index) : mIndex (index) {}
|
||||||
|
|
||||||
|
virtual void execute (Interpreter::Runtime& runtime)
|
||||||
|
{
|
||||||
|
MWScript::InterpreterContext& context
|
||||||
|
= static_cast<MWScript::InterpreterContext&> (runtime.getContext());
|
||||||
|
|
||||||
|
std::string id = runtime.getStringLiteral (runtime[0].mInteger);
|
||||||
|
runtime.pop();
|
||||||
|
|
||||||
|
Interpreter::Type_Integer value = runtime[0].mInteger;
|
||||||
|
runtime.pop();
|
||||||
|
|
||||||
|
MWWorld::Ptr ptr = context.getWorld().getPtr (id, false);
|
||||||
|
|
||||||
|
MWWorld::Class::get (ptr).getNpcStats (ptr).mSkill[mIndex].
|
||||||
|
setModified (value, 0);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
class OpModSkill : public Interpreter::Opcode0
|
||||||
|
{
|
||||||
|
int mIndex;
|
||||||
|
|
||||||
|
public:
|
||||||
|
|
||||||
|
OpModSkill (int index) : mIndex (index) {}
|
||||||
|
|
||||||
|
virtual void execute (Interpreter::Runtime& runtime)
|
||||||
|
{
|
||||||
|
MWScript::InterpreterContext& context
|
||||||
|
= static_cast<MWScript::InterpreterContext&> (runtime.getContext());
|
||||||
|
|
||||||
|
Interpreter::Type_Integer value = runtime[0].mInteger;
|
||||||
|
runtime.pop();
|
||||||
|
|
||||||
|
MWWorld::Ptr ptr = context.getReference();
|
||||||
|
|
||||||
|
value += MWWorld::Class::get (ptr).getNpcStats (ptr).mSkill[mIndex].
|
||||||
|
getModified();
|
||||||
|
|
||||||
|
MWWorld::Class::get (ptr).getNpcStats (ptr).mSkill[mIndex].
|
||||||
|
setModified (value, 0, 100);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
class OpModSkillExplicit : public Interpreter::Opcode0
|
||||||
|
{
|
||||||
|
int mIndex;
|
||||||
|
|
||||||
|
public:
|
||||||
|
|
||||||
|
OpModSkillExplicit (int index) : mIndex (index) {}
|
||||||
|
|
||||||
|
virtual void execute (Interpreter::Runtime& runtime)
|
||||||
|
{
|
||||||
|
MWScript::InterpreterContext& context
|
||||||
|
= static_cast<MWScript::InterpreterContext&> (runtime.getContext());
|
||||||
|
|
||||||
|
std::string id = runtime.getStringLiteral (runtime[0].mInteger);
|
||||||
|
runtime.pop();
|
||||||
|
|
||||||
|
Interpreter::Type_Integer value = runtime[0].mInteger;
|
||||||
|
runtime.pop();
|
||||||
|
|
||||||
|
MWWorld::Ptr ptr = context.getWorld().getPtr (id, false);
|
||||||
|
|
||||||
|
value +=
|
||||||
|
MWWorld::Class::get (ptr).getNpcStats (ptr).mSkill[mIndex].
|
||||||
|
getModified();
|
||||||
|
|
||||||
|
MWWorld::Class::get (ptr).getNpcStats (ptr).mSkill[mIndex].
|
||||||
|
setModified (value, 0, 100);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
const int numberOfAttributes = 8;
|
const int numberOfAttributes = 8;
|
||||||
|
|
||||||
const int opcodeGetAttribute = 0x2000027;
|
const int opcodeGetAttribute = 0x2000027;
|
||||||
|
@ -490,6 +644,15 @@ namespace MWScript
|
||||||
const int opcodeGetDynamicGetRatio = 0x200006f;
|
const int opcodeGetDynamicGetRatio = 0x200006f;
|
||||||
const int opcodeGetDynamicGetRatioExplicit = 0x2000072;
|
const int opcodeGetDynamicGetRatioExplicit = 0x2000072;
|
||||||
|
|
||||||
|
const int numberOfSkills = 27;
|
||||||
|
|
||||||
|
const int opcodeGetSkill = 0x200008e;
|
||||||
|
const int opcodeGetSkillExplicit = 0x20000a9;
|
||||||
|
const int opcodeSetSkill = 0x20000c4;
|
||||||
|
const int opcodeSetSkillExplicit = 0x20000df;
|
||||||
|
const int opcodeModSkill = 0x20000fa;
|
||||||
|
const int opcodeModSkillExplicit = 0x2000115;
|
||||||
|
|
||||||
void registerExtensions (Compiler::Extensions& extensions)
|
void registerExtensions (Compiler::Extensions& extensions)
|
||||||
{
|
{
|
||||||
static const char *attributes[numberOfAttributes] =
|
static const char *attributes[numberOfAttributes] =
|
||||||
|
@ -503,6 +666,16 @@ namespace MWScript
|
||||||
"health", "magicka", "fatigue"
|
"health", "magicka", "fatigue"
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static const char *skills[numberOfSkills] =
|
||||||
|
{
|
||||||
|
"block", "armorer", "mediumarmor", "heavyarmor", "bluntweapon",
|
||||||
|
"longblade", "axe", "spear", "athletics", "enchant", "destruction",
|
||||||
|
"alteration", "illusion", "conjuration", "mysticism",
|
||||||
|
"restoration", "alchemy", "unarmored", "security", "sneak",
|
||||||
|
"acrobatics", "lightarmor", "shortblade", "marksman",
|
||||||
|
"merchantile", "speechcraft", "handtohand"
|
||||||
|
};
|
||||||
|
|
||||||
std::string get ("get");
|
std::string get ("get");
|
||||||
std::string set ("set");
|
std::string set ("set");
|
||||||
std::string mod ("mod");
|
std::string mod ("mod");
|
||||||
|
@ -537,7 +710,18 @@ namespace MWScript
|
||||||
|
|
||||||
extensions.registerFunction (get + dynamics[i] + getRatio, 'f', "",
|
extensions.registerFunction (get + dynamics[i] + getRatio, 'f', "",
|
||||||
opcodeGetDynamicGetRatio+i, opcodeGetDynamicGetRatioExplicit+i);
|
opcodeGetDynamicGetRatio+i, opcodeGetDynamicGetRatioExplicit+i);
|
||||||
|
}
|
||||||
|
|
||||||
|
for (int i=0; i<numberOfSkills; ++i)
|
||||||
|
{
|
||||||
|
extensions.registerFunction (get + skills[i], 'l', "",
|
||||||
|
opcodeGetSkill+i, opcodeGetSkillExplicit+i);
|
||||||
|
|
||||||
|
extensions.registerInstruction (set + skills[i], "l",
|
||||||
|
opcodeSetSkill+i, opcodeSetSkillExplicit+i);
|
||||||
|
|
||||||
|
extensions.registerInstruction (mod + skills[i], "l",
|
||||||
|
opcodeModSkill+i, opcodeModSkillExplicit+i);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -581,6 +765,18 @@ namespace MWScript
|
||||||
interpreter.installSegment5 (opcodeGetDynamicGetRatioExplicit+i,
|
interpreter.installSegment5 (opcodeGetDynamicGetRatioExplicit+i,
|
||||||
new OpGetDynamicGetRatioExplicit (i));
|
new OpGetDynamicGetRatioExplicit (i));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
for (int i=0; i<numberOfSkills; ++i)
|
||||||
|
{
|
||||||
|
interpreter.installSegment5 (opcodeGetSkill+i, new OpGetSkill (i));
|
||||||
|
interpreter.installSegment5 (opcodeGetSkillExplicit+i, new OpGetSkillExplicit (i));
|
||||||
|
|
||||||
|
interpreter.installSegment5 (opcodeSetSkill+i, new OpSetSkill (i));
|
||||||
|
interpreter.installSegment5 (opcodeSetSkillExplicit+i, new OpSetSkillExplicit (i));
|
||||||
|
|
||||||
|
interpreter.installSegment5 (opcodeModSkill+i, new OpModSkill (i));
|
||||||
|
interpreter.installSegment5 (opcodeModSkillExplicit+i, new OpModSkillExplicit (i));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue