mirror of
https://github.com/ZDoom/qzdoom.git
synced 2025-01-18 15:11:46 +00:00
- Optimized DoDamage and DoKill.
- Do a filter and species check first to save time. - Added DMSS/KILS/RMVF_EITHER, which means if the actor is of type or species, it counts. - A_DamageTarget(20,"Normal",DMSS_EITHER,"DoomImp","CyberdemonSpecies") - This affects actor DoomImp, and anything that's of species CyberdemonSpecies. - Added a little more documentation via comments.
This commit is contained in:
parent
5a472e815b
commit
2c7a3f2eba
2 changed files with 85 additions and 67 deletions
|
@ -5039,44 +5039,51 @@ static bool DoCheckFilter(AActor *mo, const PClass *filter, bool exclude)
|
||||||
//
|
//
|
||||||
// Common A_Damage handler
|
// Common A_Damage handler
|
||||||
//
|
//
|
||||||
// A_Damage* (int amount, str damagetype, int flags)
|
// A_Damage* (int amount, str damagetype, int flags, str filter, str species)
|
||||||
// Damages the specified actor by the specified amount. Negative values heal.
|
// Damages the specified actor by the specified amount. Negative values heal.
|
||||||
|
// Flags: See below.
|
||||||
|
// Filter: Specified actor is the only type allowed to be affected.
|
||||||
|
// Species: Specified species is the only type allowed to be affected.
|
||||||
|
//
|
||||||
|
// Examples:
|
||||||
|
// A_Damage(20,"Normal",DMSS_FOILINVUL,0,"DemonicSpecies") <--Only actors
|
||||||
|
// with a species "DemonicSpecies" will be affected. Use 0 to not filter by actor.
|
||||||
//
|
//
|
||||||
//===========================================================================
|
//===========================================================================
|
||||||
|
|
||||||
enum DMSS
|
enum DMSS
|
||||||
{
|
{
|
||||||
DMSS_FOILINVUL = 1,
|
DMSS_FOILINVUL = 1, //Foil invulnerability
|
||||||
DMSS_AFFECTARMOR = 2,
|
DMSS_AFFECTARMOR = 2, //Make it affect armor
|
||||||
DMSS_KILL = 4,
|
DMSS_KILL = 4, //Damages them for their current health
|
||||||
DMSS_NOFACTOR = 8,
|
DMSS_NOFACTOR = 8, //Ignore DamageFactors
|
||||||
DMSS_FOILBUDDHA = 16,
|
DMSS_FOILBUDDHA = 16, //Can kill actors with Buddha flag, except the player.
|
||||||
DMSS_NOPROTECT = 32,
|
DMSS_NOPROTECT = 32, //Ignores PowerProtection entirely
|
||||||
DMSS_EXFILTER = 64,
|
DMSS_EXFILTER = 64, //Changes filter into a blacklisted class instead of whitelisted.
|
||||||
DMSS_EXSPECIES = 128,
|
DMSS_EXSPECIES = 128, // ^ but with species instead.
|
||||||
|
DMSS_EITHER = 256, //Allow either type or species to be affected.
|
||||||
};
|
};
|
||||||
|
|
||||||
static void DoDamage(AActor *dmgtarget, AActor *self, int amount, FName DamageType, int flags, const PClass *filter, FName species)
|
static void DoDamage(AActor *dmgtarget, AActor *self, int amount, FName DamageType, int flags, const PClass *filter, FName species)
|
||||||
{
|
{
|
||||||
int dmgFlags = 0;
|
|
||||||
if (flags & DMSS_FOILINVUL)
|
|
||||||
dmgFlags += DMG_FOILINVUL;
|
|
||||||
if (flags & DMSS_FOILBUDDHA)
|
|
||||||
dmgFlags += DMG_FOILBUDDHA;
|
|
||||||
if ((flags & DMSS_KILL) || (flags & DMSS_NOFACTOR)) //Kill implies NoFactor
|
|
||||||
dmgFlags += DMG_NO_FACTOR;
|
|
||||||
if (!(flags & DMSS_AFFECTARMOR) || (flags & DMSS_KILL)) //Kill overrides AffectArmor
|
|
||||||
dmgFlags += DMG_NO_ARMOR;
|
|
||||||
if (flags & DMSS_KILL) //Kill adds the value of the damage done to it. Allows for more controlled extreme death types.
|
|
||||||
amount += dmgtarget->health;
|
|
||||||
if (flags & DMSS_NOPROTECT) //Ignore PowerProtection.
|
|
||||||
dmgFlags += DMG_NO_PROTECT;
|
|
||||||
|
|
||||||
bool filterpass = DoCheckFilter(dmgtarget, filter, (flags & DMSS_EXFILTER) ? true : false),
|
bool filterpass = DoCheckFilter(dmgtarget, filter, (flags & DMSS_EXFILTER) ? true : false),
|
||||||
speciespass = DoCheckSpecies(dmgtarget, species, (flags & DMSS_EXSPECIES) ? true : false);
|
speciespass = DoCheckSpecies(dmgtarget, species, (flags & DMSS_EXSPECIES) ? true : false);
|
||||||
|
if ((flags & DMSS_EITHER) ? (filterpass || speciespass) : (filterpass && speciespass))
|
||||||
if (filterpass && speciespass)
|
|
||||||
{
|
{
|
||||||
|
int dmgFlags = 0;
|
||||||
|
if (flags & DMSS_FOILINVUL)
|
||||||
|
dmgFlags += DMG_FOILINVUL;
|
||||||
|
if (flags & DMSS_FOILBUDDHA)
|
||||||
|
dmgFlags += DMG_FOILBUDDHA;
|
||||||
|
if ((flags & DMSS_KILL) || (flags & DMSS_NOFACTOR)) //Kill implies NoFactor
|
||||||
|
dmgFlags += DMG_NO_FACTOR;
|
||||||
|
if (!(flags & DMSS_AFFECTARMOR) || (flags & DMSS_KILL)) //Kill overrides AffectArmor
|
||||||
|
dmgFlags += DMG_NO_ARMOR;
|
||||||
|
if (flags & DMSS_KILL) //Kill adds the value of the damage done to it. Allows for more controlled extreme death types.
|
||||||
|
amount += dmgtarget->health;
|
||||||
|
if (flags & DMSS_NOPROTECT) //Ignore PowerProtection.
|
||||||
|
dmgFlags += DMG_NO_PROTECT;
|
||||||
|
|
||||||
if (amount > 0)
|
if (amount > 0)
|
||||||
P_DamageMobj(dmgtarget, self, self, amount, DamageType, dmgFlags); //Should wind up passing them through just fine.
|
P_DamageMobj(dmgtarget, self, self, amount, DamageType, dmgFlags); //Should wind up passing them through just fine.
|
||||||
|
|
||||||
|
@ -5228,27 +5235,29 @@ DEFINE_ACTION_FUNCTION_PARAMS(AActor, A_DamageSiblings)
|
||||||
//===========================================================================
|
//===========================================================================
|
||||||
enum KILS
|
enum KILS
|
||||||
{
|
{
|
||||||
KILS_FOILINVUL = 1 << 0,
|
KILS_FOILINVUL = 1 << 0,
|
||||||
KILS_KILLMISSILES = 1 << 1,
|
KILS_KILLMISSILES = 1 << 1,
|
||||||
KILS_NOMONSTERS = 1 << 2,
|
KILS_NOMONSTERS = 1 << 2,
|
||||||
KILS_FOILBUDDHA = 1 << 3,
|
KILS_FOILBUDDHA = 1 << 3,
|
||||||
KILS_EXFILTER = 1 << 4,
|
KILS_EXFILTER = 1 << 4,
|
||||||
KILS_EXSPECIES = 1 << 5,
|
KILS_EXSPECIES = 1 << 5,
|
||||||
|
KILS_EITHER = 1 << 6,
|
||||||
};
|
};
|
||||||
|
|
||||||
static void DoKill(AActor *killtarget, AActor *self, FName damagetype, int flags, const PClass *filter, FName species)
|
static void DoKill(AActor *killtarget, AActor *self, FName damagetype, int flags, const PClass *filter, FName species)
|
||||||
{
|
{
|
||||||
int dmgFlags = DMG_NO_ARMOR + DMG_NO_FACTOR;
|
|
||||||
|
|
||||||
if (KILS_FOILINVUL)
|
|
||||||
dmgFlags += DMG_FOILINVUL;
|
|
||||||
if (KILS_FOILBUDDHA)
|
|
||||||
dmgFlags += DMG_FOILBUDDHA;
|
|
||||||
|
|
||||||
bool filterpass = DoCheckFilter(killtarget, filter, (flags & KILS_EXFILTER) ? true : false),
|
bool filterpass = DoCheckFilter(killtarget, filter, (flags & KILS_EXFILTER) ? true : false),
|
||||||
speciespass = DoCheckSpecies(killtarget, species, (flags & KILS_EXSPECIES) ? true : false);
|
speciespass = DoCheckSpecies(killtarget, species, (flags & KILS_EXSPECIES) ? true : false);
|
||||||
if (filterpass && speciespass) //Check this first. I think it'll save the engine a lot more time this way.
|
if ((flags & KILS_EITHER) ? (filterpass || speciespass) : (filterpass && speciespass)) //Check this first. I think it'll save the engine a lot more time this way.
|
||||||
{
|
{
|
||||||
|
int dmgFlags = DMG_NO_ARMOR + DMG_NO_FACTOR;
|
||||||
|
|
||||||
|
if (KILS_FOILINVUL)
|
||||||
|
dmgFlags += DMG_FOILINVUL;
|
||||||
|
if (KILS_FOILBUDDHA)
|
||||||
|
dmgFlags += DMG_FOILBUDDHA;
|
||||||
|
|
||||||
|
|
||||||
if ((killtarget->flags & MF_MISSILE) && (flags & KILS_KILLMISSILES))
|
if ((killtarget->flags & MF_MISSILE) && (flags & KILS_KILLMISSILES))
|
||||||
{
|
{
|
||||||
//[MC] Now that missiles can set masters, lets put in a check to properly destroy projectiles. BUT FIRST! New feature~!
|
//[MC] Now that missiles can set masters, lets put in a check to properly destroy projectiles. BUT FIRST! New feature~!
|
||||||
|
@ -5386,19 +5395,20 @@ DEFINE_ACTION_FUNCTION_PARAMS(AActor, A_KillSiblings)
|
||||||
|
|
||||||
enum RMVF_flags
|
enum RMVF_flags
|
||||||
{
|
{
|
||||||
RMVF_MISSILES = 1 << 0,
|
RMVF_MISSILES = 1 << 0,
|
||||||
RMVF_NOMONSTERS = 1 << 1,
|
RMVF_NOMONSTERS = 1 << 1,
|
||||||
RMVF_MISC = 1 << 2,
|
RMVF_MISC = 1 << 2,
|
||||||
RMVF_EVERYTHING = 1 << 3,
|
RMVF_EVERYTHING = 1 << 3,
|
||||||
RMVF_EXFILTER = 1 << 4,
|
RMVF_EXFILTER = 1 << 4,
|
||||||
RMVF_EXSPECIES = 1 << 5,
|
RMVF_EXSPECIES = 1 << 5,
|
||||||
|
RMVF_EITHER = 1 << 6,
|
||||||
};
|
};
|
||||||
|
|
||||||
static void DoRemove(AActor *removetarget, int flags, const PClass *filter, FName species)
|
static void DoRemove(AActor *removetarget, int flags, const PClass *filter, FName species)
|
||||||
{
|
{
|
||||||
bool filterpass = DoCheckFilter(removetarget, filter, (flags & RMVF_EXFILTER) ? true : false),
|
bool filterpass = DoCheckFilter(removetarget, filter, (flags & RMVF_EXFILTER) ? true : false),
|
||||||
speciespass = DoCheckSpecies(removetarget, species, (flags & RMVF_EXSPECIES) ? true : false);
|
speciespass = DoCheckSpecies(removetarget, species, (flags & RMVF_EXSPECIES) ? true : false);
|
||||||
if (filterpass && speciespass)
|
if ((flags & RMVF_EITHER) ? (filterpass || speciespass) : (filterpass && speciespass))
|
||||||
{
|
{
|
||||||
if ((flags & RMVF_EVERYTHING))
|
if ((flags & RMVF_EVERYTHING))
|
||||||
{
|
{
|
||||||
|
|
|
@ -396,23 +396,30 @@ enum
|
||||||
};
|
};
|
||||||
|
|
||||||
// Flags for A_Kill (Master/Target/Tracer/Children/Siblings) series
|
// Flags for A_Kill (Master/Target/Tracer/Children/Siblings) series
|
||||||
|
enum
|
||||||
const int KILS_FOILINVUL = 1;
|
{
|
||||||
const int KILS_KILLMISSILES = 2;
|
KILS_FOILINVUL = 0x00000001,
|
||||||
const int KILS_NOMONSTERS = 4;
|
KILS_KILLMISSILES = 0x00000002,
|
||||||
const int KILS_FOILBUDDHA = 8;
|
KILS_NOMONSTERS = 0x00000004,
|
||||||
const int KILS_EXFILTER = 16;
|
KILS_FOILBUDDHA = 0x00000008,
|
||||||
const int KILS_EXSPECIES = 32;
|
KILS_EXFILTER = 0x00000010,
|
||||||
|
KILS_EXSPECIES = 0x00000020,
|
||||||
|
KILS_EITHER = 0x00000040,
|
||||||
|
};
|
||||||
|
|
||||||
// Flags for A_Damage (Master/Target/Tracer/Children/Siblings/Self) series
|
// Flags for A_Damage (Master/Target/Tracer/Children/Siblings/Self) series
|
||||||
const int DMSS_FOILINVUL = 1;
|
enum
|
||||||
const int DMSS_AFFECTARMOR = 2;
|
{
|
||||||
const int DMSS_KILL = 4;
|
DMSS_FOILINVUL = 0x00000001,
|
||||||
const int DMSS_NOFACTOR = 8;
|
DMSS_AFFECTARMOR = 0x00000002,
|
||||||
const int DMSS_FOILBUDDHA = 16;
|
DMSS_KILL = 0x00000004,
|
||||||
const int DMSS_NOPROTECT = 32;
|
DMSS_NOFACTOR = 0x00000008,
|
||||||
const int DMSS_EXFILTER = 64;
|
DMSS_FOILBUDDHA = 0x00000010,
|
||||||
const int DMSS_EXSPECIES = 128;
|
DMSS_NOPROTECT = 0x00000020,
|
||||||
|
DMSS_EXFILTER = 0x00000040,
|
||||||
|
DMSS_EXSPECIES = 0x00000080,
|
||||||
|
DMSS_EITHER = 0x00000100,
|
||||||
|
};
|
||||||
|
|
||||||
// Flags for A_AlertMonsters
|
// Flags for A_AlertMonsters
|
||||||
const int AMF_TARGETEMITTER = 1;
|
const int AMF_TARGETEMITTER = 1;
|
||||||
|
@ -422,12 +429,13 @@ const int AMF_EMITFROMTARGET = 4;
|
||||||
// Flags for A_Remove*
|
// Flags for A_Remove*
|
||||||
enum
|
enum
|
||||||
{
|
{
|
||||||
RMVF_MISSILES = 1 << 0,
|
RMVF_MISSILES = 0x00000001,
|
||||||
RMVF_NOMONSTERS = 1 << 1,
|
RMVF_NOMONSTERS = 0x00000002,
|
||||||
RMVF_MISC = 1 << 2,
|
RMVF_MISC = 0x00000004,
|
||||||
RMVF_EVERYTHING = 1 << 3,
|
RMVF_EVERYTHING = 0x00000008,
|
||||||
RMVF_EXFILTER = 1 << 4,
|
RMVF_EXFILTER = 0x00000010,
|
||||||
RMVF_EXSPECIES = 1 << 5,
|
RMVF_EXSPECIES = 0x00000020,
|
||||||
|
RMVF_EITHER = 0x00000040,
|
||||||
};
|
};
|
||||||
|
|
||||||
// Flags for A_Fade*
|
// Flags for A_Fade*
|
||||||
|
|
Loading…
Reference in a new issue