ModEnc is currently in Maintenance Mode: Changes could occur at any given moment, without advance warning.
SideClass
Jump to navigation
Jump to search
The SideClass holds default settings for Sides (a.k.a. factions) which are loaded from an INI file.
Class specifications
Property | Value |
---|---|
General: | |
Derivation | AbstractClass → AbstractTypeClass → SideClass |
GUID | {C53DD372-151E-11D2-8175-006008055BB5} |
VT address (YR 1.001) | 0x7F2EC0 |
Size of member data (YR 1.001) | 0xB4 bytes |
AbstractClass derivative: | |
AbstractDerivation ID | 0x1C |
Member variables
Offset | Type | Name | Description |
---|---|---|---|
AbstractClass: | |||
0x0 | ptr | VirtualTable | Pointer to the class's Virtual Table |
0x4 | ptr | IRTTITypeInfo VTable | Pointer to an extended VTable (not sure what exactly it does) |
0x8 | ptr | INoticeSink VTable | Pointer to an extended VTable (not sure what exactly it does) |
0xC | ptr | INoticeSource VTable | Pointer to an extended VTable (not sure what exactly it does) |
0x10 | DWORD | unknown | |
0x14 | DWORD | DerivationFlags | Bit 0: set if the instance is or derives from a TechnoClass Bit 1: set if the instance is or derives from a ObjectClass Bit 2: set if the instance is or derives from a FootClass |
0x18 | DWORD | unknown | |
0x1C | DWORD | unknown | |
0x20 | bool | Dirty | Was the object changed since it was last saved? |
0x21 | BYTE | unused | |
0x22 | WORD | unused | |
AbstractTypeClass: | |||
0x24 | char[0x18] | ID | The INI name of this type (for example: SMCV). |
0x3C | BYTE | reserved | Zero-termination of the ID. |
0x3D | char[0x20] | UIName | Stringtable reference given by the UIName tag. |
0x5D | BYTE | reserved | Zero-termination of the UIName. |
0x5E | WORD | unused | |
0x60 | wchar* | UIName | Pointer to the UIName unicode string inside the stringtable. |
0x64 | char[0x31] | Name | Name given by the Name tag. |
0x95 | BYTE | reserved | Zero-termination of the Name. |
0x96 | WORD | unused | |
SideClass: | |||
0x98 | vector<int> | HouseTypeClass indices | Hold the countries assigned to this side. |
AbstractClass - Member Variables |
AbstractTypeClass - Member Variables |
SideClass - Member Variables |
Virtual Table
Offset | Return Type | Name | Arguments | Description |
---|---|---|---|---|
IUnknown: | ||||
0x0 | HRESULT | QueryInterface | REFIID iid void ** ppvObject |
MSDN: "Returns a pointer to a specified interface on an object to which a client currently holds an interface pointer." |
0x4 | ULONG | AddRef | none | MSDN: "[...] increments the reference count for an interface on an object. It should be called for every new copy of a pointer to an interface on a given object." |
0x8 | ULONG | Release | none | MSDN: "Decrements the reference count for the calling interface on a object. If the reference count on the object falls to 0, the object is freed from memory." |
IPersist: | ||||
0xC | HRESULT | GetClassID | CLSID * pClassID | MSDN: "Retrieves the class identifier (CLSID) of an object. The CLSID is a unique value that identifies the code that can manipulate the persistent data." |
IPersistStream: | ||||
0x10 | HRESULT | IsDirty | none | MSDN: "Checks the object for changes since it was last saved." |
0x14 | HRESULT | Load | IStream* stream AbstractClass* dst |
MSDN: "Initializes an object from the stream where it was previously saved." |
0x18 | HRESULT | Save | IStream* stream AbstractClass* src (3rd is unknown) |
MSDN: "Saves an object to the specified stream." |
0x1C | HRESULT | GetMaxSize | ULARGE_INTEGER * pcbSize | MSDN: "Returns the size in bytes of the stream needed to save the object." |
AbstractClass: | ||||
0x20 | none (DTOR) | Destructor | none | Frees memory and removes this instance from global arrays. |
0x24 | unknown | unknown | unknown | |
0x28 | unknown | unknown | unknown | |
0x2C | int | GetAbstractDerivationID | none | Gets the AbstractDerivationID of this class. Used to find out "what something is". |
0x30 | int | GetSize | none | Gets the size of the member data. |
0x34 | unsigned long | GetCRC | unknown | Calculates a CRC sum of this instance. |
0x38 | int | GetOwningHouseIndex | none | Gets the index of the House (player) who owns this object. |
0x3C | HouseClass* | GetOwningHouse | none | Gets a pointer to the House (player) who owns this object. |
0x40 | int | GetArrayIndex | none | Gets the index of this class instance in the global array. This will return 0 for abstract classes. |
0x44 | bool | IsDead | none | Finds out whether this instance is dead. This is only used for "living" objects with a health. |
0x48 | void | Get3DCoords | int* dst_xyz | Loads 3D coordinates into dst_xyz. |
0x4C | void | Get3DCoords_var | int* dst_xyz | Loads 3D coordinates into variables, then into dst_xyz. This method is obsolete (use 0x48). |
0x50 | unknown | unknown | unknown | |
0x54 | unknown | unknown | unknown | |
0x58 | unknown | unknown | unknown | |
0x5C | void | AdvanceFrame | none | This is an updating routine, called every frame. |
AbstractTypeClass: | ||||
0x60 | unknown | unknown | unknown | |
0x64 | bool | LoadFromINI | CCINIClass* ini | Initializes the type based on the INI file section ID. |
0x68 | bool | SaveToINI | CCINIClass* ini | Saves this type to an INI file. |
AbstractClass - Virtual Table |
AbstractTypeClass - Virtual Table |
Member functions
Address (YR 1.001) | Return Type | Name | Arguments | Description |
---|---|---|---|---|
0x6A4550 | ptr (CTOR) | Constructor | char* ID | Creates an instance. |