Revert bbdbf9a
: ScriptTimeMode was not the best solution for economy/calendar support
(cherry picked from commit 704e871a0e
)
# Conflicts:
# src/script/api/script_date.cpp
# src/script/script_storage.hpp
This commit is contained in:

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),
|
||||
|
Reference in New Issue
Block a user