- consolidated the check for "is actor an owned inventory item" into a subfunction.

This check occured 9 times in the source, better have it only once.
This commit is contained in:
Christoph Oelckers 2018-12-02 16:53:12 +01:00 committed by drfrag
parent e8a6f82682
commit e9dd8f3e4f
8 changed files with 20 additions and 32 deletions

View file

@ -1269,6 +1269,7 @@ public:
void UnlinkFromWorld(FLinkContext *ctx); void UnlinkFromWorld(FLinkContext *ctx);
void AdjustFloorClip (); void AdjustFloorClip ();
bool InStateSequence(FState * newstate, FState * basestate); bool InStateSequence(FState * newstate, FState * basestate);
bool IsMapActor();
int GetTics(FState * newstate); int GetTics(FState * newstate);
bool SetState (FState *newstate, bool nofunction=false); bool SetState (FState *newstate, bool nofunction=false);
virtual void SplashCheck(); virtual void SplashCheck();

View file

@ -942,10 +942,7 @@ static bool IsActorACountItem(AActor *mo)
// [SP] for all actors // [SP] for all actors
static bool IsActor(AActor *mo) static bool IsActor(AActor *mo)
{ {
if (mo->IsKindOf(RUNTIME_CLASS(AInventory))) return mo->IsMapActor();
return static_cast<AInventory *>(mo)->Owner == NULL; // [SP] Exclude inventory-owned items
else
return true;
} }
// [SP] modified - now allows showing count only, new arg must be passed. Also now still counts regardless, if lists are printed. // [SP] modified - now allows showing count only, new arg must be passed. Also now still counts regardless, if lists are printed.

View file

@ -2109,7 +2109,7 @@ static int RemoveClass(const PClass *cls)
continue; continue;
} }
// [SP] Don't remove owned inventory objects. // [SP] Don't remove owned inventory objects.
if (actor->IsKindOf(RUNTIME_CLASS(AInventory)) && static_cast<AInventory *>(actor)->Owner != NULL) if (!actor->IsMapActor())
{ {
continue; continue;
} }

View file

@ -3145,16 +3145,7 @@ void FParser::SF_MapThingNumExist()
} }
else else
{ {
// Inventory items in the player's inventory have to be considered non-present. t_return.value.i = SpawnedThings[intval]->IsMapActor();
if (SpawnedThings[intval]->IsKindOf(RUNTIME_CLASS(AInventory)) &&
barrier_cast<AInventory*>(SpawnedThings[intval])->Owner != NULL)
{
t_return.value.i = 0;
}
else
{
t_return.value.i = 1;
}
t_return.type = svt_int; t_return.type = svt_int;
} }
} }
@ -3684,8 +3675,7 @@ again:
{ {
if (mo->IsA(pClass)) if (mo->IsA(pClass))
{ {
if (!mo->IsKindOf (RUNTIME_CLASS(AInventory)) || if (mo->IsMapActor())
static_cast<AInventory *>(mo)->Owner == NULL)
{ {
count++; count++;
} }

View file

@ -129,9 +129,7 @@ AActor* actorvalue(const svalue_t &svalue)
if(svalue.type == svt_mobj) if(svalue.type == svt_mobj)
{ {
// Inventory items in the player's inventory have to be considered non-present. // Inventory items in the player's inventory have to be considered non-present.
if (svalue.value.mobj != NULL && if (svalue.value.mobj == NULL || !svalue.value.mobj->IsMapActor())
svalue.value.mobj->IsKindOf(RUNTIME_CLASS(AInventory)) &&
static_cast<AInventory*>(svalue.value.mobj)->Owner != NULL)
{ {
return NULL; return NULL;
} }
@ -150,9 +148,7 @@ AActor* actorvalue(const svalue_t &svalue)
return NULL; return NULL;
} }
// Inventory items in the player's inventory have to be considered non-present. // Inventory items in the player's inventory have to be considered non-present.
if (SpawnedThings[intval] != NULL && if (svalue.value.mobj == NULL || !svalue.value.mobj->IsMapActor())
SpawnedThings[intval]->IsKindOf(RUNTIME_CLASS(AInventory)) &&
barrier_cast<AInventory*>(SpawnedThings[intval])->Owner != NULL)
{ {
return NULL; return NULL;
} }

View file

@ -3712,8 +3712,7 @@ do_count:
if (tag == -1 || tagManager.SectorHasTag(actor->Sector, tag)) if (tag == -1 || tagManager.SectorHasTag(actor->Sector, tag))
{ {
// Don't count items in somebody's inventory // Don't count items in somebody's inventory
if (!actor->IsKindOf (RUNTIME_CLASS(AInventory)) || if (actor->IsMapActor())
static_cast<AInventory *>(actor)->Owner == NULL)
{ {
count++; count++;
} }
@ -3732,8 +3731,7 @@ do_count:
if (tag == -1 || tagManager.SectorHasTag(actor->Sector, tag)) if (tag == -1 || tagManager.SectorHasTag(actor->Sector, tag))
{ {
// Don't count items in somebody's inventory // Don't count items in somebody's inventory
if (!actor->IsKindOf (RUNTIME_CLASS(AInventory)) || if (actor->IsMapActor())
static_cast<AInventory *>(actor)->Owner == NULL)
{ {
count++; count++;
} }

View file

@ -631,6 +631,14 @@ DEFINE_ACTION_FUNCTION(AActor, InStateSequence)
PARAM_POINTER(basestate, FState); PARAM_POINTER(basestate, FState);
ACTION_RETURN_BOOL(self->InStateSequence(newstate, basestate)); ACTION_RETURN_BOOL(self->InStateSequence(newstate, basestate));
} }
bool AActor::IsMapActor()
{
// [SP] Don't remove owned inventory objects.
return (!IsKindOf(RUNTIME_CLASS(AInventory)) || static_cast<AInventory *>(this)->Owner == nullptr);
}
//========================================================================== //==========================================================================
// //
// AActor::GetTics // AActor::GetTics

View file

@ -431,7 +431,7 @@ void P_RemoveThing(AActor * actor)
if (actor->player == NULL || actor != actor->player->mo) if (actor->player == NULL || actor != actor->player->mo)
{ {
// Don't also remove owned inventory items // Don't also remove owned inventory items
if (actor->IsKindOf(RUNTIME_CLASS(AInventory)) && static_cast<AInventory*>(actor)->Owner != NULL) return; if (!actor->IsMapActor())
// be friendly to the level statistics. ;) // be friendly to the level statistics. ;)
actor->ClearCounters(); actor->ClearCounters();
@ -782,12 +782,10 @@ int P_Thing_CheckProximity(AActor *self, PClass *classname, double distance, int
else if (classname != mo->GetClass()) else if (classname != mo->GetClass())
continue; continue;
if (mo->IsKindOf(RUNTIME_CLASS(AInventory))) if (!mo->IsMapActor())
{ {
// Skip owned item because its position could remain unchanged since attachment to owner // Skip owned item because its position could remain unchanged since attachment to owner
// Most likely it is the last location of this item in the world before pick up // Most likely it is the last location of this item in the world before pick up
AInventory *const inventory = static_cast<AInventory*>(mo);
if (inventory != nullptr && inventory->Owner != nullptr)
continue; continue;
} }