Add cheat to fix station ratings at 100%

pull/239/head
Jonathan G Rennison 3 years ago
parent d0159f2452
commit f1cab62140

@ -185,10 +185,11 @@ static const CheatEntry _cheats_ui[] = {
{CNM_ALL, SLE_BOOL, STR_CHEAT_CROSSINGTUNNELS, &_cheats.crossing_tunnels.value, &_cheats.crossing_tunnels.been_used, nullptr },
{CNM_ALL, SLE_BOOL, STR_CHEAT_NO_JETCRASH, &_cheats.no_jetcrash.value, &_cheats.no_jetcrash.been_used, nullptr },
{CNM_LOCAL_ONLY, SLE_BOOL, STR_CHEAT_SETUP_PROD, &_cheats.setup_prod.value, &_cheats.setup_prod.been_used, &ClickSetProdCheat },
{CNM_LOCAL_ONLY, SLE_UINT8, STR_CHEAT_EDIT_MAX_HL, &_settings_game.construction.map_height_limit, &_cheats.edit_max_hl.been_used, &ClickChangeMaxHlCheat },
{CNM_LOCAL_ONLY, SLE_UINT8, STR_CHEAT_EDIT_MAX_HL, &_settings_game.construction.map_height_limit, &_cheats.edit_max_hl.been_used, &ClickChangeMaxHlCheat },
{CNM_LOCAL_ONLY, SLE_INT32, STR_CHEAT_CHANGE_DATE, &_cur_date_ymd.year, &_cheats.change_date.been_used, &ClickChangeDateCheat },
{CNM_ALL, SLF_NOT_IN_SAVE, STR_CHEAT_INFLATION_COST, &_economy.inflation_prices, &_extra_cheats.inflation_cost.been_used, nullptr },
{CNM_ALL, SLF_NOT_IN_SAVE, STR_CHEAT_INFLATION_INCOME, &_economy.inflation_payment, &_extra_cheats.inflation_income.been_used, nullptr },
{CNM_ALL, SLE_BOOL, STR_CHEAT_STATION_RATING, &_extra_cheats.station_rating.value, &_extra_cheats.station_rating.been_used, nullptr },
};
static bool IsCheatAllowed(CheatNetworkMode mode)
@ -439,7 +440,7 @@ struct CheatWindow : Window {
}
if (value != oldvalue) {
if (_networking) {
if (_networking || btn == CHT_STATION_RATING) {
if (btn != CHT_MONEY) DoCommandP(0, (uint32)btn, (uint32)value, CMD_CHEAT_SETTING);
} else {
WriteValue(ce->variable, ce->type, (int64)value);

@ -40,6 +40,7 @@ struct Cheats {
struct ExtraCheats {
Cheat inflation_cost; ///< inflation cost factor
Cheat inflation_income; ///< inflation income factor
Cheat station_rating; ///< 100% station rating
};
/** Available cheats. */
@ -54,6 +55,7 @@ enum CheatNumbers {
CHT_CHANGE_DATE, ///< Do time traveling.
CHT_INFLATION_COST, ///< Change inflation cost factor
CHT_INFLATION_INCOME,///< Change inflation income factor
CHT_STATION_RATING, ///< 100% station ratings
CHT_NUM_CHEATS, ///< Number of cheats.
};

@ -2260,6 +2260,7 @@ STR_CHEAT_INFLATION_COST :{LTBLUE}Change
STR_CHEAT_INFLATION_COST_QUERY_CAPT :{WHITE}Change inflation cost factor
STR_CHEAT_INFLATION_INCOME :{LTBLUE}Change inflation income factor: {ORANGE}{DECIMAL}
STR_CHEAT_INFLATION_INCOME_QUERY_CAPT :{WHITE}Change inflation income factor
STR_CHEAT_STATION_RATING :{LTBLUE}Stations ratings fixed at 100%: {ORANGE}{STRING1}
# Livery window
STR_LIVERY_CAPTION :{WHITE}{COMPANY} - Colour Scheme

@ -282,6 +282,10 @@ CommandCost CmdCheatSetting(TileIndex tile, DoCommandFlag flags, uint32 p1, uint
}
return CommandCost();
case CHT_STATION_RATING:
cht = &_extra_cheats.station_rating;
break;
default:
return CMD_ERROR;
}
@ -289,6 +293,11 @@ CommandCost CmdCheatSetting(TileIndex tile, DoCommandFlag flags, uint32 p1, uint
cht->value = p2;
cht->been_used = true;
SetWindowDirty(WC_CHEATS, 0);
if (p1 == CHT_STATION_RATING) {
extern void UpdateAllStationRatings();
UpdateAllStationRatings();
}
}
return CommandCost();
}

@ -28,6 +28,7 @@ struct ExtraCheatNameDesc {
static ExtraCheatNameDesc _extra_cheat_descs[] = {
{ "inflation_cost", &_extra_cheats.inflation_cost },
{ "inflation_income", &_extra_cheats.inflation_income },
{ "station_rating", &_extra_cheats.station_rating },
};
/**

@ -57,6 +57,7 @@
#include "widgets/station_widget.h"
#include "zoning.h"
#include "tunnelbridge_map.h"
#include "cheat_type.h"
#include "table/strings.h"
@ -3809,7 +3810,10 @@ static void UpdateStationRating(Station *st)
*/
uint waiting_avg = waiting / (num_dests + 1);
if (HasBit(cs->callback_mask, CBM_CARGO_STATION_RATING_CALC)) {
if (_extra_cheats.station_rating.value) {
ge->rating = rating = 255;
skip = true;
} else if (HasBit(cs->callback_mask, CBM_CARGO_STATION_RATING_CALC)) {
/* Perform custom station rating. If it succeeds the speed, days in transit and
* waiting cargo ratings must not be executed. */
@ -4135,6 +4139,14 @@ static void StationHandleSmallTick(BaseStation *st)
if (b == 0) UpdateStationRating(Station::From(st));
}
void UpdateAllStationRatings()
{
for (Station *st : Station::Iterate()) {
if (!st->IsInUse()) continue;
UpdateStationRating(st);
}
}
void OnTick_Station()
{
if (_game_mode == GM_EDITOR) return;

Loading…
Cancel
Save