mirror of
https://github.com/JGRennison/OpenTTD-patches.git
synced 2024-11-04 06:00:15 +00:00
ba34ec7ade
Replace build and refit, and group collapse implementations Fix template creation build and refit # Conflicts: # Makefile.bundle.in # config.lib # src/animated_tile.cpp # src/blitter/32bpp_anim.hpp # src/blitter/32bpp_base.hpp # src/blitter/8bpp_base.hpp # src/blitter/null.hpp # src/build_vehicle_gui.cpp # src/command.cpp # src/command_func.h # src/console_gui.cpp # src/core/smallstack_type.hpp # src/date.cpp # src/debug.cpp # src/genworld_gui.cpp # src/ground_vehicle.hpp # src/group_gui.cpp # src/lang/korean.txt # src/linkgraph/linkgraph_gui.h # src/main_gui.cpp # src/misc_gui.cpp # src/network/core/game.h # src/network/core/packet.cpp # src/network/core/udp.cpp # src/network/core/udp.h # src/network/network_content.cpp # src/network/network_type.h # src/network/network_udp.cpp # src/newgrf_house.h # src/openttd.cpp # src/order_cmd.cpp # src/order_gui.cpp # src/os/unix/crashlog_unix.cpp # src/os/windows/crashlog_win.cpp # src/osk_gui.cpp # src/pathfinder/opf/opf_ship.cpp # src/rail_cmd.cpp # src/rail_gui.cpp # src/saveload/saveload.cpp # src/settings.cpp # src/settings_gui.cpp # src/smallmap_gui.h # src/station_base.h # src/station_cmd.cpp # src/table/gameopt_settings.ini # src/table/newgrf_debug_data.h # src/table/settings.ini # src/timetable_gui.cpp # src/toolbar_gui.cpp # src/train_gui.cpp # src/vehicle.cpp # src/vehicle_gui.cpp # src/vehiclelist.cpp # src/viewport.cpp # src/widgets/dropdown.cpp # src/window_gui.h
140 lines
5.3 KiB
C++
140 lines
5.3 KiB
C++
/* $Id$ */
|
|
|
|
/*
|
|
* 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 town_type.h Types related to towns. */
|
|
|
|
#ifndef TOWN_TYPE_H
|
|
#define TOWN_TYPE_H
|
|
|
|
#include "core/enum_type.hpp"
|
|
#include "core/smallvec_type.hpp"
|
|
|
|
typedef uint16 TownID;
|
|
struct Town;
|
|
|
|
typedef std::vector<TownID> TownList;
|
|
|
|
/** Supported initial town sizes */
|
|
enum TownSize {
|
|
TSZ_SMALL, ///< Small town.
|
|
TSZ_MEDIUM, ///< Medium town.
|
|
TSZ_LARGE, ///< Large town.
|
|
TSZ_RANDOM, ///< Random size, bigger than small, smaller than large.
|
|
|
|
TSZ_END, ///< Number of available town sizes.
|
|
};
|
|
template <> struct EnumPropsT<TownSize> : MakeEnumPropsT<TownSize, byte, TSZ_SMALL, TSZ_END, TSZ_END, 2> {};
|
|
|
|
enum Ratings {
|
|
/* These refer to the maximums, so Appalling is -1000 to -400
|
|
* MAXIMUM RATINGS BOUNDARIES */
|
|
RATING_MINIMUM = -1000,
|
|
RATING_APPALLING = -400,
|
|
RATING_VERYPOOR = -200,
|
|
RATING_POOR = 0,
|
|
RATING_MEDIOCRE = 200,
|
|
RATING_GOOD = 400,
|
|
RATING_VERYGOOD = 600,
|
|
RATING_EXCELLENT = 800,
|
|
RATING_OUTSTANDING = 1000, ///< OUTSTANDING
|
|
|
|
RATING_MAXIMUM = RATING_OUTSTANDING,
|
|
|
|
RATING_INITIAL = 500, ///< initial rating
|
|
|
|
/* RATINGS AFFECTING NUMBERS */
|
|
RATING_TREE_DOWN_STEP = -35,
|
|
RATING_TREE_MINIMUM = RATING_MINIMUM,
|
|
RATING_TREE_UP_STEP = 7,
|
|
RATING_TREE_MAXIMUM = 220,
|
|
|
|
RATING_GROWTH_UP_STEP = 5, ///< when a town grows, all companies have rating increased a bit ...
|
|
RATING_GROWTH_MAXIMUM = RATING_MEDIOCRE, ///< ... up to RATING_MEDIOCRE
|
|
RATING_STATION_UP_STEP = 12, ///< when a town grows, company gains reputation for all well serviced stations ...
|
|
RATING_STATION_DOWN_STEP = -15, ///< ... but loses for badly serviced stations
|
|
|
|
RATING_TUNNEL_BRIDGE_DOWN_STEP = -250, ///< penalty for removing town owned tunnel or bridge
|
|
RATING_TUNNEL_BRIDGE_MINIMUM = 0, ///< minimum rating after removing tunnel or bridge
|
|
RATING_TUNNEL_BRIDGE_NEEDED_PERMISSIVE = 144, ///< rating needed, "Permissive" difficulty settings
|
|
RATING_TUNNEL_BRIDGE_NEEDED_NEUTRAL = 208, ///< "Neutral"
|
|
RATING_TUNNEL_BRIDGE_NEEDED_HOSTILE = 400, ///< "Hostile"
|
|
|
|
RATING_ROAD_DOWN_STEP_INNER = -50, ///< removing a roadpiece in the middle
|
|
RATING_ROAD_DOWN_STEP_EDGE = -18, ///< removing a roadpiece at the edge
|
|
RATING_ROAD_MINIMUM = -100, ///< minimum rating after removing town owned road
|
|
RATING_ROAD_NEEDED_PERMISSIVE = 16, ///< rating needed, "Permissive" difficulty settings
|
|
RATING_ROAD_NEEDED_NEUTRAL = 64, ///< "Neutral"
|
|
RATING_ROAD_NEEDED_HOSTILE = 112, ///< "Hostile"
|
|
|
|
RATING_HOUSE_MINIMUM = RATING_MINIMUM,
|
|
|
|
RATING_BRIBE_UP_STEP = 200,
|
|
RATING_BRIBE_MAXIMUM = 800,
|
|
RATING_BRIBE_DOWN_TO = -50 // XXX SHOULD BE SOMETHING LOWER?
|
|
};
|
|
|
|
/**
|
|
* Town Layouts
|
|
*/
|
|
enum TownLayout {
|
|
TL_BEGIN = 0,
|
|
TL_ORIGINAL = 0, ///< Original algorithm (min. 1 distance between roads)
|
|
TL_BETTER_ROADS, ///< Extended original algorithm (min. 2 distance between roads)
|
|
TL_2X2_GRID, ///< Geometric 2x2 grid algorithm
|
|
TL_3X3_GRID, ///< Geometric 3x3 grid algorithm
|
|
|
|
TL_RANDOM, ///< Random town layout
|
|
|
|
NUM_TLS, ///< Number of town layouts
|
|
};
|
|
template <> struct EnumPropsT<TownLayout> : MakeEnumPropsT<TownLayout, byte, TL_BEGIN, NUM_TLS, NUM_TLS, 3> {};
|
|
/** It needs to be 8bits, because we save and load it as such */
|
|
typedef SimpleTinyEnumT<TownLayout, byte> TownLayoutByte; // typedefing-enumification of TownLayout
|
|
|
|
/** Town founding setting values */
|
|
enum TownFounding {
|
|
TF_BEGIN = 0, ///< Used for iterations and limit testing
|
|
TF_FORBIDDEN = 0, ///< Forbidden
|
|
TF_ALLOWED, ///< Allowed
|
|
TF_CUSTOM_LAYOUT, ///< Allowed, with custom town layout
|
|
TF_END, ///< Used for iterations and limit testing
|
|
};
|
|
/** It needs to be 8bits, because we save and load it as such */
|
|
typedef SimpleTinyEnumT<TownFounding, byte> TownFoundingByte;
|
|
|
|
/** Town cargo generation modes */
|
|
enum TownCargoGenMode : byte {
|
|
TCGM_BEGIN = 0,
|
|
TCGM_ORIGINAL = 0, ///< Original algorithm (quadratic cargo by population)
|
|
TCGM_BITCOUNT, ///< Bit-counted algorithm (normal distribution from individual house population)
|
|
TCGM_END,
|
|
};
|
|
|
|
static const uint MAX_LENGTH_TOWN_NAME_CHARS = 32; ///< The maximum length of a town name in characters including '\0'
|
|
|
|
/** Store the maximum and actually transported cargo amount for the current and the last month. */
|
|
template <typename Tstorage>
|
|
struct TransportedCargoStat {
|
|
Tstorage old_max; ///< Maximum amount last month
|
|
Tstorage new_max; ///< Maximum amount this month
|
|
Tstorage old_act; ///< Actually transported last month
|
|
Tstorage new_act; ///< Actually transported this month
|
|
|
|
TransportedCargoStat() : old_max(0), new_max(0), old_act(0), new_act(0) {}
|
|
|
|
/** Update stats for a new month. */
|
|
void NewMonth()
|
|
{
|
|
this->old_max = this->new_max; this->new_max = 0;
|
|
this->old_act = this->new_act; this->new_act = 0;
|
|
}
|
|
};
|
|
|
|
#endif /* TOWN_TYPE_H */
|