/* * This file is part of OpenTTD. * OpenTTD is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, version 2. * OpenTTD is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. * See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with OpenTTD. If not, see . */ /** @file bridge_signal_map.h Map accessor functions for bridge signal simulation. */ #ifndef BRIDGE_SIGNAL_MAP_H #define BRIDGE_SIGNAL_MAP_H #include "tile_type.h" #include "map_func.h" #include "signal_type.h" #include "core/bitmath_func.hpp" #include "3rdparty/cpp-btree/btree_set.h" #include #include struct LongBridgeSignalStorage { std::vector signal_red_bits; }; extern std::unordered_map _long_bridge_signal_sim_map; extern btree::btree_set _bridge_signal_style_map; SignalState GetBridgeEntranceSimulatedSignalStateExtended(TileIndex t, uint16_t signal); enum { BRIDGE_M2_SIGNAL_STATE_COUNT = 11, BRIDGE_M2_SIGNAL_STATE_FIELD_SIZE = 12, BRIDGE_M2_SIGNAL_STATE_OFFSET = 4, BRIDGE_M2_SIGNAL_STATE_EXT_FLAG = 0x8000, }; inline SignalState GetBridgeEntranceSimulatedSignalState(TileIndex t, uint16_t signal) { if (signal < BRIDGE_M2_SIGNAL_STATE_COUNT) { return GB(_m[t].m2, signal + BRIDGE_M2_SIGNAL_STATE_OFFSET, 1) ? SIGNAL_STATE_RED : SIGNAL_STATE_GREEN; } else { return GetBridgeEntranceSimulatedSignalStateExtended(t, signal); } } void SetBridgeEntranceSimulatedSignalStateExtended(TileIndex t, uint16_t signal, SignalState state); inline void SetBridgeEntranceSimulatedSignalState(TileIndex t, uint16_t signal, SignalState state) { if (signal < BRIDGE_M2_SIGNAL_STATE_COUNT) { SB(_m[t].m2, signal + BRIDGE_M2_SIGNAL_STATE_OFFSET, 1, (state == SIGNAL_STATE_RED) ? 1 : 0); } else { SetBridgeEntranceSimulatedSignalStateExtended(t, signal, state); } } bool SetAllBridgeEntranceSimulatedSignalsGreenExtended(TileIndex t); inline bool SetAllBridgeEntranceSimulatedSignalsGreen(TileIndex t) { if (_m[t].m2 & BRIDGE_M2_SIGNAL_STATE_EXT_FLAG) { return SetAllBridgeEntranceSimulatedSignalsGreenExtended(t); } else { bool changed = GB(_m[t].m2, BRIDGE_M2_SIGNAL_STATE_OFFSET, BRIDGE_M2_SIGNAL_STATE_FIELD_SIZE) != 0; SB(_m[t].m2, BRIDGE_M2_SIGNAL_STATE_OFFSET, BRIDGE_M2_SIGNAL_STATE_FIELD_SIZE, 0); return changed; } } void ClearBridgeEntranceSimulatedSignalsExtended(TileIndex t); inline void ClearBridgeEntranceSimulatedSignals(TileIndex t) { if (_m[t].m2 & BRIDGE_M2_SIGNAL_STATE_EXT_FLAG) { ClearBridgeEntranceSimulatedSignalsExtended(t); } else { SB(_m[t].m2, BRIDGE_M2_SIGNAL_STATE_OFFSET, BRIDGE_M2_SIGNAL_STATE_FIELD_SIZE, 0); } } void ClearBridgeSimulatedSignalMapping(); void SetBridgeSignalStyle(TileIndex t, uint8_t style); inline uint8_t GetBridgeSignalStyle(TileIndex t) { if (likely(!HasBit(_m[t].m3, 7))) return 0; extern uint8_t GetBridgeSignalStyleExtended(TileIndex t); return GetBridgeSignalStyleExtended(t); } void ClearBridgeSignalStyleMapping(); void MarkSingleBridgeSignalDirty(TileIndex tile, TileIndex bridge_start_tile); #endif /* BRIDGE_SIGNAL_MAP_H */