1 #ifndef GAMES_COREMINER_TILE_H
2 #define GAMES_COREMINER_TILE_H
14 #include <unordered_map>
16 #include <initializer_list>
18 #include "../../joueur/src/any.hpp"
20 #include "game_object.hpp"
22 #include "impl/coreminer_fwd.hpp"
165 Tile_(std::initializer_list<std::pair<std::string, Any&&>> init);
166 Tile_() : Tile_({}){}
167 virtual void resize(
const std::string& name, std::size_t size)
override;
168 virtual void change_vec_values(
const std::string& name, std::vector<std::pair<std::size_t, Any>>& values)
override;
169 virtual void remove_key(
const std::string& name, Any& key)
override;
170 virtual std::unique_ptr<Any> add_key_value(
const std::string& name, Any& key, Any& value)
override;
171 virtual bool is_map(
const std::string& name)
override;
172 virtual void rebind_by_name(Any* to_change,
const std::string& member, std::shared_ptr<Base_object> ref)
override;
183 #endif // GAMES_COREMINER_TILE_H
const bool & is_base
Whether or not the Tile is a base Tile.
Definition: tile.hpp:54
const std::vector< Bomb > & bombs
An array of Bombs on this Tile.
Definition: tile.hpp:44
const bool & is_falling
Whether or not this Tile is about to fall after this turn.
Definition: tile.hpp:59
const Tile & tile_east
The Tile to the 'East' of this one (x+1, y). Null if out of bounds of the map.
Definition: tile.hpp:99
const bool & is_ladder
Whether or not a ladder is built on this Tile.
Definition: tile.hpp:69
const bool & is_hopper
Whether or not a hopper is on this Tile.
Definition: tile.hpp:64
const std::vector< Miner > & miners
An array of the Miners on this Tile.
Definition: tile.hpp:79
const bool & is_support
Whether or not a support is built on this Tile.
Definition: tile.hpp:74
const int & y
The y (vertical) position of this Tile.
Definition: tile.hpp:124
const Player & owner
The owner of this Tile, or undefined if owned by no-one.
Definition: tile.hpp:89
bool is_pathable()
Checks if a Tile is pathable to units
const Tile & tile_south
The Tile to the 'South' of this one (x, y+1). Null if out of bounds of the map.
Definition: tile.hpp:109
std::vector< Tile > get_neighbors()
Gets the neighbors of this Tile
bool has_neighbor(const Tile &tile)
Checks if this Tile has a specific neighboring Tile
static const std::vector< std::string > directions
The list of all valid directions Tiles can be in
Definition: tile.hpp:134
const Tile & tile_north
The Tile to the 'North' of this one (x, y-1). Null if out of bounds of the map.
Definition: tile.hpp:104
const Tile & tile_west
The Tile to the 'West' of this one (x-1, y). Null if out of bounds of the map.
Definition: tile.hpp:114
const int & x
The x (horizontal) position of this Tile.
Definition: tile.hpp:119
An object in the game. The most basic class that all game classes should inherit from automatically...
Definition: game_object.hpp:37
A Tile in the game that makes up the 2D map grid.
Definition: tile.hpp:37
const int & dirt
The amount of dirt on this Tile.
Definition: tile.hpp:49
const int & ore
The amount of ore on this Tile.
Definition: tile.hpp:84
const int & shielding
The amount of shielding on this Tile.
Definition: tile.hpp:94
A player in this game. Every AI controls one player.
Definition: player.hpp:37