Initial Commit
Initial Commit
This commit is contained in:
68
_module/nss/craft_plus2d4.nss
Normal file
68
_module/nss/craft_plus2d4.nss
Normal file
@@ -0,0 +1,68 @@
|
||||
#include "x2_inc_itemprop"
|
||||
void main()
|
||||
{
|
||||
object oPC = GetPCSpeaker();
|
||||
//Place any items in the main hand or the off-hand in the inventory
|
||||
object oCopied;
|
||||
int nCursed;
|
||||
if (GetItemInSlot(INVENTORY_SLOT_LEFTHAND, oPC) != OBJECT_INVALID)
|
||||
{
|
||||
nCursed = GetItemCursedFlag(GetItemInSlot(INVENTORY_SLOT_LEFTHAND, oPC));
|
||||
oCopied = CopyItem(GetItemInSlot(INVENTORY_SLOT_LEFTHAND, oPC), oPC, TRUE);
|
||||
if (oCopied != OBJECT_INVALID) DestroyObject(GetItemInSlot(INVENTORY_SLOT_LEFTHAND, oPC));
|
||||
if (nCursed == TRUE) SetItemCursedFlag(oCopied, TRUE);
|
||||
nCursed = FALSE;
|
||||
}
|
||||
if (GetItemInSlot(INVENTORY_SLOT_RIGHTHAND, oPC) != OBJECT_INVALID)
|
||||
{
|
||||
nCursed = GetItemCursedFlag(GetItemInSlot(INVENTORY_SLOT_RIGHTHAND, oPC));
|
||||
oCopied = CopyItem(GetItemInSlot(INVENTORY_SLOT_RIGHTHAND, oPC), oPC, TRUE);
|
||||
if (oCopied != OBJECT_INVALID) DestroyObject(GetItemInSlot(INVENTORY_SLOT_RIGHTHAND, oPC));
|
||||
if (nCursed == TRUE) SetItemCursedFlag(oCopied, TRUE);
|
||||
nCursed = FALSE;
|
||||
}
|
||||
//The end of this chunk of code
|
||||
itemproperty ipAdd;
|
||||
|
||||
object oItem = GetFirstItemInInventory(oPC);
|
||||
while (GetIsObjectValid(oItem))
|
||||
{
|
||||
if (GetLocalInt(oItem, "Prototype") == TRUE)
|
||||
{
|
||||
//If the item is a type of ammunition, we can be sure the property in question is extra damage, so apply the correct property
|
||||
//(which is different than a melee weapon's counterpart)
|
||||
if (GetLocalString(oItem, "Type") == "Ammo")
|
||||
{
|
||||
if (GetLocalString(oPC, "Parameter") == "Acid") ipAdd = ItemPropertyDamageBonus(IP_CONST_DAMAGETYPE_ACID, 167);
|
||||
if (GetLocalString(oPC, "Parameter") == "Divine") ipAdd = ItemPropertyDamageBonus(IP_CONST_DAMAGETYPE_DIVINE, 167);
|
||||
if (GetLocalString(oPC, "Parameter") == "Sonic") ipAdd = ItemPropertyDamageBonus(IP_CONST_DAMAGETYPE_SONIC, 167);
|
||||
if (GetLocalString(oPC, "Parameter") == "Fire") ipAdd = ItemPropertyDamageBonus(IP_CONST_DAMAGETYPE_FIRE, 167);
|
||||
if (GetLocalString(oPC, "Parameter") == "Cold") ipAdd = ItemPropertyDamageBonus(IP_CONST_DAMAGETYPE_COLD, 167);
|
||||
if (GetLocalString(oPC, "Parameter") == "Electrical") ipAdd = ItemPropertyDamageBonus(IP_CONST_DAMAGETYPE_ELECTRICAL, 167);
|
||||
if (GetLocalString(oPC, "Parameter") == "Bludgeoning") ipAdd = ItemPropertyDamageBonus(IP_CONST_DAMAGETYPE_BLUDGEONING, 167);
|
||||
if (GetLocalString(oPC, "Parameter") == "Piercing") ipAdd = ItemPropertyDamageBonus(IP_CONST_DAMAGETYPE_PIERCING, 167);
|
||||
SetLocalInt(oPC, "SubType", GetItemPropertySubType(ipAdd));
|
||||
IPSafeAddItemProperty(oItem, ipAdd);
|
||||
return;
|
||||
}
|
||||
|
||||
//Applying the correct property.
|
||||
if (GetLocalString(oPC, "LastProperty") == "Critical") ipAdd = ItemPropertyMassiveCritical(12);
|
||||
if (GetLocalString(oPC, "LastProperty") == "Damage")
|
||||
{
|
||||
if (GetLocalString(oPC, "Parameter") == "Acid") ipAdd = ItemPropertyDamageBonus(IP_CONST_DAMAGETYPE_ACID, 12);
|
||||
if (GetLocalString(oPC, "Parameter") == "Divine") ipAdd = ItemPropertyDamageBonus(IP_CONST_DAMAGETYPE_DIVINE, 12);
|
||||
if (GetLocalString(oPC, "Parameter") == "Sonic") ipAdd = ItemPropertyDamageBonus(IP_CONST_DAMAGETYPE_SONIC, 12);
|
||||
if (GetLocalString(oPC, "Parameter") == "Fire") ipAdd = ItemPropertyDamageBonus(IP_CONST_DAMAGETYPE_FIRE, 12);
|
||||
if (GetLocalString(oPC, "Parameter") == "Cold") ipAdd = ItemPropertyDamageBonus(IP_CONST_DAMAGETYPE_COLD, 12);
|
||||
if (GetLocalString(oPC, "Parameter") == "Electrical") ipAdd = ItemPropertyDamageBonus(IP_CONST_DAMAGETYPE_ELECTRICAL, 12);
|
||||
SetLocalInt(oPC, "SubType", GetItemPropertySubType(ipAdd));
|
||||
}
|
||||
|
||||
IPSafeAddItemProperty(oItem, ipAdd);
|
||||
|
||||
return;
|
||||
}
|
||||
oItem = GetNextItemInInventory(oPC);
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user