libcmo21/LibCmo/XContainer/XTypes.hpp

75 lines
2.2 KiB
C++
Raw Normal View History

2023-08-22 15:30:26 +08:00
#pragma once
#include <string>
#include <vector>
#include <unordered_map>
#include <cstring>
#include <cinttypes>
#include "../CK2/CKTypes.hpp"
/**
* @brief The X container part of LibCmo.
* These classes are prefixed with X in original Virtools SDK.
*/
namespace LibCmo::XContainer {
/**
@brief Class representation of a string (an array of character ended by NULL).
@remark This class now use std::string.
*/
using XString = std::string;
/**
@brief Set of bit flags.
@remark This class now use specialized std::vector<bool>.
*/
using XBitArray = std::vector<bool>;
/**
@brief Class representation of an array.
@tparam T Element Type.
2023-08-25 17:35:45 +08:00
@remark
+ This class now use std::vector<T>.
+ XSArray, XClassArray now redirect to this.
2023-08-22 15:30:26 +08:00
*/
template<typename T>
using XArray = std::vector<T>;
/**
@brief Container class for CKObject Id's.
@remark
+ This class use the template container XArray to contain object CK_ID's.
+ Supports for Check, Load, Save, Add, Remove, Find functions in the Object CK_ID array.
2023-08-25 17:35:45 +08:00
+ XSObjectArray now redirect to this.
2023-08-22 15:30:26 +08:00
@todo May independ this class to implement the functions introduced in remarks.
*/
using XObjectArray = XArray<CK2::CK_ID>;
/**
@brief Container class for CKObject pointers.
@remark
+ Exactly same as XObjectArray class, but uses XArray (Pre-allocated items)
for storing pointers, and not IDs (more efficient to retrieve the objects).
+ Supports for Check, Load, Save, Add, Remove, Find functions in the CKObject Pointer array.
2023-08-25 17:35:45 +08:00
+ XSObjectPointerArray now redirect to this.
2023-08-22 15:30:26 +08:00
@todo May independ this class to implement the functions introduced in remarks.
@see XObjectArray, CKObjectArray
*/
using XObjectPointerArray = XArray<CK2::ObjImpls::CKObject*>;
2023-08-22 15:30:26 +08:00
/**
@brief Class representation of an Hash Table container.
@tparam K The type of the key
@tparam T The type of element to insert
@tparam H The hash function to hash the key
@tparam Eq The equal function to the key
2023-08-25 17:35:45 +08:00
@remark
+ This class now use std::unordered_map<T>.
+ XNHashTable, XSHashTable now redirect to this.
2023-08-22 15:30:26 +08:00
*/
template<class K, class T, class H = std::hash<K>, class Eq = std::equal_to<K>>
using XHashTable = std::unordered_map<K, T, H, Eq>;
}