2007-05-19 09:40:18 +00:00
|
|
|
/* $Id$ */
|
|
|
|
|
|
|
|
/** @file group.h */
|
|
|
|
|
|
|
|
#ifndef GROUP_H
|
|
|
|
#define GROUP_H
|
|
|
|
|
|
|
|
#include "oldpool.h"
|
|
|
|
|
|
|
|
enum {
|
2007-07-14 23:10:27 +00:00
|
|
|
ALL_GROUP = 0xFFFD,
|
2007-05-19 09:40:18 +00:00
|
|
|
DEFAULT_GROUP = 0xFFFE,
|
|
|
|
INVALID_GROUP = 0xFFFF,
|
|
|
|
};
|
|
|
|
|
|
|
|
struct Group {
|
|
|
|
StringID string_id; ///< Group Name
|
|
|
|
|
|
|
|
uint16 num_vehicle; ///< Number of vehicles wich belong to the group
|
|
|
|
PlayerID owner; ///< Group Owner
|
|
|
|
GroupID index; ///< Array index
|
|
|
|
VehicleTypeByte vehicle_type; ///< Vehicle type of the group
|
|
|
|
|
|
|
|
bool replace_protection; ///< If set to true, the global autoreplace have no effect on the group
|
|
|
|
uint16 num_engines[TOTAL_NUM_ENGINES]; ///< Caches the number of engines of each type the player owns (no need to save this)
|
|
|
|
};
|
|
|
|
|
|
|
|
DECLARE_OLD_POOL(Group, Group, 5, 2047)
|
|
|
|
|
|
|
|
|
|
|
|
static inline bool IsValidGroup(const Group *g)
|
|
|
|
{
|
|
|
|
return g->string_id != STR_NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void DestroyGroup(Group *g)
|
|
|
|
{
|
|
|
|
DeleteName(g->string_id);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void DeleteGroup(Group *g)
|
|
|
|
{
|
|
|
|
DestroyGroup(g);
|
|
|
|
g->string_id = STR_NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline bool IsValidGroupID(GroupID index)
|
|
|
|
{
|
|
|
|
return index < GetGroupPoolSize() && IsValidGroup(GetGroup(index));
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline bool IsDefaultGroupID(GroupID index)
|
|
|
|
{
|
2007-07-14 23:10:27 +00:00
|
|
|
return index == DEFAULT_GROUP;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Checks if a GroupID stands for all vehicles of a player
|
|
|
|
* @param id_g The GroupID to check
|
|
|
|
* @return true is id_g is identical to ALL_GROUP
|
|
|
|
*/
|
|
|
|
static inline bool IsAllGroupID(GroupID id_g)
|
|
|
|
{
|
|
|
|
return id_g == ALL_GROUP;
|
2007-05-19 09:40:18 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#define FOR_ALL_GROUPS_FROM(g, start) for (g = GetGroup(start); g != NULL; g = (g->index + 1U < GetGroupPoolSize()) ? GetGroup(g->index + 1) : NULL) if (IsValidGroup(g))
|
|
|
|
#define FOR_ALL_GROUPS(g) FOR_ALL_GROUPS_FROM(g, 0)
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the current size of the GroupPool
|
|
|
|
*/
|
|
|
|
static inline uint GetGroupArraySize(void)
|
|
|
|
{
|
|
|
|
const Group *g;
|
|
|
|
uint num = 0;
|
|
|
|
|
|
|
|
FOR_ALL_GROUPS(g) num++;
|
|
|
|
|
|
|
|
return num;
|
|
|
|
}
|
|
|
|
|
2007-07-14 23:10:27 +00:00
|
|
|
/**
|
|
|
|
* Get the number of engines with EngineID id_e in the group with GroupID
|
|
|
|
* id_g
|
|
|
|
* @param id_g The GroupID of the group used
|
|
|
|
* @param id_e The EngineID of the engine to count
|
|
|
|
* @return The number of engines with EngineID id_e in the group
|
|
|
|
*/
|
|
|
|
static inline uint GetGroupNumEngines(GroupID id_g, EngineID id_e)
|
|
|
|
{
|
|
|
|
if (IsValidGroupID(id_g)) return GetGroup(id_g)->num_engines[id_e];
|
|
|
|
|
|
|
|
uint num = GetPlayer(_local_player)->num_engines[id_e];
|
|
|
|
if (!IsDefaultGroupID(id_g)) return num;
|
|
|
|
|
|
|
|
const Group *g;
|
|
|
|
FOR_ALL_GROUPS(g) num -= g->num_engines[id_e];
|
|
|
|
return num;
|
|
|
|
}
|
|
|
|
|
2007-05-19 09:40:18 +00:00
|
|
|
static inline void IncreaseGroupNumVehicle(GroupID id_g)
|
|
|
|
{
|
|
|
|
if (IsValidGroupID(id_g)) GetGroup(id_g)->num_vehicle++;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void DecreaseGroupNumVehicle(GroupID id_g)
|
|
|
|
{
|
|
|
|
if (IsValidGroupID(id_g)) GetGroup(id_g)->num_vehicle--;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void InitializeGroup();
|
|
|
|
void SetTrainGroupID(Vehicle *v, GroupID grp);
|
|
|
|
void UpdateTrainGroupID(Vehicle *v);
|
|
|
|
void RemoveVehicleFromGroup(const Vehicle *v);
|
|
|
|
void RemoveAllGroupsForPlayer(const Player *p);
|
|
|
|
|
|
|
|
#endif /* GROUP_H */
|