Added "removed" folder
This commit is contained in:
215
_removed/nw_s2_wildshape.nss
Normal file
215
_removed/nw_s2_wildshape.nss
Normal file
@@ -0,0 +1,215 @@
|
||||
//::///////////////////////////////////////////////
|
||||
//:: Wild Shape
|
||||
//:: NW_S2_WildShape
|
||||
//:: Copyright (c) 2001 Bioware Corp.
|
||||
//:://////////////////////////////////////////////
|
||||
/*
|
||||
Allows the Druid to change into animal forms.
|
||||
|
||||
Updated: Sept 30 2003, Georg Z.
|
||||
* Made Armor merge with druid to make forms
|
||||
more useful.
|
||||
|
||||
*/
|
||||
//:://////////////////////////////////////////////
|
||||
//:: Created By: Preston Watamaniuk
|
||||
//:: Created On: Jan 22, 2002
|
||||
//:://////////////////////////////////////////////
|
||||
//:: Modified By: Deva Winblood
|
||||
//:: Modified Date: January 15th-16th, 2008
|
||||
//:://////////////////////////////////////////////
|
||||
/*
|
||||
Modified to insure no shapeshifting spells are castable upon
|
||||
mounted targets. This prevents problems that can occur due
|
||||
to dismounting after shape shifting, or other issues that can
|
||||
occur due to preserved appearances getting out of synch.
|
||||
|
||||
This can additional check can be disabled by setting the variable
|
||||
X3_NO_SHAPESHIFT_SPELL_CHECK to 1 on the module object. If this
|
||||
variable is set then this script will function as it did prior to
|
||||
this modification.
|
||||
|
||||
Patch 1.70
|
||||
|
||||
- allowed to merge any custom non-weapon in left hand slot such as flags or
|
||||
musical instruments
|
||||
- added optional feature to stack ability bonuses from multiple items together
|
||||
- added optional feature to merge bracers (when items are allowed to merge)
|
||||
- cured from horse include while retaining the shapeshifting horse check
|
||||
- fixed dying when unpolymorphed as an result of sudden constitution bonus drop
|
||||
which also could result to the server crash
|
||||
*/
|
||||
|
||||
#include "70_inc_itemprop"
|
||||
#include "x2_inc_itemprop"
|
||||
|
||||
void main()
|
||||
{
|
||||
//Declare major variables
|
||||
int nSpell = GetSpellId();
|
||||
object oTarget = GetSpellTargetObject();
|
||||
effect eVis = EffectVisualEffect(VFX_IMP_POLYMORPH);
|
||||
effect ePoly;
|
||||
int nPoly;
|
||||
int nMetaMagic = GetMetaMagicFeat();
|
||||
int nDuration = GetLevelByClass(CLASS_TYPE_DRUID);
|
||||
if (!GetLocalInt(GetModule(),"X3_NO_SHAPESHIFT_SPELL_CHECK"))
|
||||
{ // check to see if abort due to being mounted
|
||||
switch(GetPhenoType(oTarget))
|
||||
{// shape shifting not allowed while mounted
|
||||
case 3:
|
||||
case 5:
|
||||
case 6:
|
||||
case 8:
|
||||
if(GetIsPC(oTarget))
|
||||
{
|
||||
FloatingTextStrRefOnCreature(111982,oTarget,FALSE);
|
||||
}
|
||||
// shape shifting not allowed while mounted
|
||||
return;
|
||||
}
|
||||
} // check to see if abort due to being mounted
|
||||
//Enter Metamagic conditions
|
||||
if (nMetaMagic == METAMAGIC_EXTEND)
|
||||
{
|
||||
nDuration = nDuration *2; //Duration is +100%
|
||||
}
|
||||
|
||||
//Determine Polymorph subradial type
|
||||
if(nSpell == 401)
|
||||
{
|
||||
nPoly = POLYMORPH_TYPE_BROWN_BEAR;
|
||||
if (nDuration >= 12)
|
||||
{
|
||||
nPoly = POLYMORPH_TYPE_DIRE_BROWN_BEAR;
|
||||
}
|
||||
}
|
||||
else if (nSpell == 402)
|
||||
{
|
||||
nPoly = POLYMORPH_TYPE_PANTHER;
|
||||
if (nDuration >= 12)
|
||||
{
|
||||
nPoly = POLYMORPH_TYPE_DIRE_PANTHER;
|
||||
}
|
||||
}
|
||||
else if (nSpell == 403)
|
||||
{
|
||||
nPoly = POLYMORPH_TYPE_WOLF;
|
||||
|
||||
if (nDuration >= 12)
|
||||
{
|
||||
nPoly = POLYMORPH_TYPE_DIRE_WOLF;
|
||||
}
|
||||
}
|
||||
else if (nSpell == 404)
|
||||
{
|
||||
nPoly = POLYMORPH_TYPE_BOAR;
|
||||
if (nDuration >= 12)
|
||||
{
|
||||
nPoly = POLYMORPH_TYPE_DIRE_BOAR;
|
||||
}
|
||||
}
|
||||
else if (nSpell == 405)
|
||||
{
|
||||
nPoly = POLYMORPH_TYPE_BADGER;
|
||||
if (nDuration >= 12)
|
||||
{
|
||||
nPoly = POLYMORPH_TYPE_DIRE_BADGER;
|
||||
}
|
||||
}
|
||||
//Fire cast spell at event for the specified target
|
||||
SignalEvent(oTarget, EventSpellCastAt(OBJECT_SELF, SPELLABILITY_WILD_SHAPE, FALSE));
|
||||
|
||||
int bWeapon = StringToInt(Get2DAString("polymorph","MergeW",nPoly)) == 1;
|
||||
int bArmor = StringToInt(Get2DAString("polymorph","MergeA",nPoly)) == 1;
|
||||
int bItems = StringToInt(Get2DAString("polymorph","MergeI",nPoly)) == 1;
|
||||
int bArms = bItems && GetLocalInt(GetModule(),"71_POLYMORPH_MERGE_ARMS");
|
||||
|
||||
object oWeaponOld = GetItemInSlot(INVENTORY_SLOT_RIGHTHAND,OBJECT_SELF);
|
||||
object oArmorOld = GetItemInSlot(INVENTORY_SLOT_CHEST,OBJECT_SELF);
|
||||
object oRing1Old = GetItemInSlot(INVENTORY_SLOT_LEFTRING,OBJECT_SELF);
|
||||
object oRing2Old = GetItemInSlot(INVENTORY_SLOT_RIGHTRING,OBJECT_SELF);
|
||||
object oAmuletOld = GetItemInSlot(INVENTORY_SLOT_NECK,OBJECT_SELF);
|
||||
object oCloakOld = GetItemInSlot(INVENTORY_SLOT_CLOAK,OBJECT_SELF);
|
||||
object oBootsOld = GetItemInSlot(INVENTORY_SLOT_BOOTS,OBJECT_SELF);
|
||||
object oBeltOld = GetItemInSlot(INVENTORY_SLOT_BELT,OBJECT_SELF);
|
||||
object oArmsOld = GetItemInSlot(INVENTORY_SLOT_ARMS,OBJECT_SELF);
|
||||
object oHelmetOld = GetItemInSlot(INVENTORY_SLOT_HEAD,OBJECT_SELF);
|
||||
object oShield = GetItemInSlot(INVENTORY_SLOT_LEFTHAND,OBJECT_SELF);
|
||||
|
||||
if (GetIsObjectValid(oShield))
|
||||
{ //1.71: this is now custom content compatible, polymorph will merge custom left-hand only items such as flags
|
||||
if (GetWeaponRanged(oShield) || IPGetIsMeleeWeapon(oShield))
|
||||
{
|
||||
oShield = OBJECT_INVALID;
|
||||
}
|
||||
}
|
||||
int nConBonus;
|
||||
if (bWeapon)
|
||||
{
|
||||
nConBonus = IPGetBestConBonus(nConBonus,oWeaponOld);
|
||||
}
|
||||
if (bArmor)
|
||||
{
|
||||
nConBonus = IPGetBestConBonus(nConBonus,oArmorOld);
|
||||
nConBonus = IPGetBestConBonus(nConBonus,oHelmetOld);
|
||||
nConBonus = IPGetBestConBonus(nConBonus,oShield);
|
||||
}
|
||||
if (bItems)
|
||||
{
|
||||
nConBonus = IPGetBestConBonus(nConBonus,oRing1Old);
|
||||
nConBonus = IPGetBestConBonus(nConBonus,oRing2Old);
|
||||
nConBonus = IPGetBestConBonus(nConBonus,oAmuletOld);
|
||||
nConBonus = IPGetBestConBonus(nConBonus,oCloakOld);
|
||||
nConBonus = IPGetBestConBonus(nConBonus,oBeltOld);
|
||||
nConBonus = IPGetBestConBonus(nConBonus,oBootsOld);
|
||||
}
|
||||
if (bArms)
|
||||
{
|
||||
nConBonus = IPGetBestConBonus(nConBonus,oArmsOld);
|
||||
}
|
||||
|
||||
//Apply the VFX impact and effects
|
||||
ePoly = EffectPolymorph(nPoly);
|
||||
if (nSpell == 402 && nDuration >= 12) ePoly = EffectLinkEffects(EffectMovementSpeedIncrease(50), ePoly); //A little extra for druids in dire panther form :)
|
||||
if(nConBonus > 0)
|
||||
{//1.70: this fixes dying when unpolymorphed issue as well as server crash related to this
|
||||
ePoly = EffectLinkEffects(ePoly,EffectAbilityIncrease(ABILITY_CONSTITUTION,nConBonus));
|
||||
}
|
||||
ePoly = ExtraordinaryEffect(ePoly);
|
||||
|
||||
ClearAllActions(); // prevents an exploit
|
||||
ApplyEffectToObject(DURATION_TYPE_INSTANT, eVis, OBJECT_SELF);
|
||||
ApplyEffectToObject(DURATION_TYPE_TEMPORARY, ePoly, OBJECT_SELF, HoursToSeconds(nDuration));
|
||||
|
||||
object oWeaponNew = GetItemInSlot(INVENTORY_SLOT_RIGHTHAND,OBJECT_SELF);
|
||||
object oArmorNew = GetItemInSlot(INVENTORY_SLOT_CARMOUR,OBJECT_SELF);
|
||||
|
||||
if (bWeapon)
|
||||
{
|
||||
IPWildShapeCopyItemProperties(oWeaponOld,oWeaponNew, TRUE);
|
||||
}
|
||||
if (bArmor)
|
||||
{
|
||||
IPWildShapeCopyItemProperties(oShield,oArmorNew);
|
||||
IPWildShapeCopyItemProperties(oHelmetOld,oArmorNew);
|
||||
IPWildShapeCopyItemProperties(oArmorOld,oArmorNew);
|
||||
}
|
||||
if (bItems)
|
||||
{
|
||||
IPWildShapeCopyItemProperties(oRing1Old,oArmorNew);
|
||||
IPWildShapeCopyItemProperties(oRing2Old,oArmorNew);
|
||||
IPWildShapeCopyItemProperties(oAmuletOld,oArmorNew);
|
||||
IPWildShapeCopyItemProperties(oCloakOld,oArmorNew);
|
||||
IPWildShapeCopyItemProperties(oBootsOld,oArmorNew);
|
||||
IPWildShapeCopyItemProperties(oBeltOld,oArmorNew);
|
||||
}
|
||||
if (bArms)
|
||||
{
|
||||
IPWildShapeCopyItemProperties(oArmsOld,oArmorNew);
|
||||
}
|
||||
if (GetLocalInt(GetModule(),"71_POLYMORPH_STACK_ABILITY_BONUSES"))
|
||||
{
|
||||
IPWildShapeStackAbilityBonuses(oArmorNew);
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user