raze/source/core/actorinfo.h
2023-04-23 17:42:07 +02:00

74 lines
1.7 KiB
C++

#pragma once
#include <stddef.h>
#include <stdint.h>
#include "maptypes.h"
#include "dobject.h"
#include "m_fixed.h"
#include "m_random.h"
class FScanner;
class FInternalLightAssociation;
enum EDefaultFlags
{
DEFF_PICNUM = 1,
DEFF_STATNUM = 2,
DEFF_SCALE = 4,
};
struct FActorInfo
{
TArray<FInternalLightAssociation *> LightAssociations;
TArray<FTextureID> SpriteSet;
PClassActor *Replacement = nullptr;
PClassActor *Replacee = nullptr;
DVector2 DefaultScale = { 0, 0 };
int TypeNum = -1; // game specific identifier.
int DefaultFlags = 0;
int DefaultCstat = 0;
FName DamageType = NAME_None; // damage type this item inflicts
// these are temporary. Due to how Build games handle their tiles, we cannot look up the textures when scripts are being parsed.
TArray<FString> SpriteSetNames;
FActorInfo() = default;
FActorInfo(const FActorInfo& other)
{
// only copy the fields that get inherited
TypeNum = other.TypeNum;
DefaultFlags = other.DefaultFlags;
DefaultCstat = other.DefaultCstat;
SpriteSetNames = other.SpriteSetNames;
DefaultScale = other.DefaultScale;
}
void ResolveTextures(const char* clsname, DCoreActor *defaults);
};
// No objects of this type will be created ever - its only use is to static_cast
// PClass to it.
class PClassActor : public PClass
{
protected:
public:
static void StaticInit ();
void BuildDefaults();
void ApplyDefaults(uint8_t *defaults);
bool SetReplacement(FName replaceName);
void InitializeDefaults();
FActorInfo *ActorInfo() const
{
return (FActorInfo*)Meta;
}
PClassActor *GetReplacement();
PClassActor *GetReplacee();
// For those times when being able to scan every kind of actor is convenient
inline static TArray<PClassActor *> AllActorClasses;
};