summaryrefslogtreecommitdiffstats
path: root/src/control/Gangs.h
diff options
context:
space:
mode:
authoraap <aap@papnet.eu>2019-06-28 09:49:47 +0200
committerGitHub <noreply@github.com>2019-06-28 09:49:47 +0200
commit6f4e01f078f66572e649e0c93ddd8dac6fc31760 (patch)
tree8e56841c926ffbcb5221ab19b92a89e4a20c5f5e /src/control/Gangs.h
parentMerge pull request #62 from erorcun/erorcun (diff)
parentChanged save/load in CGang (diff)
downloadre3-6f4e01f078f66572e649e0c93ddd8dac6fc31760.tar
re3-6f4e01f078f66572e649e0c93ddd8dac6fc31760.tar.gz
re3-6f4e01f078f66572e649e0c93ddd8dac6fc31760.tar.bz2
re3-6f4e01f078f66572e649e0c93ddd8dac6fc31760.tar.lz
re3-6f4e01f078f66572e649e0c93ddd8dac6fc31760.tar.xz
re3-6f4e01f078f66572e649e0c93ddd8dac6fc31760.tar.zst
re3-6f4e01f078f66572e649e0c93ddd8dac6fc31760.zip
Diffstat (limited to 'src/control/Gangs.h')
-rw-r--r--src/control/Gangs.h53
1 files changed, 53 insertions, 0 deletions
diff --git a/src/control/Gangs.h b/src/control/Gangs.h
new file mode 100644
index 00000000..db14ca64
--- /dev/null
+++ b/src/control/Gangs.h
@@ -0,0 +1,53 @@
+#pragma once
+
+#include "common.h"
+#include "Weapon.h"
+#include "ModelIndices.h"
+
+struct CGangInfo
+{
+ int32 m_nVehicleMI;
+ int8 m_nPedModelOverride;
+ int8 field_5;
+ int16 field_6;
+ eWeaponType m_Weapon1;
+ eWeaponType m_Weapon2;
+
+ CGangInfo() :
+ m_nVehicleMI(MI_BUS),
+ m_nPedModelOverride(-1),
+ m_Weapon1(WEAPONTYPE_UNARMED),
+ m_Weapon2(WEAPONTYPE_UNARMED)
+ {}
+};
+
+static_assert(sizeof(CGangInfo) == 0x10, "CGangInfo: error");
+
+class CGangs
+{
+public:
+ enum {
+ GANG_MAFIA = 0,
+ GANG_TRIAD,
+ GANG_DIABLOS,
+ GANG_YAKUZA,
+ GANG_YARDIE,
+ GANG_COLUMB,
+ GANG_HOODS,
+ GANG_7,
+ GANG_8,
+ NUM_GANGS
+ };
+ static void Initialize(void);
+ static void SetGangVehicleModel(int16, int);
+ static void SetGangWeapons(int16, eWeaponType, eWeaponType);
+ static void SetGangPedModelOverride(int16, int8);
+ static int8 GetGangPedModelOverride(int16);
+ static void SaveAllGangData(uint8 *, uint32 *);
+ static void LoadAllGangData(uint8 *, uint32);
+
+private:
+ static CGangInfo* GetGangInfo(int16 gang) { return &Gang[gang]; }
+
+ static CGangInfo(&Gang)[NUM_GANGS];
+};