1
0
mirror of https://github.com/VCMP-SqMod/SqMod.git synced 2025-01-18 19:47:15 +01:00

Update entity interfaces to include various functions required by the new event types.

This commit is contained in:
Sandu Liviu Catalin 2015-10-10 22:59:59 +03:00
parent 2de391dd78
commit c67c214160

View File

@ -60,7 +60,7 @@ private:
typedef struct Blip typedef struct Blip
{ {
// ---------------------------------------------------------------------------------------- // ----------------------------------------------------------------------------------------
Blip() : ID(-1), Root(0), Owned(false), Fresh(true) { /* ... */ } Blip() noexcept : ID(-1), Root(0), Owned(false), Fresh(true) { /* ... */ }
// ---------------------------------------------------------------------------------------- // ----------------------------------------------------------------------------------------
SQInt32 ID; SQInt32 ID;
@ -92,6 +92,11 @@ private:
EBlipDestroyed BlipDestroyed; EBlipDestroyed BlipDestroyed;
EBlipCustom BlipCustom; EBlipCustom BlipCustom;
// ----------------------------------------------------------------------------------------
EBlipCreated & Created() noexcept { return BlipCreated; }
EBlipDestroyed & Destroyed() noexcept { return BlipDestroyed; }
EBlipCustom & Custom() noexcept { return BlipCustom; }
} Instance; } Instance;
// -------------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------------
@ -115,19 +120,38 @@ private:
public: public:
// --------------------------------------------------------------------------------------------
static constexpr SQInt32 TypeID = ENT_BLIP;
static constexpr SQInt32 Limit = SQMOD_BLIP_POOL;
// -------------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------------
static constexpr const SQChar* Name = "Blip"; static constexpr const SQChar* Name = "Blip";
static constexpr const SQChar* CName = "CBlip"; static constexpr const SQChar* CName = "CBlip";
// --------------------------------------------------------------------------------------------
static constexpr SQInt32 TypeID = ENT_BLIP;
static constexpr SQInt32 Limit = SQMOD_BLIP_POOL;
// --------------------------------------------------------------------------------------------
static constexpr SQInt32 CreateEvID = EVT_BLIPCREATED;
static constexpr SQInt32 DestroyEvID = EVT_BLIPDESTROYED;
static constexpr SQInt32 CustomEvID = EVT_BLIPCUSTOM;
// -------------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------------
typedef std::array< Instance, Limit > Instances; typedef std::array< Instance, Limit > Instances;
// -------------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------------
typedef std::bitset< Limit > Set; typedef std::bitset< Limit > Set;
// --------------------------------------------------------------------------------------------
static bool InEvent(SQInt32 type) noexcept
{
switch (type)
{
case EVT_BLIPCREATED:
case EVT_BLIPDESTROYED:
case EVT_BLIPCUSTOM:
return true;
default:
return false;
}
}
}; };
/* ------------------------------------------------------------------------------------------------ /* ------------------------------------------------------------------------------------------------
@ -150,7 +174,7 @@ private:
typedef struct Checkpoint typedef struct Checkpoint
{ {
// ---------------------------------------------------------------------------------------- // ----------------------------------------------------------------------------------------
Checkpoint() : ID(-1), Root(0), Owned(false), Fresh(true) { /* ... */ } Checkpoint() noexcept : ID(-1), Root(0), Owned(false), Fresh(true) { /* ... */ }
// ---------------------------------------------------------------------------------------- // ----------------------------------------------------------------------------------------
SQInt32 ID; SQInt32 ID;
@ -172,6 +196,12 @@ private:
ECheckpointCustom CheckpointCustom; ECheckpointCustom CheckpointCustom;
ECheckpointEntered CheckpointEntered; ECheckpointEntered CheckpointEntered;
ECheckpointExited CheckpointExited; ECheckpointExited CheckpointExited;
// ----------------------------------------------------------------------------------------
ECheckpointCreated & Created() noexcept { return CheckpointCreated; }
ECheckpointDestroyed & Destroyed() noexcept { return CheckpointDestroyed; }
ECheckpointCustom & Custom() noexcept { return CheckpointCustom; }
} Instance; } Instance;
// -------------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------------
@ -192,19 +222,40 @@ private:
public: public:
// --------------------------------------------------------------------------------------------
static constexpr SQInt32 TypeID = ENT_CHECKPOINT;
static constexpr SQInt32 Limit = SQMOD_CHECKPOINT_POOL;
// -------------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------------
static constexpr const SQChar* Name = "Checkpoint"; static constexpr const SQChar* Name = "Checkpoint";
static constexpr const SQChar* CName = "CCheckpoint"; static constexpr const SQChar* CName = "CCheckpoint";
// --------------------------------------------------------------------------------------------
static constexpr SQInt32 TypeID = ENT_CHECKPOINT;
static constexpr SQInt32 Limit = SQMOD_CHECKPOINT_POOL;
// --------------------------------------------------------------------------------------------
static constexpr SQInt32 CreateEvID = EVT_CHECKPOINTCREATED;
static constexpr SQInt32 DestroyEvID = EVT_CHECKPOINTDESTROYED;
static constexpr SQInt32 CustomEvID = EVT_CHECKPOINTCUSTOM;
// -------------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------------
typedef std::array< Instance, Limit > Instances; typedef std::array< Instance, Limit > Instances;
// -------------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------------
typedef std::bitset< Limit > Set; typedef std::bitset< Limit > Set;
// --------------------------------------------------------------------------------------------
static bool InEvent(SQInt32 type) noexcept
{
switch (type)
{
case EVT_CHECKPOINTCREATED:
case EVT_CHECKPOINTDESTROYED:
case EVT_CHECKPOINTCUSTOM:
case EVT_CHECKPOINTENTERED:
case EVT_CHECKPOINTEXITED:
return true;
default:
return false;
}
}
}; };
/* ------------------------------------------------------------------------------------------------ /* ------------------------------------------------------------------------------------------------
@ -227,7 +278,7 @@ private:
typedef struct Keybind typedef struct Keybind
{ {
// ---------------------------------------------------------------------------------------- // ----------------------------------------------------------------------------------------
Keybind() : ID(-1), Root(0), Owned(false), Fresh(true) { /* ... */ } Keybind() noexcept : ID(-1), Root(0), Owned(false), Fresh(true) { /* ... */ }
// ---------------------------------------------------------------------------------------- // ----------------------------------------------------------------------------------------
SQInt32 ID; SQInt32 ID;
@ -257,6 +308,12 @@ private:
EKeybindCustom KeybindCustom; EKeybindCustom KeybindCustom;
EKeybindKeyPress KeybindKeyPress; EKeybindKeyPress KeybindKeyPress;
EKeybindKeyRelease KeybindKeyRelease; EKeybindKeyRelease KeybindKeyRelease;
// ----------------------------------------------------------------------------------------
EKeybindCreated & Created() noexcept { return KeybindCreated; }
EKeybindDestroyed & Destroyed() noexcept { return KeybindDestroyed; }
EKeybindCustom & Custom() noexcept { return KeybindCustom; }
} Instance; } Instance;
// -------------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------------
@ -281,19 +338,40 @@ private:
public: public:
// --------------------------------------------------------------------------------------------
static constexpr SQInt32 TypeID = ENT_KEYBIND;
static constexpr SQInt32 Limit = SQMOD_KEYBIND_POOL;
// -------------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------------
static constexpr const SQChar* Name = "Keybind"; static constexpr const SQChar* Name = "Keybind";
static constexpr const SQChar* CName = "CKeybind"; static constexpr const SQChar* CName = "CKeybind";
// --------------------------------------------------------------------------------------------
static constexpr SQInt32 TypeID = ENT_KEYBIND;
static constexpr SQInt32 Limit = SQMOD_KEYBIND_POOL;
// --------------------------------------------------------------------------------------------
static constexpr SQInt32 CreateEvID = EVT_KEYBINDCREATED;
static constexpr SQInt32 DestroyEvID = EVT_KEYBINDDESTROYED;
static constexpr SQInt32 CustomEvID = EVT_KEYBINDCUSTOM;
// -------------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------------
typedef std::array< Instance, Limit > Instances; typedef std::array< Instance, Limit > Instances;
// -------------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------------
typedef std::bitset< Limit > Set; typedef std::bitset< Limit > Set;
// --------------------------------------------------------------------------------------------
static bool InEvent(SQInt32 type) noexcept
{
switch (type)
{
case EVT_KEYBINDCREATED:
case EVT_KEYBINDDESTROYED:
case EVT_KEYBINDCUSTOM:
case EVT_KEYBINDKEYPRESS:
case EVT_KEYBINDKEYRELEASE:
return true;
default:
return false;
}
}
}; };
/* ------------------------------------------------------------------------------------------------ /* ------------------------------------------------------------------------------------------------
@ -316,7 +394,7 @@ private:
typedef struct Object typedef struct Object
{ {
// ---------------------------------------------------------------------------------------- // ----------------------------------------------------------------------------------------
Object() : ID(-1), Root(0), Owned(false), Fresh(true) { /* ... */ } Object() noexcept : ID(-1), Root(0), Owned(false), Fresh(true) { /* ... */ }
// ---------------------------------------------------------------------------------------- // ----------------------------------------------------------------------------------------
SQInt32 ID; SQInt32 ID;
@ -338,6 +416,12 @@ private:
EObjectCustom ObjectCustom; EObjectCustom ObjectCustom;
EObjectShot ObjectShot; EObjectShot ObjectShot;
EObjectBump ObjectBump; EObjectBump ObjectBump;
// ----------------------------------------------------------------------------------------
EObjectCreated & Created() noexcept { return ObjectCreated; }
EObjectDestroyed & Destroyed() noexcept { return ObjectDestroyed; }
EObjectCustom & Custom() noexcept { return ObjectCustom; }
} Instance; } Instance;
// -------------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------------
@ -358,19 +442,40 @@ private:
public: public:
// --------------------------------------------------------------------------------------------
static constexpr SQInt32 TypeID = ENT_OBJECT;
static constexpr SQInt32 Limit = SQMOD_OBJECT_POOL;
// -------------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------------
static constexpr const SQChar* Name = "Object"; static constexpr const SQChar* Name = "Object";
static constexpr const SQChar* CName = "CObject"; static constexpr const SQChar* CName = "CObject";
// --------------------------------------------------------------------------------------------
static constexpr SQInt32 TypeID = ENT_OBJECT;
static constexpr SQInt32 Limit = SQMOD_OBJECT_POOL;
// --------------------------------------------------------------------------------------------
static constexpr SQInt32 CreateEvID = EVT_OBJECTCREATED;
static constexpr SQInt32 DestroyEvID = EVT_OBJECTDESTROYED;
static constexpr SQInt32 CustomEvID = EVT_OBJECTCUSTOM;
// -------------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------------
typedef std::array< Instance, Limit > Instances; typedef std::array< Instance, Limit > Instances;
// -------------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------------
typedef std::bitset< Limit > Set; typedef std::bitset< Limit > Set;
// --------------------------------------------------------------------------------------------
static bool InEvent(SQInt32 type) noexcept
{
switch (type)
{
case EVT_OBJECTCREATED:
case EVT_OBJECTDESTROYED:
case EVT_OBJECTCUSTOM:
case EVT_OBJECTSHOT:
case EVT_OBJECTBUMP:
return true;
default:
return false;
}
}
}; };
/* ------------------------------------------------------------------------------------------------ /* ------------------------------------------------------------------------------------------------
@ -393,7 +498,7 @@ private:
typedef struct Pickup typedef struct Pickup
{ {
// ---------------------------------------------------------------------------------------- // ----------------------------------------------------------------------------------------
Pickup() : ID(-1), Root(0), Owned(false), Fresh(true) { /* ... */ } Pickup() noexcept : ID(-1), Root(0), Owned(false), Fresh(true) { /* ... */ }
// ---------------------------------------------------------------------------------------- // ----------------------------------------------------------------------------------------
SQInt32 ID; SQInt32 ID;
@ -416,6 +521,12 @@ private:
EPickupRespawn PickupRespawn; EPickupRespawn PickupRespawn;
EPickupClaimed PickupClaimed; EPickupClaimed PickupClaimed;
EPickupCollected PickupCollected; EPickupCollected PickupCollected;
// ----------------------------------------------------------------------------------------
EPickupCreated & Created() noexcept { return PickupCreated; }
EPickupDestroyed & Destroyed() noexcept { return PickupDestroyed; }
EPickupCustom & Custom() noexcept { return PickupCustom; }
} Instance; } Instance;
// -------------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------------
@ -437,19 +548,41 @@ private:
public: public:
// --------------------------------------------------------------------------------------------
static constexpr SQInt32 TypeID = ENT_PICKUP;
static constexpr SQInt32 Limit = SQMOD_PICKUP_POOL;
// -------------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------------
static constexpr const SQChar* Name = "Pickup"; static constexpr const SQChar* Name = "Pickup";
static constexpr const SQChar* CName = "CPickup"; static constexpr const SQChar* CName = "CPickup";
// --------------------------------------------------------------------------------------------
static constexpr SQInt32 TypeID = ENT_PICKUP;
static constexpr SQInt32 Limit = SQMOD_PICKUP_POOL;
// --------------------------------------------------------------------------------------------
static constexpr SQInt32 CreateEvID = EVT_PICKUPCREATED;
static constexpr SQInt32 DestroyEvID = EVT_PICKUPDESTROYED;
static constexpr SQInt32 CustomEvID = EVT_PICKUPCUSTOM;
// -------------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------------
typedef std::array< Instance, Limit > Instances; typedef std::array< Instance, Limit > Instances;
// -------------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------------
typedef std::bitset< Limit > Set; typedef std::bitset< Limit > Set;
// --------------------------------------------------------------------------------------------
static bool InEvent(SQInt32 type) noexcept
{
switch (type)
{
case EVT_PICKUPCREATED:
case EVT_PICKUPDESTROYED:
case EVT_PICKUPCUSTOM:
case EVT_PICKUPRESPAWN:
case EVT_PICKUPCLAIMED:
case EVT_PICKUPCOLLECTED:
return true;
default:
return false;
}
}
}; };
/* ------------------------------------------------------------------------------------------------ /* ------------------------------------------------------------------------------------------------
@ -472,7 +605,7 @@ private:
typedef struct Player typedef struct Player
{ {
// ---------------------------------------------------------------------------------------- // ----------------------------------------------------------------------------------------
Player() : ID(-1), Root(0), Owned(false), Fresh(true) { /* ... */ } Player() noexcept : ID(-1), Root(0), Owned(false), Fresh(true) { /* ... */ }
// ---------------------------------------------------------------------------------------- // ----------------------------------------------------------------------------------------
SQInt32 ID; SQInt32 ID;
@ -538,6 +671,12 @@ private:
EActionWasted ActionWasted; EActionWasted ActionWasted;
EActionEmbarking ActionEmbarking; EActionEmbarking ActionEmbarking;
EActionDisembarking ActionDisembarking; EActionDisembarking ActionDisembarking;
// ----------------------------------------------------------------------------------------
EPlayerCreated & Created() noexcept { return PlayerCreated; }
EPlayerDestroyed & Destroyed() noexcept { return PlayerDestroyed; }
EPlayerCustom & Custom() noexcept { return PlayerCustom; }
} Instance; } Instance;
// -------------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------------
@ -602,19 +741,97 @@ private:
public: public:
// --------------------------------------------------------------------------------------------
static constexpr SQInt32 TypeID = ENT_PLAYER;
static constexpr SQInt32 Limit = SQMOD_PLAYER_POOL;
// -------------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------------
static constexpr const SQChar* Name = "Player"; static constexpr const SQChar* Name = "Player";
static constexpr const SQChar* CName = "CPlayer"; static constexpr const SQChar* CName = "CPlayer";
// --------------------------------------------------------------------------------------------
static constexpr SQInt32 TypeID = ENT_PLAYER;
static constexpr SQInt32 Limit = SQMOD_PLAYER_POOL;
// --------------------------------------------------------------------------------------------
static constexpr SQInt32 CreateEvID = EVT_PLAYERCREATED;
static constexpr SQInt32 DestroyEvID = EVT_PLAYERDESTROYED;
static constexpr SQInt32 CustomEvID = EVT_PLAYERCUSTOM;
// -------------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------------
typedef std::array< Instance, Limit > Instances; typedef std::array< Instance, Limit > Instances;
// -------------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------------
typedef std::bitset< Limit > Set; typedef std::bitset< Limit > Set;
// --------------------------------------------------------------------------------------------
static bool InEvent(SQInt32 type) noexcept
{
switch (type)
{
case EVT_PLAYERCREATED:
case EVT_PLAYERDESTROYED:
case EVT_PLAYERCUSTOM:
case EVT_PLAYERAWAY:
case EVT_PLAYERGAMEKEYS:
case EVT_PLAYERRENAME:
case EVT_PLAYERREQUESTCLASS:
case EVT_PLAYERREQUESTSPAWN:
case EVT_PLAYERSPAWN:
case EVT_PLAYERSTARTTYPING:
case EVT_PLAYERSTOPTYPING:
case EVT_PLAYERCHAT:
case EVT_PLAYERCOMMAND:
case EVT_PLAYERMESSAGE:
case EVT_PLAYERHEALTH:
case EVT_PLAYERARMOUR:
case EVT_PLAYERWEAPON:
case EVT_PLAYERMOVE:
case EVT_PLAYERWASTED:
case EVT_PLAYERKILLED:
case EVT_PLAYERTEAMKILL:
case EVT_PLAYERSPECTATE:
case EVT_PLAYERCRASHREPORT:
case EVT_PLAYERBURNING:
case EVT_PLAYERCROUCHING:
case EVT_PLAYERSTATE:
case EVT_PLAYERACTION:
case EVT_STATENONE:
case EVT_STATENORMAL:
case EVT_STATESHOOTING:
case EVT_STATEDRIVER:
case EVT_STATEPASSENGER:
case EVT_STATEENTERDRIVER:
case EVT_STATEENTERPASSENGER:
case EVT_STATEEXITVEHICLE:
case EVT_STATEUNSPAWNED:
case EVT_ACTIONNONE:
case EVT_ACTIONNORMAL:
case EVT_ACTIONAIMING:
case EVT_ACTIONSHOOTING:
case EVT_ACTIONJUMPING:
case EVT_ACTIONLIEDOWN:
case EVT_ACTIONGETTINGUP:
case EVT_ACTIONJUMPVEHICLE:
case EVT_ACTIONDRIVING:
case EVT_ACTIONDYING:
case EVT_ACTIONWASTED:
case EVT_ACTIONEMBARKING:
case EVT_ACTIONDISEMBARKING:
case EVT_KEYBINDKEYPRESS:
case EVT_KEYBINDKEYRELEASE:
case EVT_VEHICLEEMBARKING:
case EVT_VEHICLEEMBARKED:
case EVT_VEHICLEDISEMBARK:
case EVT_PICKUPCLAIMED:
case EVT_PICKUPCOLLECTED:
case EVT_OBJECTSHOT:
case EVT_OBJECTBUMP:
case EVT_CHECKPOINTENTERED:
case EVT_CHECKPOINTEXITED:
case EVT_SPHEREENTERED:
case EVT_SPHEREEXITED:
return true;
default:
return false;
}
}
}; };
/* ------------------------------------------------------------------------------------------------ /* ------------------------------------------------------------------------------------------------
@ -637,7 +854,7 @@ private:
typedef struct Sphere typedef struct Sphere
{ {
// ---------------------------------------------------------------------------------------- // ----------------------------------------------------------------------------------------
Sphere() : ID(-1), Root(0), Owned(false), Fresh(true) { /* ... */ } Sphere() noexcept : ID(-1), Root(0), Owned(false), Fresh(true) { /* ... */ }
// ---------------------------------------------------------------------------------------- // ----------------------------------------------------------------------------------------
SQInt32 ID; SQInt32 ID;
@ -659,6 +876,12 @@ private:
ESphereCustom SphereCustom; ESphereCustom SphereCustom;
ESphereEntered SphereEntered; ESphereEntered SphereEntered;
ESphereExited SphereExited; ESphereExited SphereExited;
// ----------------------------------------------------------------------------------------
ESphereCreated & Created() noexcept { return SphereCreated; }
ESphereDestroyed & Destroyed() noexcept { return SphereDestroyed; }
ESphereCustom & Custom() noexcept { return SphereCustom; }
} Instance; } Instance;
// -------------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------------
@ -679,19 +902,40 @@ private:
public: public:
// --------------------------------------------------------------------------------------------
static constexpr SQInt32 TypeID = ENT_SPHERE;
static constexpr SQInt32 Limit = SQMOD_SPHERE_POOL;
// -------------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------------
static constexpr const SQChar* Name = "Sphere"; static constexpr const SQChar* Name = "Sphere";
static constexpr const SQChar* CName = "CSphere"; static constexpr const SQChar* CName = "CSphere";
// --------------------------------------------------------------------------------------------
static constexpr SQInt32 TypeID = ENT_SPHERE;
static constexpr SQInt32 Limit = SQMOD_SPHERE_POOL;
// --------------------------------------------------------------------------------------------
static constexpr SQInt32 CreateEvID = EVT_SPHERECREATED;
static constexpr SQInt32 DestroyEvID = EVT_SPHEREDESTROYED;
static constexpr SQInt32 CustomEvID = EVT_SPHERECUSTOM;
// -------------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------------
typedef std::array< Instance, Limit > Instances; typedef std::array< Instance, Limit > Instances;
// -------------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------------
typedef std::bitset< Limit > Set; typedef std::bitset< Limit > Set;
// --------------------------------------------------------------------------------------------
static bool InEvent(SQInt32 type) noexcept
{
switch (type)
{
case EVT_SPHERECREATED:
case EVT_SPHEREDESTROYED:
case EVT_SPHERECUSTOM:
case EVT_SPHEREENTERED:
case EVT_SPHEREEXITED:
return true;
default:
return false;
}
}
}; };
/* ------------------------------------------------------------------------------------------------ /* ------------------------------------------------------------------------------------------------
@ -714,7 +958,7 @@ private:
typedef struct Sprite typedef struct Sprite
{ {
// ---------------------------------------------------------------------------------------- // ----------------------------------------------------------------------------------------
Sprite() : ID(-1), Root(0), Owned(false), Fresh(true) { /* ... */ } Sprite() noexcept : ID(-1), Root(0), Owned(false), Fresh(true) { /* ... */ }
// ---------------------------------------------------------------------------------------- // ----------------------------------------------------------------------------------------
SQInt32 ID; SQInt32 ID;
@ -737,6 +981,12 @@ private:
ESpriteCreated SpriteCreated; ESpriteCreated SpriteCreated;
ESpriteDestroyed SpriteDestroyed; ESpriteDestroyed SpriteDestroyed;
ESpriteCustom SpriteCustom; ESpriteCustom SpriteCustom;
// ----------------------------------------------------------------------------------------
ESpriteCreated & Created() noexcept { return SpriteCreated; }
ESpriteDestroyed & Destroyed() noexcept { return SpriteDestroyed; }
ESpriteCustom & Custom() noexcept { return SpriteCustom; }
} Instance; } Instance;
// -------------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------------
@ -755,19 +1005,38 @@ private:
public: public:
// --------------------------------------------------------------------------------------------
static constexpr SQInt32 TypeID = ENT_SPRITE;
static constexpr SQInt32 Limit = SQMOD_SPRITE_POOL;
// -------------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------------
static constexpr const SQChar* Name = "Sprite"; static constexpr const SQChar* Name = "Sprite";
static constexpr const SQChar* CName = "CSprite"; static constexpr const SQChar* CName = "CSprite";
// --------------------------------------------------------------------------------------------
static constexpr SQInt32 TypeID = ENT_SPRITE;
static constexpr SQInt32 Limit = SQMOD_SPRITE_POOL;
// --------------------------------------------------------------------------------------------
static constexpr SQInt32 CreateEvID = EVT_SPRITECREATED;
static constexpr SQInt32 DestroyEvID = EVT_SPRITEDESTROYED;
static constexpr SQInt32 CustomEvID = EVT_SPRITECUSTOM;
// -------------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------------
typedef std::array< Instance, Limit > Instances; typedef std::array< Instance, Limit > Instances;
// -------------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------------
typedef std::bitset< Limit > Set; typedef std::bitset< Limit > Set;
// --------------------------------------------------------------------------------------------
static bool InEvent(SQInt32 type) noexcept
{
switch (type)
{
case EVT_SPRITECREATED:
case EVT_SPRITEDESTROYED:
case EVT_SPRITECUSTOM:
return true;
default:
return false;
}
}
}; };
/* ------------------------------------------------------------------------------------------------ /* ------------------------------------------------------------------------------------------------
@ -790,7 +1059,7 @@ private:
typedef struct Textdraw typedef struct Textdraw
{ {
// ---------------------------------------------------------------------------------------- // ----------------------------------------------------------------------------------------
Textdraw() : ID(-1), Root(0), Owned(false), Fresh(true) { /* ... */ } Textdraw() noexcept : ID(-1), Root(0), Owned(false), Fresh(true) { /* ... */ }
// ---------------------------------------------------------------------------------------- // ----------------------------------------------------------------------------------------
SQInt32 ID; SQInt32 ID;
@ -813,6 +1082,12 @@ private:
ETextdrawCreated TextdrawCreated; ETextdrawCreated TextdrawCreated;
ETextdrawDestroyed TextdrawDestroyed; ETextdrawDestroyed TextdrawDestroyed;
ETextdrawCustom TextdrawCustom; ETextdrawCustom TextdrawCustom;
// ----------------------------------------------------------------------------------------
ETextdrawCreated & Created() noexcept { return TextdrawCreated; }
ETextdrawDestroyed & Destroyed() noexcept { return TextdrawDestroyed; }
ETextdrawCustom & Custom() noexcept { return TextdrawCustom; }
} Instance; } Instance;
// -------------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------------
@ -831,19 +1106,38 @@ private:
public: public:
// --------------------------------------------------------------------------------------------
static constexpr SQInt32 TypeID = ENT_TEXTDRAW;
static constexpr SQInt32 Limit = SQMOD_TEXTDRAW_POOL;
// -------------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------------
static constexpr const SQChar* Name = "Textdraw"; static constexpr const SQChar* Name = "Textdraw";
static constexpr const SQChar* CName = "CTextdraw"; static constexpr const SQChar* CName = "CTextdraw";
// --------------------------------------------------------------------------------------------
static constexpr SQInt32 TypeID = ENT_TEXTDRAW;
static constexpr SQInt32 Limit = SQMOD_TEXTDRAW_POOL;
// --------------------------------------------------------------------------------------------
static constexpr SQInt32 CreateEvID = EVT_TEXTDRAWCREATED;
static constexpr SQInt32 DestroyEvID = EVT_TEXTDRAWDESTROYED;
static constexpr SQInt32 CustomEvID = EVT_TEXTDRAWCUSTOM;
// -------------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------------
typedef std::array< Instance, Limit > Instances; typedef std::array< Instance, Limit > Instances;
// -------------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------------
typedef std::bitset< Limit > Set; typedef std::bitset< Limit > Set;
// --------------------------------------------------------------------------------------------
static bool InEvent(SQInt32 type) noexcept
{
switch (type)
{
case EVT_TEXTDRAWCREATED:
case EVT_TEXTDRAWDESTROYED:
case EVT_TEXTDRAWCUSTOM:
return true;
default:
return false;
}
}
}; };
/* ------------------------------------------------------------------------------------------------ /* ------------------------------------------------------------------------------------------------
@ -866,7 +1160,7 @@ private:
typedef struct Vehicle typedef struct Vehicle
{ {
// ---------------------------------------------------------------------------------------- // ----------------------------------------------------------------------------------------
Vehicle() : ID(-1), Root(0), Owned(false), Fresh(true) { /* ... */ } Vehicle() noexcept : ID(-1), Root(0), Owned(false), Fresh(true) { /* ... */ }
// ---------------------------------------------------------------------------------------- // ----------------------------------------------------------------------------------------
SQInt32 ID; SQInt32 ID;
@ -893,6 +1187,12 @@ private:
EVehicleEmbarking VehicleEmbarking; EVehicleEmbarking VehicleEmbarking;
EVehicleEmbarked VehicleEmbarked; EVehicleEmbarked VehicleEmbarked;
EVehicleDisembark VehicleDisembark; EVehicleDisembark VehicleDisembark;
// ----------------------------------------------------------------------------------------
EVehicleCreated & Created() noexcept { return VehicleCreated; }
EVehicleDestroyed & Destroyed() noexcept { return VehicleDestroyed; }
EVehicleCustom & Custom() noexcept { return VehicleCustom; }
} Instance; } Instance;
// -------------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------------
@ -918,19 +1218,45 @@ private:
public: public:
// --------------------------------------------------------------------------------------------
static constexpr SQInt32 TypeID = ENT_VEHICLE;
static constexpr SQInt32 Limit = SQMOD_VEHICLE_POOL;
// -------------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------------
static constexpr const SQChar* Name = "Vehicle"; static constexpr const SQChar* Name = "Vehicle";
static constexpr const SQChar* CName = "CVehicle"; static constexpr const SQChar* CName = "CVehicle";
// --------------------------------------------------------------------------------------------
static constexpr SQInt32 TypeID = ENT_VEHICLE;
static constexpr SQInt32 Limit = SQMOD_VEHICLE_POOL;
// --------------------------------------------------------------------------------------------
static constexpr SQInt32 CreateEvID = EVT_VEHICLECREATED;
static constexpr SQInt32 DestroyEvID = EVT_VEHICLEDESTROYED;
static constexpr SQInt32 CustomEvID = EVT_VEHICLECUSTOM;
// -------------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------------
typedef std::array< Instance, Limit > Instances; typedef std::array< Instance, Limit > Instances;
// -------------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------------
typedef std::bitset< Limit > Set; typedef std::bitset< Limit > Set;
// --------------------------------------------------------------------------------------------
static bool InEvent(SQInt32 type) noexcept
{
switch (type)
{
case EVT_VEHICLECREATED:
case EVT_VEHICLEDESTROYED:
case EVT_VEHICLECUSTOM:
case EVT_VEHICLERESPAWN:
case EVT_VEHICLEEXPLODE:
case EVT_VEHICLEHEALTH:
case EVT_VEHICLEMOVE:
case EVT_VEHICLEEMBARKING:
case EVT_VEHICLEEMBARKED:
case EVT_VEHICLEDISEMBARK:
return true;
default:
return false;
}
}
}; };
/* ------------------------------------------------------------------------------------------------ /* ------------------------------------------------------------------------------------------------
@ -952,6 +1278,9 @@ public:
// -------------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------------
static constexpr SQInt32 Max = Ent< T >::Limit; static constexpr SQInt32 Max = Ent< T >::Limit;
// --------------------------------------------------------------------------------------------
static constexpr SQInt32 TypeID = Ent< T >::TypeID;
protected: protected:
// -------------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------------
@ -1023,13 +1352,21 @@ protected:
public: public:
/* -------------------------------------------------------------------------------------------- /* --------------------------------------------------------------------------------------------
* Verify that the specified entity instacne is active * Verify that the specified entity instance is active
*/ */
static bool Verify(SQInt32 id) noexcept static bool Verify(SQInt32 id) noexcept
{ {
return (VALID_ENTITYEX(id, Max) && VALID_ENTITY(s_Instances[id].ID)); return (VALID_ENTITYEX(id, Max) && VALID_ENTITY(s_Instances[id].ID));
} }
/* --------------------------------------------------------------------------------------------
* Returns a reference to the specified entity instance
*/
static typename Ent< T >::Instance & Get(SQInt32 id) noexcept
{
return s_Instances[id]; /* Expects the callee to deal with range checks! */
}
public: public:
/* -------------------------------------------------------------------------------------------- /* --------------------------------------------------------------------------------------------