/* $Id$ */ /** @file rail_type.h The different types of rail */ #ifndef RAIL_TYPE_H #define RAIL_TYPE_H #include "core/enum_type.hpp" typedef uint32 RailTypeLabel; /** * Enumeration for all possible railtypes. * * This enumeration defines all 4 possible railtypes. */ enum RailType { RAILTYPE_BEGIN = 0, ///< Used for iterations RAILTYPE_RAIL = 0, ///< Standard non-electric rails RAILTYPE_ELECTRIC = 1, ///< Electric rails RAILTYPE_MONO = 2, ///< Monorail RAILTYPE_MAGLEV = 3, ///< Maglev RAILTYPE_END, ///< Used for iterations INVALID_RAILTYPE = 0xFF ///< Flag for invalid railtype }; /** Allow incrementing of Track variables */ DECLARE_POSTFIX_INCREMENT(RailType); /** Define basic enum properties */ template <> struct EnumPropsT : MakeEnumPropsT {}; typedef TinyEnumT RailTypeByte; /** * The different roadtypes we support, but then a bitmask of them */ enum RailTypes { RAILTYPES_NONE = 0, ///< No rail types RAILTYPES_RAIL = 1 << RAILTYPE_RAIL, ///< Non-electrified rails RAILTYPES_ELECTRIC = 1 << RAILTYPE_ELECTRIC, ///< Electrified rails RAILTYPES_MONO = 1 << RAILTYPE_MONO, ///< Monorail! RAILTYPES_MAGLEV = 1 << RAILTYPE_MAGLEV, ///< Ever fast maglev INVALID_RAILTYPES = UINT_MAX ///< Invalid railtypes }; DECLARE_ENUM_AS_BIT_SET(RailTypes); #endif /* RAIL_TYPE_H */