mirror of
https://github.com/JGRennison/OpenTTD-patches.git
synced 2024-11-09 19:10:38 +00:00
e97bf271dc
This avoids a (soft) namespace conflict between the four ST_* enums.
70 lines
3.2 KiB
C
70 lines
3.2 KiB
C
/*
|
|
* 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 subsidy_base.h %Subsidy base class. */
|
|
|
|
#ifndef SUBSIDY_BASE_H
|
|
#define SUBSIDY_BASE_H
|
|
|
|
#include "cargo_type.h"
|
|
#include "company_type.h"
|
|
#include "subsidy_type.h"
|
|
#include "core/pool_type.hpp"
|
|
|
|
typedef Pool<Subsidy, SubsidyID, 1, 256> SubsidyPool;
|
|
extern SubsidyPool _subsidy_pool;
|
|
|
|
/** Struct about subsidies, offered and awarded */
|
|
struct Subsidy : SubsidyPool::PoolItem<&_subsidy_pool> {
|
|
CargoID cargo_type; ///< Cargo type involved in this subsidy, CT_INVALID for invalid subsidy
|
|
uint16 remaining; ///< Remaining months when this subsidy is valid
|
|
CompanyID awarded; ///< Subsidy is awarded to this company; INVALID_COMPANY if it's not awarded to anyone
|
|
SourceType src_type; ///< Source of subsidised path (SourceType::Industry or SourceType::Town)
|
|
SourceType dst_type; ///< Destination of subsidised path (SourceType::Industry or SourceType::Town)
|
|
SourceID src; ///< Index of source. Either TownID or IndustryID
|
|
SourceID dst; ///< Index of destination. Either TownID or IndustryID
|
|
|
|
/**
|
|
* We need an (empty) constructor so struct isn't zeroed (as C++ standard states)
|
|
*/
|
|
inline Subsidy() { }
|
|
|
|
/**
|
|
* (Empty) destructor has to be defined else operator delete might be called with nullptr parameter
|
|
*/
|
|
inline ~Subsidy() { }
|
|
|
|
/**
|
|
* Tests whether this subsidy has been awarded to someone
|
|
* @return is this subsidy awarded?
|
|
*/
|
|
inline bool IsAwarded() const
|
|
{
|
|
return this->awarded != INVALID_COMPANY;
|
|
}
|
|
|
|
void AwardTo(CompanyID company);
|
|
};
|
|
|
|
/** Constants related to subsidies */
|
|
static const uint SUBSIDY_OFFER_MONTHS = 12; ///< Duration of subsidy offer
|
|
static const uint SUBSIDY_PAX_MIN_POPULATION = 400; ///< Min. population of towns for subsidised pax route
|
|
static const uint SUBSIDY_CARGO_MIN_POPULATION = 900; ///< Min. population of destination town for cargo route
|
|
static const uint SUBSIDY_MAX_PCT_TRANSPORTED = 42; ///< Subsidy will be created only for towns/industries with less % transported
|
|
static const uint SUBSIDY_MAX_DISTANCE = 70; ///< Max. length of subsidised route (DistanceManhattan)
|
|
static const uint SUBSIDY_TOWN_CARGO_RADIUS = 6; ///< Extent of a tile area around town center when scanning for town cargo acceptance and production (6 ~= min catchmement + min station / 2)
|
|
|
|
/** Types of subsidy news messages, which determine how the date is printed and whether to use singular or plural cargo names */
|
|
enum class SubsidyDecodeParamType {
|
|
NewsOffered = 0, ///< News item for an offered subsidy
|
|
NewsAwarded = 1, ///< News item for an awarded subsidy
|
|
NewsWithdrawn = 2, ///< News item for a subsidy offer withdrawn, or expired subsidy
|
|
Gui = 3, ///< Subsidies listed in the Subsidy GUI
|
|
};
|
|
|
|
#endif /* SUBSIDY_BASE_H */
|