mirror of
https://github.com/ZDoom/gzdoom.git
synced 2025-01-08 11:00:58 +00:00
66c663e9d8
partially because the background patch has to be drawn always to overwrite the old display. - Fixed: Giving a health item to a non-player caused a crash. - Added a compatibility option to limit deh.MaxHealth to the health bonus. Originally this value wasn't used for health packs. Doing this was a bug in Boom but since there's quite a few maps out there which require Boom's altered behavior it has to be compatibility optioned. - Fixed: The health bonus's max health must be defined by deh.MaxHealth, not deh.MaxSoulsphere. To achieve this deh.MaxHealth's handling had to be altered because it has to default to 100. - Fixed: ZDBSP created incorrect side references with compressed sidedefs and both sidedefs of a linedef being the same. This only affects the external tool because the internal node builder is run after uncompressing the sidedefs. - Added Jim's latest makefile.linux. - Added a consistency check to the PNAMES loader because one crash log indicated that it crashed due to a corrupt PNAMES lump. - Brought back the sector based sound target handling as a compatibility option. This radical change just broke far too many maps that depend on the original behavior. Strife's special AI functions are excluded though because they work better with the new method. SVN r56 (trunk)
87 lines
2.7 KiB
C++
87 lines
2.7 KiB
C++
#include "actor.h"
|
|
#include "a_action.h"
|
|
#include "a_strifeglobal.h"
|
|
#include "p_enemy.h"
|
|
|
|
void A_WakeOracleSpectre (AActor *);
|
|
|
|
// Oracle -------------------------------------------------------------------
|
|
|
|
FState AOracle::States[] =
|
|
{
|
|
S_NORMAL (ORCL, 'A', -1, NULL, NULL),
|
|
|
|
S_NORMAL (ORCL, 'B', 5, NULL, &States[2]),
|
|
S_NORMAL (ORCL, 'C', 5, NULL, &States[3]),
|
|
S_NORMAL (ORCL, 'D', 5, NULL, &States[4]),
|
|
S_NORMAL (ORCL, 'E', 5, NULL, &States[5]),
|
|
S_NORMAL (ORCL, 'F', 5, NULL, &States[6]),
|
|
S_NORMAL (ORCL, 'G', 5, NULL, &States[7]),
|
|
S_NORMAL (ORCL, 'H', 5, NULL, &States[8]),
|
|
S_NORMAL (ORCL, 'I', 5, NULL, &States[9]),
|
|
S_NORMAL (ORCL, 'J', 5, NULL, &States[10]),
|
|
S_NORMAL (ORCL, 'K', 5, NULL, &States[11]),
|
|
S_NORMAL (ORCL, 'L', 5, A_NoBlocking, &States[12]),
|
|
S_NORMAL (ORCL, 'M', 5, NULL, &States[13]),
|
|
S_NORMAL (ORCL, 'N', 5, A_WakeOracleSpectre, &States[14]),
|
|
S_NORMAL (ORCL, 'O', 5, NULL, &States[15]),
|
|
S_NORMAL (ORCL, 'P', 5, NULL, &States[16]),
|
|
S_NORMAL (ORCL, 'Q', -1, NULL, NULL)
|
|
};
|
|
|
|
IMPLEMENT_ACTOR (AOracle, Strife, 199, 0)
|
|
PROP_StrifeType (65)
|
|
PROP_StrifeTeaserType (62)
|
|
PROP_StrifeTeaserType2 (63)
|
|
PROP_SpawnHealth (1)
|
|
PROP_SpawnState (0)
|
|
PROP_DeathState (1)
|
|
PROP_RadiusFixed (15)
|
|
PROP_HeightFixed (56)
|
|
PROP_Flags (MF_SOLID|MF_SHOOTABLE|MF_NOBLOOD|MF_COUNTKILL|MF_NOTDMATCH)
|
|
PROP_Flags2 (MF2_FLOORCLIP|MF2_PASSMOBJ|MF2_PUSHWALL|MF2_MCROSS)
|
|
PROP_Flags4 (MF4_FIRERESIST)
|
|
PROP_MaxDropOffHeight (32)
|
|
PROP_MinMissileChance (150)
|
|
PROP_Tag ("ORACLE")
|
|
END_DEFAULTS
|
|
|
|
//============================================================================
|
|
//
|
|
// AOracle :: NoBlockingSet
|
|
//
|
|
//============================================================================
|
|
|
|
void AOracle::NoBlockingSet ()
|
|
{
|
|
P_DropItem (this, "Meat", -1, 256);
|
|
}
|
|
|
|
void A_WakeOracleSpectre (AActor *self)
|
|
{
|
|
TThinkerIterator<AAlienSpectre3> it;
|
|
AActor *spectre = it.Next();
|
|
|
|
if (spectre != NULL)
|
|
{
|
|
spectre->Sector->SoundTarget = spectre->LastHeard = self->LastHeard;
|
|
spectre->target = self->target;
|
|
spectre->SetState (spectre->SeeState);
|
|
}
|
|
}
|
|
|
|
|
|
//============================================================================
|
|
//
|
|
// AOracle :: TakeSpecialDamage
|
|
//
|
|
// The Oracle is invulnerable to the first stage Sigil.
|
|
//
|
|
//============================================================================
|
|
|
|
int AOracle::TakeSpecialDamage (AActor *inflictor, AActor *source, int damage, int damagetype)
|
|
{
|
|
if (inflictor->IsKindOf (RUNTIME_CLASS(ASpectralLightningV1)))
|
|
return -1;
|
|
return Super::TakeSpecialDamage(inflictor, source, damage, damagetype);
|
|
}
|