summaryrefslogtreecommitdiff
path: root/src/script/api/script_basestation.hpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/script/api/script_basestation.hpp')
-rw-r--r--src/script/api/script_basestation.hpp78
1 files changed, 78 insertions, 0 deletions
diff --git a/src/script/api/script_basestation.hpp b/src/script/api/script_basestation.hpp
new file mode 100644
index 000000000..b26dbaecc
--- /dev/null
+++ b/src/script/api/script_basestation.hpp
@@ -0,0 +1,78 @@
+/* $Id$ */
+
+/*
+ * 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 <http://www.gnu.org/licenses/>.
+ */
+
+/** @file script_basestation.hpp Base for stations/waypoint handling. */
+
+#ifndef SCRIPT_BASESTATION_HPP
+#define SCRIPT_BASESTATION_HPP
+
+#include "script_error.hpp"
+
+/**
+ * Base class for stations and waypoints.
+ */
+class AIBaseStation : public AIObject {
+public:
+ /**
+ * Special station IDs for building adjacent/new stations when
+ * the adjacent/distant join features are enabled.
+ */
+ enum SpecialStationIDs {
+ STATION_NEW = 0xFFFD, ///< Build a new station
+ STATION_JOIN_ADJACENT = 0xFFFE, ///< Join an neighbouring station if one exists
+ STATION_INVALID = 0xFFFF, ///< Invalid station id.
+ };
+
+ /**
+ * Checks whether the given basestation is valid and owned by you.
+ * @param station_id The station to check.
+ * @return True if and only if the basestation is valid.
+ * @note IsValidBaseStation == (IsValidStation || IsValidWaypoint).
+ */
+ static bool IsValidBaseStation(StationID station_id);
+
+ /**
+ * Get the name of a basestation.
+ * @param station_id The basestation to get the name of.
+ * @pre IsValidBaseStation(station_id).
+ * @return The name of the station.
+ */
+ static char *GetName(StationID station_id);
+
+ /**
+ * Set the name this basestation.
+ * @param station_id The basestation to set the name of.
+ * @param name The new name of the station.
+ * @pre IsValidBaseStation(station_id).
+ * @pre 'name' must have at least one character.
+ * @pre 'name' must have at most 30 characters.
+ * @exception AIError::ERR_NAME_IS_NOT_UNIQUE
+ * @return True if the name was changed.
+ */
+ static bool SetName(StationID station_id, const char *name);
+
+ /**
+ * Get the current location of a basestation.
+ * @param station_id The basestation to get the location of.
+ * @pre IsValidBaseStation(station_id).
+ * @return The tile the basestation sign above it.
+ * @note The tile is not necessarily a station tile (and if it is, it could also belong to another station).
+ * @see AITileList_StationType.
+ */
+ static TileIndex GetLocation(StationID station_id);
+
+ /**
+ * Get the last date a station part was added to this station.
+ * @param station_id The station to look at.
+ * @return The last date some part of this station was build.
+ */
+ static int32 GetConstructionDate(StationID station_id);
+};
+
+#endif /* SCRIPT_BASESTATION_HPP */