PRC8/nwn/nwnprc/trunk/include/shd_inc_metashd.nss
Jaysyn904 6ec137a24e Updated AMS marker feats
Updated AMS marker feats.  Removed arcane & divine marker feats.  Updated Dread Necromancer for epic progression. Updated weapon baseitem models.  Updated new weapons for crafting & npc equip.
 Updated prefix.  Updated release archive.
2024-02-11 14:01:05 -05:00

237 lines
8.0 KiB
Plaintext

//::///////////////////////////////////////////////
//:: Shadowcasting include: Metashadow
//:: shd_inc_metashd
//::///////////////////////////////////////////////
/** @file
Defines functions for handling metashadows
@author Stratovarius
@date Created - 2019.2.7
@thanks to Ornedan for his work on Psionics upon which this is based.
*/
//:://////////////////////////////////////////////
//:://////////////////////////////////////////////
#include "shd_myst_const"
//////////////////////////////////////////////////
/* Constants */
//////////////////////////////////////////////////
/// No metashadows
const int METASHADOW_NONE = 0x0;
/// Quicken mystery
const int METASHADOW_QUICKEN = 0x2;
/// Empower mystery
const int METASHADOW_EMPOWER = 0x4;
/// Extend mystery
const int METASHADOW_EXTEND = 0x8;
/// Maximize mystery
const int METASHADOW_MAXIMIZE = 0x16;
/// Maximize mystery
const int METASHADOW_STILL = 0x32;
/// Internal constant. Value is equal to the lowest metashadow constant. Used when looping over metashadow flag variables
const int METASHADOW_MIN = 0x2;
/// Internal constant. Value is equal to the highest metashadow constant. Used when looping over metashadow flag variables
const int METASHADOW_MAX = 0x32;
/// Empower Mystery variable name
const string METASHADOW_EMPOWER_VAR = "PRC_ShadMeta_Empower";
/// Extend Mystery variable name
const string METASHADOW_EXTEND_VAR = "PRC_ShadMeta_Extend";
/// Quicken Mystery variable name
const string METASHADOW_QUICKEN_VAR = "PRC_ShadMeta_Quicken";
/// Maximize Mystery variable name
const string METASHADOW_MAXIMIZE_VAR = "PRC_ShadMeta_Maximize";
/// Still Mystery variable name
const string METASHADOW_STILL_VAR = "PRC_ShadMeta_Still";
/// The name of a marker variable that tells that the Mystery being shadowcast had Quicken Mystery used on it
const string PRC_MYSTERY_IS_QUICKENED = "PRC_MysteryIsQuickened";
//////////////////////////////////////////////////
/* Structures */
//////////////////////////////////////////////////
/**
* A structure that contains common data used during mystery.
*/
struct mystery{
/* Generic stuff */
/// The creature Shadowcasting the Mystery
object oShadow;
/// Whether the mystery is successful or not
int bCanMyst;
/// The creature's shadowcaster level in regards to this mystery
int nShadowcasterLevel;
/// The mystery's spell ID
int nMystId;
/// Used to mark mysteries that have gone supernatural
int bIgnoreSR;
/* Metashadows */
/// Whether Empower mystery was used with this mystery
int bEmpower;
/// Whether Extend mystery was used with this mystery
int bExtend;
/// Whether Quicken mystery was used with this mystery
int bQuicken;
/// Whether Maximize mystery was used with this mystery
int bMaximize;
/// Whether Still mystery was used with this mystery
int bStill;
/* Speak Unto the Masses */
// Check if the target is a friend of not
int bFriend;
// Saving Throw DC
int nSaveDC;
// Saving Throw
int nSaveThrow;
// Saving Throw Type
int nSaveType;
// Spell Pen
int nPen;
// Duration Effects
effect eLink;
// Impact Effects
effect eLink2;
// Any Item Property
itemproperty ipIProp1;
// Any Item Property
itemproperty ipIProp2;
// Any Item Property
itemproperty ipIProp3;
// Duration
float fDur;
};
//////////////////////////////////////////////////
/* Function prototypes */
//////////////////////////////////////////////////
/**
* Determines the metashadows used in this mystery of a mystery
* and the cost added by their use.
*
* @param myst The mystery data related to this particular mystery
* @param nMetaMystFlags An integer containing a set of bitflags that determine
* which metashadow mysterys may be used with the Mystery being shadowcast
*
* @return The mystery data, modified to account for the metashadows
*/
struct mystery EvaluateMetashadows(struct mystery myst, int nMetaMystFlags);
/**
* Calculates a mystery's damage based on the given dice and metashadows.
*
* @param nDieSize Size of the dice to use
* @param nNumberOfDice Amount of dice to roll
* @param nBonus A bonus amount of damage to add into the total once
* @param nBonusPerDie A bonus amount of damage to add into the total for each die rolled
* @param bDoesHPDamage Whether the Mystery deals hit point damage, or some other form of point damage
* @param bIsRayOrRangedTouch Whether the mystery's use involves a ranged touch attack roll or not
* @return The amount of damage the Mystery should deal
*/
int MetashadowsDamage(struct mystery myst, int nDieSize, int nNumberOfDice, int nBonus = 0,
int nBonusPerDie = 0, int bDoesHPDamage = FALSE, int bIsRayOrRangedTouch = FALSE);
//////////////////////////////////////////////////
/* Includes */
//////////////////////////////////////////////////
#include "inc_utility"
//////////////////////////////////////////////////
/* Internal functions */
//////////////////////////////////////////////////
//////////////////////////////////////////////////
/* Function definitions */
//////////////////////////////////////////////////
struct mystery EvaluateMetashadows(struct mystery myst, int nMetaMystFlags)
{
// Quicken Mystery - special handling
if(GetLocalInt(myst.oShadow, PRC_MYSTERY_IS_QUICKENED))
{
// Mark the mystery as quickened here
myst.bQuicken = TRUE;
// Delete the marker var
DeleteLocalInt(myst.oShadow, PRC_MYSTERY_IS_QUICKENED);
}
if((nMetaMystFlags & METASHADOW_EMPOWER) && (GetLocalInt(myst.oShadow, METASHADOW_EMPOWER_VAR) || GetLocalInt(myst.oShadow, "FloodShadow")))
{
// Mark the mystery as empowered here
myst.bEmpower = TRUE;
// Then clear the variable
DeleteLocalInt(myst.oShadow, METASHADOW_EMPOWER_VAR);
}
if((nMetaMystFlags & METASHADOW_EXTEND) && GetLocalInt(myst.oShadow, METASHADOW_EXTEND_VAR))
{
// Mark the mystery as extended here
myst.bExtend = TRUE;
// Then clear the variable
DeleteLocalInt(myst.oShadow, METASHADOW_EXTEND_VAR);
}
if((nMetaMystFlags & METASHADOW_MAXIMIZE) && GetLocalInt(myst.oShadow, METASHADOW_MAXIMIZE_VAR))
{
// Mark the mystery as maximized here
myst.bMaximize = TRUE;
// Then clear the variable
DeleteLocalInt(myst.oShadow, METASHADOW_MAXIMIZE_VAR);
}
return myst;
}
int MetashadowsDamage(struct mystery myst, int nDieSize, int nNumberOfDice, int nBonus = 0,
int nBonusPerDie = 0, int bDoesHPDamage = FALSE, int bIsRayOrRangedTouch = FALSE)
{
int nBaseDamage = 0,
nBonusDamage = nBonus + (nNumberOfDice * nBonusPerDie);
// Calculate the base damage
int i;
for (i = 0; i < nNumberOfDice; i++)
nBaseDamage += Random(nDieSize) + 1;
// Apply general modifying effects
if(bDoesHPDamage)
{
if(bIsRayOrRangedTouch)
{
// Anything that affects Ray Mysterys goes here
}
}
// Apply metashadows
// Both empower & maximize
if(myst.bEmpower && myst.bMaximize)
{
nBaseDamage = nBaseDamage / 2 + nDieSize * nNumberOfDice;
if(DEBUG) DoDebug("MetashadowsDamage(): Empower + Max");
}
// Just empower
else if(myst.bEmpower)
{
nBaseDamage += nBaseDamage / 2;
if(DEBUG) DoDebug("MetashadowsDamage(): Empower only");
}
// Just maximize
else if(myst.bMaximize)
{
nBaseDamage = nDieSize * nNumberOfDice;
if(DEBUG) DoDebug("MetashadowsDamage(): Max only");
}
return nBaseDamage + nBonusDamage;
}
// Test main
//void main(){}