Add: AI/GS Time Mode to choose between economy (default) and calendar time (#11603)

(cherry picked from commit bbdbf9a589)
This commit is contained in:
Tyler Trahan
2024-01-23 10:42:10 -05:00
committed by Jonathan G Rennison
parent 1f5b35fac4
commit b5b12da91b
9 changed files with 129 additions and 5 deletions

View File

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