Revert bbdbf9a: ScriptTimeMode was not the best solution for economy/calendar support

(cherry picked from commit 704e871a0eec119d27df1a5a21abb6f9da1cb8da)

# Conflicts:
#	src/script/api/script_date.cpp
#	src/script/script_storage.hpp
tmp-jgrpp
glx22 1 month ago committed by Jonathan G Rennison
parent 0b6d73fab2
commit 5b127ed23e

@ -151,7 +151,6 @@ add_files(
script_basestation.hpp
script_bridge.hpp
script_bridgelist.hpp
script_timemode.hpp
script_cargo.hpp
script_cargolist.hpp
script_cargomonitor.hpp
@ -227,7 +226,6 @@ add_files(
script_basestation.cpp
script_bridge.cpp
script_bridgelist.cpp
script_timemode.cpp
script_cargo.cpp
script_cargolist.cpp
script_cargomonitor.cpp

@ -20,7 +20,6 @@
* \b 14.0
*
* API additions:
* \li AITimeMode
* \li AITown::ROAD_LAYOUT_RANDOM
* \li AIVehicle::IsPrimaryVehicle
* \li AITileList_StationCoverage

@ -24,7 +24,6 @@
* \li GSAsyncMode
* \li GSCompanyMode::IsValid
* \li GSCompanyMode::IsDeity
* \li GSTimeMode
* \li GSTown::ROAD_LAYOUT_RANDOM
* \li GSVehicle::IsPrimaryVehicle
* \li GSOrder::SetOrderJumpTo

@ -9,7 +9,6 @@
#include "../../stdafx.h"
#include "script_date.hpp"
#include "script_timemode.hpp"
#include "../../date_func.h"
#include "../../settings_type.h"
@ -26,8 +25,6 @@
/* static */ ScriptDate::Date ScriptDate::GetCurrentDate()
{
if (ScriptTimeMode::IsCalendarMode()) return (ScriptDate::Date)::CalTime::CurDate().base();
return (ScriptDate::Date)EconTime::CurDate().base();
}
@ -40,11 +37,6 @@
{
if (date < 0) return DATE_INVALID;
if (ScriptTimeMode::IsCalendarMode()) {
::CalTime::YearMonthDay ymd = ::CalTime::ConvertDateToYMD(date);
return ymd.year.base();
}
::EconTime::YearMonthDay ymd = ::EconTime::ConvertDateToYMD(date);
return ymd.year.base();
}
@ -53,11 +45,6 @@
{
if (date < 0) return DATE_INVALID;
if (ScriptTimeMode::IsCalendarMode()) {
::CalTime::YearMonthDay ymd = ::CalTime::ConvertDateToYMD(date);
return ymd.month + 1;
}
::EconTime::YearMonthDay ymd = ::EconTime::ConvertDateToYMD(date);
return ymd.month + 1;
}
@ -66,11 +53,6 @@
{
if (date < 0) return DATE_INVALID;
if (ScriptTimeMode::IsCalendarMode()) {
::CalTime::YearMonthDay ymd = ::CalTime::ConvertDateToYMD(date);
return ymd.day;
}
::EconTime::YearMonthDay ymd = ::EconTime::ConvertDateToYMD(date);
return ymd.day;
}
@ -81,8 +63,6 @@
if (day_of_month < 1 || day_of_month > 31) return DATE_INVALID;
if (year < 0 || year > CalTime::MAX_YEAR) return DATE_INVALID;
if (ScriptTimeMode::IsCalendarMode()) return (ScriptDate::Date)::CalTime::ConvertYMDToDate(year, month - 1, day_of_month).base();
return (ScriptDate::Date)::EconTime::ConvertYMDToDate(year, month - 1, day_of_month).base();
}

@ -31,7 +31,7 @@ public:
* compose valid date values for a known year, month and day.
*/
enum Date {
DATE_INVALID = ::CalTime::INVALID_DATE.base(), ///< A value representing an invalid date.
DATE_INVALID = ::EconTime::INVALID_DATE.base(), ///< A value representing an invalid date.
};
/**

@ -277,16 +277,6 @@ ScriptObject::ActiveInstance::~ActiveInstance()
return GetStorage()->allow_do_command;
}
/* static */ void ScriptObject::SetTimeMode(bool calendar)
{
GetStorage()->time_mode = calendar;
}
/* static */ bool ScriptObject::IsCalendarTimeMode()
{
return GetStorage()->time_mode;
}
/* static */ void ScriptObject::SetCompany(CompanyID company)
{
if (GetStorage()->root_company == INVALID_OWNER) GetStorage()->root_company = company;

@ -255,20 +255,6 @@ protected:
*/
static bool GetAllowDoCommand();
/**
* Set if the script is running in calendar time or economy time mode.
* Calendar time is used by OpenTTD for technology like vehicle introductions and expiration, and variable snowline. It can be sped up or slowed down by the player.
* Economy time always runs at the same pace and handles things like cargo production, everything related to money, etc.
* @param Calendar Should we use calendar time mode? (Set to false for economy time mode.)
*/
static void SetTimeMode(bool calendar);
/**
* Check if the script is operating in calendar time mode, or in economy time mode. See SetTimeMode() for more information.
* @return True if we are in calendar time mode, false if we are in economy time mode.
*/
static bool IsCalendarTimeMode();
/**
* Set the current company to execute commands for or request
* information about.

@ -1,29 +0,0 @@
/*
* 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_timemode.cpp Implementation of ScriptTimeMode. */
#include "../../stdafx.h"
#include "script_timemode.hpp"
#include "../../safeguards.h"
ScriptTimeMode::ScriptTimeMode(bool calendar)
{
this->last_time_mode = ScriptObject::IsCalendarTimeMode();
ScriptObject::SetTimeMode(calendar);
}
ScriptTimeMode::~ScriptTimeMode()
{
ScriptObject::SetTimeMode(this->last_time_mode);
}
/* static */ bool ScriptTimeMode::IsCalendarMode()
{
return ScriptObject::IsCalendarTimeMode();
}

@ -1,45 +0,0 @@
/*
* 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_timemode.hpp Switch the time mode. */
#ifndef SCRIPT_TIMEMODE_HPP
#define SCRIPT_TIMEMODE_HPP
#include "script_object.hpp"
/**
* Class to switch the current time.
* If you create an instance of this class, the mode will be switched to either calendar time or economy time mode.
* @note Destroying this object will restore the previous time mode.
* @api ai game
*/
class ScriptTimeMode : public ScriptObject {
private:
bool last_time_mode; ///< The last time mode we were using.
public:
/**
* Creating an instance of this class switches the time mode used for queries and commands.
* Calendar time is used by OpenTTD for technology like vehicle introductions and expiration, and variable snowline. It can be sped up or slowed down by the player.
* Economy time always runs at the same pace and handles things like cargo production, everything related to money, etc.
* @param Calendar Should we use calendar time mode? (Set to false for economy time mode.)
*/
ScriptTimeMode(bool calendar);
/**
* Destroying this instance resets the time mode to the mode it was in when the instance was created.
*/
~ScriptTimeMode();
/**
* Check if the script is operating in calendar time mode, or in economy time mode. See ScriptTimeMode() for more information.
* @return True if we are in calendar time mode, false if we are in economy time mode.
*/
static bool IsCalendarMode();
};
#endif /* SCRIPT_TIMEMODE_HPP */

@ -43,7 +43,6 @@ private:
class ScriptObject *mode_instance; ///< The instance belonging to the current build mode.
ScriptAsyncModeProc *async_mode; ///< The current command async mode we are in.
class ScriptObject *async_mode_instance; ///< The instance belonging to the current command async mode.
bool time_mode; ///< True if we in calendar time mode, or false (default) if we are in economy time mode.
CompanyID root_company; ///< The root company, the company that the script really belongs to.
CompanyID company; ///< The current company.
@ -85,7 +84,6 @@ public:
mode_instance (nullptr),
async_mode (nullptr),
async_mode_instance (nullptr),
time_mode (false),
root_company (INVALID_OWNER),
company (INVALID_OWNER),
delay (1),

Loading…
Cancel
Save