author | rubidium |
Thu, 01 Feb 2007 15:49:12 +0000 | |
changeset 5893 | 7e431a4abebb |
parent 5890 | a5ba89d7f278 |
child 5896 | a9f7bdd841d4 |
permissions | -rw-r--r-- |
2186 | 1 |
/* $Id$ */ |
2 |
||
4549
106ed18a7675
(svn r6381) -Cleanup: make the '/* */' comments that span multiple lines more uniform.
rubidium
parents:
4528
diff
changeset
|
3 |
/** @file station_cmd.c */ |
2213
bab9abeaa644
(svn r2731) -Fix [ 1244171 ]: Hangar orders are now properly invalidated as soon as the airport is removed
celestar
parents:
2187
diff
changeset
|
4 |
|
0 | 5 |
#include "stdafx.h" |
1891
862800791170
(svn r2397) - CodeChange: rename all "ttd" files to "openttd" files.
Darkvater
parents:
1881
diff
changeset
|
6 |
#include "openttd.h" |
5385
3868f2e6db9b
(svn r7573) -Merged the bridge branch. Allows to build bridges of arbitrary rail/road combinations (including signals)
celestar
parents:
5380
diff
changeset
|
7 |
#include "bridge_map.h" |
1299
39c06aba09aa
(svn r1803) Move debugging stuff into files of it's own
tron
parents:
1295
diff
changeset
|
8 |
#include "debug.h" |
2163
b17b313113a0
(svn r2673) Include functions.h directly, not globally via openttd.h
tron
parents:
2148
diff
changeset
|
9 |
#include "functions.h" |
3315
c9d989783c55
(svn r4079) Add GetSation{Index,ByTile}() to get the station index resp. the station from a tile
tron
parents:
3282
diff
changeset
|
10 |
#include "station_map.h" |
1363
775a7ee52369
(svn r1867) Include tables/sprites.h only in files which need it
tron
parents:
1335
diff
changeset
|
11 |
#include "table/sprites.h" |
507
04b5403aaf6b
(svn r815) Include strings.h only in the files which need it.
tron
parents:
500
diff
changeset
|
12 |
#include "table/strings.h" |
679
04ca2cd69420
(svn r1117) Move map arrays and some related macros into their own files map.c and map.h
tron
parents:
595
diff
changeset
|
13 |
#include "map.h" |
1209
2e00193652b2
(svn r1713) Split off several functions which query/set information about a single tile from map.h and put them into a seperate file tile.h
tron
parents:
1190
diff
changeset
|
14 |
#include "tile.h" |
0 | 15 |
#include "station.h" |
16 |
#include "gfx.h" |
|
17 |
#include "window.h" |
|
18 |
#include "viewport.h" |
|
19 |
#include "command.h" |
|
20 |
#include "town.h" |
|
21 |
#include "vehicle.h" |
|
22 |
#include "news.h" |
|
23 |
#include "saveload.h" |
|
24 |
#include "economy.h" |
|
25 |
#include "player.h" |
|
26 |
#include "airport.h" |
|
405
415546028e8d
(svn r602) -newgrf: Move DrawTileSeqStruct & co and struct SpriteGroup to sprite.h (pasky)
darkvater
parents:
403
diff
changeset
|
27 |
#include "sprite.h" |
1313
f1013ec3d318
(svn r1817) -Codechange: Moved depot-functions to depot.c
truelight
parents:
1299
diff
changeset
|
28 |
#include "depot.h" |
2676
59b65b4fb480
(svn r3218) -Feature: Multiheaded train engines will now stay in the same train
bjarni
parents:
2671
diff
changeset
|
29 |
#include "train.h" |
3111
750f37699a13
(svn r3714) Add functions to turn tiles into water and shore tiles
tron
parents:
3102
diff
changeset
|
30 |
#include "water_map.h" |
3515
86dccaaef457
(svn r4367) CodeChange : Remove another direct map access in station_cmd.c. Replace an array of TileIndexDiffC by a use of loop with TileDiffXY. Thanks to Rubidium
belugas
parents:
3503
diff
changeset
|
31 |
#include "industry_map.h" |
3754
4c8cbaaa0bbe
(svn r4742) - Newstations: Add callbacks for building and drawing custom stations.
peter1138
parents:
3751
diff
changeset
|
32 |
#include "newgrf_callbacks.h" |
4c8cbaaa0bbe
(svn r4742) - Newstations: Add callbacks for building and drawing custom stations.
peter1138
parents:
3751
diff
changeset
|
33 |
#include "newgrf_station.h" |
3900
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
3884
diff
changeset
|
34 |
#include "yapf/yapf.h" |
4261
28670f743746
(svn r5887) -Cleanup: move date related functions, defines and variables to date.[ch]
rubidium
parents:
4231
diff
changeset
|
35 |
#include "date.h" |
5587
167d9a91ef02
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
rubidium
parents:
5584
diff
changeset
|
36 |
#include "helpers.hpp" |
5844
60231b36473e
(svn r8414) -Codechange: Use own AutoPtrT instead of std::auto_ptr.
KUDr
parents:
5837
diff
changeset
|
37 |
#include "misc/autoptr.hpp" |
5666
d0e00c728f41
(svn r8126) -Fix (r8125): missing #include fixes compilation error on g++ (still some warnings, working on it)
KUDr
parents:
5665
diff
changeset
|
38 |
|
1272
9aa073c64fc7
(svn r1776) -Add: Dynamic stations. You can now have up to 64k of stations
truelight
parents:
1266
diff
changeset
|
39 |
/** |
9aa073c64fc7
(svn r1776) -Add: Dynamic stations. You can now have up to 64k of stations
truelight
parents:
1266
diff
changeset
|
40 |
* Called if a new block is added to the station-pool |
9aa073c64fc7
(svn r1776) -Add: Dynamic stations. You can now have up to 64k of stations
truelight
parents:
1266
diff
changeset
|
41 |
*/ |
9aa073c64fc7
(svn r1776) -Add: Dynamic stations. You can now have up to 64k of stations
truelight
parents:
1266
diff
changeset
|
42 |
static void StationPoolNewBlock(uint start_item) |
9aa073c64fc7
(svn r1776) -Add: Dynamic stations. You can now have up to 64k of stations
truelight
parents:
1266
diff
changeset
|
43 |
{ |
9aa073c64fc7
(svn r1776) -Add: Dynamic stations. You can now have up to 64k of stations
truelight
parents:
1266
diff
changeset
|
44 |
Station *st; |
9aa073c64fc7
(svn r1776) -Add: Dynamic stations. You can now have up to 64k of stations
truelight
parents:
1266
diff
changeset
|
45 |
|
4346
66105d4f6e83
(svn r6047) -Codechange: FOR_ALL now _only_ loops valid items, and skips invalid ones
truelight
parents:
4344
diff
changeset
|
46 |
/* We don't use FOR_ALL here, because FOR_ALL skips invalid items. |
4348
d9ddb0558a48
(svn r6049) -Codechange: forgot EngineRenew in r6047
truelight
parents:
4346
diff
changeset
|
47 |
* TODO - This is just a temporary stage, this will be removed. */ |
4980 | 48 |
for (st = GetStation(start_item); st != NULL; st = (st->index + 1U < GetStationPoolSize()) ? GetStation(st->index + 1U) : NULL) st->index = start_item++; |
1272
9aa073c64fc7
(svn r1776) -Add: Dynamic stations. You can now have up to 64k of stations
truelight
parents:
1266
diff
changeset
|
49 |
} |
9aa073c64fc7
(svn r1776) -Add: Dynamic stations. You can now have up to 64k of stations
truelight
parents:
1266
diff
changeset
|
50 |
|
3587 | 51 |
static void StationPoolCleanBlock(uint start_item, uint end_item) |
52 |
{ |
|
53 |
uint i; |
|
54 |
||
55 |
for (i = start_item; i <= end_item; i++) { |
|
56 |
Station *st = GetStation(i); |
|
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
57 |
if (IsValidStation(st)) st->~Station(); |
3587 | 58 |
} |
59 |
} |
|
60 |
||
1284
e1969eb0227b
(svn r1788) -Add: Made RoadStops dynamic. You can now create up to 64k roadstops.
truelight
parents:
1272
diff
changeset
|
61 |
/** |
e1969eb0227b
(svn r1788) -Add: Made RoadStops dynamic. You can now create up to 64k roadstops.
truelight
parents:
1272
diff
changeset
|
62 |
* Called if a new block is added to the roadstop-pool |
e1969eb0227b
(svn r1788) -Add: Made RoadStops dynamic. You can now create up to 64k roadstops.
truelight
parents:
1272
diff
changeset
|
63 |
*/ |
e1969eb0227b
(svn r1788) -Add: Made RoadStops dynamic. You can now create up to 64k roadstops.
truelight
parents:
1272
diff
changeset
|
64 |
static void RoadStopPoolNewBlock(uint start_item) |
e1969eb0227b
(svn r1788) -Add: Made RoadStops dynamic. You can now create up to 64k roadstops.
truelight
parents:
1272
diff
changeset
|
65 |
{ |
e1969eb0227b
(svn r1788) -Add: Made RoadStops dynamic. You can now create up to 64k roadstops.
truelight
parents:
1272
diff
changeset
|
66 |
RoadStop *rs; |
e1969eb0227b
(svn r1788) -Add: Made RoadStops dynamic. You can now create up to 64k roadstops.
truelight
parents:
1272
diff
changeset
|
67 |
|
4346
66105d4f6e83
(svn r6047) -Codechange: FOR_ALL now _only_ loops valid items, and skips invalid ones
truelight
parents:
4344
diff
changeset
|
68 |
/* We don't use FOR_ALL here, because FOR_ALL skips invalid items. |
66105d4f6e83
(svn r6047) -Codechange: FOR_ALL now _only_ loops valid items, and skips invalid ones
truelight
parents:
4344
diff
changeset
|
69 |
* TODO - This is just a temporary stage, this will be removed. */ |
5718 | 70 |
for (rs = GetRoadStop(start_item); rs != NULL; rs = (rs->index + 1U < GetRoadStopPoolSize()) ? GetRoadStop(rs->index + 1U) : NULL) { |
71 |
rs->xy = INVALID_TILE; |
|
72 |
rs->index = start_item++; |
|
73 |
} |
|
1284
e1969eb0227b
(svn r1788) -Add: Made RoadStops dynamic. You can now create up to 64k roadstops.
truelight
parents:
1272
diff
changeset
|
74 |
} |
e1969eb0227b
(svn r1788) -Add: Made RoadStops dynamic. You can now create up to 64k roadstops.
truelight
parents:
1272
diff
changeset
|
75 |
|
5216
8bd14ee39af2
(svn r7331) - Codechange: Rename all memory pool macro's and types to "old pool", so the new pool implementation can be committed alongside it.
matthijs
parents:
5116
diff
changeset
|
76 |
DEFINE_OLD_POOL(Station, Station, StationPoolNewBlock, StationPoolCleanBlock) |
8bd14ee39af2
(svn r7331) - Codechange: Rename all memory pool macro's and types to "old pool", so the new pool implementation can be committed alongside it.
matthijs
parents:
5116
diff
changeset
|
77 |
DEFINE_OLD_POOL(RoadStop, RoadStop, RoadStopPoolNewBlock, NULL) |
1272
9aa073c64fc7
(svn r1776) -Add: Dynamic stations. You can now have up to 64k of stations
truelight
parents:
1266
diff
changeset
|
78 |
|
9aa073c64fc7
(svn r1776) -Add: Dynamic stations. You can now have up to 64k of stations
truelight
parents:
1266
diff
changeset
|
79 |
|
0 | 80 |
extern void UpdateAirplanesOnNewStation(Station *st); |
81 |
||
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
82 |
|
5836
a60d2114780e
(svn r8402) -Codechange: Move RoadStop-specific enums to the RoadStop class, and changed a one-member enum into a static const. Simplify their naming and add some doxygen-comments to RoadStop
celestar
parents:
5834
diff
changeset
|
83 |
RoadStop* GetRoadStopByTile(TileIndex tile, RoadStop::Type type) |
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
84 |
{ |
3315
c9d989783c55
(svn r4079) Add GetSation{Index,ByTile}() to get the station index resp. the station from a tile
tron
parents:
3282
diff
changeset
|
85 |
const Station* st = GetStationByTile(tile); |
2639 | 86 |
RoadStop* rs; |
87 |
||
5876 | 88 |
for (rs = st->GetPrimaryRoadStop(type); rs->xy != tile; rs = rs->next) { |
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
89 |
assert(rs->next != NULL); |
2639 | 90 |
} |
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
91 |
|
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
92 |
return rs; |
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
93 |
} |
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
94 |
|
5836
a60d2114780e
(svn r8402) -Codechange: Move RoadStop-specific enums to the RoadStop class, and changed a one-member enum into a static const. Simplify their naming and add some doxygen-comments to RoadStop
celestar
parents:
5834
diff
changeset
|
95 |
uint GetNumRoadStopsInStation(const Station* st, RoadStop::Type type) |
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
96 |
{ |
2549 | 97 |
uint num = 0; |
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
98 |
const RoadStop *rs; |
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
99 |
|
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
100 |
assert(st != NULL); |
5876 | 101 |
for (rs = st->GetPrimaryRoadStop(type); rs != NULL; rs = rs->next) num++; |
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
102 |
|
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
103 |
return num; |
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
104 |
} |
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
105 |
|
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
106 |
|
703
3f64a428fcbc
(svn r1153) -Fix: FindCatchmentRadius is now a function that uses the enums instead
truelight
parents:
701
diff
changeset
|
107 |
/* Calculate the radius of the station. Basicly it is the biggest |
4549
106ed18a7675
(svn r6381) -Cleanup: make the '/* */' comments that span multiple lines more uniform.
rubidium
parents:
4528
diff
changeset
|
108 |
* radius that is available within the station */ |
2643 | 109 |
static uint FindCatchmentRadius(const Station* st) |
703
3f64a428fcbc
(svn r1153) -Fix: FindCatchmentRadius is now a function that uses the enums instead
truelight
parents:
701
diff
changeset
|
110 |
{ |
5601
d58f82901b2f
(svn r8055) -Codechange: Replace the different max, dmax, maxu whatever macros by a simple template function max(), that requires two arguments of the same type. While I'm at it change a variable called "max" to "maxval" in a function that calls max().
celestar
parents:
5587
diff
changeset
|
111 |
CatchmentAera ret = CA_NONE; |
703
3f64a428fcbc
(svn r1153) -Fix: FindCatchmentRadius is now a function that uses the enums instead
truelight
parents:
701
diff
changeset
|
112 |
|
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
113 |
if (st->bus_stops != NULL) ret = max(ret, CA_BUS); |
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
114 |
if (st->truck_stops != NULL) ret = max(ret, CA_TRUCK); |
703
3f64a428fcbc
(svn r1153) -Fix: FindCatchmentRadius is now a function that uses the enums instead
truelight
parents:
701
diff
changeset
|
115 |
if (st->train_tile) ret = max(ret, CA_TRAIN); |
3f64a428fcbc
(svn r1153) -Fix: FindCatchmentRadius is now a function that uses the enums instead
truelight
parents:
701
diff
changeset
|
116 |
if (st->dock_tile) ret = max(ret, CA_DOCK); |
3f64a428fcbc
(svn r1153) -Fix: FindCatchmentRadius is now a function that uses the enums instead
truelight
parents:
701
diff
changeset
|
117 |
|
3f64a428fcbc
(svn r1153) -Fix: FindCatchmentRadius is now a function that uses the enums instead
truelight
parents:
701
diff
changeset
|
118 |
if (st->airport_tile) { |
3f64a428fcbc
(svn r1153) -Fix: FindCatchmentRadius is now a function that uses the enums instead
truelight
parents:
701
diff
changeset
|
119 |
switch (st->airport_type) { |
3f64a428fcbc
(svn r1153) -Fix: FindCatchmentRadius is now a function that uses the enums instead
truelight
parents:
701
diff
changeset
|
120 |
case AT_OILRIG: ret = max(ret, CA_AIR_OILPAD); break; |
3f64a428fcbc
(svn r1153) -Fix: FindCatchmentRadius is now a function that uses the enums instead
truelight
parents:
701
diff
changeset
|
121 |
case AT_SMALL: ret = max(ret, CA_AIR_SMALL); break; |
3f64a428fcbc
(svn r1153) -Fix: FindCatchmentRadius is now a function that uses the enums instead
truelight
parents:
701
diff
changeset
|
122 |
case AT_HELIPORT: ret = max(ret, CA_AIR_HELIPORT); break; |
3f64a428fcbc
(svn r1153) -Fix: FindCatchmentRadius is now a function that uses the enums instead
truelight
parents:
701
diff
changeset
|
123 |
case AT_LARGE: ret = max(ret, CA_AIR_LARGE); break; |
3f64a428fcbc
(svn r1153) -Fix: FindCatchmentRadius is now a function that uses the enums instead
truelight
parents:
701
diff
changeset
|
124 |
case AT_METROPOLITAN: ret = max(ret, CA_AIR_METRO); break; |
3f64a428fcbc
(svn r1153) -Fix: FindCatchmentRadius is now a function that uses the enums instead
truelight
parents:
701
diff
changeset
|
125 |
case AT_INTERNATIONAL: ret = max(ret, CA_AIR_INTER); break; |
4059
b1e1c1193f0a
(svn r5346) - Feature: Add 4 new airports. 2 for aircraft, 2 for helicopters.
richk
parents:
4000
diff
changeset
|
126 |
case AT_COMMUTER: ret = max(ret, CA_AIR_COMMUTER); break; |
b1e1c1193f0a
(svn r5346) - Feature: Add 4 new airports. 2 for aircraft, 2 for helicopters.
richk
parents:
4000
diff
changeset
|
127 |
case AT_HELIDEPOT: ret = max(ret, CA_AIR_HELIDEPOT); break; |
b1e1c1193f0a
(svn r5346) - Feature: Add 4 new airports. 2 for aircraft, 2 for helicopters.
richk
parents:
4000
diff
changeset
|
128 |
case AT_INTERCON: ret = max(ret, CA_AIR_INTERCON); break; |
b1e1c1193f0a
(svn r5346) - Feature: Add 4 new airports. 2 for aircraft, 2 for helicopters.
richk
parents:
4000
diff
changeset
|
129 |
case AT_HELISTATION: ret = max(ret, CA_AIR_HELISTATION); break; |
703
3f64a428fcbc
(svn r1153) -Fix: FindCatchmentRadius is now a function that uses the enums instead
truelight
parents:
701
diff
changeset
|
130 |
} |
3f64a428fcbc
(svn r1153) -Fix: FindCatchmentRadius is now a function that uses the enums instead
truelight
parents:
701
diff
changeset
|
131 |
} |
3f64a428fcbc
(svn r1153) -Fix: FindCatchmentRadius is now a function that uses the enums instead
truelight
parents:
701
diff
changeset
|
132 |
|
3f64a428fcbc
(svn r1153) -Fix: FindCatchmentRadius is now a function that uses the enums instead
truelight
parents:
701
diff
changeset
|
133 |
return ret; |
3f64a428fcbc
(svn r1153) -Fix: FindCatchmentRadius is now a function that uses the enums instead
truelight
parents:
701
diff
changeset
|
134 |
} |
3f64a428fcbc
(svn r1153) -Fix: FindCatchmentRadius is now a function that uses the enums instead
truelight
parents:
701
diff
changeset
|
135 |
|
0 | 136 |
#define CHECK_STATIONS_ERR ((Station*)-1) |
137 |
||
2498
3ed05caa4449
(svn r3024) -Codechange: Another batch of replacements of int/uint/int16/byte/-1 with proper types and constants
tron
parents:
2493
diff
changeset
|
138 |
static Station* GetStationAround(TileIndex tile, int w, int h, StationID closest_station) |
0 | 139 |
{ |
140 |
// check around to see if there's any stations there |
|
1981 | 141 |
BEGIN_TILE_LOOP(tile_cur, w + 2, h + 2, tile - TileDiffXY(1, 1)) |
1035
812f837ee03f
(svn r1536) Move GET_TILEHEIGHT, GET_TILETYPE and IS_TILETYPE to map.h, turn them into inline functions and add some asserts
tron
parents:
1032
diff
changeset
|
142 |
if (IsTileType(tile_cur, MP_STATION)) { |
3315
c9d989783c55
(svn r4079) Add GetSation{Index,ByTile}() to get the station index resp. the station from a tile
tron
parents:
3282
diff
changeset
|
143 |
StationID t = GetStationIndex(tile_cur); |
28
635ad4c62bec
(svn r29) -Fix You cannot take ownership of an oilrig by building right next to it
darkvater
parents:
27
diff
changeset
|
144 |
{ |
919
544f374ee392
(svn r1407) -Codechange: changed a lot around _stations, _vehicles, _towns and _industries
truelight
parents:
909
diff
changeset
|
145 |
Station *st = GetStation(t); |
28
635ad4c62bec
(svn r29) -Fix You cannot take ownership of an oilrig by building right next to it
darkvater
parents:
27
diff
changeset
|
146 |
// you cannot take control of an oilrig!! |
635ad4c62bec
(svn r29) -Fix You cannot take ownership of an oilrig by building right next to it
darkvater
parents:
27
diff
changeset
|
147 |
if (st->airport_type == AT_OILRIG && st->facilities == (FACIL_AIRPORT|FACIL_DOCK)) |
635ad4c62bec
(svn r29) -Fix You cannot take ownership of an oilrig by building right next to it
darkvater
parents:
27
diff
changeset
|
148 |
continue; |
635ad4c62bec
(svn r29) -Fix You cannot take ownership of an oilrig by building right next to it
darkvater
parents:
27
diff
changeset
|
149 |
} |
635ad4c62bec
(svn r29) -Fix You cannot take ownership of an oilrig by building right next to it
darkvater
parents:
27
diff
changeset
|
150 |
|
2498
3ed05caa4449
(svn r3024) -Codechange: Another batch of replacements of int/uint/int16/byte/-1 with proper types and constants
tron
parents:
2493
diff
changeset
|
151 |
if (closest_station == INVALID_STATION) { |
0 | 152 |
closest_station = t; |
153 |
} else if (closest_station != t) { |
|
154 |
_error_message = STR_3006_ADJOINS_MORE_THAN_ONE_EXISTING; |
|
155 |
return CHECK_STATIONS_ERR; |
|
156 |
} |
|
157 |
} |
|
1981 | 158 |
END_TILE_LOOP(tile_cur, w + 2, h + 2, tile - TileDiffXY(1, 1)) |
2498
3ed05caa4449
(svn r3024) -Codechange: Another batch of replacements of int/uint/int16/byte/-1 with proper types and constants
tron
parents:
2493
diff
changeset
|
159 |
return (closest_station == INVALID_STATION) ? NULL : GetStation(closest_station); |
0 | 160 |
} |
161 |
||
1093
4fdc46eaf423
(svn r1594) Convert all undefined parameter lists to (void) and add the appropriate warning flags in the Makefile
tron
parents:
1078
diff
changeset
|
162 |
static Station *AllocateStation(void) |
0 | 163 |
{ |
1272
9aa073c64fc7
(svn r1776) -Add: Dynamic stations. You can now have up to 64k of stations
truelight
parents:
1266
diff
changeset
|
164 |
Station *st = NULL; |
0 | 165 |
|
4346
66105d4f6e83
(svn r6047) -Codechange: FOR_ALL now _only_ loops valid items, and skips invalid ones
truelight
parents:
4344
diff
changeset
|
166 |
/* We don't use FOR_ALL here, because FOR_ALL skips invalid items. |
66105d4f6e83
(svn r6047) -Codechange: FOR_ALL now _only_ loops valid items, and skips invalid ones
truelight
parents:
4344
diff
changeset
|
167 |
* TODO - This is just a temporary stage, this will be removed. */ |
4980 | 168 |
for (st = GetStation(0); st != NULL; st = (st->index + 1U < GetStationPoolSize()) ? GetStation(st->index + 1U) : NULL) { |
4346
66105d4f6e83
(svn r6047) -Codechange: FOR_ALL now _only_ loops valid items, and skips invalid ones
truelight
parents:
4344
diff
changeset
|
169 |
if (!IsValidStation(st)) { |
1551
b1c7df6daa63
(svn r2055) -CodeChange: Begun introducting StationID
celestar
parents:
1527
diff
changeset
|
170 |
StationID index = st->index; |
1272
9aa073c64fc7
(svn r1776) -Add: Dynamic stations. You can now have up to 64k of stations
truelight
parents:
1266
diff
changeset
|
171 |
|
9aa073c64fc7
(svn r1776) -Add: Dynamic stations. You can now have up to 64k of stations
truelight
parents:
1266
diff
changeset
|
172 |
memset(st, 0, sizeof(Station)); |
9aa073c64fc7
(svn r1776) -Add: Dynamic stations. You can now have up to 64k of stations
truelight
parents:
1266
diff
changeset
|
173 |
st->index = index; |
9aa073c64fc7
(svn r1776) -Add: Dynamic stations. You can now have up to 64k of stations
truelight
parents:
1266
diff
changeset
|
174 |
return st; |
0 | 175 |
} |
176 |
} |
|
177 |
||
1272
9aa073c64fc7
(svn r1776) -Add: Dynamic stations. You can now have up to 64k of stations
truelight
parents:
1266
diff
changeset
|
178 |
/* Check if we can add a block to the pool */ |
4980 | 179 |
if (AddBlockToPool(&_Station_pool)) return AllocateStation(); |
1272
9aa073c64fc7
(svn r1776) -Add: Dynamic stations. You can now have up to 64k of stations
truelight
parents:
1266
diff
changeset
|
180 |
|
9aa073c64fc7
(svn r1776) -Add: Dynamic stations. You can now have up to 64k of stations
truelight
parents:
1266
diff
changeset
|
181 |
_error_message = STR_3008_TOO_MANY_STATIONS_LOADING; |
9aa073c64fc7
(svn r1776) -Add: Dynamic stations. You can now have up to 64k of stations
truelight
parents:
1266
diff
changeset
|
182 |
return NULL; |
0 | 183 |
} |
184 |
||
185 |
||
3515
86dccaaef457
(svn r4367) CodeChange : Remove another direct map access in station_cmd.c. Replace an array of TileIndexDiffC by a use of loop with TileDiffXY. Thanks to Rubidium
belugas
parents:
3503
diff
changeset
|
186 |
/** |
86dccaaef457
(svn r4367) CodeChange : Remove another direct map access in station_cmd.c. Replace an array of TileIndexDiffC by a use of loop with TileDiffXY. Thanks to Rubidium
belugas
parents:
3503
diff
changeset
|
187 |
* Counts the numbers of tiles matching a specific type in the area around |
86dccaaef457
(svn r4367) CodeChange : Remove another direct map access in station_cmd.c. Replace an array of TileIndexDiffC by a use of loop with TileDiffXY. Thanks to Rubidium
belugas
parents:
3503
diff
changeset
|
188 |
* @param tile the center tile of the 'count area' |
86dccaaef457
(svn r4367) CodeChange : Remove another direct map access in station_cmd.c. Replace an array of TileIndexDiffC by a use of loop with TileDiffXY. Thanks to Rubidium
belugas
parents:
3503
diff
changeset
|
189 |
* @param type the type of tile searched for |
86dccaaef457
(svn r4367) CodeChange : Remove another direct map access in station_cmd.c. Replace an array of TileIndexDiffC by a use of loop with TileDiffXY. Thanks to Rubidium
belugas
parents:
3503
diff
changeset
|
190 |
* @param industry when type == MP_INDUSTRY, the type of the industry, |
86dccaaef457
(svn r4367) CodeChange : Remove another direct map access in station_cmd.c. Replace an array of TileIndexDiffC by a use of loop with TileDiffXY. Thanks to Rubidium
belugas
parents:
3503
diff
changeset
|
191 |
* in all other cases this parameter is ignored |
86dccaaef457
(svn r4367) CodeChange : Remove another direct map access in station_cmd.c. Replace an array of TileIndexDiffC by a use of loop with TileDiffXY. Thanks to Rubidium
belugas
parents:
3503
diff
changeset
|
192 |
* @result the noumber of matching tiles around |
86dccaaef457
(svn r4367) CodeChange : Remove another direct map access in station_cmd.c. Replace an array of TileIndexDiffC by a use of loop with TileDiffXY. Thanks to Rubidium
belugas
parents:
3503
diff
changeset
|
193 |
*/ |
86dccaaef457
(svn r4367) CodeChange : Remove another direct map access in station_cmd.c. Replace an array of TileIndexDiffC by a use of loop with TileDiffXY. Thanks to Rubidium
belugas
parents:
3503
diff
changeset
|
194 |
static int CountMapSquareAround(TileIndex tile, TileType type, IndustryType industry) |
1977
37bbebf94434
(svn r2483) Replace almost 500 "uint tile" (and variants) with "TileIndex tile"
tron
parents:
1942
diff
changeset
|
195 |
{ |
3515
86dccaaef457
(svn r4367) CodeChange : Remove another direct map access in station_cmd.c. Replace an array of TileIndexDiffC by a use of loop with TileDiffXY. Thanks to Rubidium
belugas
parents:
3503
diff
changeset
|
196 |
TileIndex cur_tile; |
86dccaaef457
(svn r4367) CodeChange : Remove another direct map access in station_cmd.c. Replace an array of TileIndexDiffC by a use of loop with TileDiffXY. Thanks to Rubidium
belugas
parents:
3503
diff
changeset
|
197 |
int dx, dy; |
0 | 198 |
int num = 0; |
199 |
||
3515
86dccaaef457
(svn r4367) CodeChange : Remove another direct map access in station_cmd.c. Replace an array of TileIndexDiffC by a use of loop with TileDiffXY. Thanks to Rubidium
belugas
parents:
3503
diff
changeset
|
200 |
for (dx = -3; dx <= 3; dx++) { |
86dccaaef457
(svn r4367) CodeChange : Remove another direct map access in station_cmd.c. Replace an array of TileIndexDiffC by a use of loop with TileDiffXY. Thanks to Rubidium
belugas
parents:
3503
diff
changeset
|
201 |
for (dy = -3; dy <= 3; dy++) { |
3682
e435df955cf6
(svn r4602) - Fix: an assertion triggered when building a station near the south corner of the map (appeared in r4367)
glx
parents:
3676
diff
changeset
|
202 |
cur_tile = TILE_MASK(tile + TileDiffXY(dx, dy)); |
3515
86dccaaef457
(svn r4367) CodeChange : Remove another direct map access in station_cmd.c. Replace an array of TileIndexDiffC by a use of loop with TileDiffXY. Thanks to Rubidium
belugas
parents:
3503
diff
changeset
|
203 |
|
86dccaaef457
(svn r4367) CodeChange : Remove another direct map access in station_cmd.c. Replace an array of TileIndexDiffC by a use of loop with TileDiffXY. Thanks to Rubidium
belugas
parents:
3503
diff
changeset
|
204 |
if (IsTileType(cur_tile, type)) { |
86dccaaef457
(svn r4367) CodeChange : Remove another direct map access in station_cmd.c. Replace an array of TileIndexDiffC by a use of loop with TileDiffXY. Thanks to Rubidium
belugas
parents:
3503
diff
changeset
|
205 |
switch (type) { |
86dccaaef457
(svn r4367) CodeChange : Remove another direct map access in station_cmd.c. Replace an array of TileIndexDiffC by a use of loop with TileDiffXY. Thanks to Rubidium
belugas
parents:
3503
diff
changeset
|
206 |
case MP_INDUSTRY: |
86dccaaef457
(svn r4367) CodeChange : Remove another direct map access in station_cmd.c. Replace an array of TileIndexDiffC by a use of loop with TileDiffXY. Thanks to Rubidium
belugas
parents:
3503
diff
changeset
|
207 |
if (GetIndustryType(cur_tile) == industry) |
86dccaaef457
(svn r4367) CodeChange : Remove another direct map access in station_cmd.c. Replace an array of TileIndexDiffC by a use of loop with TileDiffXY. Thanks to Rubidium
belugas
parents:
3503
diff
changeset
|
208 |
num++; |
86dccaaef457
(svn r4367) CodeChange : Remove another direct map access in station_cmd.c. Replace an array of TileIndexDiffC by a use of loop with TileDiffXY. Thanks to Rubidium
belugas
parents:
3503
diff
changeset
|
209 |
break; |
86dccaaef457
(svn r4367) CodeChange : Remove another direct map access in station_cmd.c. Replace an array of TileIndexDiffC by a use of loop with TileDiffXY. Thanks to Rubidium
belugas
parents:
3503
diff
changeset
|
210 |
|
86dccaaef457
(svn r4367) CodeChange : Remove another direct map access in station_cmd.c. Replace an array of TileIndexDiffC by a use of loop with TileDiffXY. Thanks to Rubidium
belugas
parents:
3503
diff
changeset
|
211 |
case MP_WATER: |
86dccaaef457
(svn r4367) CodeChange : Remove another direct map access in station_cmd.c. Replace an array of TileIndexDiffC by a use of loop with TileDiffXY. Thanks to Rubidium
belugas
parents:
3503
diff
changeset
|
212 |
if (!IsWater(cur_tile)) |
86dccaaef457
(svn r4367) CodeChange : Remove another direct map access in station_cmd.c. Replace an array of TileIndexDiffC by a use of loop with TileDiffXY. Thanks to Rubidium
belugas
parents:
3503
diff
changeset
|
213 |
break; |
86dccaaef457
(svn r4367) CodeChange : Remove another direct map access in station_cmd.c. Replace an array of TileIndexDiffC by a use of loop with TileDiffXY. Thanks to Rubidium
belugas
parents:
3503
diff
changeset
|
214 |
/* FALL THROUGH WHEN WATER TILE */ |
86dccaaef457
(svn r4367) CodeChange : Remove another direct map access in station_cmd.c. Replace an array of TileIndexDiffC by a use of loop with TileDiffXY. Thanks to Rubidium
belugas
parents:
3503
diff
changeset
|
215 |
case MP_TREES: |
86dccaaef457
(svn r4367) CodeChange : Remove another direct map access in station_cmd.c. Replace an array of TileIndexDiffC by a use of loop with TileDiffXY. Thanks to Rubidium
belugas
parents:
3503
diff
changeset
|
216 |
num++; |
86dccaaef457
(svn r4367) CodeChange : Remove another direct map access in station_cmd.c. Replace an array of TileIndexDiffC by a use of loop with TileDiffXY. Thanks to Rubidium
belugas
parents:
3503
diff
changeset
|
217 |
break; |
86dccaaef457
(svn r4367) CodeChange : Remove another direct map access in station_cmd.c. Replace an array of TileIndexDiffC by a use of loop with TileDiffXY. Thanks to Rubidium
belugas
parents:
3503
diff
changeset
|
218 |
|
86dccaaef457
(svn r4367) CodeChange : Remove another direct map access in station_cmd.c. Replace an array of TileIndexDiffC by a use of loop with TileDiffXY. Thanks to Rubidium
belugas
parents:
3503
diff
changeset
|
219 |
default: |
86dccaaef457
(svn r4367) CodeChange : Remove another direct map access in station_cmd.c. Replace an array of TileIndexDiffC by a use of loop with TileDiffXY. Thanks to Rubidium
belugas
parents:
3503
diff
changeset
|
220 |
break; |
86dccaaef457
(svn r4367) CodeChange : Remove another direct map access in station_cmd.c. Replace an array of TileIndexDiffC by a use of loop with TileDiffXY. Thanks to Rubidium
belugas
parents:
3503
diff
changeset
|
221 |
} |
86dccaaef457
(svn r4367) CodeChange : Remove another direct map access in station_cmd.c. Replace an array of TileIndexDiffC by a use of loop with TileDiffXY. Thanks to Rubidium
belugas
parents:
3503
diff
changeset
|
222 |
} |
86dccaaef457
(svn r4367) CodeChange : Remove another direct map access in station_cmd.c. Replace an array of TileIndexDiffC by a use of loop with TileDiffXY. Thanks to Rubidium
belugas
parents:
3503
diff
changeset
|
223 |
} |
0 | 224 |
} |
225 |
||
226 |
return num; |
|
227 |
} |
|
228 |
||
229 |
#define M(x) ((x) - STR_SV_STNAME) |
|
230 |
||
1977
37bbebf94434
(svn r2483) Replace almost 500 "uint tile" (and variants) with "TileIndex tile"
tron
parents:
1942
diff
changeset
|
231 |
static bool GenerateStationName(Station *st, TileIndex tile, int flag) |
0 | 232 |
{ |
233 |
static const uint32 _gen_station_name_bits[] = { |
|
1454 | 234 |
0, /* 0 */ |
235 |
1 << M(STR_SV_STNAME_AIRPORT), /* 1 */ |
|
236 |
1 << M(STR_SV_STNAME_OILFIELD), /* 2 */ |
|
237 |
1 << M(STR_SV_STNAME_DOCKS), /* 3 */ |
|
238 |
0x1FF << M(STR_SV_STNAME_BUOY_1), /* 4 */ |
|
239 |
1 << M(STR_SV_STNAME_HELIPORT), /* 5 */ |
|
0 | 240 |
}; |
241 |
||
242 |
Town *t = st->town; |
|
243 |
uint32 free_names = (uint32)-1; |
|
244 |
int found; |
|
245 |
uint z,z2; |
|
246 |
unsigned long tmp; |
|
247 |
||
248 |
{ |
|
249 |
Station *s; |
|
250 |
||
251 |
FOR_ALL_STATIONS(s) { |
|
4346
66105d4f6e83
(svn r6047) -Codechange: FOR_ALL now _only_ loops valid items, and skips invalid ones
truelight
parents:
4344
diff
changeset
|
252 |
if (s != st && s->town==t) { |
0 | 253 |
uint str = M(s->string_id); |
254 |
if (str <= 0x20) { |
|
255 |
if (str == M(STR_SV_STNAME_FOREST)) |
|
256 |
str = M(STR_SV_STNAME_WOODS); |
|
257 |
CLRBIT(free_names, str); |
|
258 |
} |
|
259 |
} |
|
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
159
diff
changeset
|
260 |
} |
0 | 261 |
} |
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
159
diff
changeset
|
262 |
|
0 | 263 |
/* check default names */ |
264 |
tmp = free_names & _gen_station_name_bits[flag]; |
|
265 |
if (tmp != 0) { |
|
266 |
found = FindFirstBit(tmp); |
|
267 |
goto done; |
|
268 |
} |
|
269 |
||
270 |
/* check mine? */ |
|
271 |
if (HASBIT(free_names, M(STR_SV_STNAME_MINES))) { |
|
3515
86dccaaef457
(svn r4367) CodeChange : Remove another direct map access in station_cmd.c. Replace an array of TileIndexDiffC by a use of loop with TileDiffXY. Thanks to Rubidium
belugas
parents:
3503
diff
changeset
|
272 |
if (CountMapSquareAround(tile, MP_INDUSTRY, IT_COAL_MINE) >= 2 || |
86dccaaef457
(svn r4367) CodeChange : Remove another direct map access in station_cmd.c. Replace an array of TileIndexDiffC by a use of loop with TileDiffXY. Thanks to Rubidium
belugas
parents:
3503
diff
changeset
|
273 |
CountMapSquareAround(tile, MP_INDUSTRY, IT_IRON_MINE) >= 2 || |
86dccaaef457
(svn r4367) CodeChange : Remove another direct map access in station_cmd.c. Replace an array of TileIndexDiffC by a use of loop with TileDiffXY. Thanks to Rubidium
belugas
parents:
3503
diff
changeset
|
274 |
CountMapSquareAround(tile, MP_INDUSTRY, IT_COPPER_MINE) >= 2 || |
86dccaaef457
(svn r4367) CodeChange : Remove another direct map access in station_cmd.c. Replace an array of TileIndexDiffC by a use of loop with TileDiffXY. Thanks to Rubidium
belugas
parents:
3503
diff
changeset
|
275 |
CountMapSquareAround(tile, MP_INDUSTRY, IT_GOLD_MINE) >= 2 || |
86dccaaef457
(svn r4367) CodeChange : Remove another direct map access in station_cmd.c. Replace an array of TileIndexDiffC by a use of loop with TileDiffXY. Thanks to Rubidium
belugas
parents:
3503
diff
changeset
|
276 |
CountMapSquareAround(tile, MP_INDUSTRY, IT_DIAMOND_MINE) >= 2) { |
1454 | 277 |
found = M(STR_SV_STNAME_MINES); |
278 |
goto done; |
|
279 |
} |
|
0 | 280 |
} |
281 |
||
282 |
/* check close enough to town to get central as name? */ |
|
1245
3822f77cbc53
(svn r1749) Move the functions which calculate distances to map.[ch] and give the more meaningful names
tron
parents:
1239
diff
changeset
|
283 |
if (DistanceMax(tile,t->xy) < 8) { |
0 | 284 |
found = M(STR_SV_STNAME); |
285 |
if (HASBIT(free_names, M(STR_SV_STNAME))) goto done; |
|
286 |
||
287 |
found = M(STR_SV_STNAME_CENTRAL); |
|
288 |
if (HASBIT(free_names, M(STR_SV_STNAME_CENTRAL))) goto done; |
|
289 |
} |
|
290 |
||
291 |
/* Check lakeside */ |
|
1472
a2abe3b9d7a7
(svn r1976) Cleanups - mostly indentation and fiddling with loops
tron
parents:
1457
diff
changeset
|
292 |
if (HASBIT(free_names, M(STR_SV_STNAME_LAKESIDE)) && |
a2abe3b9d7a7
(svn r1976) Cleanups - mostly indentation and fiddling with loops
tron
parents:
1457
diff
changeset
|
293 |
DistanceFromEdge(tile) < 20 && |
3515
86dccaaef457
(svn r4367) CodeChange : Remove another direct map access in station_cmd.c. Replace an array of TileIndexDiffC by a use of loop with TileDiffXY. Thanks to Rubidium
belugas
parents:
3503
diff
changeset
|
294 |
CountMapSquareAround(tile, MP_WATER, 0) >= 5) { |
1454 | 295 |
found = M(STR_SV_STNAME_LAKESIDE); |
296 |
goto done; |
|
297 |
} |
|
0 | 298 |
|
299 |
/* Check woods */ |
|
1472
a2abe3b9d7a7
(svn r1976) Cleanups - mostly indentation and fiddling with loops
tron
parents:
1457
diff
changeset
|
300 |
if (HASBIT(free_names, M(STR_SV_STNAME_WOODS)) && ( |
3515
86dccaaef457
(svn r4367) CodeChange : Remove another direct map access in station_cmd.c. Replace an array of TileIndexDiffC by a use of loop with TileDiffXY. Thanks to Rubidium
belugas
parents:
3503
diff
changeset
|
301 |
CountMapSquareAround(tile, MP_TREES, 0) >= 8 || |
86dccaaef457
(svn r4367) CodeChange : Remove another direct map access in station_cmd.c. Replace an array of TileIndexDiffC by a use of loop with TileDiffXY. Thanks to Rubidium
belugas
parents:
3503
diff
changeset
|
302 |
CountMapSquareAround(tile, MP_INDUSTRY, IT_FOREST) >= 2) |
1472
a2abe3b9d7a7
(svn r1976) Cleanups - mostly indentation and fiddling with loops
tron
parents:
1457
diff
changeset
|
303 |
) { |
a2abe3b9d7a7
(svn r1976) Cleanups - mostly indentation and fiddling with loops
tron
parents:
1457
diff
changeset
|
304 |
found = _opt.landscape == LT_DESERT ? |
a2abe3b9d7a7
(svn r1976) Cleanups - mostly indentation and fiddling with loops
tron
parents:
1457
diff
changeset
|
305 |
M(STR_SV_STNAME_FOREST) : M(STR_SV_STNAME_WOODS); |
1454 | 306 |
goto done; |
0 | 307 |
} |
308 |
||
309 |
/* check elevation compared to town */ |
|
310 |
z = GetTileZ(tile); |
|
311 |
z2 = GetTileZ(t->xy); |
|
312 |
if (z < z2) { |
|
313 |
found = M(STR_SV_STNAME_VALLEY); |
|
314 |
if (HASBIT(free_names, M(STR_SV_STNAME_VALLEY))) goto done; |
|
315 |
} else if (z > z2) { |
|
316 |
found = M(STR_SV_STNAME_HEIGHTS); |
|
317 |
if (HASBIT(free_names, M(STR_SV_STNAME_HEIGHTS))) goto done; |
|
318 |
} |
|
319 |
||
320 |
/* check direction compared to town */ |
|
321 |
{ |
|
322 |
static const int8 _direction_and_table[] = { |
|
323 |
~( (1<<M(STR_SV_STNAME_WEST)) | (1<<M(STR_SV_STNAME_EAST)) | (1<<M(STR_SV_STNAME_NORTH)) ), |
|
324 |
~( (1<<M(STR_SV_STNAME_SOUTH)) | (1<<M(STR_SV_STNAME_WEST)) | (1<<M(STR_SV_STNAME_NORTH)) ), |
|
325 |
~( (1<<M(STR_SV_STNAME_SOUTH)) | (1<<M(STR_SV_STNAME_EAST)) | (1<<M(STR_SV_STNAME_NORTH)) ), |
|
326 |
~( (1<<M(STR_SV_STNAME_SOUTH)) | (1<<M(STR_SV_STNAME_WEST)) | (1<<M(STR_SV_STNAME_EAST)) ), |
|
327 |
}; |
|
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
159
diff
changeset
|
328 |
|
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
159
diff
changeset
|
329 |
free_names &= _direction_and_table[ |
926
a6d140a6a4de
(svn r1414) Move TileIndex, TILE_MASK and GET_TILE_[XY] to map.h and turn the latter into inline functions names Tile[XY]
tron
parents:
919
diff
changeset
|
330 |
(TileX(tile) < TileX(t->xy)) + |
a6d140a6a4de
(svn r1414) Move TileIndex, TILE_MASK and GET_TILE_[XY] to map.h and turn the latter into inline functions names Tile[XY]
tron
parents:
919
diff
changeset
|
331 |
(TileY(tile) < TileY(t->xy)) * 2]; |
0 | 332 |
} |
333 |
||
334 |
tmp = free_names & ((1<<1)|(1<<2)|(1<<3)|(1<<4)|(1<<6)|(1<<7)|(1<<12)|(1<<26)|(1<<27)|(1<<28)|(1<<29)|(1<<30)); |
|
335 |
if (tmp == 0) { |
|
336 |
_error_message = STR_3007_TOO_MANY_STATIONS_LOADING; |
|
337 |
return false; |
|
338 |
} |
|
339 |
found = FindFirstBit(tmp); |
|
340 |
||
341 |
done: |
|
342 |
st->string_id = found + STR_SV_STNAME; |
|
343 |
return true; |
|
344 |
} |
|
345 |
#undef M |
|
346 |
||
2498
3ed05caa4449
(svn r3024) -Codechange: Another batch of replacements of int/uint/int16/byte/-1 with proper types and constants
tron
parents:
2493
diff
changeset
|
347 |
static Station* GetClosestStationFromTile(TileIndex tile, uint threshold, PlayerID owner) |
0 | 348 |
{ |
1424
38b76de179c9
(svn r1928) Miscellaneous cleanups (data types, whitespace, const correctness)
tron
parents:
1423
diff
changeset
|
349 |
Station* best_station = NULL; |
38b76de179c9
(svn r1928) Miscellaneous cleanups (data types, whitespace, const correctness)
tron
parents:
1423
diff
changeset
|
350 |
Station* st; |
0 | 351 |
|
352 |
FOR_ALL_STATIONS(st) { |
|
4848
45f848b46222
(svn r6774) -Codechange: Rename the badly named OWNER_SPECTATOR to PLAYER_SPECTATOR and
Darkvater
parents:
4638
diff
changeset
|
353 |
if ((owner == PLAYER_SPECTATOR || st->owner == owner)) { |
1424
38b76de179c9
(svn r1928) Miscellaneous cleanups (data types, whitespace, const correctness)
tron
parents:
1423
diff
changeset
|
354 |
uint cur_dist = DistanceManhattan(tile, st->xy); |
38b76de179c9
(svn r1928) Miscellaneous cleanups (data types, whitespace, const correctness)
tron
parents:
1423
diff
changeset
|
355 |
|
38b76de179c9
(svn r1928) Miscellaneous cleanups (data types, whitespace, const correctness)
tron
parents:
1423
diff
changeset
|
356 |
if (cur_dist < threshold) { |
38b76de179c9
(svn r1928) Miscellaneous cleanups (data types, whitespace, const correctness)
tron
parents:
1423
diff
changeset
|
357 |
threshold = cur_dist; |
38b76de179c9
(svn r1928) Miscellaneous cleanups (data types, whitespace, const correctness)
tron
parents:
1423
diff
changeset
|
358 |
best_station = st; |
38b76de179c9
(svn r1928) Miscellaneous cleanups (data types, whitespace, const correctness)
tron
parents:
1423
diff
changeset
|
359 |
} |
0 | 360 |
} |
361 |
} |
|
362 |
||
363 |
return best_station; |
|
364 |
} |
|
365 |
||
366 |
// Update the virtual coords needed to draw the station sign. |
|
367 |
// st = Station to update for. |
|
368 |
static void UpdateStationVirtCoord(Station *st) |
|
369 |
{ |
|
3422
a6eba3443452
(svn r4249) -Codechange: Replace more occurences of 16 by TILE_SIZE and of 8 by TILE_HEIGHT. Reverted one change from the previous commit because it was faulty
celestar
parents:
3418
diff
changeset
|
370 |
Point pt = RemapCoords2(TileX(st->xy) * TILE_SIZE, TileY(st->xy) * TILE_SIZE); |
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
371 |
|
0 | 372 |
pt.y -= 32; |
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
373 |
if (st->facilities & FACIL_AIRPORT && st->airport_type == AT_OILRIG) pt.y -= 16; |
0 | 374 |
|
534
306bc86eb23e
(svn r901) Small step in the process to clean up the DPARAM mess:
tron
parents:
507
diff
changeset
|
375 |
SetDParam(0, st->index); |
306bc86eb23e
(svn r901) Small step in the process to clean up the DPARAM mess:
tron
parents:
507
diff
changeset
|
376 |
SetDParam(1, st->facilities); |
0 | 377 |
UpdateViewportSignPos(&st->sign, pt.x, pt.y, STR_305C_0); |
378 |
} |
|
379 |
||
380 |
// Update the virtual coords needed to draw the station sign for all stations. |
|
1093
4fdc46eaf423
(svn r1594) Convert all undefined parameter lists to (void) and add the appropriate warning flags in the Makefile
tron
parents:
1078
diff
changeset
|
381 |
void UpdateAllStationVirtCoord(void) |
0 | 382 |
{ |
2639 | 383 |
Station* st; |
384 |
||
0 | 385 |
FOR_ALL_STATIONS(st) { |
4346
66105d4f6e83
(svn r6047) -Codechange: FOR_ALL now _only_ loops valid items, and skips invalid ones
truelight
parents:
4344
diff
changeset
|
386 |
UpdateStationVirtCoord(st); |
0 | 387 |
} |
388 |
} |
|
389 |
||
390 |
// Update the station virt coords while making the modified parts dirty. |
|
391 |
static void UpdateStationVirtCoordDirty(Station *st) |
|
392 |
{ |
|
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
393 |
st->MarkDirty(); |
0 | 394 |
UpdateStationVirtCoord(st); |
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
395 |
st->MarkDirty(); |
0 | 396 |
} |
397 |
||
398 |
// Get a mask of the cargo types that the station accepts. |
|
1424
38b76de179c9
(svn r1928) Miscellaneous cleanups (data types, whitespace, const correctness)
tron
parents:
1423
diff
changeset
|
399 |
static uint GetAcceptanceMask(const Station *st) |
0 | 400 |
{ |
401 |
uint mask = 0; |
|
1424
38b76de179c9
(svn r1928) Miscellaneous cleanups (data types, whitespace, const correctness)
tron
parents:
1423
diff
changeset
|
402 |
uint i; |
38b76de179c9
(svn r1928) Miscellaneous cleanups (data types, whitespace, const correctness)
tron
parents:
1423
diff
changeset
|
403 |
|
38b76de179c9
(svn r1928) Miscellaneous cleanups (data types, whitespace, const correctness)
tron
parents:
1423
diff
changeset
|
404 |
for (i = 0; i != NUM_CARGO; i++) { |
38b76de179c9
(svn r1928) Miscellaneous cleanups (data types, whitespace, const correctness)
tron
parents:
1423
diff
changeset
|
405 |
if (st->goods[i].waiting_acceptance & 0x8000) mask |= 1 << i; |
0 | 406 |
} |
407 |
return mask; |
|
408 |
} |
|
409 |
||
410 |
// Items contains the two cargo names that are to be accepted or rejected. |
|
411 |
// msg is the string id of the message to display. |
|
5690
2f290fd103cd
(svn r8153) -Codechange: Change UpdateStationAcceptance() and ShowRejectOrAcceptNews() to work with cargo IDs instead of cargo names, and explicitly list the different strings to use.
peter1138
parents:
5683
diff
changeset
|
412 |
static void ShowRejectOrAcceptNews(const Station *st, uint num_items, CargoID *cargo, StringID msg) |
0 | 413 |
{ |
5690
2f290fd103cd
(svn r8153) -Codechange: Change UpdateStationAcceptance() and ShowRejectOrAcceptNews() to work with cargo IDs instead of cargo names, and explicitly list the different strings to use.
peter1138
parents:
5683
diff
changeset
|
414 |
for (uint i = 0; i < num_items; i++) { |
2f290fd103cd
(svn r8153) -Codechange: Change UpdateStationAcceptance() and ShowRejectOrAcceptNews() to work with cargo IDs instead of cargo names, and explicitly list the different strings to use.
peter1138
parents:
5683
diff
changeset
|
415 |
SetDParam(i + 1, _cargoc.names_s[cargo[i]]); |
0 | 416 |
} |
5690
2f290fd103cd
(svn r8153) -Codechange: Change UpdateStationAcceptance() and ShowRejectOrAcceptNews() to work with cargo IDs instead of cargo names, and explicitly list the different strings to use.
peter1138
parents:
5683
diff
changeset
|
417 |
|
2f290fd103cd
(svn r8153) -Codechange: Change UpdateStationAcceptance() and ShowRejectOrAcceptNews() to work with cargo IDs instead of cargo names, and explicitly list the different strings to use.
peter1138
parents:
5683
diff
changeset
|
418 |
SetDParam(0, st->index); |
2f290fd103cd
(svn r8153) -Codechange: Change UpdateStationAcceptance() and ShowRejectOrAcceptNews() to work with cargo IDs instead of cargo names, and explicitly list the different strings to use.
peter1138
parents:
5683
diff
changeset
|
419 |
AddNewsItem(msg, NEWS_FLAGS(NM_SMALL, NF_VIEWPORT|NF_TILE, NT_ACCEPTANCE, 0), st->xy, 0); |
0 | 420 |
} |
421 |
||
422 |
// Get a list of the cargo types being produced around the tile. |
|
1424
38b76de179c9
(svn r1928) Miscellaneous cleanups (data types, whitespace, const correctness)
tron
parents:
1423
diff
changeset
|
423 |
void GetProductionAroundTiles(AcceptedCargo produced, TileIndex tile, |
38b76de179c9
(svn r1928) Miscellaneous cleanups (data types, whitespace, const correctness)
tron
parents:
1423
diff
changeset
|
424 |
int w, int h, int rad) |
0 | 425 |
{ |
426 |
int x,y; |
|
427 |
int x1,y1,x2,y2; |
|
428 |
int xc,yc; |
|
429 |
||
2133 | 430 |
memset(produced, 0, sizeof(AcceptedCargo)); |
0 | 431 |
|
926
a6d140a6a4de
(svn r1414) Move TileIndex, TILE_MASK and GET_TILE_[XY] to map.h and turn the latter into inline functions names Tile[XY]
tron
parents:
919
diff
changeset
|
432 |
x = TileX(tile); |
a6d140a6a4de
(svn r1414) Move TileIndex, TILE_MASK and GET_TILE_[XY] to map.h and turn the latter into inline functions names Tile[XY]
tron
parents:
919
diff
changeset
|
433 |
y = TileY(tile); |
0 | 434 |
|
1424
38b76de179c9
(svn r1928) Miscellaneous cleanups (data types, whitespace, const correctness)
tron
parents:
1423
diff
changeset
|
435 |
// expand the region by rad tiles on each side |
0 | 436 |
// while making sure that we remain inside the board. |
856
918759cedca8
(svn r1337) Use MapMax[XY]() (or MapSize[XY]() if appropriate) instead of TILE_MAX_[XY]
tron
parents:
847
diff
changeset
|
437 |
x2 = min(x + w + rad, MapSizeX()); |
1424
38b76de179c9
(svn r1928) Miscellaneous cleanups (data types, whitespace, const correctness)
tron
parents:
1423
diff
changeset
|
438 |
x1 = max(x - rad, 0); |
568
b0d0df062880
(svn r979) Allow more realistically sized catchment areas
Celestar
parents:
555
diff
changeset
|
439 |
|
856
918759cedca8
(svn r1337) Use MapMax[XY]() (or MapSize[XY]() if appropriate) instead of TILE_MAX_[XY]
tron
parents:
847
diff
changeset
|
440 |
y2 = min(y + h + rad, MapSizeY()); |
1424
38b76de179c9
(svn r1928) Miscellaneous cleanups (data types, whitespace, const correctness)
tron
parents:
1423
diff
changeset
|
441 |
y1 = max(y - rad, 0); |
0 | 442 |
|
443 |
assert(x1 < x2); |
|
444 |
assert(y1 < y2); |
|
445 |
assert(w > 0); |
|
446 |
assert(h > 0); |
|
447 |
||
1424
38b76de179c9
(svn r1928) Miscellaneous cleanups (data types, whitespace, const correctness)
tron
parents:
1423
diff
changeset
|
448 |
for (yc = y1; yc != y2; yc++) { |
38b76de179c9
(svn r1928) Miscellaneous cleanups (data types, whitespace, const correctness)
tron
parents:
1423
diff
changeset
|
449 |
for (xc = x1; xc != x2; xc++) { |
0 | 450 |
if (!(IS_INSIDE_1D(xc, x, w) && IS_INSIDE_1D(yc, y, h))) { |
451 |
GetProducedCargoProc *gpc; |
|
1981 | 452 |
TileIndex tile = TileXY(xc, yc); |
1424
38b76de179c9
(svn r1928) Miscellaneous cleanups (data types, whitespace, const correctness)
tron
parents:
1423
diff
changeset
|
453 |
|
1214
8262981ac274
(svn r1718) Use the enum TileType as parameter/return type for [GS]etTileType() instead of plain int.
tron
parents:
1209
diff
changeset
|
454 |
gpc = _tile_type_procs[GetTileType(tile)]->get_produced_cargo_proc; |
0 | 455 |
if (gpc != NULL) { |
3344
fc86351d4641
(svn r4128) - CodeChange: Add proper semantics for CargoID for such variables instead of using the general byte-type.
Darkvater
parents:
3334
diff
changeset
|
456 |
CargoID cargos[2] = { CT_INVALID, CT_INVALID }; |
1424
38b76de179c9
(svn r1928) Miscellaneous cleanups (data types, whitespace, const correctness)
tron
parents:
1423
diff
changeset
|
457 |
|
0 | 458 |
gpc(tile, cargos); |
1424
38b76de179c9
(svn r1928) Miscellaneous cleanups (data types, whitespace, const correctness)
tron
parents:
1423
diff
changeset
|
459 |
if (cargos[0] != CT_INVALID) { |
0 | 460 |
produced[cargos[0]]++; |
1424
38b76de179c9
(svn r1928) Miscellaneous cleanups (data types, whitespace, const correctness)
tron
parents:
1423
diff
changeset
|
461 |
if (cargos[1] != CT_INVALID) { |
0 | 462 |
produced[cargos[1]]++; |
463 |
} |
|
464 |
} |
|
465 |
} |
|
466 |
} |
|
1424
38b76de179c9
(svn r1928) Miscellaneous cleanups (data types, whitespace, const correctness)
tron
parents:
1423
diff
changeset
|
467 |
} |
38b76de179c9
(svn r1928) Miscellaneous cleanups (data types, whitespace, const correctness)
tron
parents:
1423
diff
changeset
|
468 |
} |
0 | 469 |
} |
470 |
||
471 |
// Get a list of the cargo types that are accepted around the tile. |
|
1424
38b76de179c9
(svn r1928) Miscellaneous cleanups (data types, whitespace, const correctness)
tron
parents:
1423
diff
changeset
|
472 |
void GetAcceptanceAroundTiles(AcceptedCargo accepts, TileIndex tile, |
38b76de179c9
(svn r1928) Miscellaneous cleanups (data types, whitespace, const correctness)
tron
parents:
1423
diff
changeset
|
473 |
int w, int h, int rad) |
0 | 474 |
{ |
475 |
int x,y; |
|
476 |
int x1,y1,x2,y2; |
|
477 |
int xc,yc; |
|
473
77f0ef57e7cf
(svn r724) Remove restriction that a tile can only accept 3 cargo types.
tron
parents:
457
diff
changeset
|
478 |
|
77f0ef57e7cf
(svn r724) Remove restriction that a tile can only accept 3 cargo types.
tron
parents:
457
diff
changeset
|
479 |
memset(accepts, 0, sizeof(AcceptedCargo)); |
0 | 480 |
|
926
a6d140a6a4de
(svn r1414) Move TileIndex, TILE_MASK and GET_TILE_[XY] to map.h and turn the latter into inline functions names Tile[XY]
tron
parents:
919
diff
changeset
|
481 |
x = TileX(tile); |
a6d140a6a4de
(svn r1414) Move TileIndex, TILE_MASK and GET_TILE_[XY] to map.h and turn the latter into inline functions names Tile[XY]
tron
parents:
919
diff
changeset
|
482 |
y = TileY(tile); |
0 | 483 |
|
1424
38b76de179c9
(svn r1928) Miscellaneous cleanups (data types, whitespace, const correctness)
tron
parents:
1423
diff
changeset
|
484 |
// expand the region by rad tiles on each side |
0 | 485 |
// while making sure that we remain inside the board. |
856
918759cedca8
(svn r1337) Use MapMax[XY]() (or MapSize[XY]() if appropriate) instead of TILE_MAX_[XY]
tron
parents:
847
diff
changeset
|
486 |
x2 = min(x + w + rad, MapSizeX()); |
918759cedca8
(svn r1337) Use MapMax[XY]() (or MapSize[XY]() if appropriate) instead of TILE_MAX_[XY]
tron
parents:
847
diff
changeset
|
487 |
y2 = min(y + h + rad, MapSizeY()); |
1424
38b76de179c9
(svn r1928) Miscellaneous cleanups (data types, whitespace, const correctness)
tron
parents:
1423
diff
changeset
|
488 |
x1 = max(x - rad, 0); |
38b76de179c9
(svn r1928) Miscellaneous cleanups (data types, whitespace, const correctness)
tron
parents:
1423
diff
changeset
|
489 |
y1 = max(y - rad, 0); |
0 | 490 |
|
491 |
assert(x1 < x2); |
|
492 |
assert(y1 < y2); |
|
493 |
assert(w > 0); |
|
494 |
assert(h > 0); |
|
495 |
||
1424
38b76de179c9
(svn r1928) Miscellaneous cleanups (data types, whitespace, const correctness)
tron
parents:
1423
diff
changeset
|
496 |
for (yc = y1; yc != y2; yc++) { |
38b76de179c9
(svn r1928) Miscellaneous cleanups (data types, whitespace, const correctness)
tron
parents:
1423
diff
changeset
|
497 |
for (xc = x1; xc != x2; xc++) { |
1981 | 498 |
TileIndex tile = TileXY(xc, yc); |
1424
38b76de179c9
(svn r1928) Miscellaneous cleanups (data types, whitespace, const correctness)
tron
parents:
1423
diff
changeset
|
499 |
|
1035
812f837ee03f
(svn r1536) Move GET_TILEHEIGHT, GET_TILETYPE and IS_TILETYPE to map.h, turn them into inline functions and add some asserts
tron
parents:
1032
diff
changeset
|
500 |
if (!IsTileType(tile, MP_STATION)) { |
473
77f0ef57e7cf
(svn r724) Remove restriction that a tile can only accept 3 cargo types.
tron
parents:
457
diff
changeset
|
501 |
AcceptedCargo ac; |
1424
38b76de179c9
(svn r1928) Miscellaneous cleanups (data types, whitespace, const correctness)
tron
parents:
1423
diff
changeset
|
502 |
uint i; |
473
77f0ef57e7cf
(svn r724) Remove restriction that a tile can only accept 3 cargo types.
tron
parents:
457
diff
changeset
|
503 |
|
77f0ef57e7cf
(svn r724) Remove restriction that a tile can only accept 3 cargo types.
tron
parents:
457
diff
changeset
|
504 |
GetAcceptedCargo(tile, ac); |
2639 | 505 |
for (i = 0; i < lengthof(ac); ++i) accepts[i] += ac[i]; |
0 | 506 |
} |
1424
38b76de179c9
(svn r1928) Miscellaneous cleanups (data types, whitespace, const correctness)
tron
parents:
1423
diff
changeset
|
507 |
} |
38b76de179c9
(svn r1928) Miscellaneous cleanups (data types, whitespace, const correctness)
tron
parents:
1423
diff
changeset
|
508 |
} |
0 | 509 |
} |
510 |
||
2793
a0d17504b599
(svn r3341) -Codechange: make mingw32 happy, and renamed Rectangle, because it already exists on that platform
truelight
parents:
2767
diff
changeset
|
511 |
typedef struct ottd_Rectangle { |
1423
11cd644bf8f8
(svn r1927) Replace implementation of UpdateStationAcceptance(). The new one doesn't malloc() and calculates the station area in one pass instead of 3
tron
parents:
1417
diff
changeset
|
512 |
uint min_x; |
11cd644bf8f8
(svn r1927) Replace implementation of UpdateStationAcceptance(). The new one doesn't malloc() and calculates the station area in one pass instead of 3
tron
parents:
1417
diff
changeset
|
513 |
uint min_y; |
11cd644bf8f8
(svn r1927) Replace implementation of UpdateStationAcceptance(). The new one doesn't malloc() and calculates the station area in one pass instead of 3
tron
parents:
1417
diff
changeset
|
514 |
uint max_x; |
11cd644bf8f8
(svn r1927) Replace implementation of UpdateStationAcceptance(). The new one doesn't malloc() and calculates the station area in one pass instead of 3
tron
parents:
1417
diff
changeset
|
515 |
uint max_y; |
2793
a0d17504b599
(svn r3341) -Codechange: make mingw32 happy, and renamed Rectangle, because it already exists on that platform
truelight
parents:
2767
diff
changeset
|
516 |
} ottd_Rectangle; |
a0d17504b599
(svn r3341) -Codechange: make mingw32 happy, and renamed Rectangle, because it already exists on that platform
truelight
parents:
2767
diff
changeset
|
517 |
|
5103
fbd04229cae3
(svn r7174) -CodeChange: CheckStationSpreadOut() now uses MergePoint() for bounding rectangle calculation.
KUDr
parents:
5098
diff
changeset
|
518 |
static inline void MergePoint(ottd_Rectangle* rect, TileIndex tile) |
1423
11cd644bf8f8
(svn r1927) Replace implementation of UpdateStationAcceptance(). The new one doesn't malloc() and calculates the station area in one pass instead of 3
tron
parents:
1417
diff
changeset
|
519 |
{ |
11cd644bf8f8
(svn r1927) Replace implementation of UpdateStationAcceptance(). The new one doesn't malloc() and calculates the station area in one pass instead of 3
tron
parents:
1417
diff
changeset
|
520 |
uint x = TileX(tile); |
11cd644bf8f8
(svn r1927) Replace implementation of UpdateStationAcceptance(). The new one doesn't malloc() and calculates the station area in one pass instead of 3
tron
parents:
1417
diff
changeset
|
521 |
uint y = TileY(tile); |
11cd644bf8f8
(svn r1927) Replace implementation of UpdateStationAcceptance(). The new one doesn't malloc() and calculates the station area in one pass instead of 3
tron
parents:
1417
diff
changeset
|
522 |
|
11cd644bf8f8
(svn r1927) Replace implementation of UpdateStationAcceptance(). The new one doesn't malloc() and calculates the station area in one pass instead of 3
tron
parents:
1417
diff
changeset
|
523 |
if (rect->min_x > x) rect->min_x = x; |
11cd644bf8f8
(svn r1927) Replace implementation of UpdateStationAcceptance(). The new one doesn't malloc() and calculates the station area in one pass instead of 3
tron
parents:
1417
diff
changeset
|
524 |
if (rect->min_y > y) rect->min_y = y; |
11cd644bf8f8
(svn r1927) Replace implementation of UpdateStationAcceptance(). The new one doesn't malloc() and calculates the station area in one pass instead of 3
tron
parents:
1417
diff
changeset
|
525 |
if (rect->max_x < x) rect->max_x = x; |
11cd644bf8f8
(svn r1927) Replace implementation of UpdateStationAcceptance(). The new one doesn't malloc() and calculates the station area in one pass instead of 3
tron
parents:
1417
diff
changeset
|
526 |
if (rect->max_y < y) rect->max_y = y; |
11cd644bf8f8
(svn r1927) Replace implementation of UpdateStationAcceptance(). The new one doesn't malloc() and calculates the station area in one pass instead of 3
tron
parents:
1417
diff
changeset
|
527 |
} |
11cd644bf8f8
(svn r1927) Replace implementation of UpdateStationAcceptance(). The new one doesn't malloc() and calculates the station area in one pass instead of 3
tron
parents:
1417
diff
changeset
|
528 |
|
0 | 529 |
// Update the acceptance for a station. |
530 |
// show_msg controls whether to display a message that acceptance was changed. |
|
531 |
static void UpdateStationAcceptance(Station *st, bool show_msg) |
|
532 |
{ |
|
533 |
uint old_acc, new_acc; |
|
1423
11cd644bf8f8
(svn r1927) Replace implementation of UpdateStationAcceptance(). The new one doesn't malloc() and calculates the station area in one pass instead of 3
tron
parents:
1417
diff
changeset
|
534 |
const RoadStop *cur_rs; |
0 | 535 |
int i; |
2793
a0d17504b599
(svn r3341) -Codechange: make mingw32 happy, and renamed Rectangle, because it already exists on that platform
truelight
parents:
2767
diff
changeset
|
536 |
ottd_Rectangle rect; |
1423
11cd644bf8f8
(svn r1927) Replace implementation of UpdateStationAcceptance(). The new one doesn't malloc() and calculates the station area in one pass instead of 3
tron
parents:
1417
diff
changeset
|
537 |
int rad; |
11cd644bf8f8
(svn r1927) Replace implementation of UpdateStationAcceptance(). The new one doesn't malloc() and calculates the station area in one pass instead of 3
tron
parents:
1417
diff
changeset
|
538 |
AcceptedCargo accepts; |
0 | 539 |
|
1507
18cb39ddddfd
(svn r2011) - Fix: [ 1162209 ] Fix OS/2 build (orudge) #2
darkvater
parents:
1477
diff
changeset
|
540 |
rect.min_x = MapSizeX(); |
18cb39ddddfd
(svn r2011) - Fix: [ 1162209 ] Fix OS/2 build (orudge) #2
darkvater
parents:
1477
diff
changeset
|
541 |
rect.min_y = MapSizeY(); |
18cb39ddddfd
(svn r2011) - Fix: [ 1162209 ] Fix OS/2 build (orudge) #2
darkvater
parents:
1477
diff
changeset
|
542 |
rect.max_x = rect.max_y = 0; |
0 | 543 |
// Don't update acceptance for a buoy |
2639 | 544 |
if (IsBuoy(st)) return; |
0 | 545 |
|
546 |
/* old accepted goods types */ |
|
547 |
old_acc = GetAcceptanceMask(st); |
|
548 |
||
549 |
// Put all the tiles that span an area in the table. |
|
550 |
if (st->train_tile != 0) { |
|
1423
11cd644bf8f8
(svn r1927) Replace implementation of UpdateStationAcceptance(). The new one doesn't malloc() and calculates the station area in one pass instead of 3
tron
parents:
1417
diff
changeset
|
551 |
MergePoint(&rect, st->train_tile); |
11cd644bf8f8
(svn r1927) Replace implementation of UpdateStationAcceptance(). The new one doesn't malloc() and calculates the station area in one pass instead of 3
tron
parents:
1417
diff
changeset
|
552 |
MergePoint(&rect, |
1981 | 553 |
st->train_tile + TileDiffXY(st->trainst_w - 1, st->trainst_h - 1) |
1423
11cd644bf8f8
(svn r1927) Replace implementation of UpdateStationAcceptance(). The new one doesn't malloc() and calculates the station area in one pass instead of 3
tron
parents:
1417
diff
changeset
|
554 |
); |
0 | 555 |
} |
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
556 |
|
0 | 557 |
if (st->airport_tile != 0) { |
3876
468642825a10
(svn r4918) Move the information about the size of airports from an global array into the struct which describes an airport
tron
parents:
3873
diff
changeset
|
558 |
const AirportFTAClass* afc = GetAirport(st->airport_type); |
468642825a10
(svn r4918) Move the information about the size of airports from an global array into the struct which describes an airport
tron
parents:
3873
diff
changeset
|
559 |
|
1423
11cd644bf8f8
(svn r1927) Replace implementation of UpdateStationAcceptance(). The new one doesn't malloc() and calculates the station area in one pass instead of 3
tron
parents:
1417
diff
changeset
|
560 |
MergePoint(&rect, st->airport_tile); |
11cd644bf8f8
(svn r1927) Replace implementation of UpdateStationAcceptance(). The new one doesn't malloc() and calculates the station area in one pass instead of 3
tron
parents:
1417
diff
changeset
|
561 |
MergePoint(&rect, |
3876
468642825a10
(svn r4918) Move the information about the size of airports from an global array into the struct which describes an airport
tron
parents:
3873
diff
changeset
|
562 |
st->airport_tile + TileDiffXY(afc->size_x - 1, afc->size_y - 1) |
1423
11cd644bf8f8
(svn r1927) Replace implementation of UpdateStationAcceptance(). The new one doesn't malloc() and calculates the station area in one pass instead of 3
tron
parents:
1417
diff
changeset
|
563 |
); |
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
564 |
} |
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
565 |
|
1423
11cd644bf8f8
(svn r1927) Replace implementation of UpdateStationAcceptance(). The new one doesn't malloc() and calculates the station area in one pass instead of 3
tron
parents:
1417
diff
changeset
|
566 |
if (st->dock_tile != 0) MergePoint(&rect, st->dock_tile); |
11cd644bf8f8
(svn r1927) Replace implementation of UpdateStationAcceptance(). The new one doesn't malloc() and calculates the station area in one pass instead of 3
tron
parents:
1417
diff
changeset
|
567 |
|
11cd644bf8f8
(svn r1927) Replace implementation of UpdateStationAcceptance(). The new one doesn't malloc() and calculates the station area in one pass instead of 3
tron
parents:
1417
diff
changeset
|
568 |
for (cur_rs = st->bus_stops; cur_rs != NULL; cur_rs = cur_rs->next) { |
11cd644bf8f8
(svn r1927) Replace implementation of UpdateStationAcceptance(). The new one doesn't malloc() and calculates the station area in one pass instead of 3
tron
parents:
1417
diff
changeset
|
569 |
MergePoint(&rect, cur_rs->xy); |
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
570 |
} |
0 | 571 |
|
1423
11cd644bf8f8
(svn r1927) Replace implementation of UpdateStationAcceptance(). The new one doesn't malloc() and calculates the station area in one pass instead of 3
tron
parents:
1417
diff
changeset
|
572 |
for (cur_rs = st->truck_stops; cur_rs != NULL; cur_rs = cur_rs->next) { |
11cd644bf8f8
(svn r1927) Replace implementation of UpdateStationAcceptance(). The new one doesn't malloc() and calculates the station area in one pass instead of 3
tron
parents:
1417
diff
changeset
|
573 |
MergePoint(&rect, cur_rs->xy); |
0 | 574 |
} |
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
575 |
|
2631
2ed0eb408229
(svn r3173) Use the trinary operator and switch to improve readability
tron
parents:
2630
diff
changeset
|
576 |
rad = (_patches.modified_catchment) ? FindCatchmentRadius(st) : 4; |
0 | 577 |
|
578 |
// And retrieve the acceptance. |
|
1423
11cd644bf8f8
(svn r1927) Replace implementation of UpdateStationAcceptance(). The new one doesn't malloc() and calculates the station area in one pass instead of 3
tron
parents:
1417
diff
changeset
|
579 |
if (rect.max_x >= rect.min_x) { |
11cd644bf8f8
(svn r1927) Replace implementation of UpdateStationAcceptance(). The new one doesn't malloc() and calculates the station area in one pass instead of 3
tron
parents:
1417
diff
changeset
|
580 |
GetAcceptanceAroundTiles( |
11cd644bf8f8
(svn r1927) Replace implementation of UpdateStationAcceptance(). The new one doesn't malloc() and calculates the station area in one pass instead of 3
tron
parents:
1417
diff
changeset
|
581 |
accepts, |
1981 | 582 |
TileXY(rect.min_x, rect.min_y), |
1423
11cd644bf8f8
(svn r1927) Replace implementation of UpdateStationAcceptance(). The new one doesn't malloc() and calculates the station area in one pass instead of 3
tron
parents:
1417
diff
changeset
|
583 |
rect.max_x - rect.min_x + 1, |
11cd644bf8f8
(svn r1927) Replace implementation of UpdateStationAcceptance(). The new one doesn't malloc() and calculates the station area in one pass instead of 3
tron
parents:
1417
diff
changeset
|
584 |
rect.max_y - rect.min_y + 1, |
11cd644bf8f8
(svn r1927) Replace implementation of UpdateStationAcceptance(). The new one doesn't malloc() and calculates the station area in one pass instead of 3
tron
parents:
1417
diff
changeset
|
585 |
rad |
11cd644bf8f8
(svn r1927) Replace implementation of UpdateStationAcceptance(). The new one doesn't malloc() and calculates the station area in one pass instead of 3
tron
parents:
1417
diff
changeset
|
586 |
); |
0 | 587 |
} else { |
588 |
memset(accepts, 0, sizeof(accepts)); |
|
589 |
} |
|
590 |
||
591 |
// Adjust in case our station only accepts fewer kinds of goods |
|
1424
38b76de179c9
(svn r1928) Miscellaneous cleanups (data types, whitespace, const correctness)
tron
parents:
1423
diff
changeset
|
592 |
for (i = 0; i != NUM_CARGO; i++) { |
0 | 593 |
uint amt = min(accepts[i], 15); |
594 |
||
595 |
// Make sure the station can accept the goods type. |
|
596 |
if ((i != CT_PASSENGERS && !(st->facilities & (byte)~FACIL_BUS_STOP)) || |
|
597 |
(i == CT_PASSENGERS && !(st->facilities & (byte)~FACIL_TRUCK_STOP))) |
|
598 |
amt = 0; |
|
599 |
||
2504
5ae89f643cdc
(svn r3030) More work for GB/SB, this time concerning the waiting_acceptance attribute of stations
tron
parents:
2502
diff
changeset
|
600 |
SB(st->goods[i].waiting_acceptance, 12, 4, amt); |
0 | 601 |
} |
602 |
||
603 |
// Only show a message in case the acceptance was actually changed. |
|
604 |
new_acc = GetAcceptanceMask(st); |
|
605 |
if (old_acc == new_acc) |
|
606 |
return; |
|
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
159
diff
changeset
|
607 |
|
0 | 608 |
// show a message to report that the acceptance was changed? |
609 |
if (show_msg && st->owner == _local_player && st->facilities) { |
|
5690
2f290fd103cd
(svn r8153) -Codechange: Change UpdateStationAcceptance() and ShowRejectOrAcceptNews() to work with cargo IDs instead of cargo names, and explicitly list the different strings to use.
peter1138
parents:
5683
diff
changeset
|
610 |
/* List of accept and reject strings for different number of |
2f290fd103cd
(svn r8153) -Codechange: Change UpdateStationAcceptance() and ShowRejectOrAcceptNews() to work with cargo IDs instead of cargo names, and explicitly list the different strings to use.
peter1138
parents:
5683
diff
changeset
|
611 |
* cargo types */ |
2f290fd103cd
(svn r8153) -Codechange: Change UpdateStationAcceptance() and ShowRejectOrAcceptNews() to work with cargo IDs instead of cargo names, and explicitly list the different strings to use.
peter1138
parents:
5683
diff
changeset
|
612 |
static const StringID accept_msg[] = { |
2f290fd103cd
(svn r8153) -Codechange: Change UpdateStationAcceptance() and ShowRejectOrAcceptNews() to work with cargo IDs instead of cargo names, and explicitly list the different strings to use.
peter1138
parents:
5683
diff
changeset
|
613 |
STR_3040_NOW_ACCEPTS, |
2f290fd103cd
(svn r8153) -Codechange: Change UpdateStationAcceptance() and ShowRejectOrAcceptNews() to work with cargo IDs instead of cargo names, and explicitly list the different strings to use.
peter1138
parents:
5683
diff
changeset
|
614 |
STR_3041_NOW_ACCEPTS_AND, |
2f290fd103cd
(svn r8153) -Codechange: Change UpdateStationAcceptance() and ShowRejectOrAcceptNews() to work with cargo IDs instead of cargo names, and explicitly list the different strings to use.
peter1138
parents:
5683
diff
changeset
|
615 |
}; |
2f290fd103cd
(svn r8153) -Codechange: Change UpdateStationAcceptance() and ShowRejectOrAcceptNews() to work with cargo IDs instead of cargo names, and explicitly list the different strings to use.
peter1138
parents:
5683
diff
changeset
|
616 |
static const StringID reject_msg[] = { |
2f290fd103cd
(svn r8153) -Codechange: Change UpdateStationAcceptance() and ShowRejectOrAcceptNews() to work with cargo IDs instead of cargo names, and explicitly list the different strings to use.
peter1138
parents:
5683
diff
changeset
|
617 |
STR_303E_NO_LONGER_ACCEPTS, |
2f290fd103cd
(svn r8153) -Codechange: Change UpdateStationAcceptance() and ShowRejectOrAcceptNews() to work with cargo IDs instead of cargo names, and explicitly list the different strings to use.
peter1138
parents:
5683
diff
changeset
|
618 |
STR_303F_NO_LONGER_ACCEPTS_OR, |
2f290fd103cd
(svn r8153) -Codechange: Change UpdateStationAcceptance() and ShowRejectOrAcceptNews() to work with cargo IDs instead of cargo names, and explicitly list the different strings to use.
peter1138
parents:
5683
diff
changeset
|
619 |
}; |
2f290fd103cd
(svn r8153) -Codechange: Change UpdateStationAcceptance() and ShowRejectOrAcceptNews() to work with cargo IDs instead of cargo names, and explicitly list the different strings to use.
peter1138
parents:
5683
diff
changeset
|
620 |
|
2f290fd103cd
(svn r8153) -Codechange: Change UpdateStationAcceptance() and ShowRejectOrAcceptNews() to work with cargo IDs instead of cargo names, and explicitly list the different strings to use.
peter1138
parents:
5683
diff
changeset
|
621 |
/* Array of accepted and rejected cargo types */ |
2f290fd103cd
(svn r8153) -Codechange: Change UpdateStationAcceptance() and ShowRejectOrAcceptNews() to work with cargo IDs instead of cargo names, and explicitly list the different strings to use.
peter1138
parents:
5683
diff
changeset
|
622 |
CargoID accepts[2] = { CT_INVALID, CT_INVALID }; |
2f290fd103cd
(svn r8153) -Codechange: Change UpdateStationAcceptance() and ShowRejectOrAcceptNews() to work with cargo IDs instead of cargo names, and explicitly list the different strings to use.
peter1138
parents:
5683
diff
changeset
|
623 |
CargoID rejects[2] = { CT_INVALID, CT_INVALID }; |
2f290fd103cd
(svn r8153) -Codechange: Change UpdateStationAcceptance() and ShowRejectOrAcceptNews() to work with cargo IDs instead of cargo names, and explicitly list the different strings to use.
peter1138
parents:
5683
diff
changeset
|
624 |
uint num_acc = 0; |
2f290fd103cd
(svn r8153) -Codechange: Change UpdateStationAcceptance() and ShowRejectOrAcceptNews() to work with cargo IDs instead of cargo names, and explicitly list the different strings to use.
peter1138
parents:
5683
diff
changeset
|
625 |
uint num_rej = 0; |
2f290fd103cd
(svn r8153) -Codechange: Change UpdateStationAcceptance() and ShowRejectOrAcceptNews() to work with cargo IDs instead of cargo names, and explicitly list the different strings to use.
peter1138
parents:
5683
diff
changeset
|
626 |
|
2f290fd103cd
(svn r8153) -Codechange: Change UpdateStationAcceptance() and ShowRejectOrAcceptNews() to work with cargo IDs instead of cargo names, and explicitly list the different strings to use.
peter1138
parents:
5683
diff
changeset
|
627 |
/* Test each cargo type to see if its acceptange has changed */ |
2f290fd103cd
(svn r8153) -Codechange: Change UpdateStationAcceptance() and ShowRejectOrAcceptNews() to work with cargo IDs instead of cargo names, and explicitly list the different strings to use.
peter1138
parents:
5683
diff
changeset
|
628 |
for (CargoID i = 0; i < NUM_CARGO; i++) { |
2f290fd103cd
(svn r8153) -Codechange: Change UpdateStationAcceptance() and ShowRejectOrAcceptNews() to work with cargo IDs instead of cargo names, and explicitly list the different strings to use.
peter1138
parents:
5683
diff
changeset
|
629 |
if (HASBIT(new_acc, i)) { |
2f290fd103cd
(svn r8153) -Codechange: Change UpdateStationAcceptance() and ShowRejectOrAcceptNews() to work with cargo IDs instead of cargo names, and explicitly list the different strings to use.
peter1138
parents:
5683
diff
changeset
|
630 |
if (!HASBIT(old_acc, i) && num_acc < lengthof(accepts)) { |
2f290fd103cd
(svn r8153) -Codechange: Change UpdateStationAcceptance() and ShowRejectOrAcceptNews() to work with cargo IDs instead of cargo names, and explicitly list the different strings to use.
peter1138
parents:
5683
diff
changeset
|
631 |
/* New cargo is accepted */ |
2f290fd103cd
(svn r8153) -Codechange: Change UpdateStationAcceptance() and ShowRejectOrAcceptNews() to work with cargo IDs instead of cargo names, and explicitly list the different strings to use.
peter1138
parents:
5683
diff
changeset
|
632 |
accepts[num_acc++] = i; |
2f290fd103cd
(svn r8153) -Codechange: Change UpdateStationAcceptance() and ShowRejectOrAcceptNews() to work with cargo IDs instead of cargo names, and explicitly list the different strings to use.
peter1138
parents:
5683
diff
changeset
|
633 |
} |
0 | 634 |
} else { |
5690
2f290fd103cd
(svn r8153) -Codechange: Change UpdateStationAcceptance() and ShowRejectOrAcceptNews() to work with cargo IDs instead of cargo names, and explicitly list the different strings to use.
peter1138
parents:
5683
diff
changeset
|
635 |
if (HASBIT(old_acc, i) && num_rej < lengthof(rejects)) { |
2f290fd103cd
(svn r8153) -Codechange: Change UpdateStationAcceptance() and ShowRejectOrAcceptNews() to work with cargo IDs instead of cargo names, and explicitly list the different strings to use.
peter1138
parents:
5683
diff
changeset
|
636 |
/* Old cargo is no longer accepted */ |
2f290fd103cd
(svn r8153) -Codechange: Change UpdateStationAcceptance() and ShowRejectOrAcceptNews() to work with cargo IDs instead of cargo names, and explicitly list the different strings to use.
peter1138
parents:
5683
diff
changeset
|
637 |
rejects[num_rej++] = i; |
2f290fd103cd
(svn r8153) -Codechange: Change UpdateStationAcceptance() and ShowRejectOrAcceptNews() to work with cargo IDs instead of cargo names, and explicitly list the different strings to use.
peter1138
parents:
5683
diff
changeset
|
638 |
} |
0 | 639 |
} |
5690
2f290fd103cd
(svn r8153) -Codechange: Change UpdateStationAcceptance() and ShowRejectOrAcceptNews() to work with cargo IDs instead of cargo names, and explicitly list the different strings to use.
peter1138
parents:
5683
diff
changeset
|
640 |
} |
2f290fd103cd
(svn r8153) -Codechange: Change UpdateStationAcceptance() and ShowRejectOrAcceptNews() to work with cargo IDs instead of cargo names, and explicitly list the different strings to use.
peter1138
parents:
5683
diff
changeset
|
641 |
|
2f290fd103cd
(svn r8153) -Codechange: Change UpdateStationAcceptance() and ShowRejectOrAcceptNews() to work with cargo IDs instead of cargo names, and explicitly list the different strings to use.
peter1138
parents:
5683
diff
changeset
|
642 |
/* Show news message if there are any changes */ |
2f290fd103cd
(svn r8153) -Codechange: Change UpdateStationAcceptance() and ShowRejectOrAcceptNews() to work with cargo IDs instead of cargo names, and explicitly list the different strings to use.
peter1138
parents:
5683
diff
changeset
|
643 |
if (num_acc > 0) ShowRejectOrAcceptNews(st, num_acc, accepts, accept_msg[num_acc - 1]); |
2f290fd103cd
(svn r8153) -Codechange: Change UpdateStationAcceptance() and ShowRejectOrAcceptNews() to work with cargo IDs instead of cargo names, and explicitly list the different strings to use.
peter1138
parents:
5683
diff
changeset
|
644 |
if (num_rej > 0) ShowRejectOrAcceptNews(st, num_rej, rejects, reject_msg[num_rej - 1]); |
0 | 645 |
} |
646 |
||
647 |
// redraw the station view since acceptance changed |
|
648 |
InvalidateWindowWidget(WC_STATION_VIEW, st->index, 4); |
|
649 |
} |
|
650 |
||
5098
7de23befaee4
(svn r7169) -Fix: [FS#388] Station sign (and base station coordinates) didn't move along with station when station moved by walking. (HMage)
KUDr
parents:
4982
diff
changeset
|
651 |
static void UpdateStationSignCoord(Station *st) |
7de23befaee4
(svn r7169) -Fix: [FS#388] Station sign (and base station coordinates) didn't move along with station when station moved by walking. (HMage)
KUDr
parents:
4982
diff
changeset
|
652 |
{ |
5676
7a641ebbc080
(svn r8136) -Codechange: Station spread rectangle manipulators turned into StationRect::methods.
KUDr
parents:
5668
diff
changeset
|
653 |
StationRect *r = &st->rect; |
7a641ebbc080
(svn r8136) -Codechange: Station spread rectangle manipulators turned into StationRect::methods.
KUDr
parents:
5668
diff
changeset
|
654 |
|
7a641ebbc080
(svn r8136) -Codechange: Station spread rectangle manipulators turned into StationRect::methods.
KUDr
parents:
5668
diff
changeset
|
655 |
if (r->IsEmpty()) return; // no tiles belong to this station |
5395
7727da322d66
(svn r7585) -Codechange: CheckStationSpreadOut() took too much CPU. Station rectangle is now maintained instead of calculating it each time by walking through whole map. Should help with the performance issue related to AIs trying to build road stops too often. (idea by Celestar)
KUDr
parents:
5385
diff
changeset
|
656 |
|
7727da322d66
(svn r7585) -Codechange: CheckStationSpreadOut() took too much CPU. Station rectangle is now maintained instead of calculating it each time by walking through whole map. Should help with the performance issue related to AIs trying to build road stops too often. (idea by Celestar)
KUDr
parents:
5385
diff
changeset
|
657 |
// clamp sign coord to be inside the station rect |
7727da322d66
(svn r7585) -Codechange: CheckStationSpreadOut() took too much CPU. Station rectangle is now maintained instead of calculating it each time by walking through whole map. Should help with the performance issue related to AIs trying to build road stops too often. (idea by Celestar)
KUDr
parents:
5385
diff
changeset
|
658 |
st->xy = TileXY(clampu(TileX(st->xy), r->left, r->right), clampu(TileY(st->xy), r->top, r->bottom)); |
5098
7de23befaee4
(svn r7169) -Fix: [FS#388] Station sign (and base station coordinates) didn't move along with station when station moved by walking. (HMage)
KUDr
parents:
4982
diff
changeset
|
659 |
UpdateStationVirtCoordDirty(st); |
7de23befaee4
(svn r7169) -Fix: [FS#388] Station sign (and base station coordinates) didn't move along with station when station moved by walking. (HMage)
KUDr
parents:
4982
diff
changeset
|
660 |
} |
7de23befaee4
(svn r7169) -Fix: [FS#388] Station sign (and base station coordinates) didn't move along with station when station moved by walking. (HMage)
KUDr
parents:
4982
diff
changeset
|
661 |
|
0 | 662 |
// This is called right after a station was deleted. |
663 |
// It checks if the whole station is free of substations, and if so, the station will be |
|
664 |
// deleted after a little while. |
|
2639 | 665 |
static void DeleteStationIfEmpty(Station* st) |
666 |
{ |
|
0 | 667 |
if (st->facilities == 0) { |
668 |
st->delete_ctr = 0; |
|
3812
e6fc916c17ab
(svn r4822) -Feature: Station List View can now be sorted and filtered (by waiting cargo type and facilities)
celestar
parents:
3789
diff
changeset
|
669 |
RebuildStationLists(); |
28
635ad4c62bec
(svn r29) -Fix You cannot take ownership of an oilrig by building right next to it
darkvater
parents:
27
diff
changeset
|
670 |
InvalidateWindow(WC_STATION_LIST, st->owner); |
27
87c8058a69b5
(svn r28) -Fix removing station merged with oilrig, will reset oilrigs ownership
darkvater
parents:
22
diff
changeset
|
671 |
} |
5098
7de23befaee4
(svn r7169) -Fix: [FS#388] Station sign (and base station coordinates) didn't move along with station when station moved by walking. (HMage)
KUDr
parents:
4982
diff
changeset
|
672 |
/* station remains but it probably lost some parts - station sign should stay in the station boundaries */ |
7de23befaee4
(svn r7169) -Fix: [FS#388] Station sign (and base station coordinates) didn't move along with station when station moved by walking. (HMage)
KUDr
parents:
4982
diff
changeset
|
673 |
UpdateStationSignCoord(st); |
0 | 674 |
} |
675 |
||
1977
37bbebf94434
(svn r2483) Replace almost 500 "uint tile" (and variants) with "TileIndex tile"
tron
parents:
1942
diff
changeset
|
676 |
static int32 ClearTile_Station(TileIndex tile, byte flags); |
977
ab88e042b39d
(svn r1472) -Fix: correct error message for when trying to build a railroad station over a bus/truck/etc-station.
darkvater
parents:
972
diff
changeset
|
677 |
|
0 | 678 |
// Tries to clear the given area. Returns the cost in case of success. |
679 |
// Or an error code if it failed. |
|
2498
3ed05caa4449
(svn r3024) -Codechange: Another batch of replacements of int/uint/int16/byte/-1 with proper types and constants
tron
parents:
2493
diff
changeset
|
680 |
int32 CheckFlatLandBelow(TileIndex tile, uint w, uint h, uint flags, uint invalid_dirs, StationID* station) |
0 | 681 |
{ |
682 |
int32 cost = 0, ret; |
|
683 |
||
3636
a36cc46e754d
(svn r4541) Add a type for slopes and replace many magic numbers by the appropriate enums
tron
parents:
3630
diff
changeset
|
684 |
Slope tileh; |
1335
a5f223b9f549
(svn r1839) Move GetTileSlope() and GetTileZ() into tile.[ch] and use more explicit types as parameters
tron
parents:
1328
diff
changeset
|
685 |
uint z; |
a5f223b9f549
(svn r1839) Move GetTileSlope() and GetTileZ() into tile.[ch] and use more explicit types as parameters
tron
parents:
1328
diff
changeset
|
686 |
int allowed_z = -1; |
a5f223b9f549
(svn r1839) Move GetTileSlope() and GetTileZ() into tile.[ch] and use more explicit types as parameters
tron
parents:
1328
diff
changeset
|
687 |
int flat_z; |
0 | 688 |
|
689 |
BEGIN_TILE_LOOP(tile_cur, w, h, tile) |
|
5385
3868f2e6db9b
(svn r7573) -Merged the bridge branch. Allows to build bridges of arbitrary rail/road combinations (including signals)
celestar
parents:
5380
diff
changeset
|
690 |
if (MayHaveBridgeAbove(tile_cur) && IsBridgeAbove(tile_cur)) { |
3868f2e6db9b
(svn r7573) -Merged the bridge branch. Allows to build bridges of arbitrary rail/road combinations (including signals)
celestar
parents:
5380
diff
changeset
|
691 |
return_cmd_error(STR_5007_MUST_DEMOLISH_BRIDGE_FIRST); |
3868f2e6db9b
(svn r7573) -Merged the bridge branch. Allows to build bridges of arbitrary rail/road combinations (including signals)
celestar
parents:
5380
diff
changeset
|
692 |
} |
3868f2e6db9b
(svn r7573) -Merged the bridge branch. Allows to build bridges of arbitrary rail/road combinations (including signals)
celestar
parents:
5380
diff
changeset
|
693 |
|
2639 | 694 |
if (!EnsureNoVehicle(tile_cur)) return CMD_ERROR; |
0 | 695 |
|
696 |
tileh = GetTileSlope(tile_cur, &z); |
|
697 |
||
2085
876f20a0e843
(svn r2595) -Codechange: Introduced "IsSteepTileh" to find whether a tile is steep
celestar
parents:
2049
diff
changeset
|
698 |
/* Prohibit building if |
4549
106ed18a7675
(svn r6381) -Cleanup: make the '/* */' comments that span multiple lines more uniform.
rubidium
parents:
4528
diff
changeset
|
699 |
* 1) The tile is "steep" (i.e. stretches two height levels) |
106ed18a7675
(svn r6381) -Cleanup: make the '/* */' comments that span multiple lines more uniform.
rubidium
parents:
4528
diff
changeset
|
700 |
* -OR- |
106ed18a7675
(svn r6381) -Cleanup: make the '/* */' comments that span multiple lines more uniform.
rubidium
parents:
4528
diff
changeset
|
701 |
* 2) The tile is non-flat if |
106ed18a7675
(svn r6381) -Cleanup: make the '/* */' comments that span multiple lines more uniform.
rubidium
parents:
4528
diff
changeset
|
702 |
* a) the player building is an "old-school" AI |
106ed18a7675
(svn r6381) -Cleanup: make the '/* */' comments that span multiple lines more uniform.
rubidium
parents:
4528
diff
changeset
|
703 |
* -OR- |
106ed18a7675
(svn r6381) -Cleanup: make the '/* */' comments that span multiple lines more uniform.
rubidium
parents:
4528
diff
changeset
|
704 |
* b) the build_on_slopes switch is disabled |
106ed18a7675
(svn r6381) -Cleanup: make the '/* */' comments that span multiple lines more uniform.
rubidium
parents:
4528
diff
changeset
|
705 |
*/ |
3636
a36cc46e754d
(svn r4541) Add a type for slopes and replace many magic numbers by the appropriate enums
tron
parents:
3630
diff
changeset
|
706 |
if (IsSteepSlope(tileh) || |
a36cc46e754d
(svn r4541) Add a type for slopes and replace many magic numbers by the appropriate enums
tron
parents:
3630
diff
changeset
|
707 |
((_is_old_ai_player || !_patches.build_on_slopes) && tileh != SLOPE_FLAT)) { |
3183
90c676e6a50d
(svn r3829) Reduce the use of _error_message by directly returning error codes instead of using this global variable
tron
parents:
3161
diff
changeset
|
708 |
return_cmd_error(STR_0007_FLAT_LAND_REQUIRED); |
0 | 709 |
} |
710 |
||
711 |
flat_z = z; |
|
3636
a36cc46e754d
(svn r4541) Add a type for slopes and replace many magic numbers by the appropriate enums
tron
parents:
3630
diff
changeset
|
712 |
if (tileh != SLOPE_FLAT) { |
0 | 713 |
// need to check so the entrance to the station is not pointing at a slope. |
3636
a36cc46e754d
(svn r4541) Add a type for slopes and replace many magic numbers by the appropriate enums
tron
parents:
3630
diff
changeset
|
714 |
if ((invalid_dirs&1 && !(tileh & SLOPE_NE) && (uint)w_cur == w) || |
4434
a08cb4b5c179
(svn r6204) -Cleanup: replace non-indentation with spaces; like '}<TAB>else {' -> '} else {', tabs between code and comment, etc.
rubidium
parents:
4399
diff
changeset
|
715 |
(invalid_dirs&2 && !(tileh & SLOPE_SE) && h_cur == 1) || |
3636
a36cc46e754d
(svn r4541) Add a type for slopes and replace many magic numbers by the appropriate enums
tron
parents:
3630
diff
changeset
|
716 |
(invalid_dirs&4 && !(tileh & SLOPE_SW) && w_cur == 1) || |
a36cc46e754d
(svn r4541) Add a type for slopes and replace many magic numbers by the appropriate enums
tron
parents:
3630
diff
changeset
|
717 |
(invalid_dirs&8 && !(tileh & SLOPE_NW) && (uint)h_cur == h)) { |
3183
90c676e6a50d
(svn r3829) Reduce the use of _error_message by directly returning error codes instead of using this global variable
tron
parents:
3161
diff
changeset
|
718 |
return_cmd_error(STR_0007_FLAT_LAND_REQUIRED); |
0 | 719 |
} |
720 |
cost += _price.terraform; |
|
3645
7f950533d510
(svn r4554) Replace magic numbers by TILE_{HEIGHT,SIZE}
tron
parents:
3636
diff
changeset
|
721 |
flat_z += TILE_HEIGHT; |
0 | 722 |
} |
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
159
diff
changeset
|
723 |
|
0 | 724 |
// get corresponding flat level and make sure that all parts of the station have the same level. |
725 |
if (allowed_z == -1) { |
|
726 |
// first tile |
|
727 |
allowed_z = flat_z; |
|
728 |
} else if (allowed_z != flat_z) { |
|
3183
90c676e6a50d
(svn r3829) Reduce the use of _error_message by directly returning error codes instead of using this global variable
tron
parents:
3161
diff
changeset
|
729 |
return_cmd_error(STR_0007_FLAT_LAND_REQUIRED); |
0 | 730 |
} |
731 |
||
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
159
diff
changeset
|
732 |
// if station is set, then we have special handling to allow building on top of already existing stations. |
2498
3ed05caa4449
(svn r3024) -Codechange: Another batch of replacements of int/uint/int16/byte/-1 with proper types and constants
tron
parents:
2493
diff
changeset
|
733 |
// so station points to INVALID_STATION if we can build on any station. or it points to a station if we're only allowed to build |
0 | 734 |
// on exactly that station. |
1035
812f837ee03f
(svn r1536) Move GET_TILEHEIGHT, GET_TILETYPE and IS_TILETYPE to map.h, turn them into inline functions and add some asserts
tron
parents:
1032
diff
changeset
|
735 |
if (station != NULL && IsTileType(tile_cur, MP_STATION)) { |
3334
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
736 |
if (!IsRailwayStation(tile_cur)) { |
3183
90c676e6a50d
(svn r3829) Reduce the use of _error_message by directly returning error codes instead of using this global variable
tron
parents:
3161
diff
changeset
|
737 |
return ClearTile_Station(tile_cur, DC_AUTO); // get error message |
0 | 738 |
} else { |
3315
c9d989783c55
(svn r4079) Add GetSation{Index,ByTile}() to get the station index resp. the station from a tile
tron
parents:
3282
diff
changeset
|
739 |
StationID st = GetStationIndex(tile_cur); |
2498
3ed05caa4449
(svn r3024) -Codechange: Another batch of replacements of int/uint/int16/byte/-1 with proper types and constants
tron
parents:
2493
diff
changeset
|
740 |
if (*station == INVALID_STATION) { |
0 | 741 |
*station = st; |
2498
3ed05caa4449
(svn r3024) -Codechange: Another batch of replacements of int/uint/int16/byte/-1 with proper types and constants
tron
parents:
2493
diff
changeset
|
742 |
} else if (*station != st) { |
3183
90c676e6a50d
(svn r3829) Reduce the use of _error_message by directly returning error codes instead of using this global variable
tron
parents:
3161
diff
changeset
|
743 |
return_cmd_error(STR_3006_ADJOINS_MORE_THAN_ONE_EXISTING); |
0 | 744 |
} |
745 |
} |
|
746 |
} else { |
|
3491
35d747bb5e82
(svn r4342) Change the first two parameters of commands - virtual pixel coordinates of the tile to operate on - to a TileIndex
tron
parents:
3482
diff
changeset
|
747 |
ret = DoCommand(tile_cur, 0, 0, flags, CMD_LANDSCAPE_CLEAR); |
3183
90c676e6a50d
(svn r3829) Reduce the use of _error_message by directly returning error codes instead of using this global variable
tron
parents:
3161
diff
changeset
|
748 |
if (CmdFailed(ret)) return ret; |
0 | 749 |
cost += ret; |
750 |
} |
|
751 |
END_TILE_LOOP(tile_cur, w, h, tile) |
|
752 |
||
753 |
return cost; |
|
754 |
} |
|
755 |
||
3157
3f35e2d9c8e3
(svn r3783) Replace further ints and magic numbers by Direction, DiagDirection and friends
tron
parents:
3123
diff
changeset
|
756 |
static bool CanExpandRailroadStation(Station* st, uint* fin, Axis axis) |
0 | 757 |
{ |
758 |
uint curw = st->trainst_w, curh = st->trainst_h; |
|
1977
37bbebf94434
(svn r2483) Replace almost 500 "uint tile" (and variants) with "TileIndex tile"
tron
parents:
1942
diff
changeset
|
759 |
TileIndex tile = fin[0]; |
0 | 760 |
uint w = fin[1]; |
761 |
uint h = fin[2]; |
|
762 |
||
763 |
if (_patches.nonuniform_stations) { |
|
764 |
// determine new size of train station region.. |
|
926
a6d140a6a4de
(svn r1414) Move TileIndex, TILE_MASK and GET_TILE_[XY] to map.h and turn the latter into inline functions names Tile[XY]
tron
parents:
919
diff
changeset
|
765 |
int x = min(TileX(st->train_tile), TileX(tile)); |
a6d140a6a4de
(svn r1414) Move TileIndex, TILE_MASK and GET_TILE_[XY] to map.h and turn the latter into inline functions names Tile[XY]
tron
parents:
919
diff
changeset
|
766 |
int y = min(TileY(st->train_tile), TileY(tile)); |
a6d140a6a4de
(svn r1414) Move TileIndex, TILE_MASK and GET_TILE_[XY] to map.h and turn the latter into inline functions names Tile[XY]
tron
parents:
919
diff
changeset
|
767 |
curw = max(TileX(st->train_tile) + curw, TileX(tile) + w) - x; |
a6d140a6a4de
(svn r1414) Move TileIndex, TILE_MASK and GET_TILE_[XY] to map.h and turn the latter into inline functions names Tile[XY]
tron
parents:
919
diff
changeset
|
768 |
curh = max(TileY(st->train_tile) + curh, TileY(tile) + h) - y; |
1981 | 769 |
tile = TileXY(x, y); |
0 | 770 |
} else { |
3157
3f35e2d9c8e3
(svn r3783) Replace further ints and magic numbers by Direction, DiagDirection and friends
tron
parents:
3123
diff
changeset
|
771 |
// check so the orientation is the same |
3334
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
772 |
if (GetRailStationAxis(st->train_tile) != axis) { |
1189
257509152c47
(svn r1693) -Fix: [ 1108618 ] A wrong error message was displayed when trying to
Celestar
parents:
1174
diff
changeset
|
773 |
_error_message = STR_306D_NONUNIFORM_STATIONS_DISALLOWED; |
257509152c47
(svn r1693) -Fix: [ 1108618 ] A wrong error message was displayed when trying to
Celestar
parents:
1174
diff
changeset
|
774 |
return false; |
257509152c47
(svn r1693) -Fix: [ 1108618 ] A wrong error message was displayed when trying to
Celestar
parents:
1174
diff
changeset
|
775 |
} |
0 | 776 |
|
777 |
// check if the new station adjoins the old station in either direction |
|
1981 | 778 |
if (curw == w && st->train_tile == tile + TileDiffXY(0, h)) { |
0 | 779 |
// above |
780 |
curh += h; |
|
1981 | 781 |
} else if (curw == w && st->train_tile == tile - TileDiffXY(0, curh)) { |
0 | 782 |
// below |
1981 | 783 |
tile -= TileDiffXY(0, curh); |
0 | 784 |
curh += h; |
1981 | 785 |
} else if (curh == h && st->train_tile == tile + TileDiffXY(w, 0)) { |
0 | 786 |
// to the left |
787 |
curw += w; |
|
1981 | 788 |
} else if (curh == h && st->train_tile == tile - TileDiffXY(curw, 0)) { |
0 | 789 |
// to the right |
1981 | 790 |
tile -= TileDiffXY(curw, 0); |
0 | 791 |
curw += w; |
1189
257509152c47
(svn r1693) -Fix: [ 1108618 ] A wrong error message was displayed when trying to
Celestar
parents:
1174
diff
changeset
|
792 |
} else { |
257509152c47
(svn r1693) -Fix: [ 1108618 ] A wrong error message was displayed when trying to
Celestar
parents:
1174
diff
changeset
|
793 |
_error_message = STR_306D_NONUNIFORM_STATIONS_DISALLOWED; |
0 | 794 |
return false; |
1189
257509152c47
(svn r1693) -Fix: [ 1108618 ] A wrong error message was displayed when trying to
Celestar
parents:
1174
diff
changeset
|
795 |
} |
0 | 796 |
} |
797 |
// make sure the final size is not too big. |
|
1189
257509152c47
(svn r1693) -Fix: [ 1108618 ] A wrong error message was displayed when trying to
Celestar
parents:
1174
diff
changeset
|
798 |
if (curw > _patches.station_spread || curh > _patches.station_spread) { |
257509152c47
(svn r1693) -Fix: [ 1108618 ] A wrong error message was displayed when trying to
Celestar
parents:
1174
diff
changeset
|
799 |
_error_message = STR_306C_STATION_TOO_SPREAD_OUT; |
257509152c47
(svn r1693) -Fix: [ 1108618 ] A wrong error message was displayed when trying to
Celestar
parents:
1174
diff
changeset
|
800 |
return false; |
257509152c47
(svn r1693) -Fix: [ 1108618 ] A wrong error message was displayed when trying to
Celestar
parents:
1174
diff
changeset
|
801 |
} |
0 | 802 |
|
803 |
// now tile contains the new value for st->train_tile |
|
804 |
// curw, curh contain the new value for width and height |
|
805 |
fin[0] = tile; |
|
806 |
fin[1] = curw; |
|
807 |
fin[2] = curh; |
|
808 |
return true; |
|
809 |
} |
|
810 |
||
536 | 811 |
static inline byte *CreateSingle(byte *layout, int n) |
0 | 812 |
{ |
813 |
int i = n; |
|
814 |
do *layout++ = 0; while (--i); |
|
815 |
layout[((n-1) >> 1)-n] = 2; |
|
816 |
return layout; |
|
817 |
} |
|
818 |
||
536 | 819 |
static inline byte *CreateMulti(byte *layout, int n, byte b) |
0 | 820 |
{ |
821 |
int i = n; |
|
822 |
do *layout++ = b; while (--i); |
|
823 |
if (n > 4) { |
|
824 |
layout[0-n] = 0; |
|
825 |
layout[n-1-n] = 0; |
|
826 |
} |
|
827 |
return layout; |
|
828 |
} |
|
829 |
||
3676
680dfa6336a1
(svn r4593) CodeChange : Renamed spec (when using StationSpec) to statspec.
belugas
parents:
3657
diff
changeset
|
830 |
static void GetStationLayout(byte *layout, int numtracks, int plat_len, const StationSpec *statspec) |
0 | 831 |
{ |
3676
680dfa6336a1
(svn r4593) CodeChange : Renamed spec (when using StationSpec) to statspec.
belugas
parents:
3657
diff
changeset
|
832 |
if (statspec != NULL && statspec->lengths >= plat_len && |
680dfa6336a1
(svn r4593) CodeChange : Renamed spec (when using StationSpec) to statspec.
belugas
parents:
3657
diff
changeset
|
833 |
statspec->platforms[plat_len - 1] >= numtracks && |
680dfa6336a1
(svn r4593) CodeChange : Renamed spec (when using StationSpec) to statspec.
belugas
parents:
3657
diff
changeset
|
834 |
statspec->layouts[plat_len - 1][numtracks - 1]) { |
449
2856e9ce0754
(svn r659) Support for cutomized TTDPatch-style new stations (no selector GUI yet) (pasky)
tron
parents:
445
diff
changeset
|
835 |
/* Custom layout defined, follow it. */ |
3676
680dfa6336a1
(svn r4593) CodeChange : Renamed spec (when using StationSpec) to statspec.
belugas
parents:
3657
diff
changeset
|
836 |
memcpy(layout, statspec->layouts[plat_len - 1][numtracks - 1], |
1472
a2abe3b9d7a7
(svn r1976) Cleanups - mostly indentation and fiddling with loops
tron
parents:
1457
diff
changeset
|
837 |
plat_len * numtracks); |
449
2856e9ce0754
(svn r659) Support for cutomized TTDPatch-style new stations (no selector GUI yet) (pasky)
tron
parents:
445
diff
changeset
|
838 |
return; |
2856e9ce0754
(svn r659) Support for cutomized TTDPatch-style new stations (no selector GUI yet) (pasky)
tron
parents:
445
diff
changeset
|
839 |
} |
2856e9ce0754
(svn r659) Support for cutomized TTDPatch-style new stations (no selector GUI yet) (pasky)
tron
parents:
445
diff
changeset
|
840 |
|
0 | 841 |
if (plat_len == 1) { |
842 |
CreateSingle(layout, numtracks); |
|
843 |
} else { |
|
2639 | 844 |
if (numtracks & 1) layout = CreateSingle(layout, plat_len); |
845 |
numtracks >>= 1; |
|
0 | 846 |
|
847 |
while (--numtracks >= 0) { |
|
848 |
layout = CreateMulti(layout, plat_len, 4); |
|
849 |
layout = CreateMulti(layout, plat_len, 6); |
|
850 |
} |
|
851 |
} |
|
852 |
} |
|
853 |
||
1775
548dc04d50e2
(svn r2279) - Fix: Check the parameters of the first 10 Commands. While there also add proper comments for the functions and fix up CmdFailed()
Darkvater
parents:
1774
diff
changeset
|
854 |
/** Build railroad station |
3491
35d747bb5e82
(svn r4342) Change the first two parameters of commands - virtual pixel coordinates of the tile to operate on - to a TileIndex
tron
parents:
3482
diff
changeset
|
855 |
* @param tile_org starting position of station dragging/placement |
1775
548dc04d50e2
(svn r2279) - Fix: Check the parameters of the first 10 Commands. While there also add proper comments for the functions and fix up CmdFailed()
Darkvater
parents:
1774
diff
changeset
|
856 |
* @param p1 various bitstuffed elements |
548dc04d50e2
(svn r2279) - Fix: Check the parameters of the first 10 Commands. While there also add proper comments for the functions and fix up CmdFailed()
Darkvater
parents:
1774
diff
changeset
|
857 |
* - p1 = (bit 0) - orientation (p1 & 1) |
2140
a04d0142ad65
(svn r2650) Convert many explicit shifts+ands to extract bits to invocations of GB - should be a bit nicer to read
tron
parents:
2133
diff
changeset
|
858 |
* - p1 = (bit 8-15) - number of tracks |
a04d0142ad65
(svn r2650) Convert many explicit shifts+ands to extract bits to invocations of GB - should be a bit nicer to read
tron
parents:
2133
diff
changeset
|
859 |
* - p1 = (bit 16-23) - platform length |
1775
548dc04d50e2
(svn r2279) - Fix: Check the parameters of the first 10 Commands. While there also add proper comments for the functions and fix up CmdFailed()
Darkvater
parents:
1774
diff
changeset
|
860 |
* @param p2 various bitstuffed elements |
548dc04d50e2
(svn r2279) - Fix: Check the parameters of the first 10 Commands. While there also add proper comments for the functions and fix up CmdFailed()
Darkvater
parents:
1774
diff
changeset
|
861 |
* - p2 = (bit 0- 3) - railtype (p2 & 0xF) |
3587 | 862 |
* - p2 = (bit 8-15) - custom station class |
863 |
* - p2 = (bit 16-23) - custom station id |
|
0 | 864 |
*/ |
3491
35d747bb5e82
(svn r4342) Change the first two parameters of commands - virtual pixel coordinates of the tile to operate on - to a TileIndex
tron
parents:
3482
diff
changeset
|
865 |
int32 CmdBuildRailroadStation(TileIndex tile_org, uint32 flags, uint32 p1, uint32 p2) |
0 | 866 |
{ |
1775
548dc04d50e2
(svn r2279) - Fix: Check the parameters of the first 10 Commands. While there also add proper comments for the functions and fix up CmdFailed()
Darkvater
parents:
1774
diff
changeset
|
867 |
Station *st; |
548dc04d50e2
(svn r2279) - Fix: Check the parameters of the first 10 Commands. While there also add proper comments for the functions and fix up CmdFailed()
Darkvater
parents:
1774
diff
changeset
|
868 |
int w_org, h_org; |
0 | 869 |
int32 cost, ret; |
2498
3ed05caa4449
(svn r3024) -Codechange: Another batch of replacements of int/uint/int16/byte/-1 with proper types and constants
tron
parents:
2493
diff
changeset
|
870 |
StationID est; |
0 | 871 |
int plat_len, numtracks; |
3157
3f35e2d9c8e3
(svn r3783) Replace further ints and magic numbers by Direction, DiagDirection and friends
tron
parents:
3123
diff
changeset
|
872 |
Axis axis; |
0 | 873 |
uint finalvalues[3]; |
3587 | 874 |
const StationSpec *statspec; |
875 |
int specindex; |
|
0 | 876 |
|
877 |
SET_EXPENSES_TYPE(EXPENSES_CONSTRUCTION); |
|
878 |
||
879 |
/* Does the authority allow this? */ |
|
1775
548dc04d50e2
(svn r2279) - Fix: Check the parameters of the first 10 Commands. While there also add proper comments for the functions and fix up CmdFailed()
Darkvater
parents:
1774
diff
changeset
|
880 |
if (!(flags & DC_NO_TOWN_RATING) && !CheckIfAuthorityAllows(tile_org)) return CMD_ERROR; |
548dc04d50e2
(svn r2279) - Fix: Check the parameters of the first 10 Commands. While there also add proper comments for the functions and fix up CmdFailed()
Darkvater
parents:
1774
diff
changeset
|
881 |
if (!ValParamRailtype(p2 & 0xF)) return CMD_ERROR; |
548dc04d50e2
(svn r2279) - Fix: Check the parameters of the first 10 Commands. While there also add proper comments for the functions and fix up CmdFailed()
Darkvater
parents:
1774
diff
changeset
|
882 |
|
548dc04d50e2
(svn r2279) - Fix: Check the parameters of the first 10 Commands. While there also add proper comments for the functions and fix up CmdFailed()
Darkvater
parents:
1774
diff
changeset
|
883 |
/* unpack parameters */ |
5587
167d9a91ef02
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
rubidium
parents:
5584
diff
changeset
|
884 |
axis = (Axis)(p1 & 1); |
2140
a04d0142ad65
(svn r2650) Convert many explicit shifts+ands to extract bits to invocations of GB - should be a bit nicer to read
tron
parents:
2133
diff
changeset
|
885 |
numtracks = GB(p1, 8, 8); |
a04d0142ad65
(svn r2650) Convert many explicit shifts+ands to extract bits to invocations of GB - should be a bit nicer to read
tron
parents:
2133
diff
changeset
|
886 |
plat_len = GB(p1, 16, 8); |
1775
548dc04d50e2
(svn r2279) - Fix: Check the parameters of the first 10 Commands. While there also add proper comments for the functions and fix up CmdFailed()
Darkvater
parents:
1774
diff
changeset
|
887 |
/* w = length, h = num_tracks */ |
3157
3f35e2d9c8e3
(svn r3783) Replace further ints and magic numbers by Direction, DiagDirection and friends
tron
parents:
3123
diff
changeset
|
888 |
if (axis == AXIS_X) { |
3f35e2d9c8e3
(svn r3783) Replace further ints and magic numbers by Direction, DiagDirection and friends
tron
parents:
3123
diff
changeset
|
889 |
w_org = plat_len; |
3f35e2d9c8e3
(svn r3783) Replace further ints and magic numbers by Direction, DiagDirection and friends
tron
parents:
3123
diff
changeset
|
890 |
h_org = numtracks; |
3f35e2d9c8e3
(svn r3783) Replace further ints and magic numbers by Direction, DiagDirection and friends
tron
parents:
3123
diff
changeset
|
891 |
} else { |
1775
548dc04d50e2
(svn r2279) - Fix: Check the parameters of the first 10 Commands. While there also add proper comments for the functions and fix up CmdFailed()
Darkvater
parents:
1774
diff
changeset
|
892 |
h_org = plat_len; |
548dc04d50e2
(svn r2279) - Fix: Check the parameters of the first 10 Commands. While there also add proper comments for the functions and fix up CmdFailed()
Darkvater
parents:
1774
diff
changeset
|
893 |
w_org = numtracks; |
0 | 894 |
} |
895 |
||
1781
5e2fef482637
(svn r2285) - Codechange: Fix up some of the missing things from server-checking; namely bridge-type, bridge-length, dragged end-tile (bridge/station), station_spread
Darkvater
parents:
1775
diff
changeset
|
896 |
if (h_org > _patches.station_spread || w_org > _patches.station_spread) return CMD_ERROR; |
5e2fef482637
(svn r2285) - Codechange: Fix up some of the missing things from server-checking; namely bridge-type, bridge-length, dragged end-tile (bridge/station), station_spread
Darkvater
parents:
1775
diff
changeset
|
897 |
|
0 | 898 |
// these values are those that will be stored in train_tile and station_platforms |
899 |
finalvalues[0] = tile_org; |
|
900 |
finalvalues[1] = w_org; |
|
901 |
finalvalues[2] = h_org; |
|
902 |
||
903 |
// Make sure the area below consists of clear tiles. (OR tiles belonging to a certain rail station) |
|
2498
3ed05caa4449
(svn r3024) -Codechange: Another batch of replacements of int/uint/int16/byte/-1 with proper types and constants
tron
parents:
2493
diff
changeset
|
904 |
est = INVALID_STATION; |
313
0c7cac001d1a
(svn r319) -Fix: [ 1029064 ] Building a station acted weird in some rare situations
truelight
parents:
243
diff
changeset
|
905 |
// If DC_EXEC is in flag, do not want to pass it to CheckFlatLandBelow, because of a nice bug |
0c7cac001d1a
(svn r319) -Fix: [ 1029064 ] Building a station acted weird in some rare situations
truelight
parents:
243
diff
changeset
|
906 |
// for detail info, see: https://sourceforge.net/tracker/index.php?func=detail&aid=1029064&group_id=103924&atid=636365 |
3183
90c676e6a50d
(svn r3829) Reduce the use of _error_message by directly returning error codes instead of using this global variable
tron
parents:
3161
diff
changeset
|
907 |
ret = CheckFlatLandBelow(tile_org, w_org, h_org, flags & ~DC_EXEC, 5 << axis, _patches.nonuniform_stations ? &est : NULL); |
90c676e6a50d
(svn r3829) Reduce the use of _error_message by directly returning error codes instead of using this global variable
tron
parents:
3161
diff
changeset
|
908 |
if (CmdFailed(ret)) return ret; |
0 | 909 |
cost = ret + (numtracks * _price.train_station_track + _price.train_station_length) * plat_len; |
910 |
||
911 |
// Make sure there are no similar stations around us. |
|
912 |
st = GetStationAround(tile_org, w_org, h_org, est); |
|
913 |
if (st == CHECK_STATIONS_ERR) return CMD_ERROR; |
|
914 |
||
915 |
// See if there is a deleted station close to us. |
|
916 |
if (st == NULL) { |
|
917 |
st = GetClosestStationFromTile(tile_org, 8, _current_player); |
|
918 |
if (st != NULL && st->facilities) st = NULL; |
|
919 |
} |
|
920 |
||
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
921 |
/* In case of new station if DC_EXEC is NOT set we still need to create the station |
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
922 |
* to test if everything is OK. In this case we need to delete it before return. */ |
5844
60231b36473e
(svn r8414) -Codechange: Use own AutoPtrT instead of std::auto_ptr.
KUDr
parents:
5837
diff
changeset
|
923 |
AutoPtrT<Station> st_auto_delete; |
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
924 |
|
0 | 925 |
if (st != NULL) { |
926 |
// Reuse an existing station. |
|
927 |
if (st->owner != OWNER_NONE && st->owner != _current_player) |
|
928 |
return_cmd_error(STR_3009_TOO_CLOSE_TO_ANOTHER_STATION); |
|
929 |
||
930 |
if (st->train_tile != 0) { |
|
84
1e0721c29bad
(svn r85) -Add: initial commit of new AI (enable in Patch menu)
truelight
parents:
71
diff
changeset
|
931 |
// check if we want to expanding an already existing station? |
2422
897a01f7c624
(svn r2948) -Fix: the old AI needs a special flag that triggers all kind of special
truelight
parents:
2395
diff
changeset
|
932 |
if (_is_old_ai_player || !_patches.join_stations) |
0 | 933 |
return_cmd_error(STR_3005_TOO_CLOSE_TO_ANOTHER_RAILROAD); |
3157
3f35e2d9c8e3
(svn r3783) Replace further ints and magic numbers by Direction, DiagDirection and friends
tron
parents:
3123
diff
changeset
|
934 |
if (!CanExpandRailroadStation(st, finalvalues, axis)) |
1189
257509152c47
(svn r1693) -Fix: [ 1108618 ] A wrong error message was displayed when trying to
Celestar
parents:
1174
diff
changeset
|
935 |
return CMD_ERROR; |
0 | 936 |
} |
937 |
||
1189
257509152c47
(svn r1693) -Fix: [ 1108618 ] A wrong error message was displayed when trying to
Celestar
parents:
1174
diff
changeset
|
938 |
//XXX can't we pack this in the "else" part of the if above? |
5676
7a641ebbc080
(svn r8136) -Codechange: Station spread rectangle manipulators turned into StationRect::methods.
KUDr
parents:
5668
diff
changeset
|
939 |
if (!st->rect.BeforeAddRect(tile_org, w_org, h_org, StationRect::ADD_TEST)) return CMD_ERROR; |
4434
a08cb4b5c179
(svn r6204) -Cleanup: replace non-indentation with spaces; like '}<TAB>else {' -> '} else {', tabs between code and comment, etc.
rubidium
parents:
4399
diff
changeset
|
940 |
} else { |
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
941 |
/* allocate and initialize new station */ |
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
942 |
st = new Station(tile_org); |
2639 | 943 |
if (st == NULL) return CMD_ERROR; |
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
159
diff
changeset
|
944 |
|
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
945 |
/* ensure that in case of error (or no DC_EXEC) the station gets deleted upon return */ |
5844
60231b36473e
(svn r8414) -Codechange: Use own AutoPtrT instead of std::auto_ptr.
KUDr
parents:
5837
diff
changeset
|
946 |
st_auto_delete = st; |
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
947 |
|
0 | 948 |
st->town = ClosestTownFromTile(tile_org, (uint)-1); |
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
949 |
if (!GenerateStationName(st, tile_org, 0)) return CMD_ERROR; |
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
950 |
|
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
951 |
if (IsValidPlayer(_current_player) && (flags & DC_EXEC) != 0) { |
0 | 952 |
SETBIT(st->town->have_ratings, _current_player); |
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
953 |
} |
0 | 954 |
} |
955 |
||
3587 | 956 |
/* Check if the given station class is valid */ |
957 |
if (GB(p2, 8, 8) >= STAT_CLASS_MAX) return CMD_ERROR; |
|
958 |
||
959 |
/* Check if we can allocate a custom stationspec to this station */ |
|
5587
167d9a91ef02
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
rubidium
parents:
5584
diff
changeset
|
960 |
statspec = GetCustomStationSpec((StationClassID)GB(p2, 8, 8), GB(p2, 16, 8)); |
3587 | 961 |
specindex = AllocateSpecToStation(statspec, st, flags & DC_EXEC); |
962 |
if (specindex == -1) return CMD_ERROR; |
|
963 |
||
3754
4c8cbaaa0bbe
(svn r4742) - Newstations: Add callbacks for building and drawing custom stations.
peter1138
parents:
3751
diff
changeset
|
964 |
if (statspec != NULL) { |
4c8cbaaa0bbe
(svn r4742) - Newstations: Add callbacks for building and drawing custom stations.
peter1138
parents:
3751
diff
changeset
|
965 |
/* Perform NewStation checks */ |
4c8cbaaa0bbe
(svn r4742) - Newstations: Add callbacks for building and drawing custom stations.
peter1138
parents:
3751
diff
changeset
|
966 |
|
4c8cbaaa0bbe
(svn r4742) - Newstations: Add callbacks for building and drawing custom stations.
peter1138
parents:
3751
diff
changeset
|
967 |
/* Check if the station size is permitted */ |
4c8cbaaa0bbe
(svn r4742) - Newstations: Add callbacks for building and drawing custom stations.
peter1138
parents:
3751
diff
changeset
|
968 |
if (HASBIT(statspec->disallowed_platforms, numtracks - 1) || HASBIT(statspec->disallowed_lengths, plat_len - 1)) { |
4c8cbaaa0bbe
(svn r4742) - Newstations: Add callbacks for building and drawing custom stations.
peter1138
parents:
3751
diff
changeset
|
969 |
return CMD_ERROR; |
4c8cbaaa0bbe
(svn r4742) - Newstations: Add callbacks for building and drawing custom stations.
peter1138
parents:
3751
diff
changeset
|
970 |
} |
4c8cbaaa0bbe
(svn r4742) - Newstations: Add callbacks for building and drawing custom stations.
peter1138
parents:
3751
diff
changeset
|
971 |
|
4c8cbaaa0bbe
(svn r4742) - Newstations: Add callbacks for building and drawing custom stations.
peter1138
parents:
3751
diff
changeset
|
972 |
/* Check if the station is buildable */ |
4c8cbaaa0bbe
(svn r4742) - Newstations: Add callbacks for building and drawing custom stations.
peter1138
parents:
3751
diff
changeset
|
973 |
if (HASBIT(statspec->callbackmask, CBM_STATION_AVAIL) && GetStationCallback(CBID_STATION_AVAILABILITY, 0, 0, statspec, NULL, INVALID_TILE) == 0) { |
4c8cbaaa0bbe
(svn r4742) - Newstations: Add callbacks for building and drawing custom stations.
peter1138
parents:
3751
diff
changeset
|
974 |
return CMD_ERROR; |
4c8cbaaa0bbe
(svn r4742) - Newstations: Add callbacks for building and drawing custom stations.
peter1138
parents:
3751
diff
changeset
|
975 |
} |
4c8cbaaa0bbe
(svn r4742) - Newstations: Add callbacks for building and drawing custom stations.
peter1138
parents:
3751
diff
changeset
|
976 |
} |
4c8cbaaa0bbe
(svn r4742) - Newstations: Add callbacks for building and drawing custom stations.
peter1138
parents:
3751
diff
changeset
|
977 |
|
0 | 978 |
if (flags & DC_EXEC) { |
1977
37bbebf94434
(svn r2483) Replace almost 500 "uint tile" (and variants) with "TileIndex tile"
tron
parents:
1942
diff
changeset
|
979 |
TileIndexDiff tile_delta; |
0 | 980 |
byte *layout_ptr; |
3769
7d3b35126fc1
(svn r4761) - Newstations: support platform information in variable 10 (callback parameter 1) when building a station
peter1138
parents:
3766
diff
changeset
|
981 |
byte numtracks_orig; |
2824
4409cab99b02
(svn r3372) - Fix: update signal states when building or removing rail station blocks
peter1138
parents:
2817
diff
changeset
|
982 |
Track track; |
0 | 983 |
|
313
0c7cac001d1a
(svn r319) -Fix: [ 1029064 ] Building a station acted weird in some rare situations
truelight
parents:
243
diff
changeset
|
984 |
// Now really clear the land below the station |
0c7cac001d1a
(svn r319) -Fix: [ 1029064 ] Building a station acted weird in some rare situations
truelight
parents:
243
diff
changeset
|
985 |
// It should never return CMD_ERROR.. but you never know ;) |
0c7cac001d1a
(svn r319) -Fix: [ 1029064 ] Building a station acted weird in some rare situations
truelight
parents:
243
diff
changeset
|
986 |
// (a bit strange function name for it, but it really does clear the land, when DC_EXEC is in flags) |
3183
90c676e6a50d
(svn r3829) Reduce the use of _error_message by directly returning error codes instead of using this global variable
tron
parents:
3161
diff
changeset
|
987 |
ret = CheckFlatLandBelow(tile_org, w_org, h_org, flags, 5 << axis, _patches.nonuniform_stations ? &est : NULL); |
90c676e6a50d
(svn r3829) Reduce the use of _error_message by directly returning error codes instead of using this global variable
tron
parents:
3161
diff
changeset
|
988 |
if (CmdFailed(ret)) return ret; |
313
0c7cac001d1a
(svn r319) -Fix: [ 1029064 ] Building a station acted weird in some rare situations
truelight
parents:
243
diff
changeset
|
989 |
|
0 | 990 |
st->train_tile = finalvalues[0]; |
5721
fa4e587f59f5
(svn r8231) -Fix (r8125): MP desync caused by calling Random() from station constructor. This was wrong because station constructor is called also when loading savegame and when player tries to build station when it is not sure that it will succeed (thanks Rubidium)
KUDr
parents:
5718
diff
changeset
|
991 |
st->AddFacility(FACIL_TRAIN, finalvalues[0]); |
0 | 992 |
|
993 |
st->trainst_w = finalvalues[1]; |
|
994 |
st->trainst_h = finalvalues[2]; |
|
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
159
diff
changeset
|
995 |
|
5676
7a641ebbc080
(svn r8136) -Codechange: Station spread rectangle manipulators turned into StationRect::methods.
KUDr
parents:
5668
diff
changeset
|
996 |
st->rect.BeforeAddRect(tile_org, w_org, h_org, StationRect::ADD_TRY); |
5395
7727da322d66
(svn r7585) -Codechange: CheckStationSpreadOut() took too much CPU. Station rectangle is now maintained instead of calculating it each time by walking through whole map. Should help with the performance issue related to AIs trying to build road stops too often. (idea by Celestar)
KUDr
parents:
5385
diff
changeset
|
997 |
|
3157
3f35e2d9c8e3
(svn r3783) Replace further ints and magic numbers by Direction, DiagDirection and friends
tron
parents:
3123
diff
changeset
|
998 |
tile_delta = (axis == AXIS_X ? TileDiffXY(1, 0) : TileDiffXY(0, 1)); |
4158 | 999 |
track = AxisToTrack(axis); |
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
159
diff
changeset
|
1000 |
|
5587
167d9a91ef02
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
rubidium
parents:
5584
diff
changeset
|
1001 |
layout_ptr = (byte*)alloca(numtracks * plat_len); |
449
2856e9ce0754
(svn r659) Support for cutomized TTDPatch-style new stations (no selector GUI yet) (pasky)
tron
parents:
445
diff
changeset
|
1002 |
GetStationLayout(layout_ptr, numtracks, plat_len, statspec); |
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
159
diff
changeset
|
1003 |
|
3769
7d3b35126fc1
(svn r4761) - Newstations: support platform information in variable 10 (callback parameter 1) when building a station
peter1138
parents:
3766
diff
changeset
|
1004 |
numtracks_orig = numtracks; |
7d3b35126fc1
(svn r4761) - Newstations: support platform information in variable 10 (callback parameter 1) when building a station
peter1138
parents:
3766
diff
changeset
|
1005 |
|
0 | 1006 |
do { |
1775
548dc04d50e2
(svn r2279) - Fix: Check the parameters of the first 10 Commands. While there also add proper comments for the functions and fix up CmdFailed()
Darkvater
parents:
1774
diff
changeset
|
1007 |
TileIndex tile = tile_org; |
0 | 1008 |
int w = plat_len; |
1009 |
do { |
|
3769
7d3b35126fc1
(svn r4761) - Newstations: support platform information in variable 10 (callback parameter 1) when building a station
peter1138
parents:
3766
diff
changeset
|
1010 |
byte layout = *layout_ptr++; |
5587
167d9a91ef02
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
rubidium
parents:
5584
diff
changeset
|
1011 |
MakeRailStation(tile, st->owner, st->index, axis, layout, (RailType)GB(p2, 0, 4)); |
3587 | 1012 |
SetCustomStationSpecIndex(tile, specindex); |
3742
c5ef7a92daa5
(svn r4724) - Newstations: Add per-tile random data for station tiles.
peter1138
parents:
3741
diff
changeset
|
1013 |
SetStationTileRandomBits(tile, GB(Random(), 0, 4)); |
0 | 1014 |
|
3754
4c8cbaaa0bbe
(svn r4742) - Newstations: Add callbacks for building and drawing custom stations.
peter1138
parents:
3751
diff
changeset
|
1015 |
if (statspec != NULL) { |
3784
213a1a3f8697
(svn r4780) - Newstations: when building using a dynamic layout, add the station axis to the returned tile type. Also supply correct parameters to var 10.
peter1138
parents:
3775
diff
changeset
|
1016 |
/* Use a fixed axis for GetPlatformInfo as our platforms / numtracks are always the right way around */ |
213a1a3f8697
(svn r4780) - Newstations: when building using a dynamic layout, add the station axis to the returned tile type. Also supply correct parameters to var 10.
peter1138
parents:
3775
diff
changeset
|
1017 |
uint32 platinfo = GetPlatformInfo(AXIS_X, 0, plat_len, numtracks_orig, plat_len - w, numtracks_orig - numtracks, false); |
3769
7d3b35126fc1
(svn r4761) - Newstations: support platform information in variable 10 (callback parameter 1) when building a station
peter1138
parents:
3766
diff
changeset
|
1018 |
uint16 callback = GetStationCallback(CBID_STATION_TILE_LAYOUT, platinfo, 0, statspec, st, tile); |
3784
213a1a3f8697
(svn r4780) - Newstations: when building using a dynamic layout, add the station axis to the returned tile type. Also supply correct parameters to var 10.
peter1138
parents:
3775
diff
changeset
|
1019 |
if (callback != CALLBACK_FAILED && callback < 8) SetStationGfx(tile, callback + axis); |
3754
4c8cbaaa0bbe
(svn r4742) - Newstations: Add callbacks for building and drawing custom stations.
peter1138
parents:
3751
diff
changeset
|
1020 |
} |
4c8cbaaa0bbe
(svn r4742) - Newstations: Add callbacks for building and drawing custom stations.
peter1138
parents:
3751
diff
changeset
|
1021 |
|
0 | 1022 |
tile += tile_delta; |
1023 |
} while (--w); |
|
2824
4409cab99b02
(svn r3372) - Fix: update signal states when building or removing rail station blocks
peter1138
parents:
2817
diff
changeset
|
1024 |
SetSignalsOnBothDir(tile_org, track); |
3900
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
3884
diff
changeset
|
1025 |
YapfNotifyTrackLayoutChange(tile_org, track); |
1981 | 1026 |
tile_org += tile_delta ^ TileDiffXY(1, 1); // perpendicular to tile_delta |
0 | 1027 |
} while (--numtracks); |
1028 |
||
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1029 |
st->MarkTilesDirty(); |
0 | 1030 |
UpdateStationVirtCoordDirty(st); |
1031 |
UpdateStationAcceptance(st, false); |
|
3812
e6fc916c17ab
(svn r4822) -Feature: Station List View can now be sorted and filtered (by waiting cargo type and facilities)
celestar
parents:
3789
diff
changeset
|
1032 |
RebuildStationLists(); |
0 | 1033 |
InvalidateWindow(WC_STATION_LIST, st->owner); |
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1034 |
/* success, so don't delete the new station */ |
5844
60231b36473e
(svn r8414) -Codechange: Use own AutoPtrT instead of std::auto_ptr.
KUDr
parents:
5837
diff
changeset
|
1035 |
st_auto_delete.Release(); |
0 | 1036 |
} |
1037 |
||
1038 |
return cost; |
|
1039 |
} |
|
1040 |
||
1041 |
static void MakeRailwayStationAreaSmaller(Station *st) |
|
1042 |
{ |
|
1043 |
uint w = st->trainst_w; |
|
1044 |
uint h = st->trainst_h; |
|
1977
37bbebf94434
(svn r2483) Replace almost 500 "uint tile" (and variants) with "TileIndex tile"
tron
parents:
1942
diff
changeset
|
1045 |
TileIndex tile = st->train_tile; |
0 | 1046 |
uint i; |
1047 |
||
1048 |
restart: |
|
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
159
diff
changeset
|
1049 |
|
0 | 1050 |
// too small? |
1051 |
if (w != 0 && h != 0) { |
|
1052 |
// check the left side, x = constant, y changes |
|
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1053 |
for (i = 0; !st->TileBelongsToRailStation(tile + TileDiffXY(0, i));) { |
0 | 1054 |
// the left side is unused? |
1981 | 1055 |
if (++i == h) { |
1056 |
tile += TileDiffXY(1, 0); |
|
1057 |
w--; |
|
1058 |
goto restart; |
|
1059 |
} |
|
1060 |
} |
|
0 | 1061 |
|
1062 |
// check the right side, x = constant, y changes |
|
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1063 |
for (i = 0; !st->TileBelongsToRailStation(tile + TileDiffXY(w - 1, i));) { |
0 | 1064 |
// the right side is unused? |
1981 | 1065 |
if (++i == h) { |
1066 |
w--; |
|
1067 |
goto restart; |
|
1068 |
} |
|
1069 |
} |
|
0 | 1070 |
|
1071 |
// check the upper side, y = constant, x changes |
|
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1072 |
for (i = 0; !st->TileBelongsToRailStation(tile + TileDiffXY(i, 0));) { |
0 | 1073 |
// the left side is unused? |
1981 | 1074 |
if (++i == w) { |
1075 |
tile += TileDiffXY(0, 1); |
|
1076 |
h--; |
|
1077 |
goto restart; |
|
1078 |
} |
|
1079 |
} |
|
0 | 1080 |
|
1081 |
// check the lower side, y = constant, x changes |
|
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1082 |
for (i = 0; !st->TileBelongsToRailStation(tile + TileDiffXY(i, h - 1));) { |
0 | 1083 |
// the left side is unused? |
1981 | 1084 |
if (++i == w) { |
1085 |
h--; |
|
1086 |
goto restart; |
|
1087 |
} |
|
1088 |
} |
|
0 | 1089 |
} else { |
1090 |
tile = 0; |
|
1091 |
} |
|
1092 |
||
1093 |
st->trainst_w = w; |
|
1094 |
st->trainst_h = h; |
|
1095 |
st->train_tile = tile; |
|
1096 |
} |
|
1097 |
||
1782
48749e4c2dc6
(svn r2286) - CodeChange: paramcheck the next batch of commands.
Darkvater
parents:
1781
diff
changeset
|
1098 |
/** Remove a single tile from a railroad station. |
48749e4c2dc6
(svn r2286) - CodeChange: paramcheck the next batch of commands.
Darkvater
parents:
1781
diff
changeset
|
1099 |
* This allows for custom-built station with holes and weird layouts |
3491
35d747bb5e82
(svn r4342) Change the first two parameters of commands - virtual pixel coordinates of the tile to operate on - to a TileIndex
tron
parents:
3482
diff
changeset
|
1100 |
* @param tile tile of station piece to remove |
1782
48749e4c2dc6
(svn r2286) - CodeChange: paramcheck the next batch of commands.
Darkvater
parents:
1781
diff
changeset
|
1101 |
* @param p1 unused |
48749e4c2dc6
(svn r2286) - CodeChange: paramcheck the next batch of commands.
Darkvater
parents:
1781
diff
changeset
|
1102 |
* @param p2 unused |
48749e4c2dc6
(svn r2286) - CodeChange: paramcheck the next batch of commands.
Darkvater
parents:
1781
diff
changeset
|
1103 |
*/ |
3491
35d747bb5e82
(svn r4342) Change the first two parameters of commands - virtual pixel coordinates of the tile to operate on - to a TileIndex
tron
parents:
3482
diff
changeset
|
1104 |
int32 CmdRemoveFromRailroadStation(TileIndex tile, uint32 flags, uint32 p1, uint32 p2) |
0 | 1105 |
{ |
1106 |
Station *st; |
|
1107 |
||
889
64d2f7d5f02b
(svn r1375) -Fix: [1050990] Buying trains sometimes accounted for incorrectly. Was the result of the cost getting reset in a recursive call of docommand. That is fixed. In addition all cost-commands are typed explicitely. Please do not forget to do so or your costs will be credited to construction if you are unlucky.
darkvater
parents:
863
diff
changeset
|
1108 |
SET_EXPENSES_TYPE(EXPENSES_CONSTRUCTION); |
64d2f7d5f02b
(svn r1375) -Fix: [1050990] Buying trains sometimes accounted for incorrectly. Was the result of the cost getting reset in a recursive call of docommand. That is fixed. In addition all cost-commands are typed explicitely. Please do not forget to do so or your costs will be credited to construction if you are unlucky.
darkvater
parents:
863
diff
changeset
|
1109 |
|
0 | 1110 |
// make sure the specified tile belongs to the current player, and that it is a railroad station. |
3334
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
1111 |
if (!IsTileType(tile, MP_STATION) || !IsRailwayStation(tile) || !_patches.nonuniform_stations) return CMD_ERROR; |
3315
c9d989783c55
(svn r4079) Add GetSation{Index,ByTile}() to get the station index resp. the station from a tile
tron
parents:
3282
diff
changeset
|
1112 |
st = GetStationByTile(tile); |
149
5f7d4b21df01
(svn r150) -Fix: [1010833] Turning on the magic bulldozer removes oil rigs
darkvater
parents:
123
diff
changeset
|
1113 |
if (_current_player != OWNER_WATER && (!CheckOwnership(st->owner) || !EnsureNoVehicle(tile))) return CMD_ERROR; |
0 | 1114 |
|
1115 |
// if we reached here, it means we can actually delete it. do that. |
|
1116 |
if (flags & DC_EXEC) { |
|
3587 | 1117 |
uint specindex = GetCustomStationSpecIndex(tile); |
3334
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
1118 |
Track track = GetRailStationTrack(tile); |
0 | 1119 |
DoClearSquare(tile); |
5676
7a641ebbc080
(svn r8136) -Codechange: Station spread rectangle manipulators turned into StationRect::methods.
KUDr
parents:
5668
diff
changeset
|
1120 |
st->rect.AfterRemoveTile(st, tile); |
2824
4409cab99b02
(svn r3372) - Fix: update signal states when building or removing rail station blocks
peter1138
parents:
2817
diff
changeset
|
1121 |
SetSignalsOnBothDir(tile, track); |
3900
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
3884
diff
changeset
|
1122 |
YapfNotifyTrackLayoutChange(tile, track); |
3587 | 1123 |
|
1124 |
DeallocateSpecFromStation(st, specindex); |
|
1125 |
||
0 | 1126 |
// now we need to make the "spanned" area of the railway station smaller if we deleted something at the edges. |
1127 |
// we also need to adjust train_tile. |
|
1128 |
MakeRailwayStationAreaSmaller(st); |
|
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1129 |
st->MarkTilesDirty(); |
5098
7de23befaee4
(svn r7169) -Fix: [FS#388] Station sign (and base station coordinates) didn't move along with station when station moved by walking. (HMage)
KUDr
parents:
4982
diff
changeset
|
1130 |
UpdateStationSignCoord(st); |
0 | 1131 |
|
1132 |
// if we deleted the whole station, delete the train facility. |
|
1133 |
if (st->train_tile == 0) { |
|
1134 |
st->facilities &= ~FACIL_TRAIN; |
|
1135 |
UpdateStationVirtCoordDirty(st); |
|
1136 |
DeleteStationIfEmpty(st); |
|
1137 |
} |
|
1138 |
} |
|
1139 |
return _price.remove_rail_station; |
|
1140 |
} |
|
1141 |
||
1142 |
// determine the number of platforms for the station |
|
2436
7d5df545bd5d
(svn r2962) - const correctness for all Get* functions and most Draw* functions that don't change their pointer parameters
Darkvater
parents:
2427
diff
changeset
|
1143 |
uint GetStationPlatforms(const Station *st, TileIndex tile) |
0 | 1144 |
{ |
2498
3ed05caa4449
(svn r3024) -Codechange: Another batch of replacements of int/uint/int16/byte/-1 with proper types and constants
tron
parents:
2493
diff
changeset
|
1145 |
TileIndex t; |
3ed05caa4449
(svn r3024) -Codechange: Another batch of replacements of int/uint/int16/byte/-1 with proper types and constants
tron
parents:
2493
diff
changeset
|
1146 |
TileIndexDiff delta; |
3334
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
1147 |
Axis axis; |
2639 | 1148 |
uint len; |
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1149 |
assert(st->TileBelongsToRailStation(tile)); |
0 | 1150 |
|
1151 |
len = 0; |
|
3334
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
1152 |
axis = GetRailStationAxis(tile); |
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
1153 |
delta = (axis == AXIS_X ? TileDiffXY(1, 0) : TileDiffXY(0, 1)); |
0 | 1154 |
|
1155 |
// find starting tile.. |
|
1156 |
t = tile; |
|
2639 | 1157 |
do { |
1158 |
t -= delta; |
|
1159 |
len++; |
|
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1160 |
} while (st->TileBelongsToRailStation(t) && GetRailStationAxis(t) == axis); |
0 | 1161 |
|
1162 |
// find ending tile |
|
1163 |
t = tile; |
|
2639 | 1164 |
do { |
1165 |
t += delta; |
|
1166 |
len++; |
|
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1167 |
} while (st->TileBelongsToRailStation(t) && GetRailStationAxis(t) == axis); |
0 | 1168 |
|
1169 |
return len - 1; |
|
1170 |
} |
|
1171 |
||
3928
53fe96558353
(svn r5063) -Codechange: Add a function to determine the length of a platform (request by KUDr)
celestar
parents:
3900
diff
changeset
|
1172 |
/** Determines the REMAINING length of a platform, starting at (and including) |
4549
106ed18a7675
(svn r6381) -Cleanup: make the '/* */' comments that span multiple lines more uniform.
rubidium
parents:
4528
diff
changeset
|
1173 |
* the given tile. |
106ed18a7675
(svn r6381) -Cleanup: make the '/* */' comments that span multiple lines more uniform.
rubidium
parents:
4528
diff
changeset
|
1174 |
* @param tile the tile from which to start searching. Must be a railway station tile |
106ed18a7675
(svn r6381) -Cleanup: make the '/* */' comments that span multiple lines more uniform.
rubidium
parents:
4528
diff
changeset
|
1175 |
* @param dir The direction in which to search. |
106ed18a7675
(svn r6381) -Cleanup: make the '/* */' comments that span multiple lines more uniform.
rubidium
parents:
4528
diff
changeset
|
1176 |
* @return The platform length |
106ed18a7675
(svn r6381) -Cleanup: make the '/* */' comments that span multiple lines more uniform.
rubidium
parents:
4528
diff
changeset
|
1177 |
*/ |
3928
53fe96558353
(svn r5063) -Codechange: Add a function to determine the length of a platform (request by KUDr)
celestar
parents:
3900
diff
changeset
|
1178 |
uint GetPlatformLength(TileIndex tile, DiagDirection dir) |
53fe96558353
(svn r5063) -Codechange: Add a function to determine the length of a platform (request by KUDr)
celestar
parents:
3900
diff
changeset
|
1179 |
{ |
53fe96558353
(svn r5063) -Codechange: Add a function to determine the length of a platform (request by KUDr)
celestar
parents:
3900
diff
changeset
|
1180 |
TileIndex start_tile = tile; |
53fe96558353
(svn r5063) -Codechange: Add a function to determine the length of a platform (request by KUDr)
celestar
parents:
3900
diff
changeset
|
1181 |
uint length = 0; |
53fe96558353
(svn r5063) -Codechange: Add a function to determine the length of a platform (request by KUDr)
celestar
parents:
3900
diff
changeset
|
1182 |
assert(IsRailwayStationTile(tile)); |
53fe96558353
(svn r5063) -Codechange: Add a function to determine the length of a platform (request by KUDr)
celestar
parents:
3900
diff
changeset
|
1183 |
assert(dir < DIAGDIR_END); |
53fe96558353
(svn r5063) -Codechange: Add a function to determine the length of a platform (request by KUDr)
celestar
parents:
3900
diff
changeset
|
1184 |
|
53fe96558353
(svn r5063) -Codechange: Add a function to determine the length of a platform (request by KUDr)
celestar
parents:
3900
diff
changeset
|
1185 |
do { |
53fe96558353
(svn r5063) -Codechange: Add a function to determine the length of a platform (request by KUDr)
celestar
parents:
3900
diff
changeset
|
1186 |
length ++; |
4559
aa0c13e39840
(svn r6406) -Codechange: Rename TileOffsByDir to TileOffsByDiagDir because it accepts
Darkvater
parents:
4549
diff
changeset
|
1187 |
tile += TileOffsByDiagDir(dir); |
3928
53fe96558353
(svn r5063) -Codechange: Add a function to determine the length of a platform (request by KUDr)
celestar
parents:
3900
diff
changeset
|
1188 |
} while (IsCompatibleTrainStationTile(tile, start_tile)); |
53fe96558353
(svn r5063) -Codechange: Add a function to determine the length of a platform (request by KUDr)
celestar
parents:
3900
diff
changeset
|
1189 |
|
53fe96558353
(svn r5063) -Codechange: Add a function to determine the length of a platform (request by KUDr)
celestar
parents:
3900
diff
changeset
|
1190 |
return length; |
53fe96558353
(svn r5063) -Codechange: Add a function to determine the length of a platform (request by KUDr)
celestar
parents:
3900
diff
changeset
|
1191 |
} |
53fe96558353
(svn r5063) -Codechange: Add a function to determine the length of a platform (request by KUDr)
celestar
parents:
3900
diff
changeset
|
1192 |
|
53fe96558353
(svn r5063) -Codechange: Add a function to determine the length of a platform (request by KUDr)
celestar
parents:
3900
diff
changeset
|
1193 |
|
149
5f7d4b21df01
(svn r150) -Fix: [1010833] Turning on the magic bulldozer removes oil rigs
darkvater
parents:
123
diff
changeset
|
1194 |
static int32 RemoveRailroadStation(Station *st, TileIndex tile, uint32 flags) |
0 | 1195 |
{ |
1196 |
int w,h; |
|
5362
1a3af9aa3697
(svn r7547) -Fix: The cost of rail station removal was calculated based on the area occupied by the station. This produced unreasonably large removal costs for non-uniform stations. Now it is based on number of station tiles actually removed.
KUDr
parents:
5247
diff
changeset
|
1197 |
int32 cost = 0; |
0 | 1198 |
|
149
5f7d4b21df01
(svn r150) -Fix: [1010833] Turning on the magic bulldozer removes oil rigs
darkvater
parents:
123
diff
changeset
|
1199 |
/* if there is flooding and non-uniform stations are enabled, remove platforms tile by tile */ |
5f7d4b21df01
(svn r150) -Fix: [1010833] Turning on the magic bulldozer removes oil rigs
darkvater
parents:
123
diff
changeset
|
1200 |
if (_current_player == OWNER_WATER && _patches.nonuniform_stations) |
3491
35d747bb5e82
(svn r4342) Change the first two parameters of commands - virtual pixel coordinates of the tile to operate on - to a TileIndex
tron
parents:
3482
diff
changeset
|
1201 |
return DoCommand(tile, 0, 0, DC_EXEC, CMD_REMOVE_FROM_RAILROAD_STATION); |
149
5f7d4b21df01
(svn r150) -Fix: [1010833] Turning on the magic bulldozer removes oil rigs
darkvater
parents:
123
diff
changeset
|
1202 |
|
0 | 1203 |
/* Current player owns the station? */ |
1204 |
if (_current_player != OWNER_WATER && !CheckOwnership(st->owner)) |
|
1205 |
return CMD_ERROR; |
|
1206 |
||
1207 |
/* determine width and height of platforms */ |
|
1208 |
tile = st->train_tile; |
|
1209 |
w = st->trainst_w; |
|
1210 |
h = st->trainst_h; |
|
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
159
diff
changeset
|
1211 |
|
0 | 1212 |
assert(w != 0 && h != 0); |
1213 |
||
1214 |
/* clear all areas of the station */ |
|
1215 |
do { |
|
1216 |
int w_bak = w; |
|
1217 |
do { |
|
1218 |
// for nonuniform stations, only remove tiles that are actually train station tiles |
|
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1219 |
if (st->TileBelongsToRailStation(tile)) { |
0 | 1220 |
if (!EnsureNoVehicle(tile)) |
1221 |
return CMD_ERROR; |
|
5362
1a3af9aa3697
(svn r7547) -Fix: The cost of rail station removal was calculated based on the area occupied by the station. This produced unreasonably large removal costs for non-uniform stations. Now it is based on number of station tiles actually removed.
KUDr
parents:
5247
diff
changeset
|
1222 |
cost += _price.remove_rail_station; |
2824
4409cab99b02
(svn r3372) - Fix: update signal states when building or removing rail station blocks
peter1138
parents:
2817
diff
changeset
|
1223 |
if (flags & DC_EXEC) { |
3334
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
1224 |
Track track = GetRailStationTrack(tile); |
0 | 1225 |
DoClearSquare(tile); |
2824
4409cab99b02
(svn r3372) - Fix: update signal states when building or removing rail station blocks
peter1138
parents:
2817
diff
changeset
|
1226 |
SetSignalsOnBothDir(tile, track); |
3900
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
3884
diff
changeset
|
1227 |
YapfNotifyTrackLayoutChange(tile, track); |
2824
4409cab99b02
(svn r3372) - Fix: update signal states when building or removing rail station blocks
peter1138
parents:
2817
diff
changeset
|
1228 |
} |
0 | 1229 |
} |
1981 | 1230 |
tile += TileDiffXY(1, 0); |
0 | 1231 |
} while (--w); |
1232 |
w = w_bak; |
|
1981 | 1233 |
tile += TileDiffXY(-w, 1); |
0 | 1234 |
} while (--h); |
1235 |
||
1236 |
if (flags & DC_EXEC) { |
|
5676
7a641ebbc080
(svn r8136) -Codechange: Station spread rectangle manipulators turned into StationRect::methods.
KUDr
parents:
5668
diff
changeset
|
1237 |
st->rect.AfterRemoveRect(st, st->train_tile, st->trainst_w, st->trainst_h); |
5395
7727da322d66
(svn r7585) -Codechange: CheckStationSpreadOut() took too much CPU. Station rectangle is now maintained instead of calculating it each time by walking through whole map. Should help with the performance issue related to AIs trying to build road stops too often. (idea by Celestar)
KUDr
parents:
5385
diff
changeset
|
1238 |
|
0 | 1239 |
st->train_tile = 0; |
5395
7727da322d66
(svn r7585) -Codechange: CheckStationSpreadOut() took too much CPU. Station rectangle is now maintained instead of calculating it each time by walking through whole map. Should help with the performance issue related to AIs trying to build road stops too often. (idea by Celestar)
KUDr
parents:
5385
diff
changeset
|
1240 |
st->trainst_w = st->trainst_h = 0; |
0 | 1241 |
st->facilities &= ~FACIL_TRAIN; |
1242 |
||
3587 | 1243 |
free(st->speclist); |
1244 |
st->num_specs = 0; |
|
1245 |
st->speclist = NULL; |
|
1246 |
||
0 | 1247 |
UpdateStationVirtCoordDirty(st); |
1248 |
DeleteStationIfEmpty(st); |
|
1249 |
} |
|
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
159
diff
changeset
|
1250 |
|
0 | 1251 |
return cost; |
1252 |
} |
|
1253 |
||
3435
dfba5b1c7c2d
(svn r4265) - Fix: compile warning on VS2005 (parameter 2 different from declaration)
Darkvater
parents:
3431
diff
changeset
|
1254 |
int32 DoConvertStationRail(TileIndex tile, RailType totype, bool exec) |
0 | 1255 |
{ |
3315
c9d989783c55
(svn r4079) Add GetSation{Index,ByTile}() to get the station index resp. the station from a tile
tron
parents:
3282
diff
changeset
|
1256 |
const Station* st = GetStationByTile(tile); |
c9d989783c55
(svn r4079) Add GetSation{Index,ByTile}() to get the station index resp. the station from a tile
tron
parents:
3282
diff
changeset
|
1257 |
|
0 | 1258 |
if (!CheckOwnership(st->owner) || !EnsureNoVehicle(tile)) return CMD_ERROR; |
1259 |
||
1260 |
// tile is not a railroad station? |
|
3334
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
1261 |
if (!IsRailwayStation(tile)) return CMD_ERROR; |
0 | 1262 |
|
3242
4c32bf21153b
(svn r3916) Get/Set the rail type by [GS]etRailType{Crossing,OnBridge,}()
tron
parents:
3222
diff
changeset
|
1263 |
if (GetRailType(tile) == totype) return CMD_ERROR; |
0 | 1264 |
|
5116
3c0c3da214ca
(svn r7195) -Feature: [FS#297, optional elrails] New patches/vehicles option 'disable electrified railways'.
KUDr
parents:
5103
diff
changeset
|
1265 |
// 'hidden' elrails can't be downgraded to normal rail when elrails are disabled |
3c0c3da214ca
(svn r7195) -Feature: [FS#297, optional elrails] New patches/vehicles option 'disable electrified railways'.
KUDr
parents:
5103
diff
changeset
|
1266 |
if (_patches.disable_elrails && totype == RAILTYPE_RAIL && GetRailType(tile) == RAILTYPE_ELECTRIC) return CMD_ERROR; |
3c0c3da214ca
(svn r7195) -Feature: [FS#297, optional elrails] New patches/vehicles option 'disable electrified railways'.
KUDr
parents:
5103
diff
changeset
|
1267 |
|
0 | 1268 |
if (exec) { |
3242
4c32bf21153b
(svn r3916) Get/Set the rail type by [GS]etRailType{Crossing,OnBridge,}()
tron
parents:
3222
diff
changeset
|
1269 |
SetRailType(tile, totype); |
0 | 1270 |
MarkTileDirtyByTile(tile); |
3900
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
3884
diff
changeset
|
1271 |
YapfNotifyTrackLayoutChange(tile, GetRailStationTrack(tile)); |
0 | 1272 |
} |
1273 |
||
1274 |
return _price.build_rail >> 1; |
|
1275 |
} |
|
1276 |
||
3691
56dfcf599c3f
(svn r4619) -Codechange: Rename FindRoadStationSpot into FindRoadStopSpot and try to document it a little.
celestar
parents:
3687
diff
changeset
|
1277 |
/** Heavy wizardry used to add a roadstop to a station. |
4549
106ed18a7675
(svn r6381) -Cleanup: make the '/* */' comments that span multiple lines more uniform.
rubidium
parents:
4528
diff
changeset
|
1278 |
* To understand the function, lets first look at what is passed around, |
5867 | 1279 |
* especially the last parameter. CmdBuildRoadStop allocates a road |
4549
106ed18a7675
(svn r6381) -Cleanup: make the '/* */' comments that span multiple lines more uniform.
rubidium
parents:
4528
diff
changeset
|
1280 |
* stop and needs to put that stop into the linked list of road stops. |
106ed18a7675
(svn r6381) -Cleanup: make the '/* */' comments that span multiple lines more uniform.
rubidium
parents:
4528
diff
changeset
|
1281 |
* It (CmdBuildRoadStop) has a **currstop pointer which points to element |
106ed18a7675
(svn r6381) -Cleanup: make the '/* */' comments that span multiple lines more uniform.
rubidium
parents:
4528
diff
changeset
|
1282 |
* in the linked list of stops (each element in this list being a pointer |
106ed18a7675
(svn r6381) -Cleanup: make the '/* */' comments that span multiple lines more uniform.
rubidium
parents:
4528
diff
changeset
|
1283 |
* in itself, hence the double pointer). We (FindRoadStopSpot) need to |
106ed18a7675
(svn r6381) -Cleanup: make the '/* */' comments that span multiple lines more uniform.
rubidium
parents:
4528
diff
changeset
|
1284 |
* modify this pointer (**currstop) thus we need to pass by reference, |
106ed18a7675
(svn r6381) -Cleanup: make the '/* */' comments that span multiple lines more uniform.
rubidium
parents:
4528
diff
changeset
|
1285 |
* obtaining a triple pointer (***currstop). When finished, **currstop |
106ed18a7675
(svn r6381) -Cleanup: make the '/* */' comments that span multiple lines more uniform.
rubidium
parents:
4528
diff
changeset
|
1286 |
* in CmdBuildRoadStop will contain the address of the pointer which will |
5867 | 1287 |
* then point into the global roadstop array. |
5836
a60d2114780e
(svn r8402) -Codechange: Move RoadStop-specific enums to the RoadStop class, and changed a one-member enum into a static const. Simplify their naming and add some doxygen-comments to RoadStop
celestar
parents:
5834
diff
changeset
|
1288 |
* @param[in] truck_station Determines whether a stop is RoadStop::BUS or RoadStop::TRUCK |
4549
106ed18a7675
(svn r6381) -Cleanup: make the '/* */' comments that span multiple lines more uniform.
rubidium
parents:
4528
diff
changeset
|
1289 |
* @param[in] station The station to do the whole procedure for |
106ed18a7675
(svn r6381) -Cleanup: make the '/* */' comments that span multiple lines more uniform.
rubidium
parents:
4528
diff
changeset
|
1290 |
* @param[out] currstop See the detailed function description |
106ed18a7675
(svn r6381) -Cleanup: make the '/* */' comments that span multiple lines more uniform.
rubidium
parents:
4528
diff
changeset
|
1291 |
* @param prev See the detailed function description |
106ed18a7675
(svn r6381) -Cleanup: make the '/* */' comments that span multiple lines more uniform.
rubidium
parents:
4528
diff
changeset
|
1292 |
*/ |
5867 | 1293 |
static void FindRoadStopSpot(bool truck_station, Station* st, RoadStop*** currstop) |
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
1294 |
{ |
3691
56dfcf599c3f
(svn r4619) -Codechange: Rename FindRoadStationSpot into FindRoadStopSpot and try to document it a little.
celestar
parents:
3687
diff
changeset
|
1295 |
RoadStop **primary_stop = (truck_station) ? &st->truck_stops : &st->bus_stops; |
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
1296 |
|
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
1297 |
if (*primary_stop == NULL) { |
3691
56dfcf599c3f
(svn r4619) -Codechange: Rename FindRoadStationSpot into FindRoadStopSpot and try to document it a little.
celestar
parents:
3687
diff
changeset
|
1298 |
//we have no roadstop of the type yet, so write a "primary stop" |
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
1299 |
*currstop = primary_stop; |
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
1300 |
} else { |
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
1301 |
//there are stops already, so append to the end of the list |
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
1302 |
*currstop = &(*primary_stop)->next; |
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
1303 |
while (**currstop != NULL) { |
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
1304 |
*currstop = &(**currstop)->next; |
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
1305 |
} |
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
1306 |
} |
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
1307 |
} |
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
1308 |
|
3691
56dfcf599c3f
(svn r4619) -Codechange: Rename FindRoadStationSpot into FindRoadStopSpot and try to document it a little.
celestar
parents:
3687
diff
changeset
|
1309 |
/** Build a bus or truck stop |
56dfcf599c3f
(svn r4619) -Codechange: Rename FindRoadStationSpot into FindRoadStopSpot and try to document it a little.
celestar
parents:
3687
diff
changeset
|
1310 |
* @param tile tile to build the stop at |
3333 | 1311 |
* @param p1 entrance direction (DiagDirection) |
1782
48749e4c2dc6
(svn r2286) - CodeChange: paramcheck the next batch of commands.
Darkvater
parents:
1781
diff
changeset
|
1312 |
* @param p2 0 for Bus stops, 1 for truck stops |
0 | 1313 |
*/ |
3491
35d747bb5e82
(svn r4342) Change the first two parameters of commands - virtual pixel coordinates of the tile to operate on - to a TileIndex
tron
parents:
3482
diff
changeset
|
1314 |
int32 CmdBuildRoadStop(TileIndex tile, uint32 flags, uint32 p1, uint32 p2) |
0 | 1315 |
{ |
1782
48749e4c2dc6
(svn r2286) - CodeChange: paramcheck the next batch of commands.
Darkvater
parents:
1781
diff
changeset
|
1316 |
Station *st; |
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
1317 |
RoadStop *road_stop; |
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
1318 |
RoadStop **currstop; |
0 | 1319 |
int32 cost; |
3183
90c676e6a50d
(svn r3829) Reduce the use of _error_message by directly returning error codes instead of using this global variable
tron
parents:
3161
diff
changeset
|
1320 |
int32 ret; |
1782
48749e4c2dc6
(svn r2286) - CodeChange: paramcheck the next batch of commands.
Darkvater
parents:
1781
diff
changeset
|
1321 |
bool type = !!p2; |
48749e4c2dc6
(svn r2286) - CodeChange: paramcheck the next batch of commands.
Darkvater
parents:
1781
diff
changeset
|
1322 |
|
48749e4c2dc6
(svn r2286) - CodeChange: paramcheck the next batch of commands.
Darkvater
parents:
1781
diff
changeset
|
1323 |
/* Saveguard the parameters */ |
5587
167d9a91ef02
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
rubidium
parents:
5584
diff
changeset
|
1324 |
if (!IsValidDiagDirection((DiagDirection)p1)) return CMD_ERROR; |
0 | 1325 |
|
1326 |
SET_EXPENSES_TYPE(EXPENSES_CONSTRUCTION); |
|
1327 |
||
1328 |
if (!(flags & DC_NO_TOWN_RATING) && !CheckIfAuthorityAllows(tile)) |
|
1329 |
return CMD_ERROR; |
|
1330 |
||
3183
90c676e6a50d
(svn r3829) Reduce the use of _error_message by directly returning error codes instead of using this global variable
tron
parents:
3161
diff
changeset
|
1331 |
ret = CheckFlatLandBelow(tile, 1, 1, flags, 1 << p1, NULL); |
90c676e6a50d
(svn r3829) Reduce the use of _error_message by directly returning error codes instead of using this global variable
tron
parents:
3161
diff
changeset
|
1332 |
if (CmdFailed(ret)) return ret; |
90c676e6a50d
(svn r3829) Reduce the use of _error_message by directly returning error codes instead of using this global variable
tron
parents:
3161
diff
changeset
|
1333 |
cost = ret; |
0 | 1334 |
|
5587
167d9a91ef02
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
rubidium
parents:
5584
diff
changeset
|
1335 |
st = GetStationAround(tile, 1, 1, INVALID_STATION); |
2639 | 1336 |
if (st == CHECK_STATIONS_ERR) return CMD_ERROR; |
0 | 1337 |
|
1338 |
/* Find a station close to us */ |
|
1339 |
if (st == NULL) { |
|
1340 |
st = GetClosestStationFromTile(tile, 8, _current_player); |
|
2989 | 1341 |
if (st != NULL && st->facilities != 0) st = NULL; |
0 | 1342 |
} |
1343 |
||
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
1344 |
//give us a road stop in the list, and check if something went wrong |
5716 | 1345 |
road_stop = new RoadStop(tile); |
2951 | 1346 |
if (road_stop == NULL) { |
1347 |
return_cmd_error(type ? STR_3008B_TOO_MANY_TRUCK_STOPS : STR_3008A_TOO_MANY_BUS_STOPS); |
|
1348 |
} |
|
1349 |
||
5833
a0abc408c0bb
(svn r8399) -Fix (r8185): a new road stop was always created in CmdBuildRoadStop(), but it was not deleted if DC_EXEC flag was not set or if the station creation failed
glx
parents:
5721
diff
changeset
|
1350 |
/* ensure that in case of error (or no DC_EXEC) the new road stop gets deleted upon return */ |
5844
60231b36473e
(svn r8414) -Codechange: Use own AutoPtrT instead of std::auto_ptr.
KUDr
parents:
5837
diff
changeset
|
1351 |
AutoPtrT<RoadStop> rs_auto_delete(road_stop); |
5833
a0abc408c0bb
(svn r8399) -Fix (r8185): a new road stop was always created in CmdBuildRoadStop(), but it was not deleted if DC_EXEC flag was not set or if the station creation failed
glx
parents:
5721
diff
changeset
|
1352 |
|
2989 | 1353 |
if (st != NULL && |
5837
e9c21cf7c7d9
(svn r8403) -Fix (r8402): Forgot to remove an enum
celestar
parents:
5836
diff
changeset
|
1354 |
GetNumRoadStopsInStation(st, RoadStop::BUS) + GetNumRoadStopsInStation(st, RoadStop::TRUCK) >= RoadStop::LIMIT) { |
2951 | 1355 |
return_cmd_error(type ? STR_3008B_TOO_MANY_TRUCK_STOPS : STR_3008A_TOO_MANY_BUS_STOPS); |
1356 |
} |
|
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
1357 |
|
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1358 |
/* In case of new station if DC_EXEC is NOT set we still need to create the station |
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1359 |
* to test if everything is OK. In this case we need to delete it before return. */ |
5844
60231b36473e
(svn r8414) -Codechange: Use own AutoPtrT instead of std::auto_ptr.
KUDr
parents:
5837
diff
changeset
|
1360 |
AutoPtrT<Station> st_auto_delete; |
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1361 |
|
0 | 1362 |
if (st != NULL) { |
2951 | 1363 |
if (st->owner != OWNER_NONE && st->owner != _current_player) { |
0 | 1364 |
return_cmd_error(STR_3009_TOO_CLOSE_TO_ANOTHER_STATION); |
2951 | 1365 |
} |
1366 |
||
5676
7a641ebbc080
(svn r8136) -Codechange: Station spread rectangle manipulators turned into StationRect::methods.
KUDr
parents:
5668
diff
changeset
|
1367 |
if (!st->rect.BeforeAddTile(tile, StationRect::ADD_TEST)) return CMD_ERROR; |
0 | 1368 |
|
5867 | 1369 |
FindRoadStopSpot(type, st, &currstop); |
0 | 1370 |
} else { |
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1371 |
/* allocate and initialize new station */ |
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1372 |
st = new Station(tile); |
2639 | 1373 |
if (st == NULL) return CMD_ERROR; |
0 | 1374 |
|
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1375 |
/* ensure that in case of error (or no DC_EXEC) the new station gets deleted upon return */ |
5844
60231b36473e
(svn r8414) -Codechange: Use own AutoPtrT instead of std::auto_ptr.
KUDr
parents:
5837
diff
changeset
|
1376 |
st_auto_delete = st; |
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1377 |
|
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1378 |
|
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1379 |
Town *t = st->town = ClosestTownFromTile(tile, (uint)-1); |
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1380 |
if (!GenerateStationName(st, tile, 0)) return CMD_ERROR; |
0 | 1381 |
|
5867 | 1382 |
FindRoadStopSpot(type, st, &currstop); |
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
1383 |
|
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1384 |
if (IsValidPlayer(_current_player) && (flags & DC_EXEC) != 0) { |
0 | 1385 |
SETBIT(t->have_ratings, _current_player); |
2951 | 1386 |
} |
0 | 1387 |
|
1388 |
st->sign.width_1 = 0; |
|
1389 |
} |
|
1390 |
||
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
1391 |
cost += (type) ? _price.build_truck_station : _price.build_bus_station; |
0 | 1392 |
|
1393 |
if (flags & DC_EXEC) { |
|
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
1394 |
//point to the correct item in the _busstops or _truckstops array |
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
1395 |
*currstop = road_stop; |
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
1396 |
|
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
1397 |
//initialize an empty station |
5721
fa4e587f59f5
(svn r8231) -Fix (r8125): MP desync caused by calling Random() from station constructor. This was wrong because station constructor is called also when loading savegame and when player tries to build station when it is not sure that it will succeed (thanks Rubidium)
KUDr
parents:
5718
diff
changeset
|
1398 |
st->AddFacility((type) ? FACIL_TRUCK_STOP : FACIL_BUS_STOP, tile); |
0 | 1399 |
|
5676
7a641ebbc080
(svn r8136) -Codechange: Station spread rectangle manipulators turned into StationRect::methods.
KUDr
parents:
5668
diff
changeset
|
1400 |
st->rect.BeforeAddTile(tile, StationRect::ADD_TRY); |
5395
7727da322d66
(svn r7585) -Codechange: CheckStationSpreadOut() took too much CPU. Station rectangle is now maintained instead of calculating it each time by walking through whole map. Should help with the performance issue related to AIs trying to build road stops too often. (idea by Celestar)
KUDr
parents:
5385
diff
changeset
|
1401 |
|
5836
a60d2114780e
(svn r8402) -Codechange: Move RoadStop-specific enums to the RoadStop class, and changed a one-member enum into a static const. Simplify their naming and add some doxygen-comments to RoadStop
celestar
parents:
5834
diff
changeset
|
1402 |
MakeRoadStop(tile, st->owner, st->index, type ? RoadStop::TRUCK : RoadStop::BUS, (DiagDirection)p1); |
0 | 1403 |
|
1404 |
UpdateStationVirtCoordDirty(st); |
|
1405 |
UpdateStationAcceptance(st, false); |
|
3812
e6fc916c17ab
(svn r4822) -Feature: Station List View can now be sorted and filtered (by waiting cargo type and facilities)
celestar
parents:
3789
diff
changeset
|
1406 |
RebuildStationLists(); |
0 | 1407 |
InvalidateWindow(WC_STATION_LIST, st->owner); |
5833
a0abc408c0bb
(svn r8399) -Fix (r8185): a new road stop was always created in CmdBuildRoadStop(), but it was not deleted if DC_EXEC flag was not set or if the station creation failed
glx
parents:
5721
diff
changeset
|
1408 |
/* success, so don't delete the new station and the new road stop */ |
5844
60231b36473e
(svn r8414) -Codechange: Use own AutoPtrT instead of std::auto_ptr.
KUDr
parents:
5837
diff
changeset
|
1409 |
st_auto_delete.Release(); |
60231b36473e
(svn r8414) -Codechange: Use own AutoPtrT instead of std::auto_ptr.
KUDr
parents:
5837
diff
changeset
|
1410 |
rs_auto_delete.Release(); |
0 | 1411 |
} |
1412 |
return cost; |
|
1413 |
} |
|
1414 |
||
1415 |
// Remove a bus station |
|
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
1416 |
static int32 RemoveRoadStop(Station *st, uint32 flags, TileIndex tile) |
0 | 1417 |
{ |
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
1418 |
RoadStop **primary_stop; |
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
1419 |
RoadStop *cur_stop; |
3334
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
1420 |
bool is_truck = IsTruckStop(tile); |
0 | 1421 |
|
2951 | 1422 |
if (_current_player != OWNER_WATER && !CheckOwnership(st->owner)) { |
0 | 1423 |
return CMD_ERROR; |
2951 | 1424 |
} |
0 | 1425 |
|
2639 | 1426 |
if (is_truck) { // truck stop |
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
1427 |
primary_stop = &st->truck_stops; |
5836
a60d2114780e
(svn r8402) -Codechange: Move RoadStop-specific enums to the RoadStop class, and changed a one-member enum into a static const. Simplify their naming and add some doxygen-comments to RoadStop
celestar
parents:
5834
diff
changeset
|
1428 |
cur_stop = GetRoadStopByTile(tile, RoadStop::TRUCK); |
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
1429 |
} else { |
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
1430 |
primary_stop = &st->bus_stops; |
5836
a60d2114780e
(svn r8402) -Codechange: Move RoadStop-specific enums to the RoadStop class, and changed a one-member enum into a static const. Simplify their naming and add some doxygen-comments to RoadStop
celestar
parents:
5834
diff
changeset
|
1431 |
cur_stop = GetRoadStopByTile(tile, RoadStop::BUS); |
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
1432 |
} |
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
1433 |
|
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
1434 |
assert(cur_stop != NULL); |
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
159
diff
changeset
|
1435 |
|
2951 | 1436 |
if (!EnsureNoVehicle(tile)) return CMD_ERROR; |
0 | 1437 |
|
1438 |
if (flags & DC_EXEC) { |
|
5867 | 1439 |
if (*primary_stop == cur_stop) { |
1440 |
// removed the first stop in the list |
|
1441 |
*primary_stop = cur_stop->next; |
|
1442 |
// removed the only stop? |
|
1443 |
if (*primary_stop == NULL) { |
|
1444 |
st->facilities &= (is_truck ? ~FACIL_TRUCK_STOP : ~FACIL_BUS_STOP); |
|
1445 |
} |
|
1446 |
} else { |
|
1447 |
// tell the predecessor in the list to skip this stop |
|
1448 |
RoadStop *pred = *primary_stop; |
|
1449 |
while (pred->next != cur_stop) pred = pred->next; |
|
1450 |
pred->next = cur_stop->next; |
|
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
1451 |
} |
0 | 1452 |
|
5708
4c4c5ec2bed6
(svn r8185) -Codechange: Equipped Roadstops with new/delete operators and gave them proper constructors/destructors (Thanks to KUDr for a nice interactive C++ lesson)
celestar
parents:
5697
diff
changeset
|
1453 |
delete cur_stop; |
4398
9232bcc7422a
(svn r6151) -Codechange: DeleteStation/DeleteRoadStop removes a station/RoadStop from the pool
truelight
parents:
4397
diff
changeset
|
1454 |
DoClearSquare(tile); |
5676
7a641ebbc080
(svn r8136) -Codechange: Station spread rectangle manipulators turned into StationRect::methods.
KUDr
parents:
5668
diff
changeset
|
1455 |
st->rect.AfterRemoveTile(st, tile); |
4398
9232bcc7422a
(svn r6151) -Codechange: DeleteStation/DeleteRoadStop removes a station/RoadStop from the pool
truelight
parents:
4397
diff
changeset
|
1456 |
|
0 | 1457 |
UpdateStationVirtCoordDirty(st); |
1458 |
DeleteStationIfEmpty(st); |
|
1459 |
} |
|
1460 |
||
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
1461 |
return (is_truck) ? _price.remove_truck_station : _price.remove_bus_station; |
0 | 1462 |
} |
1463 |
||
1464 |
||
1465 |
||
1466 |
// FIXME -- need to move to its corresponding Airport variable |
|
1467 |
// Country Airfield (small) |
|
3429
20b7bab277c1
(svn r4257) -Codechange: Renamed the airport_map5_tiles_* variables into airport_sections_*
celestar
parents:
3422
diff
changeset
|
1468 |
static const byte _airport_sections_country[] = { |
0 | 1469 |
54, 53, 52, 65, |
1470 |
58, 57, 56, 55, |
|
1471 |
64, 63, 63, 62 |
|
1472 |
}; |
|
1473 |
||
1474 |
// City Airport (large) |
|
3429
20b7bab277c1
(svn r4257) -Codechange: Renamed the airport_map5_tiles_* variables into airport_sections_*
celestar
parents:
3422
diff
changeset
|
1475 |
static const byte _airport_sections_town[] = { |
2549 | 1476 |
31, 9, 33, 9, 9, 32, |
1477 |
27, 36, 29, 34, 8, 10, |
|
0 | 1478 |
30, 11, 35, 13, 20, 21, |
1479 |
51, 12, 14, 17, 19, 28, |
|
1480 |
38, 13, 15, 16, 18, 39, |
|
1481 |
26, 22, 23, 24, 25, 26 |
|
1482 |
}; |
|
1483 |
||
1484 |
// Metropolitain Airport (large) - 2 runways |
|
3429
20b7bab277c1
(svn r4257) -Codechange: Renamed the airport_map5_tiles_* variables into airport_sections_*
celestar
parents:
3422
diff
changeset
|
1485 |
static const byte _airport_sections_metropolitan[] = { |
2549 | 1486 |
31, 9, 33, 9, 9, 32, |
1487 |
27, 36, 29, 34, 8, 10, |
|
1488 |
30, 11, 35, 13, 20, 21, |
|
1489 |
102, 8, 8, 8, 8, 28, |
|
1490 |
83, 84, 84, 84, 84, 83, |
|
1491 |
26, 23, 23, 23, 23, 26 |
|
0 | 1492 |
}; |
1493 |
||
1494 |
// International Airport (large) - 2 runways |
|
3429
20b7bab277c1
(svn r4257) -Codechange: Renamed the airport_map5_tiles_* variables into airport_sections_*
celestar
parents:
3422
diff
changeset
|
1495 |
static const byte _airport_sections_international[] = { |
3554
86230061c3e7
(svn r4426) Code Cleaning : replacing tabs with spaces, removing obvious comments, aligning arrays etc...
belugas
parents:
3553
diff
changeset
|
1496 |
88, 89, 89, 89, 89, 89, 88, |
86230061c3e7
(svn r4426) Code Cleaning : replacing tabs with spaces, removing obvious comments, aligning arrays etc...
belugas
parents:
3553
diff
changeset
|
1497 |
51, 8, 8, 8, 8, 8, 32, |
2549 | 1498 |
30, 8, 11, 27, 11, 8, 10, |
0 | 1499 |
32, 8, 11, 27, 11, 8, 114, |
1500 |
87, 8, 11, 85, 11, 8, 114, |
|
2549 | 1501 |
87, 8, 8, 8, 8, 8, 90, |
1502 |
26, 23, 23, 23, 23, 23, 26 |
|
0 | 1503 |
}; |
1504 |
||
4059
b1e1c1193f0a
(svn r5346) - Feature: Add 4 new airports. 2 for aircraft, 2 for helicopters.
richk
parents:
4000
diff
changeset
|
1505 |
// Intercontinental Airport (vlarge) - 4 runways |
b1e1c1193f0a
(svn r5346) - Feature: Add 4 new airports. 2 for aircraft, 2 for helicopters.
richk
parents:
4000
diff
changeset
|
1506 |
static const byte _airport_sections_intercontinental[] = { |
4077
d4d440dd8925
(svn r5391) Miscellaneous, mostly bracing and whitespace, nothing spectacular
tron
parents:
4066
diff
changeset
|
1507 |
102, 120, 89, 89, 89, 89, 89, 89, 118, |
d4d440dd8925
(svn r5391) Miscellaneous, mostly bracing and whitespace, nothing spectacular
tron
parents:
4066
diff
changeset
|
1508 |
120, 22, 22, 22, 22, 22, 22, 119, 117, |
d4d440dd8925
(svn r5391) Miscellaneous, mostly bracing and whitespace, nothing spectacular
tron
parents:
4066
diff
changeset
|
1509 |
87, 54, 87, 8, 8, 8, 8, 51, 117, |
d4d440dd8925
(svn r5391) Miscellaneous, mostly bracing and whitespace, nothing spectacular
tron
parents:
4066
diff
changeset
|
1510 |
87, 162, 87, 85, 116, 116, 8, 9, 10, |
4059
b1e1c1193f0a
(svn r5346) - Feature: Add 4 new airports. 2 for aircraft, 2 for helicopters.
richk
parents:
4000
diff
changeset
|
1511 |
87, 8, 8, 11, 31, 11, 8, 160, 32, |
b1e1c1193f0a
(svn r5346) - Feature: Add 4 new airports. 2 for aircraft, 2 for helicopters.
richk
parents:
4000
diff
changeset
|
1512 |
32, 160, 8, 11, 27, 11, 8, 8, 10, |
b1e1c1193f0a
(svn r5346) - Feature: Add 4 new airports. 2 for aircraft, 2 for helicopters.
richk
parents:
4000
diff
changeset
|
1513 |
87, 8, 8, 11, 30, 11, 8, 8, 10, |
4066
2d099b946f10
(svn r5362) - Fix: Updated sprites in New Airports to be allow cleaner replacement by newgrf graphics. All tiles now use SPR_AIRPORT_APRON as the tarmac. Created two new sprites in airports.grf for half-grass half-tarmac tiles on Intercontinental airport.
richk
parents:
4059
diff
changeset
|
1514 |
87, 142, 8, 11, 29, 11, 10, 163, 10, |
2d099b946f10
(svn r5362) - Fix: Updated sprites in New Airports to be allow cleaner replacement by newgrf graphics. All tiles now use SPR_AIRPORT_APRON as the tarmac. Created two new sprites in airports.grf for half-grass half-tarmac tiles on Intercontinental airport.
richk
parents:
4059
diff
changeset
|
1515 |
87, 164, 87, 8, 8, 8, 10, 37, 117, |
4077
d4d440dd8925
(svn r5391) Miscellaneous, mostly bracing and whitespace, nothing spectacular
tron
parents:
4066
diff
changeset
|
1516 |
87, 120, 89, 89, 89, 89, 89, 89, 119, |
d4d440dd8925
(svn r5391) Miscellaneous, mostly bracing and whitespace, nothing spectacular
tron
parents:
4066
diff
changeset
|
1517 |
121, 22, 22, 22, 22, 22, 22, 119, 37 |
4059
b1e1c1193f0a
(svn r5346) - Feature: Add 4 new airports. 2 for aircraft, 2 for helicopters.
richk
parents:
4000
diff
changeset
|
1518 |
}; |
b1e1c1193f0a
(svn r5346) - Feature: Add 4 new airports. 2 for aircraft, 2 for helicopters.
richk
parents:
4000
diff
changeset
|
1519 |
|
b1e1c1193f0a
(svn r5346) - Feature: Add 4 new airports. 2 for aircraft, 2 for helicopters.
richk
parents:
4000
diff
changeset
|
1520 |
|
b1e1c1193f0a
(svn r5346) - Feature: Add 4 new airports. 2 for aircraft, 2 for helicopters.
richk
parents:
4000
diff
changeset
|
1521 |
// Commuter Airfield (small) |
b1e1c1193f0a
(svn r5346) - Feature: Add 4 new airports. 2 for aircraft, 2 for helicopters.
richk
parents:
4000
diff
changeset
|
1522 |
static const byte _airport_sections_commuter[] = { |
b1e1c1193f0a
(svn r5346) - Feature: Add 4 new airports. 2 for aircraft, 2 for helicopters.
richk
parents:
4000
diff
changeset
|
1523 |
85, 30, 115, 115, 32, |
b1e1c1193f0a
(svn r5346) - Feature: Add 4 new airports. 2 for aircraft, 2 for helicopters.
richk
parents:
4000
diff
changeset
|
1524 |
87, 8, 8, 8, 10, |
b1e1c1193f0a
(svn r5346) - Feature: Add 4 new airports. 2 for aircraft, 2 for helicopters.
richk
parents:
4000
diff
changeset
|
1525 |
87, 11, 11, 11, 10, |
b1e1c1193f0a
(svn r5346) - Feature: Add 4 new airports. 2 for aircraft, 2 for helicopters.
richk
parents:
4000
diff
changeset
|
1526 |
26, 23, 23, 23, 26 |
b1e1c1193f0a
(svn r5346) - Feature: Add 4 new airports. 2 for aircraft, 2 for helicopters.
richk
parents:
4000
diff
changeset
|
1527 |
}; |
b1e1c1193f0a
(svn r5346) - Feature: Add 4 new airports. 2 for aircraft, 2 for helicopters.
richk
parents:
4000
diff
changeset
|
1528 |
|
0 | 1529 |
// Heliport |
3429
20b7bab277c1
(svn r4257) -Codechange: Renamed the airport_map5_tiles_* variables into airport_sections_*
celestar
parents:
3422
diff
changeset
|
1530 |
static const byte _airport_sections_heliport[] = { |
0 | 1531 |
66, |
1532 |
}; |
|
1533 |
||
4059
b1e1c1193f0a
(svn r5346) - Feature: Add 4 new airports. 2 for aircraft, 2 for helicopters.
richk
parents:
4000
diff
changeset
|
1534 |
// Helidepot |
b1e1c1193f0a
(svn r5346) - Feature: Add 4 new airports. 2 for aircraft, 2 for helicopters.
richk
parents:
4000
diff
changeset
|
1535 |
static const byte _airport_sections_helidepot[] = { |
b1e1c1193f0a
(svn r5346) - Feature: Add 4 new airports. 2 for aircraft, 2 for helicopters.
richk
parents:
4000
diff
changeset
|
1536 |
124, 32, |
b1e1c1193f0a
(svn r5346) - Feature: Add 4 new airports. 2 for aircraft, 2 for helicopters.
richk
parents:
4000
diff
changeset
|
1537 |
122, 123 |
b1e1c1193f0a
(svn r5346) - Feature: Add 4 new airports. 2 for aircraft, 2 for helicopters.
richk
parents:
4000
diff
changeset
|
1538 |
}; |
b1e1c1193f0a
(svn r5346) - Feature: Add 4 new airports. 2 for aircraft, 2 for helicopters.
richk
parents:
4000
diff
changeset
|
1539 |
|
b1e1c1193f0a
(svn r5346) - Feature: Add 4 new airports. 2 for aircraft, 2 for helicopters.
richk
parents:
4000
diff
changeset
|
1540 |
// Helistation |
b1e1c1193f0a
(svn r5346) - Feature: Add 4 new airports. 2 for aircraft, 2 for helicopters.
richk
parents:
4000
diff
changeset
|
1541 |
static const byte _airport_sections_helistation[] = { |
b1e1c1193f0a
(svn r5346) - Feature: Add 4 new airports. 2 for aircraft, 2 for helicopters.
richk
parents:
4000
diff
changeset
|
1542 |
32, 134, 159, 158, |
b1e1c1193f0a
(svn r5346) - Feature: Add 4 new airports. 2 for aircraft, 2 for helicopters.
richk
parents:
4000
diff
changeset
|
1543 |
161, 142, 142, 157 |
b1e1c1193f0a
(svn r5346) - Feature: Add 4 new airports. 2 for aircraft, 2 for helicopters.
richk
parents:
4000
diff
changeset
|
1544 |
}; |
b1e1c1193f0a
(svn r5346) - Feature: Add 4 new airports. 2 for aircraft, 2 for helicopters.
richk
parents:
4000
diff
changeset
|
1545 |
|
3471
e454e2c0c23e
(svn r4316) -Codechange: finished r4257 (forgot one variable there)
celestar
parents:
3435
diff
changeset
|
1546 |
static const byte * const _airport_sections[] = { |
4059
b1e1c1193f0a
(svn r5346) - Feature: Add 4 new airports. 2 for aircraft, 2 for helicopters.
richk
parents:
4000
diff
changeset
|
1547 |
_airport_sections_country, // Country Airfield (small) |
b1e1c1193f0a
(svn r5346) - Feature: Add 4 new airports. 2 for aircraft, 2 for helicopters.
richk
parents:
4000
diff
changeset
|
1548 |
_airport_sections_town, // City Airport (large) |
b1e1c1193f0a
(svn r5346) - Feature: Add 4 new airports. 2 for aircraft, 2 for helicopters.
richk
parents:
4000
diff
changeset
|
1549 |
_airport_sections_heliport, // Heliport |
b1e1c1193f0a
(svn r5346) - Feature: Add 4 new airports. 2 for aircraft, 2 for helicopters.
richk
parents:
4000
diff
changeset
|
1550 |
_airport_sections_metropolitan, // Metropolitain Airport (large) |
b1e1c1193f0a
(svn r5346) - Feature: Add 4 new airports. 2 for aircraft, 2 for helicopters.
richk
parents:
4000
diff
changeset
|
1551 |
_airport_sections_international, // International Airport (xlarge) |
b1e1c1193f0a
(svn r5346) - Feature: Add 4 new airports. 2 for aircraft, 2 for helicopters.
richk
parents:
4000
diff
changeset
|
1552 |
_airport_sections_commuter, // Commuter Airport (small) |
b1e1c1193f0a
(svn r5346) - Feature: Add 4 new airports. 2 for aircraft, 2 for helicopters.
richk
parents:
4000
diff
changeset
|
1553 |
_airport_sections_helidepot, // Helidepot |
b1e1c1193f0a
(svn r5346) - Feature: Add 4 new airports. 2 for aircraft, 2 for helicopters.
richk
parents:
4000
diff
changeset
|
1554 |
_airport_sections_intercontinental, // Intercontinental Airport (xxlarge) |
b1e1c1193f0a
(svn r5346) - Feature: Add 4 new airports. 2 for aircraft, 2 for helicopters.
richk
parents:
4000
diff
changeset
|
1555 |
_airport_sections_helistation // Helistation |
0 | 1556 |
}; |
1557 |
||
1784
d0698aac0c2e
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
Darkvater
parents:
1782
diff
changeset
|
1558 |
/** Place an Airport. |
3491
35d747bb5e82
(svn r4342) Change the first two parameters of commands - virtual pixel coordinates of the tile to operate on - to a TileIndex
tron
parents:
3482
diff
changeset
|
1559 |
* @param tile tile where airport will be built |
1784
d0698aac0c2e
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
Darkvater
parents:
1782
diff
changeset
|
1560 |
* @param p1 airport type, @see airport.h |
d0698aac0c2e
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
Darkvater
parents:
1782
diff
changeset
|
1561 |
* @param p2 unused |
0 | 1562 |
*/ |
3491
35d747bb5e82
(svn r4342) Change the first two parameters of commands - virtual pixel coordinates of the tile to operate on - to a TileIndex
tron
parents:
3482
diff
changeset
|
1563 |
int32 CmdBuildAirport(TileIndex tile, uint32 flags, uint32 p1, uint32 p2) |
0 | 1564 |
{ |
1565 |
Town *t; |
|
1566 |
Station *st; |
|
1567 |
int32 cost; |
|
3183
90c676e6a50d
(svn r3829) Reduce the use of _error_message by directly returning error codes instead of using this global variable
tron
parents:
3161
diff
changeset
|
1568 |
int32 ret; |
1784
d0698aac0c2e
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
Darkvater
parents:
1782
diff
changeset
|
1569 |
int w, h; |
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
159
diff
changeset
|
1570 |
bool airport_upgrade = true; |
3876
468642825a10
(svn r4918) Move the information about the size of airports from an global array into the struct which describes an airport
tron
parents:
3873
diff
changeset
|
1571 |
const AirportFTAClass* afc; |
0 | 1572 |
|
1573 |
SET_EXPENSES_TYPE(EXPENSES_CONSTRUCTION); |
|
1574 |
||
1784
d0698aac0c2e
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
Darkvater
parents:
1782
diff
changeset
|
1575 |
/* Check if a valid, buildable airport was chosen for construction */ |
3471
e454e2c0c23e
(svn r4316) -Codechange: finished r4257 (forgot one variable there)
celestar
parents:
3435
diff
changeset
|
1576 |
if (p1 > lengthof(_airport_sections) || !HASBIT(GetValidAirports(), p1)) return CMD_ERROR; |
1784
d0698aac0c2e
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
Darkvater
parents:
1782
diff
changeset
|
1577 |
|
0 | 1578 |
if (!(flags & DC_NO_TOWN_RATING) && !CheckIfAuthorityAllows(tile)) |
1579 |
return CMD_ERROR; |
|
1580 |
||
1581 |
t = ClosestTownFromTile(tile, (uint)-1); |
|
1582 |
||
1583 |
/* Check if local auth refuses a new airport */ |
|
1584 |
{ |
|
1585 |
uint num = 0; |
|
1586 |
FOR_ALL_STATIONS(st) { |
|
4346
66105d4f6e83
(svn r6047) -Codechange: FOR_ALL now _only_ loops valid items, and skips invalid ones
truelight
parents:
4344
diff
changeset
|
1587 |
if (st->town == t && st->facilities&FACIL_AIRPORT && st->airport_type != AT_OILRIG) |
0 | 1588 |
num++; |
1589 |
} |
|
1590 |
if (num >= 2) { |
|
534
306bc86eb23e
(svn r901) Small step in the process to clean up the DPARAM mess:
tron
parents:
507
diff
changeset
|
1591 |
SetDParam(0, t->index); |
0 | 1592 |
return_cmd_error(STR_2035_LOCAL_AUTHORITY_REFUSES); |
1593 |
} |
|
1594 |
} |
|
1595 |
||
3876
468642825a10
(svn r4918) Move the information about the size of airports from an global array into the struct which describes an airport
tron
parents:
3873
diff
changeset
|
1596 |
afc = GetAirport(p1); |
468642825a10
(svn r4918) Move the information about the size of airports from an global array into the struct which describes an airport
tron
parents:
3873
diff
changeset
|
1597 |
w = afc->size_x; |
468642825a10
(svn r4918) Move the information about the size of airports from an global array into the struct which describes an airport
tron
parents:
3873
diff
changeset
|
1598 |
h = afc->size_y; |
0 | 1599 |
|
3183
90c676e6a50d
(svn r3829) Reduce the use of _error_message by directly returning error codes instead of using this global variable
tron
parents:
3161
diff
changeset
|
1600 |
ret = CheckFlatLandBelow(tile, w, h, flags, 0, NULL); |
90c676e6a50d
(svn r3829) Reduce the use of _error_message by directly returning error codes instead of using this global variable
tron
parents:
3161
diff
changeset
|
1601 |
if (CmdFailed(ret)) return ret; |
90c676e6a50d
(svn r3829) Reduce the use of _error_message by directly returning error codes instead of using this global variable
tron
parents:
3161
diff
changeset
|
1602 |
cost = ret; |
0 | 1603 |
|
5587
167d9a91ef02
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
rubidium
parents:
5584
diff
changeset
|
1604 |
st = GetStationAround(tile, w, h, INVALID_STATION); |
1784
d0698aac0c2e
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
Darkvater
parents:
1782
diff
changeset
|
1605 |
if (st == CHECK_STATIONS_ERR) return CMD_ERROR; |
0 | 1606 |
|
1607 |
/* Find a station close to us */ |
|
1608 |
if (st == NULL) { |
|
1609 |
st = GetClosestStationFromTile(tile, 8, _current_player); |
|
1784
d0698aac0c2e
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
Darkvater
parents:
1782
diff
changeset
|
1610 |
if (st != NULL && st->facilities) st = NULL; |
0 | 1611 |
} |
1612 |
||
5513
1ccea4948917
(svn r7810) -Fix: FS#504 Building airport whose size exceeds max station spread-out caused assert. (Zuu)
KUDr
parents:
5475
diff
changeset
|
1613 |
if (w > _patches.station_spread || h > _patches.station_spread) { |
1ccea4948917
(svn r7810) -Fix: FS#504 Building airport whose size exceeds max station spread-out caused assert. (Zuu)
KUDr
parents:
5475
diff
changeset
|
1614 |
_error_message = STR_306C_STATION_TOO_SPREAD_OUT; |
1ccea4948917
(svn r7810) -Fix: FS#504 Building airport whose size exceeds max station spread-out caused assert. (Zuu)
KUDr
parents:
5475
diff
changeset
|
1615 |
return CMD_ERROR; |
1ccea4948917
(svn r7810) -Fix: FS#504 Building airport whose size exceeds max station spread-out caused assert. (Zuu)
KUDr
parents:
5475
diff
changeset
|
1616 |
} |
1ccea4948917
(svn r7810) -Fix: FS#504 Building airport whose size exceeds max station spread-out caused assert. (Zuu)
KUDr
parents:
5475
diff
changeset
|
1617 |
|
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1618 |
/* In case of new station if DC_EXEC is NOT set we still need to create the station |
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1619 |
* to test if everything is OK. In this case we need to delete it before return. */ |
5844
60231b36473e
(svn r8414) -Codechange: Use own AutoPtrT instead of std::auto_ptr.
KUDr
parents:
5837
diff
changeset
|
1620 |
AutoPtrT<Station> st_auto_delete; |
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1621 |
|
0 | 1622 |
if (st != NULL) { |
1623 |
if (st->owner != OWNER_NONE && st->owner != _current_player) |
|
1624 |
return_cmd_error(STR_3009_TOO_CLOSE_TO_ANOTHER_STATION); |
|
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
159
diff
changeset
|
1625 |
|
5676
7a641ebbc080
(svn r8136) -Codechange: Station spread rectangle manipulators turned into StationRect::methods.
KUDr
parents:
5668
diff
changeset
|
1626 |
if (!st->rect.BeforeAddRect(tile, w, h, StationRect::ADD_TEST)) return CMD_ERROR; |
0 | 1627 |
|
1628 |
if (st->airport_tile != 0) |
|
1629 |
return_cmd_error(STR_300D_TOO_CLOSE_TO_ANOTHER_AIRPORT); |
|
1630 |
} else { |
|
1631 |
airport_upgrade = false; |
|
1632 |
||
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1633 |
/* allocate and initialize new station */ |
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1634 |
st = new Station(tile); |
1784
d0698aac0c2e
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
Darkvater
parents:
1782
diff
changeset
|
1635 |
if (st == NULL) return CMD_ERROR; |
0 | 1636 |
|
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1637 |
/* ensure that in case of error (or no DC_EXEC) the station gets deleted upon return */ |
5844
60231b36473e
(svn r8414) -Codechange: Use own AutoPtrT instead of std::auto_ptr.
KUDr
parents:
5837
diff
changeset
|
1638 |
st_auto_delete = st; |
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1639 |
|
1265
71ed55c20f6e
(svn r1769) Don't compute the same value twice, remove one function call
tron
parents:
1247
diff
changeset
|
1640 |
st->town = t; |
0 | 1641 |
|
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1642 |
if (IsValidPlayer(_current_player) && (flags & DC_EXEC) != 0) { |
0 | 1643 |
SETBIT(t->have_ratings, _current_player); |
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1644 |
} |
0 | 1645 |
|
1646 |
st->sign.width_1 = 0; |
|
1647 |
||
1648 |
// if airport type equals Heliport then generate |
|
1649 |
// type 5 name, which is heliport, otherwise airport names (1) |
|
4059
b1e1c1193f0a
(svn r5346) - Feature: Add 4 new airports. 2 for aircraft, 2 for helicopters.
richk
parents:
4000
diff
changeset
|
1650 |
if (!GenerateStationName(st, tile, (p1 == AT_HELIPORT)||(p1 == AT_HELIDEPOT)||(p1 == AT_HELISTATION) ? 5 : 1)) |
0 | 1651 |
return CMD_ERROR; |
1652 |
} |
|
1653 |
||
1654 |
cost += _price.build_airport * w * h; |
|
1655 |
||
1656 |
if (flags & DC_EXEC) { |
|
1657 |
st->airport_tile = tile; |
|
5721
fa4e587f59f5
(svn r8231) -Fix (r8125): MP desync caused by calling Random() from station constructor. This was wrong because station constructor is called also when loading savegame and when player tries to build station when it is not sure that it will succeed (thanks Rubidium)
KUDr
parents:
5718
diff
changeset
|
1658 |
st->AddFacility(FACIL_AIRPORT, tile); |
0 | 1659 |
st->airport_type = (byte)p1; |
1660 |
st->airport_flags = 0; |
|
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
159
diff
changeset
|
1661 |
|
5676
7a641ebbc080
(svn r8136) -Codechange: Station spread rectangle manipulators turned into StationRect::methods.
KUDr
parents:
5668
diff
changeset
|
1662 |
st->rect.BeforeAddRect(tile, w, h, StationRect::ADD_TRY); |
5395
7727da322d66
(svn r7585) -Codechange: CheckStationSpreadOut() took too much CPU. Station rectangle is now maintained instead of calculating it each time by walking through whole map. Should help with the performance issue related to AIs trying to build road stops too often. (idea by Celestar)
KUDr
parents:
5385
diff
changeset
|
1663 |
|
2639 | 1664 |
/* if airport was demolished while planes were en-route to it, the |
1665 |
* positions can no longer be the same (v->u.air.pos), since different |
|
1666 |
* airports have different indexes. So update all planes en-route to this |
|
1667 |
* airport. Only update if |
|
1668 |
* 1. airport is upgraded |
|
1669 |
* 2. airport is added to existing station (unfortunately unavoideable) |
|
1670 |
*/ |
|
2549 | 1671 |
if (airport_upgrade) UpdateAirplanesOnNewStation(st); |
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
159
diff
changeset
|
1672 |
|
0 | 1673 |
{ |
3471
e454e2c0c23e
(svn r4316) -Codechange: finished r4257 (forgot one variable there)
celestar
parents:
3435
diff
changeset
|
1674 |
const byte *b = _airport_sections[p1]; |
2549 | 1675 |
|
3033
9cba043eb38f
(svn r3613) Some more const, indentation, whitespace and similar stuff
tron
parents:
3032
diff
changeset
|
1676 |
BEGIN_TILE_LOOP(tile_cur, w, h, tile) { |
3334
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
1677 |
MakeAirport(tile_cur, st->owner, st->index, *b++); |
3033
9cba043eb38f
(svn r3613) Some more const, indentation, whitespace and similar stuff
tron
parents:
3032
diff
changeset
|
1678 |
} END_TILE_LOOP(tile_cur, w, h, tile) |
0 | 1679 |
} |
1680 |
||
1681 |
UpdateStationVirtCoordDirty(st); |
|
1682 |
UpdateStationAcceptance(st, false); |
|
3812
e6fc916c17ab
(svn r4822) -Feature: Station List View can now be sorted and filtered (by waiting cargo type and facilities)
celestar
parents:
3789
diff
changeset
|
1683 |
RebuildStationLists(); |
0 | 1684 |
InvalidateWindow(WC_STATION_LIST, st->owner); |
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1685 |
/* success, so don't delete the new station */ |
5844
60231b36473e
(svn r8414) -Codechange: Use own AutoPtrT instead of std::auto_ptr.
KUDr
parents:
5837
diff
changeset
|
1686 |
st_auto_delete.Release(); |
0 | 1687 |
} |
1688 |
||
1689 |
return cost; |
|
1690 |
} |
|
1691 |
||
1692 |
static int32 RemoveAirport(Station *st, uint32 flags) |
|
1693 |
{ |
|
1977
37bbebf94434
(svn r2483) Replace almost 500 "uint tile" (and variants) with "TileIndex tile"
tron
parents:
1942
diff
changeset
|
1694 |
TileIndex tile; |
0 | 1695 |
int w,h; |
1696 |
int32 cost; |
|
3876
468642825a10
(svn r4918) Move the information about the size of airports from an global array into the struct which describes an airport
tron
parents:
3873
diff
changeset
|
1697 |
const AirportFTAClass* afc; |
0 | 1698 |
|
1699 |
if (_current_player != OWNER_WATER && !CheckOwnership(st->owner)) |
|
1700 |
return CMD_ERROR; |
|
1701 |
||
1702 |
tile = st->airport_tile; |
|
1703 |
||
3876
468642825a10
(svn r4918) Move the information about the size of airports from an global array into the struct which describes an airport
tron
parents:
3873
diff
changeset
|
1704 |
afc = GetAirport(st->airport_type); |
468642825a10
(svn r4918) Move the information about the size of airports from an global array into the struct which describes an airport
tron
parents:
3873
diff
changeset
|
1705 |
w = afc->size_x; |
468642825a10
(svn r4918) Move the information about the size of airports from an global array into the struct which describes an airport
tron
parents:
3873
diff
changeset
|
1706 |
h = afc->size_y; |
0 | 1707 |
|
1708 |
cost = w * h * _price.remove_airport; |
|
1709 |
||
3033
9cba043eb38f
(svn r3613) Some more const, indentation, whitespace and similar stuff
tron
parents:
3032
diff
changeset
|
1710 |
BEGIN_TILE_LOOP(tile_cur, w, h, tile) { |
9cba043eb38f
(svn r3613) Some more const, indentation, whitespace and similar stuff
tron
parents:
3032
diff
changeset
|
1711 |
if (!EnsureNoVehicle(tile_cur)) return CMD_ERROR; |
0 | 1712 |
|
1713 |
if (flags & DC_EXEC) { |
|
1714 |
DeleteAnimatedTile(tile_cur); |
|
1715 |
DoClearSquare(tile_cur); |
|
1716 |
} |
|
3033
9cba043eb38f
(svn r3613) Some more const, indentation, whitespace and similar stuff
tron
parents:
3032
diff
changeset
|
1717 |
} END_TILE_LOOP(tile_cur, w,h,tile) |
0 | 1718 |
|
1719 |
if (flags & DC_EXEC) { |
|
700 | 1720 |
uint i; |
1721 |
||
3033
9cba043eb38f
(svn r3613) Some more const, indentation, whitespace and similar stuff
tron
parents:
3032
diff
changeset
|
1722 |
for (i = 0; i < afc->nof_depots; ++i) { |
9cba043eb38f
(svn r3613) Some more const, indentation, whitespace and similar stuff
tron
parents:
3032
diff
changeset
|
1723 |
DeleteWindowById( |
9cba043eb38f
(svn r3613) Some more const, indentation, whitespace and similar stuff
tron
parents:
3032
diff
changeset
|
1724 |
WC_VEHICLE_DEPOT, tile + ToTileIndexDiff(afc->airport_depots[i]) |
9cba043eb38f
(svn r3613) Some more const, indentation, whitespace and similar stuff
tron
parents:
3032
diff
changeset
|
1725 |
); |
9cba043eb38f
(svn r3613) Some more const, indentation, whitespace and similar stuff
tron
parents:
3032
diff
changeset
|
1726 |
} |
755
80091de50044
(svn r1211) -Feature: Introduce sticky windows to all vehicle windows...Just make sure you do not sticky more than 23 at a time. Also a lot of places in the code invalidated the 'status bar' of the vehicle, referring to it as widget 4. This is now widget 5 and has been #definitized
darkvater
parents:
709
diff
changeset
|
1727 |
|
5676
7a641ebbc080
(svn r8136) -Codechange: Station spread rectangle manipulators turned into StationRect::methods.
KUDr
parents:
5668
diff
changeset
|
1728 |
st->rect.AfterRemoveRect(st, tile, w, h); |
5395
7727da322d66
(svn r7585) -Codechange: CheckStationSpreadOut() took too much CPU. Station rectangle is now maintained instead of calculating it each time by walking through whole map. Should help with the performance issue related to AIs trying to build road stops too often. (idea by Celestar)
KUDr
parents:
5385
diff
changeset
|
1729 |
|
0 | 1730 |
st->airport_tile = 0; |
1731 |
st->facilities &= ~FACIL_AIRPORT; |
|
1732 |
||
1733 |
UpdateStationVirtCoordDirty(st); |
|
1734 |
DeleteStationIfEmpty(st); |
|
1735 |
} |
|
1736 |
||
1737 |
return cost; |
|
1738 |
} |
|
1739 |
||
1784
d0698aac0c2e
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
Darkvater
parents:
1782
diff
changeset
|
1740 |
/** Build a buoy. |
3491
35d747bb5e82
(svn r4342) Change the first two parameters of commands - virtual pixel coordinates of the tile to operate on - to a TileIndex
tron
parents:
3482
diff
changeset
|
1741 |
* @param tile tile where to place the bouy |
1784
d0698aac0c2e
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
Darkvater
parents:
1782
diff
changeset
|
1742 |
* @param p1 unused |
d0698aac0c2e
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
Darkvater
parents:
1782
diff
changeset
|
1743 |
* @param p2 unused |
0 | 1744 |
*/ |
3491
35d747bb5e82
(svn r4342) Change the first two parameters of commands - virtual pixel coordinates of the tile to operate on - to a TileIndex
tron
parents:
3482
diff
changeset
|
1745 |
int32 CmdBuildBuoy(TileIndex tile, uint32 flags, uint32 p1, uint32 p2) |
0 | 1746 |
{ |
1747 |
Station *st; |
|
1748 |
||
1749 |
SET_EXPENSES_TYPE(EXPENSES_CONSTRUCTION); |
|
1750 |
||
3374
faff80c38bcc
(svn r4173) -Codechange: Use IsClearWaterTile for buoy construction
celestar
parents:
3362
diff
changeset
|
1751 |
if (!IsClearWaterTile(tile) || tile == 0) return_cmd_error(STR_304B_SITE_UNSUITABLE); |
0 | 1752 |
|
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1753 |
/* allocate and initialize new station */ |
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1754 |
st = new Station(tile); |
1784
d0698aac0c2e
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
Darkvater
parents:
1782
diff
changeset
|
1755 |
if (st == NULL) return CMD_ERROR; |
0 | 1756 |
|
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1757 |
/* ensure that in case of error (or no DC_EXEC) the station gets deleted upon return */ |
5844
60231b36473e
(svn r8414) -Codechange: Use own AutoPtrT instead of std::auto_ptr.
KUDr
parents:
5837
diff
changeset
|
1758 |
AutoPtrT<Station> st_auto_delete(st); |
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1759 |
|
3055
ed20cba49858
(svn r3644) Don't use FindLandscapeHeightByTile() when it's overkill - often it was just a complicated way of writing GetTileSlope(tile, NULL)
tron
parents:
3047
diff
changeset
|
1760 |
st->town = ClosestTownFromTile(tile, (uint)-1); |
0 | 1761 |
st->sign.width_1 = 0; |
1762 |
||
3055
ed20cba49858
(svn r3644) Don't use FindLandscapeHeightByTile() when it's overkill - often it was just a complicated way of writing GetTileSlope(tile, NULL)
tron
parents:
3047
diff
changeset
|
1763 |
if (!GenerateStationName(st, tile, 4)) return CMD_ERROR; |
0 | 1764 |
|
1765 |
if (flags & DC_EXEC) { |
|
3055
ed20cba49858
(svn r3644) Don't use FindLandscapeHeightByTile() when it's overkill - often it was just a complicated way of writing GetTileSlope(tile, NULL)
tron
parents:
3047
diff
changeset
|
1766 |
st->dock_tile = tile; |
0 | 1767 |
st->facilities |= FACIL_DOCK; |
1751
009a240d035a
(svn r2255) - Fix: [ 9680363 ] [NPF] Broken buoy handling for ships
matthijs
parents:
1706
diff
changeset
|
1768 |
/* Buoys are marked in the Station struct by this flag. Yes, it is this |
009a240d035a
(svn r2255) - Fix: [ 9680363 ] [NPF] Broken buoy handling for ships
matthijs
parents:
1706
diff
changeset
|
1769 |
* braindead.. */ |
0 | 1770 |
st->had_vehicle_of_type |= HVOT_BUOY; |
1771 |
st->owner = OWNER_NONE; |
|
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
159
diff
changeset
|
1772 |
|
71
1b8e15a10515
(svn r72) -Add: build_date of station (viewable with Query tool)
truelight
parents:
65
diff
changeset
|
1773 |
st->build_date = _date; |
0 | 1774 |
|
3334
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
1775 |
MakeBuoy(tile, st->index); |
0 | 1776 |
|
1777 |
UpdateStationVirtCoordDirty(st); |
|
1778 |
UpdateStationAcceptance(st, false); |
|
3812
e6fc916c17ab
(svn r4822) -Feature: Station List View can now be sorted and filtered (by waiting cargo type and facilities)
celestar
parents:
3789
diff
changeset
|
1779 |
RebuildStationLists(); |
0 | 1780 |
InvalidateWindow(WC_STATION_LIST, st->owner); |
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1781 |
/* success, so don't delete the new station */ |
5844
60231b36473e
(svn r8414) -Codechange: Use own AutoPtrT instead of std::auto_ptr.
KUDr
parents:
5837
diff
changeset
|
1782 |
st_auto_delete.Release(); |
0 | 1783 |
} |
1784 |
||
1785 |
return _price.build_dock; |
|
1786 |
} |
|
1787 |
||
1078
1b9163f2e7eb
(svn r1579) Fix: [ 1105963 ] Buoys can now only be removed if no ship has it in their schedule.
dominik
parents:
1067
diff
changeset
|
1788 |
/* Checks if any ship is servicing the buoy specified. Returns yes or no */ |
1b9163f2e7eb
(svn r1579) Fix: [ 1105963 ] Buoys can now only be removed if no ship has it in their schedule.
dominik
parents:
1067
diff
changeset
|
1789 |
static bool CheckShipsOnBuoy(Station *st) |
1b9163f2e7eb
(svn r1579) Fix: [ 1105963 ] Buoys can now only be removed if no ship has it in their schedule.
dominik
parents:
1067
diff
changeset
|
1790 |
{ |
1b9163f2e7eb
(svn r1579) Fix: [ 1105963 ] Buoys can now only be removed if no ship has it in their schedule.
dominik
parents:
1067
diff
changeset
|
1791 |
const Vehicle *v; |
1b9163f2e7eb
(svn r1579) Fix: [ 1105963 ] Buoys can now only be removed if no ship has it in their schedule.
dominik
parents:
1067
diff
changeset
|
1792 |
FOR_ALL_VEHICLES(v) { |
1b9163f2e7eb
(svn r1579) Fix: [ 1105963 ] Buoys can now only be removed if no ship has it in their schedule.
dominik
parents:
1067
diff
changeset
|
1793 |
if (v->type == VEH_Ship) { |
1b9163f2e7eb
(svn r1579) Fix: [ 1105963 ] Buoys can now only be removed if no ship has it in their schedule.
dominik
parents:
1067
diff
changeset
|
1794 |
const Order *order; |
1b9163f2e7eb
(svn r1579) Fix: [ 1105963 ] Buoys can now only be removed if no ship has it in their schedule.
dominik
parents:
1067
diff
changeset
|
1795 |
FOR_VEHICLE_ORDERS(v, order) { |
4527
fa30d19685c2
(svn r6353) -Codechange: Make DestinationID a typedef of uin16, which is as large as any type of destinataion (StationID, DepotID, WaypointID) it can hold
tron
parents:
4467
diff
changeset
|
1796 |
if (order->type == OT_GOTO_STATION && order->dest == st->index) { |
1078
1b9163f2e7eb
(svn r1579) Fix: [ 1105963 ] Buoys can now only be removed if no ship has it in their schedule.
dominik
parents:
1067
diff
changeset
|
1797 |
return true; |
1b9163f2e7eb
(svn r1579) Fix: [ 1105963 ] Buoys can now only be removed if no ship has it in their schedule.
dominik
parents:
1067
diff
changeset
|
1798 |
} |
1b9163f2e7eb
(svn r1579) Fix: [ 1105963 ] Buoys can now only be removed if no ship has it in their schedule.
dominik
parents:
1067
diff
changeset
|
1799 |
} |
1b9163f2e7eb
(svn r1579) Fix: [ 1105963 ] Buoys can now only be removed if no ship has it in their schedule.
dominik
parents:
1067
diff
changeset
|
1800 |
} |
1b9163f2e7eb
(svn r1579) Fix: [ 1105963 ] Buoys can now only be removed if no ship has it in their schedule.
dominik
parents:
1067
diff
changeset
|
1801 |
} |
1b9163f2e7eb
(svn r1579) Fix: [ 1105963 ] Buoys can now only be removed if no ship has it in their schedule.
dominik
parents:
1067
diff
changeset
|
1802 |
return false; |
1b9163f2e7eb
(svn r1579) Fix: [ 1105963 ] Buoys can now only be removed if no ship has it in their schedule.
dominik
parents:
1067
diff
changeset
|
1803 |
} |
1b9163f2e7eb
(svn r1579) Fix: [ 1105963 ] Buoys can now only be removed if no ship has it in their schedule.
dominik
parents:
1067
diff
changeset
|
1804 |
|
0 | 1805 |
static int32 RemoveBuoy(Station *st, uint32 flags) |
1806 |
{ |
|
1977
37bbebf94434
(svn r2483) Replace almost 500 "uint tile" (and variants) with "TileIndex tile"
tron
parents:
1942
diff
changeset
|
1807 |
TileIndex tile; |
0 | 1808 |
|
4850
93095755db8c
(svn r6776) -Codechange: Use IsValidPlayer() function to determine of a PlayerID is an
Darkvater
parents:
4848
diff
changeset
|
1809 |
/* XXX: strange stuff */ |
93095755db8c
(svn r6776) -Codechange: Use IsValidPlayer() function to determine of a PlayerID is an
Darkvater
parents:
4848
diff
changeset
|
1810 |
if (!IsValidPlayer(_current_player)) return_cmd_error(INVALID_STRING_ID); |
0 | 1811 |
|
1812 |
tile = st->dock_tile; |
|
1813 |
||
2639 | 1814 |
if (CheckShipsOnBuoy(st)) return_cmd_error(STR_BUOY_IS_IN_USE); |
1815 |
if (!EnsureNoVehicle(tile)) return CMD_ERROR; |
|
0 | 1816 |
|
1817 |
if (flags & DC_EXEC) { |
|
1818 |
st->dock_tile = 0; |
|
1751
009a240d035a
(svn r2255) - Fix: [ 9680363 ] [NPF] Broken buoy handling for ships
matthijs
parents:
1706
diff
changeset
|
1819 |
/* Buoys are marked in the Station struct by this flag. Yes, it is this |
009a240d035a
(svn r2255) - Fix: [ 9680363 ] [NPF] Broken buoy handling for ships
matthijs
parents:
1706
diff
changeset
|
1820 |
* braindead.. */ |
0 | 1821 |
st->facilities &= ~FACIL_DOCK; |
1822 |
st->had_vehicle_of_type &= ~HVOT_BUOY; |
|
1823 |
||
3111
750f37699a13
(svn r3714) Add functions to turn tiles into water and shore tiles
tron
parents:
3102
diff
changeset
|
1824 |
MakeWater(tile); |
750f37699a13
(svn r3714) Add functions to turn tiles into water and shore tiles
tron
parents:
3102
diff
changeset
|
1825 |
MarkTileDirtyByTile(tile); |
0 | 1826 |
|
1827 |
UpdateStationVirtCoordDirty(st); |
|
1828 |
DeleteStationIfEmpty(st); |
|
1829 |
} |
|
1830 |
||
1831 |
return _price.remove_truck_station; |
|
1832 |
} |
|
1833 |
||
909
65cdb609b7a6
(svn r1396) Introduce TileIndexDiffC - the compile time version of TileIndexDiff
tron
parents:
900
diff
changeset
|
1834 |
static const TileIndexDiffC _dock_tileoffs_chkaround[] = { |
65cdb609b7a6
(svn r1396) Introduce TileIndexDiffC - the compile time version of TileIndexDiff
tron
parents:
900
diff
changeset
|
1835 |
{-1, 0}, |
65cdb609b7a6
(svn r1396) Introduce TileIndexDiffC - the compile time version of TileIndexDiff
tron
parents:
900
diff
changeset
|
1836 |
{ 0, 0}, |
65cdb609b7a6
(svn r1396) Introduce TileIndexDiffC - the compile time version of TileIndexDiff
tron
parents:
900
diff
changeset
|
1837 |
{ 0, 0}, |
65cdb609b7a6
(svn r1396) Introduce TileIndexDiffC - the compile time version of TileIndexDiff
tron
parents:
900
diff
changeset
|
1838 |
{ 0, -1} |
0 | 1839 |
}; |
4344
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
1840 |
static const byte _dock_w_chk[4] = { 2, 1, 2, 1 }; |
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
1841 |
static const byte _dock_h_chk[4] = { 1, 2, 1, 2 }; |
0 | 1842 |
|
1784
d0698aac0c2e
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
Darkvater
parents:
1782
diff
changeset
|
1843 |
/** Build a dock/haven. |
3491
35d747bb5e82
(svn r4342) Change the first two parameters of commands - virtual pixel coordinates of the tile to operate on - to a TileIndex
tron
parents:
3482
diff
changeset
|
1844 |
* @param tile tile where dock will be built |
1784
d0698aac0c2e
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
Darkvater
parents:
1782
diff
changeset
|
1845 |
* @param p1 unused |
d0698aac0c2e
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
Darkvater
parents:
1782
diff
changeset
|
1846 |
* @param p2 unused |
d0698aac0c2e
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
Darkvater
parents:
1782
diff
changeset
|
1847 |
*/ |
3491
35d747bb5e82
(svn r4342) Change the first two parameters of commands - virtual pixel coordinates of the tile to operate on - to a TileIndex
tron
parents:
3482
diff
changeset
|
1848 |
int32 CmdBuildDock(TileIndex tile, uint32 flags, uint32 p1, uint32 p2) |
0 | 1849 |
{ |
3055
ed20cba49858
(svn r3644) Don't use FindLandscapeHeightByTile() when it's overkill - often it was just a complicated way of writing GetTileSlope(tile, NULL)
tron
parents:
3047
diff
changeset
|
1850 |
TileIndex tile_cur; |
3157
3f35e2d9c8e3
(svn r3783) Replace further ints and magic numbers by Direction, DiagDirection and friends
tron
parents:
3123
diff
changeset
|
1851 |
DiagDirection direction; |
0 | 1852 |
int32 cost; |
1853 |
Station *st; |
|
1854 |
||
1855 |
SET_EXPENSES_TYPE(EXPENSES_CONSTRUCTION); |
|
1856 |
||
3055
ed20cba49858
(svn r3644) Don't use FindLandscapeHeightByTile() when it's overkill - often it was just a complicated way of writing GetTileSlope(tile, NULL)
tron
parents:
3047
diff
changeset
|
1857 |
switch (GetTileSlope(tile, NULL)) { |
3636
a36cc46e754d
(svn r4541) Add a type for slopes and replace many magic numbers by the appropriate enums
tron
parents:
3630
diff
changeset
|
1858 |
case SLOPE_SW: direction = DIAGDIR_NE; break; |
a36cc46e754d
(svn r4541) Add a type for slopes and replace many magic numbers by the appropriate enums
tron
parents:
3630
diff
changeset
|
1859 |
case SLOPE_SE: direction = DIAGDIR_NW; break; |
a36cc46e754d
(svn r4541) Add a type for slopes and replace many magic numbers by the appropriate enums
tron
parents:
3630
diff
changeset
|
1860 |
case SLOPE_NW: direction = DIAGDIR_SE; break; |
a36cc46e754d
(svn r4541) Add a type for slopes and replace many magic numbers by the appropriate enums
tron
parents:
3630
diff
changeset
|
1861 |
case SLOPE_NE: direction = DIAGDIR_SW; break; |
3055
ed20cba49858
(svn r3644) Don't use FindLandscapeHeightByTile() when it's overkill - often it was just a complicated way of writing GetTileSlope(tile, NULL)
tron
parents:
3047
diff
changeset
|
1862 |
default: return_cmd_error(STR_304B_SITE_UNSUITABLE); |
ed20cba49858
(svn r3644) Don't use FindLandscapeHeightByTile() when it's overkill - often it was just a complicated way of writing GetTileSlope(tile, NULL)
tron
parents:
3047
diff
changeset
|
1863 |
} |
ed20cba49858
(svn r3644) Don't use FindLandscapeHeightByTile() when it's overkill - often it was just a complicated way of writing GetTileSlope(tile, NULL)
tron
parents:
3047
diff
changeset
|
1864 |
|
4619
aa9747946f8e
(svn r6477) - Fix a loop-hole that allowed docks to be built regardless of town authority rating.
peter1138
parents:
4559
diff
changeset
|
1865 |
if (!(flags & DC_NO_TOWN_RATING) && !CheckIfAuthorityAllows(tile)) return CMD_ERROR; |
aa9747946f8e
(svn r6477) - Fix a loop-hole that allowed docks to be built regardless of town authority rating.
peter1138
parents:
4559
diff
changeset
|
1866 |
|
3055
ed20cba49858
(svn r3644) Don't use FindLandscapeHeightByTile() when it's overkill - often it was just a complicated way of writing GetTileSlope(tile, NULL)
tron
parents:
3047
diff
changeset
|
1867 |
if (!EnsureNoVehicle(tile)) return CMD_ERROR; |
ed20cba49858
(svn r3644) Don't use FindLandscapeHeightByTile() when it's overkill - often it was just a complicated way of writing GetTileSlope(tile, NULL)
tron
parents:
3047
diff
changeset
|
1868 |
|
3491
35d747bb5e82
(svn r4342) Change the first two parameters of commands - virtual pixel coordinates of the tile to operate on - to a TileIndex
tron
parents:
3482
diff
changeset
|
1869 |
cost = DoCommand(tile, 0, 0, flags, CMD_LANDSCAPE_CLEAR); |
1784
d0698aac0c2e
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
Darkvater
parents:
1782
diff
changeset
|
1870 |
if (CmdFailed(cost)) return CMD_ERROR; |
0 | 1871 |
|
4559
aa0c13e39840
(svn r6406) -Codechange: Rename TileOffsByDir to TileOffsByDiagDir because it accepts
Darkvater
parents:
4549
diff
changeset
|
1872 |
tile_cur = tile + TileOffsByDiagDir(direction); |
0 | 1873 |
|
1784
d0698aac0c2e
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
Darkvater
parents:
1782
diff
changeset
|
1874 |
if (!EnsureNoVehicle(tile_cur)) return CMD_ERROR; |
0 | 1875 |
|
3636
a36cc46e754d
(svn r4541) Add a type for slopes and replace many magic numbers by the appropriate enums
tron
parents:
3630
diff
changeset
|
1876 |
if (!IsTileType(tile_cur, MP_WATER) || GetTileSlope(tile_cur, NULL) != SLOPE_FLAT) { |
3055
ed20cba49858
(svn r3644) Don't use FindLandscapeHeightByTile() when it's overkill - often it was just a complicated way of writing GetTileSlope(tile, NULL)
tron
parents:
3047
diff
changeset
|
1877 |
return_cmd_error(STR_304B_SITE_UNSUITABLE); |
ed20cba49858
(svn r3644) Don't use FindLandscapeHeightByTile() when it's overkill - often it was just a complicated way of writing GetTileSlope(tile, NULL)
tron
parents:
3047
diff
changeset
|
1878 |
} |
0 | 1879 |
|
3491
35d747bb5e82
(svn r4342) Change the first two parameters of commands - virtual pixel coordinates of the tile to operate on - to a TileIndex
tron
parents:
3482
diff
changeset
|
1880 |
cost = DoCommand(tile_cur, 0, 0, flags, CMD_LANDSCAPE_CLEAR); |
1784
d0698aac0c2e
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
Darkvater
parents:
1782
diff
changeset
|
1881 |
if (CmdFailed(cost)) return CMD_ERROR; |
0 | 1882 |
|
4559
aa0c13e39840
(svn r6406) -Codechange: Rename TileOffsByDir to TileOffsByDiagDir because it accepts
Darkvater
parents:
4549
diff
changeset
|
1883 |
tile_cur += TileOffsByDiagDir(direction); |
3636
a36cc46e754d
(svn r4541) Add a type for slopes and replace many magic numbers by the appropriate enums
tron
parents:
3630
diff
changeset
|
1884 |
if (!IsTileType(tile_cur, MP_WATER) || GetTileSlope(tile_cur, NULL) != SLOPE_FLAT) { |
0 | 1885 |
return_cmd_error(STR_304B_SITE_UNSUITABLE); |
3055
ed20cba49858
(svn r3644) Don't use FindLandscapeHeightByTile() when it's overkill - often it was just a complicated way of writing GetTileSlope(tile, NULL)
tron
parents:
3047
diff
changeset
|
1886 |
} |
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
159
diff
changeset
|
1887 |
|
0 | 1888 |
/* middle */ |
909
65cdb609b7a6
(svn r1396) Introduce TileIndexDiffC - the compile time version of TileIndexDiff
tron
parents:
900
diff
changeset
|
1889 |
st = GetStationAround( |
65cdb609b7a6
(svn r1396) Introduce TileIndexDiffC - the compile time version of TileIndexDiff
tron
parents:
900
diff
changeset
|
1890 |
tile + ToTileIndexDiff(_dock_tileoffs_chkaround[direction]), |
5587
167d9a91ef02
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
rubidium
parents:
5584
diff
changeset
|
1891 |
_dock_w_chk[direction], _dock_h_chk[direction], INVALID_STATION); |
1784
d0698aac0c2e
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
Darkvater
parents:
1782
diff
changeset
|
1892 |
if (st == CHECK_STATIONS_ERR) return CMD_ERROR; |
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
159
diff
changeset
|
1893 |
|
0 | 1894 |
/* Find a station close to us */ |
1895 |
if (st == NULL) { |
|
1896 |
st = GetClosestStationFromTile(tile, 8, _current_player); |
|
1897 |
if (st!=NULL && st->facilities) st = NULL; |
|
1898 |
} |
|
1899 |
||
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1900 |
/* In case of new station if DC_EXEC is NOT set we still need to create the station |
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1901 |
* to test if everything is OK. In this case we need to delete it before return. */ |
5844
60231b36473e
(svn r8414) -Codechange: Use own AutoPtrT instead of std::auto_ptr.
KUDr
parents:
5837
diff
changeset
|
1902 |
AutoPtrT<Station> st_auto_delete; |
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1903 |
|
0 | 1904 |
if (st != NULL) { |
1905 |
if (st->owner != OWNER_NONE && st->owner != _current_player) |
|
1906 |
return_cmd_error(STR_3009_TOO_CLOSE_TO_ANOTHER_STATION); |
|
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
159
diff
changeset
|
1907 |
|
5676
7a641ebbc080
(svn r8136) -Codechange: Station spread rectangle manipulators turned into StationRect::methods.
KUDr
parents:
5668
diff
changeset
|
1908 |
if (!st->rect.BeforeAddRect(tile, _dock_w_chk[direction], _dock_h_chk[direction], StationRect::ADD_TEST)) return CMD_ERROR; |
1784
d0698aac0c2e
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
Darkvater
parents:
1782
diff
changeset
|
1909 |
|
d0698aac0c2e
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
Darkvater
parents:
1782
diff
changeset
|
1910 |
if (st->dock_tile != 0) return_cmd_error(STR_304C_TOO_CLOSE_TO_ANOTHER_DOCK); |
0 | 1911 |
} else { |
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1912 |
/* allocate and initialize new station */ |
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1913 |
st = new Station(tile); |
1784
d0698aac0c2e
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
Darkvater
parents:
1782
diff
changeset
|
1914 |
if (st == NULL) return CMD_ERROR; |
0 | 1915 |
|
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1916 |
/* ensure that in case of error (or no DC_EXEC) the station gets deleted upon return */ |
5844
60231b36473e
(svn r8414) -Codechange: Use own AutoPtrT instead of std::auto_ptr.
KUDr
parents:
5837
diff
changeset
|
1917 |
st_auto_delete = st; |
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1918 |
|
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1919 |
Town *t = st->town = ClosestTownFromTile(tile, (uint)-1); |
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1920 |
|
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1921 |
if (IsValidPlayer(_current_player) && (flags & DC_EXEC) != 0) { |
0 | 1922 |
SETBIT(t->have_ratings, _current_player); |
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1923 |
} |
0 | 1924 |
|
1925 |
st->sign.width_1 = 0; |
|
1926 |
||
1784
d0698aac0c2e
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
Darkvater
parents:
1782
diff
changeset
|
1927 |
if (!GenerateStationName(st, tile, 3)) return CMD_ERROR; |
0 | 1928 |
} |
1929 |
||
1930 |
if (flags & DC_EXEC) { |
|
1931 |
st->dock_tile = tile; |
|
5721
fa4e587f59f5
(svn r8231) -Fix (r8125): MP desync caused by calling Random() from station constructor. This was wrong because station constructor is called also when loading savegame and when player tries to build station when it is not sure that it will succeed (thanks Rubidium)
KUDr
parents:
5718
diff
changeset
|
1932 |
st->AddFacility(FACIL_DOCK, tile); |
0 | 1933 |
|
5676
7a641ebbc080
(svn r8136) -Codechange: Station spread rectangle manipulators turned into StationRect::methods.
KUDr
parents:
5668
diff
changeset
|
1934 |
st->rect.BeforeAddRect(tile, _dock_w_chk[direction], _dock_h_chk[direction], StationRect::ADD_TRY); |
5395
7727da322d66
(svn r7585) -Codechange: CheckStationSpreadOut() took too much CPU. Station rectangle is now maintained instead of calculating it each time by walking through whole map. Should help with the performance issue related to AIs trying to build road stops too often. (idea by Celestar)
KUDr
parents:
5385
diff
changeset
|
1935 |
|
3334
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
1936 |
MakeDock(tile, st->owner, st->index, direction); |
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
159
diff
changeset
|
1937 |
|
0 | 1938 |
UpdateStationVirtCoordDirty(st); |
1939 |
UpdateStationAcceptance(st, false); |
|
3812
e6fc916c17ab
(svn r4822) -Feature: Station List View can now be sorted and filtered (by waiting cargo type and facilities)
celestar
parents:
3789
diff
changeset
|
1940 |
RebuildStationLists(); |
0 | 1941 |
InvalidateWindow(WC_STATION_LIST, st->owner); |
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
1942 |
/* success, so don't delete the new station */ |
5844
60231b36473e
(svn r8414) -Codechange: Use own AutoPtrT instead of std::auto_ptr.
KUDr
parents:
5837
diff
changeset
|
1943 |
st_auto_delete.Release(); |
0 | 1944 |
} |
1945 |
return _price.build_dock; |
|
1946 |
} |
|
1947 |
||
1948 |
static int32 RemoveDock(Station *st, uint32 flags) |
|
1949 |
{ |
|
1977
37bbebf94434
(svn r2483) Replace almost 500 "uint tile" (and variants) with "TileIndex tile"
tron
parents:
1942
diff
changeset
|
1950 |
TileIndex tile1; |
37bbebf94434
(svn r2483) Replace almost 500 "uint tile" (and variants) with "TileIndex tile"
tron
parents:
1942
diff
changeset
|
1951 |
TileIndex tile2; |
0 | 1952 |
|
2639 | 1953 |
if (!CheckOwnership(st->owner)) return CMD_ERROR; |
0 | 1954 |
|
1955 |
tile1 = st->dock_tile; |
|
4559
aa0c13e39840
(svn r6406) -Codechange: Rename TileOffsByDir to TileOffsByDiagDir because it accepts
Darkvater
parents:
4549
diff
changeset
|
1956 |
tile2 = tile1 + TileOffsByDiagDir(GetDockDirection(tile1)); |
0 | 1957 |
|
2639 | 1958 |
if (!EnsureNoVehicle(tile1)) return CMD_ERROR; |
1959 |
if (!EnsureNoVehicle(tile2)) return CMD_ERROR; |
|
0 | 1960 |
|
1961 |
if (flags & DC_EXEC) { |
|
1962 |
DoClearSquare(tile1); |
|
3111
750f37699a13
(svn r3714) Add functions to turn tiles into water and shore tiles
tron
parents:
3102
diff
changeset
|
1963 |
MakeWater(tile2); |
5395
7727da322d66
(svn r7585) -Codechange: CheckStationSpreadOut() took too much CPU. Station rectangle is now maintained instead of calculating it each time by walking through whole map. Should help with the performance issue related to AIs trying to build road stops too often. (idea by Celestar)
KUDr
parents:
5385
diff
changeset
|
1964 |
|
5676
7a641ebbc080
(svn r8136) -Codechange: Station spread rectangle manipulators turned into StationRect::methods.
KUDr
parents:
5668
diff
changeset
|
1965 |
st->rect.AfterRemoveTile(st, tile1); |
7a641ebbc080
(svn r8136) -Codechange: Station spread rectangle manipulators turned into StationRect::methods.
KUDr
parents:
5668
diff
changeset
|
1966 |
st->rect.AfterRemoveTile(st, tile2); |
5395
7727da322d66
(svn r7585) -Codechange: CheckStationSpreadOut() took too much CPU. Station rectangle is now maintained instead of calculating it each time by walking through whole map. Should help with the performance issue related to AIs trying to build road stops too often. (idea by Celestar)
KUDr
parents:
5385
diff
changeset
|
1967 |
|
3111
750f37699a13
(svn r3714) Add functions to turn tiles into water and shore tiles
tron
parents:
3102
diff
changeset
|
1968 |
MarkTileDirtyByTile(tile2); |
0 | 1969 |
|
1970 |
st->dock_tile = 0; |
|
1971 |
st->facilities &= ~FACIL_DOCK; |
|
1972 |
||
1973 |
UpdateStationVirtCoordDirty(st); |
|
1974 |
DeleteStationIfEmpty(st); |
|
1975 |
} |
|
1976 |
||
1977 |
return _price.remove_dock; |
|
1978 |
} |
|
1979 |
||
1980 |
#include "table/station_land.h" |
|
1981 |
||
3763
7098c393c172
(svn r4754) - Newstations: expose default station display data via a function so we can use it (rarely) in other places.
peter1138
parents:
3754
diff
changeset
|
1982 |
const DrawTileSprites *GetStationTileLayout(byte gfx) |
7098c393c172
(svn r4754) - Newstations: expose default station display data via a function so we can use it (rarely) in other places.
peter1138
parents:
3754
diff
changeset
|
1983 |
{ |
7098c393c172
(svn r4754) - Newstations: expose default station display data via a function so we can use it (rarely) in other places.
peter1138
parents:
3754
diff
changeset
|
1984 |
return &_station_display_datas[gfx]; |
7098c393c172
(svn r4754) - Newstations: expose default station display data via a function so we can use it (rarely) in other places.
peter1138
parents:
3754
diff
changeset
|
1985 |
} |
0 | 1986 |
|
1987 |
static void DrawTile_Station(TileInfo *ti) |
|
1988 |
{ |
|
1989 |
const DrawTileSeqStruct *dtss; |
|
449
2856e9ce0754
(svn r659) Support for cutomized TTDPatch-style new stations (no selector GUI yet) (pasky)
tron
parents:
445
diff
changeset
|
1990 |
const DrawTileSprites *t = NULL; |
3242
4c32bf21153b
(svn r3916) Get/Set the rail type by [GS]etRailType{Crossing,OnBridge,}()
tron
parents:
3222
diff
changeset
|
1991 |
RailType railtype = GetRailType(ti->tile); |
2254
99de94953104
(svn r2774) -Codechange: Removed TRACKTYPE_SPRITE_PITCH globally and replaced it by a member of RailtypeInfo
celestar
parents:
2213
diff
changeset
|
1992 |
const RailtypeInfo *rti = GetRailTypeInfo(railtype); |
449
2856e9ce0754
(svn r659) Support for cutomized TTDPatch-style new stations (no selector GUI yet) (pasky)
tron
parents:
445
diff
changeset
|
1993 |
uint32 relocation = 0; |
3775
0fb5118536c3
(svn r4767) - Newstations: fix loading / use of custom ground sprites
peter1138
parents:
3771
diff
changeset
|
1994 |
const Station *st = NULL; |
0fb5118536c3
(svn r4767) - Newstations: fix loading / use of custom ground sprites
peter1138
parents:
3771
diff
changeset
|
1995 |
const StationSpec *statspec = NULL; |
4227
3ff996bf3f28
(svn r5773) Clarify why the owner is checked before a palette is chosen when drawing a station tile: some stations are not owned by players
tron
parents:
4177
diff
changeset
|
1996 |
PlayerID owner = GetTileOwner(ti->tile); |
5668
36b39f4a9032
(svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
peter1138
parents:
5667
diff
changeset
|
1997 |
SpriteID image; |
36b39f4a9032
(svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
peter1138
parents:
5667
diff
changeset
|
1998 |
SpriteID palette; |
4227
3ff996bf3f28
(svn r5773) Clarify why the owner is checked before a palette is chosen when drawing a station tile: some stations are not owned by players
tron
parents:
4177
diff
changeset
|
1999 |
|
4850
93095755db8c
(svn r6776) -Codechange: Use IsValidPlayer() function to determine of a PlayerID is an
Darkvater
parents:
4848
diff
changeset
|
2000 |
if (IsValidPlayer(owner)) { |
4227
3ff996bf3f28
(svn r5773) Clarify why the owner is checked before a palette is chosen when drawing a station tile: some stations are not owned by players
tron
parents:
4177
diff
changeset
|
2001 |
palette = PLAYER_SPRITE_COLOR(owner); |
3ff996bf3f28
(svn r5773) Clarify why the owner is checked before a palette is chosen when drawing a station tile: some stations are not owned by players
tron
parents:
4177
diff
changeset
|
2002 |
} else { |
3ff996bf3f28
(svn r5773) Clarify why the owner is checked before a palette is chosen when drawing a station tile: some stations are not owned by players
tron
parents:
4177
diff
changeset
|
2003 |
// Some stations are not owner by a player, namely oil rigs |
3ff996bf3f28
(svn r5773) Clarify why the owner is checked before a palette is chosen when drawing a station tile: some stations are not owned by players
tron
parents:
4177
diff
changeset
|
2004 |
palette = PALETTE_TO_GREY; |
0 | 2005 |
} |
2006 |
||
3334
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
2007 |
// don't show foundation for docks |
3636
a36cc46e754d
(svn r4541) Add a type for slopes and replace many magic numbers by the appropriate enums
tron
parents:
3630
diff
changeset
|
2008 |
if (ti->tileh != SLOPE_FLAT && !IsDock(ti->tile)) |
0 | 2009 |
DrawFoundation(ti, ti->tileh); |
2010 |
||
3568
c60d7aceed1a
(svn r4450) - NewStations, rename *CustomStationSprite() to *CustomStationSpecIndex() to reflect their use, and alter the test for determining if a station has customised graphics.
peter1138
parents:
3554
diff
changeset
|
2011 |
if (IsCustomStationSpecIndex(ti->tile)) { |
449
2856e9ce0754
(svn r659) Support for cutomized TTDPatch-style new stations (no selector GUI yet) (pasky)
tron
parents:
445
diff
changeset
|
2012 |
// look for customization |
3775
0fb5118536c3
(svn r4767) - Newstations: fix loading / use of custom ground sprites
peter1138
parents:
3771
diff
changeset
|
2013 |
st = GetStationByTile(ti->tile); |
0fb5118536c3
(svn r4767) - Newstations: fix loading / use of custom ground sprites
peter1138
parents:
3771
diff
changeset
|
2014 |
statspec = st->speclist[GetCustomStationSpecIndex(ti->tile)].spec; |
449
2856e9ce0754
(svn r659) Support for cutomized TTDPatch-style new stations (no selector GUI yet) (pasky)
tron
parents:
445
diff
changeset
|
2015 |
|
2856e9ce0754
(svn r659) Support for cutomized TTDPatch-style new stations (no selector GUI yet) (pasky)
tron
parents:
445
diff
changeset
|
2016 |
//debug("Cust-o-mized %p", statspec); |
2856e9ce0754
(svn r659) Support for cutomized TTDPatch-style new stations (no selector GUI yet) (pasky)
tron
parents:
445
diff
changeset
|
2017 |
|
2856e9ce0754
(svn r659) Support for cutomized TTDPatch-style new stations (no selector GUI yet) (pasky)
tron
parents:
445
diff
changeset
|
2018 |
if (statspec != NULL) { |
3576
18fb92480771
(svn r4462) - Newstations: ensure the chosen tile layout is available from a custom station
peter1138
parents:
3574
diff
changeset
|
2019 |
uint tile = GetStationGfx(ti->tile); |
449
2856e9ce0754
(svn r659) Support for cutomized TTDPatch-style new stations (no selector GUI yet) (pasky)
tron
parents:
445
diff
changeset
|
2020 |
|
3751
ce6408fdb788
(svn r4739) - Newstations: remove cargo type parameter of GetCustomStationRelocation() as we can determine it internally
peter1138
parents:
3742
diff
changeset
|
2021 |
relocation = GetCustomStationRelocation(statspec, st, ti->tile); |
3576
18fb92480771
(svn r4462) - Newstations: ensure the chosen tile layout is available from a custom station
peter1138
parents:
3574
diff
changeset
|
2022 |
|
3754
4c8cbaaa0bbe
(svn r4742) - Newstations: Add callbacks for building and drawing custom stations.
peter1138
parents:
3751
diff
changeset
|
2023 |
if (HASBIT(statspec->callbackmask, CBM_CUSTOM_LAYOUT)) { |
4c8cbaaa0bbe
(svn r4742) - Newstations: Add callbacks for building and drawing custom stations.
peter1138
parents:
3751
diff
changeset
|
2024 |
uint16 callback = GetStationCallback(CBID_STATION_SPRITE_LAYOUT, 0, 0, statspec, st, ti->tile); |
4886
19d09a4386ad
(svn r6823) - Codechange: Ignore bit 0 of a NewStation custom tile callback result. This fixes cosmetic problems with some add on stations.
peter1138
parents:
4873
diff
changeset
|
2025 |
if (callback != CALLBACK_FAILED) tile = (callback & ~1) + GetRailStationAxis(ti->tile); |
3754
4c8cbaaa0bbe
(svn r4742) - Newstations: Add callbacks for building and drawing custom stations.
peter1138
parents:
3751
diff
changeset
|
2026 |
} |
4c8cbaaa0bbe
(svn r4742) - Newstations: Add callbacks for building and drawing custom stations.
peter1138
parents:
3751
diff
changeset
|
2027 |
|
3576
18fb92480771
(svn r4462) - Newstations: ensure the chosen tile layout is available from a custom station
peter1138
parents:
3574
diff
changeset
|
2028 |
/* Ensure the chosen tile layout is valid for this custom station */ |
3754
4c8cbaaa0bbe
(svn r4742) - Newstations: Add callbacks for building and drawing custom stations.
peter1138
parents:
3751
diff
changeset
|
2029 |
if (statspec->renderdata != NULL) { |
5587
167d9a91ef02
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
rubidium
parents:
5584
diff
changeset
|
2030 |
t = &statspec->renderdata[tile < statspec->tiles ? tile : (uint)GetRailStationAxis(ti->tile)]; |
3754
4c8cbaaa0bbe
(svn r4742) - Newstations: Add callbacks for building and drawing custom stations.
peter1138
parents:
3751
diff
changeset
|
2031 |
} |
449
2856e9ce0754
(svn r659) Support for cutomized TTDPatch-style new stations (no selector GUI yet) (pasky)
tron
parents:
445
diff
changeset
|
2032 |
} |
2856e9ce0754
(svn r659) Support for cutomized TTDPatch-style new stations (no selector GUI yet) (pasky)
tron
parents:
445
diff
changeset
|
2033 |
} |
2856e9ce0754
(svn r659) Support for cutomized TTDPatch-style new stations (no selector GUI yet) (pasky)
tron
parents:
445
diff
changeset
|
2034 |
|
3737
1e4df4eb9298
(svn r4719) - Newstations: instead of drawing nothing, fall back to the default sprite layout if a station layout specifies so.
peter1138
parents:
3699
diff
changeset
|
2035 |
if (t == NULL || t->seq == NULL) t = &_station_display_datas[GetStationGfx(ti->tile)]; |
384
809833b4068d
(svn r576) -newgrf: Cleanup horrible table/(station|unmovable)_land.h DrawTileSeqStruct hacks needed for custom station supports (pasky)
darkvater
parents:
354
diff
changeset
|
2036 |
|
809833b4068d
(svn r576) -newgrf: Cleanup horrible table/(station|unmovable)_land.h DrawTileSeqStruct hacks needed for custom station supports (pasky)
darkvater
parents:
354
diff
changeset
|
2037 |
image = t->ground_sprite; |
5668
36b39f4a9032
(svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
peter1138
parents:
5667
diff
changeset
|
2038 |
if (HASBIT(image, SPRITE_MODIFIER_USE_OFFSET)) { |
3775
0fb5118536c3
(svn r4767) - Newstations: fix loading / use of custom ground sprites
peter1138
parents:
3771
diff
changeset
|
2039 |
image += GetCustomStationGroundRelocation(statspec, st, ti->tile); |
0fb5118536c3
(svn r4767) - Newstations: fix loading / use of custom ground sprites
peter1138
parents:
3771
diff
changeset
|
2040 |
image += rti->custom_ground_offset; |
0fb5118536c3
(svn r4767) - Newstations: fix loading / use of custom ground sprites
peter1138
parents:
3771
diff
changeset
|
2041 |
} else { |
0fb5118536c3
(svn r4767) - Newstations: fix loading / use of custom ground sprites
peter1138
parents:
3771
diff
changeset
|
2042 |
image += rti->total_offset; |
0fb5118536c3
(svn r4767) - Newstations: fix loading / use of custom ground sprites
peter1138
parents:
3771
diff
changeset
|
2043 |
} |
449
2856e9ce0754
(svn r659) Support for cutomized TTDPatch-style new stations (no selector GUI yet) (pasky)
tron
parents:
445
diff
changeset
|
2044 |
|
2856e9ce0754
(svn r659) Support for cutomized TTDPatch-style new stations (no selector GUI yet) (pasky)
tron
parents:
445
diff
changeset
|
2045 |
// station_land array has been increased from 82 elements to 114 |
2856e9ce0754
(svn r659) Support for cutomized TTDPatch-style new stations (no selector GUI yet) (pasky)
tron
parents:
445
diff
changeset
|
2046 |
// but this is something else. If AI builds station with 114 it looks all weird |
5668
36b39f4a9032
(svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
peter1138
parents:
5667
diff
changeset
|
2047 |
DrawGroundSprite(image, HASBIT(image, PALETTE_MODIFIER_COLOR) ? palette : PAL_NONE); |
0 | 2048 |
|
3789
c50647c927e4
(svn r4785) - Newstations: don't draw catenary on non-track tiles
glx
parents:
3784
diff
changeset
|
2049 |
if (GetRailType(ti->tile) == RAILTYPE_ELECTRIC && IsStationTileElectrifiable(ti->tile)) DrawCatenary(ti); |
3355
e414a0b104a6
(svn r4150) -Feature: Merged elrails into trunk. Thanks to Tron for lots of code and proofreading, thanks to peter1138 for another lot of code and ideas.
celestar
parents:
3344
diff
changeset
|
2050 |
|
384
809833b4068d
(svn r576) -newgrf: Cleanup horrible table/(station|unmovable)_land.h DrawTileSeqStruct hacks needed for custom station supports (pasky)
darkvater
parents:
354
diff
changeset
|
2051 |
foreach_draw_tile_seq(dtss, t->seq) { |
5668
36b39f4a9032
(svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
peter1138
parents:
5667
diff
changeset
|
2052 |
SpriteID pal; |
36b39f4a9032
(svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
peter1138
parents:
5667
diff
changeset
|
2053 |
|
3775
0fb5118536c3
(svn r4767) - Newstations: fix loading / use of custom ground sprites
peter1138
parents:
3771
diff
changeset
|
2054 |
image = dtss->image; |
5709
b9169cdd6019
(svn r8186) -Fix (FS#557): Apply railtype offset to station graphics if no custom station is in use.
peter1138
parents:
5708
diff
changeset
|
2055 |
if (relocation == 0 || HASBIT(image, SPRITE_MODIFIER_USE_OFFSET)) { |
3775
0fb5118536c3
(svn r4767) - Newstations: fix loading / use of custom ground sprites
peter1138
parents:
3771
diff
changeset
|
2056 |
image += rti->total_offset; |
0fb5118536c3
(svn r4767) - Newstations: fix loading / use of custom ground sprites
peter1138
parents:
3771
diff
changeset
|
2057 |
} else { |
0fb5118536c3
(svn r4767) - Newstations: fix loading / use of custom ground sprites
peter1138
parents:
3771
diff
changeset
|
2058 |
image += relocation; |
0fb5118536c3
(svn r4767) - Newstations: fix loading / use of custom ground sprites
peter1138
parents:
3771
diff
changeset
|
2059 |
} |
0fb5118536c3
(svn r4767) - Newstations: fix loading / use of custom ground sprites
peter1138
parents:
3771
diff
changeset
|
2060 |
|
384
809833b4068d
(svn r576) -newgrf: Cleanup horrible table/(station|unmovable)_land.h DrawTileSeqStruct hacks needed for custom station supports (pasky)
darkvater
parents:
354
diff
changeset
|
2061 |
if (_display_opt & DO_TRANS_BUILDINGS) { |
5668
36b39f4a9032
(svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
peter1138
parents:
5667
diff
changeset
|
2062 |
SETBIT(image, PALETTE_MODIFIER_TRANSPARENT); |
36b39f4a9032
(svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
peter1138
parents:
5667
diff
changeset
|
2063 |
pal = PALETTE_TO_TRANSPARENT; |
36b39f4a9032
(svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
peter1138
parents:
5667
diff
changeset
|
2064 |
} else if (HASBIT(image, PALETTE_MODIFIER_COLOR)) { |
36b39f4a9032
(svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
peter1138
parents:
5667
diff
changeset
|
2065 |
pal = palette; |
36b39f4a9032
(svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
peter1138
parents:
5667
diff
changeset
|
2066 |
} else { |
36b39f4a9032
(svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
peter1138
parents:
5667
diff
changeset
|
2067 |
pal = dtss->pal; |
384
809833b4068d
(svn r576) -newgrf: Cleanup horrible table/(station|unmovable)_land.h DrawTileSeqStruct hacks needed for custom station supports (pasky)
darkvater
parents:
354
diff
changeset
|
2068 |
} |
809833b4068d
(svn r576) -newgrf: Cleanup horrible table/(station|unmovable)_land.h DrawTileSeqStruct hacks needed for custom station supports (pasky)
darkvater
parents:
354
diff
changeset
|
2069 |
|
0 | 2070 |
if ((byte)dtss->delta_z != 0x80) { |
4230
f4e93251e2f6
(svn r5787) Rename width, height and unk of struct DrawTileSeqStruct to size_{x,y,z}
tron
parents:
4227
diff
changeset
|
2071 |
AddSortableSpriteToDraw( |
5668
36b39f4a9032
(svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
peter1138
parents:
5667
diff
changeset
|
2072 |
image, pal, |
4230
f4e93251e2f6
(svn r5787) Rename width, height and unk of struct DrawTileSeqStruct to size_{x,y,z}
tron
parents:
4227
diff
changeset
|
2073 |
ti->x + dtss->delta_x, ti->y + dtss->delta_y, |
f4e93251e2f6
(svn r5787) Rename width, height and unk of struct DrawTileSeqStruct to size_{x,y,z}
tron
parents:
4227
diff
changeset
|
2074 |
dtss->size_x, dtss->size_y, |
f4e93251e2f6
(svn r5787) Rename width, height and unk of struct DrawTileSeqStruct to size_{x,y,z}
tron
parents:
4227
diff
changeset
|
2075 |
dtss->size_z, ti->z + dtss->delta_z |
f4e93251e2f6
(svn r5787) Rename width, height and unk of struct DrawTileSeqStruct to size_{x,y,z}
tron
parents:
4227
diff
changeset
|
2076 |
); |
0 | 2077 |
} else { |
5668
36b39f4a9032
(svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
peter1138
parents:
5667
diff
changeset
|
2078 |
AddChildSpriteScreen(image, pal, dtss->delta_x, dtss->delta_y); |
0 | 2079 |
} |
2080 |
} |
|
2081 |
} |
|
2082 |
||
2520
8a52362c4ada
(svn r3049) Replace byte/int/uint by RailType where appropriate
tron
parents:
2517
diff
changeset
|
2083 |
void StationPickerDrawSprite(int x, int y, RailType railtype, int image) |
0 | 2084 |
{ |
5668
36b39f4a9032
(svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
peter1138
parents:
5667
diff
changeset
|
2085 |
SpriteID pal, img; |
0 | 2086 |
const DrawTileSeqStruct *dtss; |
384
809833b4068d
(svn r576) -newgrf: Cleanup horrible table/(station|unmovable)_land.h DrawTileSeqStruct hacks needed for custom station supports (pasky)
darkvater
parents:
354
diff
changeset
|
2087 |
const DrawTileSprites *t; |
2254
99de94953104
(svn r2774) -Codechange: Removed TRACKTYPE_SPRITE_PITCH globally and replaced it by a member of RailtypeInfo
celestar
parents:
2213
diff
changeset
|
2088 |
const RailtypeInfo *rti = GetRailTypeInfo(railtype); |
0 | 2089 |
|
5668
36b39f4a9032
(svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
peter1138
parents:
5667
diff
changeset
|
2090 |
pal = PLAYER_SPRITE_COLOR(_local_player); |
0 | 2091 |
|
384
809833b4068d
(svn r576) -newgrf: Cleanup horrible table/(station|unmovable)_land.h DrawTileSeqStruct hacks needed for custom station supports (pasky)
darkvater
parents:
354
diff
changeset
|
2092 |
t = &_station_display_datas[image]; |
809833b4068d
(svn r576) -newgrf: Cleanup horrible table/(station|unmovable)_land.h DrawTileSeqStruct hacks needed for custom station supports (pasky)
darkvater
parents:
354
diff
changeset
|
2093 |
|
809833b4068d
(svn r576) -newgrf: Cleanup horrible table/(station|unmovable)_land.h DrawTileSeqStruct hacks needed for custom station supports (pasky)
darkvater
parents:
354
diff
changeset
|
2094 |
img = t->ground_sprite; |
5668
36b39f4a9032
(svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
peter1138
parents:
5667
diff
changeset
|
2095 |
DrawSprite(img + rti->total_offset, HASBIT(img, PALETTE_MODIFIER_COLOR) ? pal : PAL_NONE, x, y); |
0 | 2096 |
|
384
809833b4068d
(svn r576) -newgrf: Cleanup horrible table/(station|unmovable)_land.h DrawTileSeqStruct hacks needed for custom station supports (pasky)
darkvater
parents:
354
diff
changeset
|
2097 |
foreach_draw_tile_seq(dtss, t->seq) { |
0 | 2098 |
Point pt = RemapCoords(dtss->delta_x, dtss->delta_y, dtss->delta_z); |
5668
36b39f4a9032
(svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
peter1138
parents:
5667
diff
changeset
|
2099 |
DrawSprite(dtss->image + rti->total_offset, pal, x + pt.x, y + pt.y); |
0 | 2100 |
} |
2101 |
} |
|
2102 |
||
4231
2823b3643862
(svn r5794) Pass the TileIndex plus x and y coordinates into GetSlopeZ_* instead of a TileInfo
tron
parents:
4230
diff
changeset
|
2103 |
static uint GetSlopeZ_Station(TileIndex tile, uint x, uint y) |
0 | 2104 |
{ |
4231
2823b3643862
(svn r5794) Pass the TileIndex plus x and y coordinates into GetSlopeZ_* instead of a TileInfo
tron
parents:
4230
diff
changeset
|
2105 |
return GetTileMaxZ(tile); |
0 | 2106 |
} |
2107 |
||
3636
a36cc46e754d
(svn r4541) Add a type for slopes and replace many magic numbers by the appropriate enums
tron
parents:
3630
diff
changeset
|
2108 |
static Slope GetSlopeTileh_Station(TileIndex tile, Slope tileh) |
39 | 2109 |
{ |
3636
a36cc46e754d
(svn r4541) Add a type for slopes and replace many magic numbers by the appropriate enums
tron
parents:
3630
diff
changeset
|
2110 |
return SLOPE_FLAT; |
39 | 2111 |
} |
2112 |
||
1977
37bbebf94434
(svn r2483) Replace almost 500 "uint tile" (and variants) with "TileIndex tile"
tron
parents:
1942
diff
changeset
|
2113 |
static void GetAcceptedCargo_Station(TileIndex tile, AcceptedCargo ac) |
0 | 2114 |
{ |
2115 |
/* not used */ |
|
2116 |
} |
|
2117 |
||
1977
37bbebf94434
(svn r2483) Replace almost 500 "uint tile" (and variants) with "TileIndex tile"
tron
parents:
1942
diff
changeset
|
2118 |
static void GetTileDesc_Station(TileIndex tile, TileDesc *td) |
0 | 2119 |
{ |
2120 |
StringID str; |
|
2121 |
||
1901
03bf9bf99319
(svn r2407) Use {Get,Is}TileOwner to get/check the owner of a tile and fix some bogus reads of _map_owner
tron
parents:
1891
diff
changeset
|
2122 |
td->owner = GetTileOwner(tile); |
3315
c9d989783c55
(svn r4079) Add GetSation{Index,ByTile}() to get the station index resp. the station from a tile
tron
parents:
3282
diff
changeset
|
2123 |
td->build_date = GetStationByTile(tile)->build_date; |
2049
538e73c53f54
(svn r2558) Change the internal map format from 7 arrays to one array of structs, this doesn't change the saved format for now. It's a stepping stone for further changes.
tron
parents:
2008
diff
changeset
|
2124 |
|
3334
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
2125 |
switch (GetStationType(tile)) { |
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
2126 |
default: NOT_REACHED(); |
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
2127 |
case STATION_RAIL: str = STR_305E_RAILROAD_STATION; break; |
3882
c2e3e12e71d6
(svn r4938) Remove STATION_HANGAR, because it isn't really a station type of its own
tron
parents:
3876
diff
changeset
|
2128 |
case STATION_AIRPORT: |
c2e3e12e71d6
(svn r4938) Remove STATION_HANGAR, because it isn't really a station type of its own
tron
parents:
3876
diff
changeset
|
2129 |
str = (IsHangar(tile) ? STR_305F_AIRCRAFT_HANGAR : STR_3060_AIRPORT); |
c2e3e12e71d6
(svn r4938) Remove STATION_HANGAR, because it isn't really a station type of its own
tron
parents:
3876
diff
changeset
|
2130 |
break; |
3334
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
2131 |
case STATION_TRUCK: str = STR_3061_TRUCK_LOADING_AREA; break; |
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
2132 |
case STATION_BUS: str = STR_3062_BUS_STATION; break; |
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
2133 |
case STATION_OILRIG: str = STR_4807_OIL_RIG; break; |
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
2134 |
case STATION_DOCK: str = STR_3063_SHIP_DOCK; break; |
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
2135 |
case STATION_BUOY: str = STR_3069_BUOY; break; |
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
2136 |
} |
0 | 2137 |
td->str = str; |
2138 |
} |
|
2139 |
||
2140 |
||
1977
37bbebf94434
(svn r2483) Replace almost 500 "uint tile" (and variants) with "TileIndex tile"
tron
parents:
1942
diff
changeset
|
2141 |
static uint32 GetTileTrackStatus_Station(TileIndex tile, TransportType mode) |
37bbebf94434
(svn r2483) Replace almost 500 "uint tile" (and variants) with "TileIndex tile"
tron
parents:
1942
diff
changeset
|
2142 |
{ |
1032
b8094fcab4bc
(svn r1533) Turn an if cascade into a switch and move a const array to the only location where it is used
tron
parents:
1024
diff
changeset
|
2143 |
switch (mode) { |
b8094fcab4bc
(svn r1533) Turn an if cascade into a switch and move a const array to the only location where it is used
tron
parents:
1024
diff
changeset
|
2144 |
case TRANSPORT_RAIL: |
4077
d4d440dd8925
(svn r5391) Miscellaneous, mostly bracing and whitespace, nothing spectacular
tron
parents:
4066
diff
changeset
|
2145 |
if (IsRailwayStation(tile) && !IsStationTileBlocked(tile)) { |
3334
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
2146 |
return TrackToTrackBits(GetRailStationTrack(tile)) * 0x101; |
1032
b8094fcab4bc
(svn r1533) Turn an if cascade into a switch and move a const array to the only location where it is used
tron
parents:
1024
diff
changeset
|
2147 |
} |
b8094fcab4bc
(svn r1533) Turn an if cascade into a switch and move a const array to the only location where it is used
tron
parents:
1024
diff
changeset
|
2148 |
break; |
b8094fcab4bc
(svn r1533) Turn an if cascade into a switch and move a const array to the only location where it is used
tron
parents:
1024
diff
changeset
|
2149 |
|
b8094fcab4bc
(svn r1533) Turn an if cascade into a switch and move a const array to the only location where it is used
tron
parents:
1024
diff
changeset
|
2150 |
case TRANSPORT_WATER: |
b8094fcab4bc
(svn r1533) Turn an if cascade into a switch and move a const array to the only location where it is used
tron
parents:
1024
diff
changeset
|
2151 |
// buoy is coded as a station, it is always on open water |
4077
d4d440dd8925
(svn r5391) Miscellaneous, mostly bracing and whitespace, nothing spectacular
tron
parents:
4066
diff
changeset
|
2152 |
if (IsBuoy_(tile)) return TRACK_BIT_ALL * 0x101; |
1032
b8094fcab4bc
(svn r1533) Turn an if cascade into a switch and move a const array to the only location where it is used
tron
parents:
1024
diff
changeset
|
2153 |
break; |
b8094fcab4bc
(svn r1533) Turn an if cascade into a switch and move a const array to the only location where it is used
tron
parents:
1024
diff
changeset
|
2154 |
|
3900
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
3884
diff
changeset
|
2155 |
case TRANSPORT_ROAD: |
4077
d4d440dd8925
(svn r5391) Miscellaneous, mostly bracing and whitespace, nothing spectacular
tron
parents:
4066
diff
changeset
|
2156 |
if (IsRoadStopTile(tile)) { |
4158 | 2157 |
return AxisToTrackBits(DiagDirToAxis(GetRoadStopDir(tile))) * 0x101; |
4077
d4d440dd8925
(svn r5391) Miscellaneous, mostly bracing and whitespace, nothing spectacular
tron
parents:
4066
diff
changeset
|
2158 |
} |
3900
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
3884
diff
changeset
|
2159 |
break; |
2c84ed52709d
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
KUDr
parents:
3884
diff
changeset
|
2160 |
|
1032
b8094fcab4bc
(svn r1533) Turn an if cascade into a switch and move a const array to the only location where it is used
tron
parents:
1024
diff
changeset
|
2161 |
default: |
b8094fcab4bc
(svn r1533) Turn an if cascade into a switch and move a const array to the only location where it is used
tron
parents:
1024
diff
changeset
|
2162 |
break; |
0 | 2163 |
} |
1032
b8094fcab4bc
(svn r1533) Turn an if cascade into a switch and move a const array to the only location where it is used
tron
parents:
1024
diff
changeset
|
2164 |
|
3334
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
2165 |
return 0; |
0 | 2166 |
} |
2167 |
||
2660 | 2168 |
|
1977
37bbebf94434
(svn r2483) Replace almost 500 "uint tile" (and variants) with "TileIndex tile"
tron
parents:
1942
diff
changeset
|
2169 |
static void TileLoop_Station(TileIndex tile) |
0 | 2170 |
{ |
2660 | 2171 |
// FIXME -- GetTileTrackStatus_Station -> animated stationtiles |
2172 |
// hardcoded.....not good |
|
3540
3bcf5348842b
(svn r4403) CodeChange : Add GetStationGfx and make use of [G|S]etStationGfx accessors. Also, use GetStationGfx instead of directly accessing the map for functions in station_map.h
belugas
parents:
3527
diff
changeset
|
2173 |
switch (GetStationGfx(tile)) { |
3545
b08ce1bbb589
(svn r4411) CodeChange : Define and use some Gfx for both stations and industries. More are still to come
belugas
parents:
3540
diff
changeset
|
2174 |
case GFX_RADAR_LARGE_FIRST: |
b08ce1bbb589
(svn r4411) CodeChange : Define and use some Gfx for both stations and industries. More are still to come
belugas
parents:
3540
diff
changeset
|
2175 |
case GFX_WINDSACK_FIRST : // for small airport |
3554
86230061c3e7
(svn r4426) Code Cleaning : replacing tabs with spaces, removing obvious comments, aligning arrays etc...
belugas
parents:
3553
diff
changeset
|
2176 |
case GFX_RADAR_INTERNATIONAL_FIRST: |
86230061c3e7
(svn r4426) Code Cleaning : replacing tabs with spaces, removing obvious comments, aligning arrays etc...
belugas
parents:
3553
diff
changeset
|
2177 |
case GFX_RADAR_METROPOLITAN_FIRST: |
4059
b1e1c1193f0a
(svn r5346) - Feature: Add 4 new airports. 2 for aircraft, 2 for helicopters.
richk
parents:
4000
diff
changeset
|
2178 |
case GFX_RADAR_DISTRICTWE_FIRST: // radar district W-E airport |
4066
2d099b946f10
(svn r5362) - Fix: Updated sprites in New Airports to be allow cleaner replacement by newgrf graphics. All tiles now use SPR_AIRPORT_APRON as the tarmac. Created two new sprites in airports.grf for half-grass half-tarmac tiles on Intercontinental airport.
richk
parents:
4059
diff
changeset
|
2179 |
case GFX_WINDSACK_INTERCON_FIRST : // for intercontinental airport |
2660 | 2180 |
AddAnimatedTile(tile); |
2181 |
break; |
|
2182 |
||
3545
b08ce1bbb589
(svn r4411) CodeChange : Define and use some Gfx for both stations and industries. More are still to come
belugas
parents:
3540
diff
changeset
|
2183 |
case GFX_OILRIG_BASE: //(station part) |
b08ce1bbb589
(svn r4411) CodeChange : Define and use some Gfx for both stations and industries. More are still to come
belugas
parents:
3540
diff
changeset
|
2184 |
case GFX_BUOY_BASE: |
2660 | 2185 |
TileLoop_Water(tile); |
2186 |
break; |
|
2187 |
||
2188 |
default: break; |
|
2189 |
} |
|
0 | 2190 |
} |
2191 |
||
2192 |
||
1977
37bbebf94434
(svn r2483) Replace almost 500 "uint tile" (and variants) with "TileIndex tile"
tron
parents:
1942
diff
changeset
|
2193 |
static void AnimateTile_Station(TileIndex tile) |
0 | 2194 |
{ |
4467
156585f085d2
(svn r6252) Replace a comglomerate of ifs for animated station tiles by a small table and a loop iterating over it
tron
parents:
4434
diff
changeset
|
2195 |
typedef struct AnimData { |
156585f085d2
(svn r6252) Replace a comglomerate of ifs for animated station tiles by a small table and a loop iterating over it
tron
parents:
4434
diff
changeset
|
2196 |
StationGfx from; // first sprite |
156585f085d2
(svn r6252) Replace a comglomerate of ifs for animated station tiles by a small table and a loop iterating over it
tron
parents:
4434
diff
changeset
|
2197 |
StationGfx to; // last sprite |
156585f085d2
(svn r6252) Replace a comglomerate of ifs for animated station tiles by a small table and a loop iterating over it
tron
parents:
4434
diff
changeset
|
2198 |
byte delay; |
156585f085d2
(svn r6252) Replace a comglomerate of ifs for animated station tiles by a small table and a loop iterating over it
tron
parents:
4434
diff
changeset
|
2199 |
} AnimData; |
156585f085d2
(svn r6252) Replace a comglomerate of ifs for animated station tiles by a small table and a loop iterating over it
tron
parents:
4434
diff
changeset
|
2200 |
|
156585f085d2
(svn r6252) Replace a comglomerate of ifs for animated station tiles by a small table and a loop iterating over it
tron
parents:
4434
diff
changeset
|
2201 |
static const AnimData data[] = { |
156585f085d2
(svn r6252) Replace a comglomerate of ifs for animated station tiles by a small table and a loop iterating over it
tron
parents:
4434
diff
changeset
|
2202 |
{ GFX_RADAR_LARGE_FIRST, GFX_RADAR_LARGE_LAST, 3 }, |
156585f085d2
(svn r6252) Replace a comglomerate of ifs for animated station tiles by a small table and a loop iterating over it
tron
parents:
4434
diff
changeset
|
2203 |
{ GFX_WINDSACK_FIRST, GFX_WINDSACK_LAST, 1 }, |
156585f085d2
(svn r6252) Replace a comglomerate of ifs for animated station tiles by a small table and a loop iterating over it
tron
parents:
4434
diff
changeset
|
2204 |
{ GFX_RADAR_INTERNATIONAL_FIRST, GFX_RADAR_INTERNATIONAL_LAST, 3 }, |
156585f085d2
(svn r6252) Replace a comglomerate of ifs for animated station tiles by a small table and a loop iterating over it
tron
parents:
4434
diff
changeset
|
2205 |
{ GFX_RADAR_METROPOLITAN_FIRST, GFX_RADAR_METROPOLITAN_LAST, 3 }, |
156585f085d2
(svn r6252) Replace a comglomerate of ifs for animated station tiles by a small table and a loop iterating over it
tron
parents:
4434
diff
changeset
|
2206 |
{ GFX_RADAR_DISTRICTWE_FIRST, GFX_RADAR_DISTRICTWE_LAST, 3 }, |
156585f085d2
(svn r6252) Replace a comglomerate of ifs for animated station tiles by a small table and a loop iterating over it
tron
parents:
4434
diff
changeset
|
2207 |
{ GFX_WINDSACK_INTERCON_FIRST, GFX_WINDSACK_INTERCON_LAST, 1 } |
156585f085d2
(svn r6252) Replace a comglomerate of ifs for animated station tiles by a small table and a loop iterating over it
tron
parents:
4434
diff
changeset
|
2208 |
}; |
156585f085d2
(svn r6252) Replace a comglomerate of ifs for animated station tiles by a small table and a loop iterating over it
tron
parents:
4434
diff
changeset
|
2209 |
|
3545
b08ce1bbb589
(svn r4411) CodeChange : Define and use some Gfx for both stations and industries. More are still to come
belugas
parents:
3540
diff
changeset
|
2210 |
StationGfx gfx = GetStationGfx(tile); |
4467
156585f085d2
(svn r6252) Replace a comglomerate of ifs for animated station tiles by a small table and a loop iterating over it
tron
parents:
4434
diff
changeset
|
2211 |
const AnimData* i; |
156585f085d2
(svn r6252) Replace a comglomerate of ifs for animated station tiles by a small table and a loop iterating over it
tron
parents:
4434
diff
changeset
|
2212 |
|
156585f085d2
(svn r6252) Replace a comglomerate of ifs for animated station tiles by a small table and a loop iterating over it
tron
parents:
4434
diff
changeset
|
2213 |
for (i = data; i != endof(data); i++) { |
156585f085d2
(svn r6252) Replace a comglomerate of ifs for animated station tiles by a small table and a loop iterating over it
tron
parents:
4434
diff
changeset
|
2214 |
if (i->from <= gfx && gfx <= i->to) { |
156585f085d2
(svn r6252) Replace a comglomerate of ifs for animated station tiles by a small table and a loop iterating over it
tron
parents:
4434
diff
changeset
|
2215 |
if ((_tick_counter & i->delay) == 0) { |
156585f085d2
(svn r6252) Replace a comglomerate of ifs for animated station tiles by a small table and a loop iterating over it
tron
parents:
4434
diff
changeset
|
2216 |
SetStationGfx(tile, gfx < i->to ? gfx + 1 : i->from); |
156585f085d2
(svn r6252) Replace a comglomerate of ifs for animated station tiles by a small table and a loop iterating over it
tron
parents:
4434
diff
changeset
|
2217 |
MarkTileDirtyByTile(tile); |
156585f085d2
(svn r6252) Replace a comglomerate of ifs for animated station tiles by a small table and a loop iterating over it
tron
parents:
4434
diff
changeset
|
2218 |
} |
156585f085d2
(svn r6252) Replace a comglomerate of ifs for animated station tiles by a small table and a loop iterating over it
tron
parents:
4434
diff
changeset
|
2219 |
break; |
3545
b08ce1bbb589
(svn r4411) CodeChange : Define and use some Gfx for both stations and industries. More are still to come
belugas
parents:
3540
diff
changeset
|
2220 |
} |
0 | 2221 |
} |
2222 |
} |
|
2223 |
||
3033
9cba043eb38f
(svn r3613) Some more const, indentation, whitespace and similar stuff
tron
parents:
3032
diff
changeset
|
2224 |
|
1977
37bbebf94434
(svn r2483) Replace almost 500 "uint tile" (and variants) with "TileIndex tile"
tron
parents:
1942
diff
changeset
|
2225 |
static void ClickTile_Station(TileIndex tile) |
0 | 2226 |
{ |
3334
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
2227 |
if (IsHangar(tile)) { |
4638
05955c6cb536
(svn r6513) -Codechange: unified the code to draw depot windows
bjarni
parents:
4619
diff
changeset
|
2228 |
ShowDepotWindow(tile, VEH_Aircraft); |
0 | 2229 |
} else { |
3315
c9d989783c55
(svn r4079) Add GetSation{Index,ByTile}() to get the station index resp. the station from a tile
tron
parents:
3282
diff
changeset
|
2230 |
ShowStationViewWindow(GetStationIndex(tile)); |
0 | 2231 |
} |
2232 |
} |
|
2233 |
||
2234 |
static const byte _enter_station_speedtable[12] = { |
|
2235 |
215, 195, 175, 155, 135, 115, 95, 75, 55, 35, 15, 0 |
|
2236 |
}; |
|
2237 |
||
1977
37bbebf94434
(svn r2483) Replace almost 500 "uint tile" (and variants) with "TileIndex tile"
tron
parents:
1942
diff
changeset
|
2238 |
static uint32 VehicleEnter_Station(Vehicle *v, TileIndex tile, int x, int y) |
0 | 2239 |
{ |
2240 |
if (v->type == VEH_Train) { |
|
3334
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
2241 |
if (IsRailwayStation(tile) && IsFrontEngine(v) && |
4559
aa0c13e39840
(svn r6406) -Codechange: Rename TileOffsByDir to TileOffsByDiagDir because it accepts
Darkvater
parents:
4549
diff
changeset
|
2242 |
!IsCompatibleTrainStationTile(tile + TileOffsByDiagDir(DirToDiagDir(v->direction)), tile)) { |
3315
c9d989783c55
(svn r4079) Add GetSation{Index,ByTile}() to get the station index resp. the station from a tile
tron
parents:
3282
diff
changeset
|
2243 |
StationID station_id = GetStationIndex(tile); |
2989 | 2244 |
|
555
02df8a1b7f33
(svn r955) Replace uint16 for orders with struct Order
tron
parents:
543
diff
changeset
|
2245 |
if ((!(v->current_order.flags & OF_NON_STOP) && !_patches.new_nonstop) || |
4527
fa30d19685c2
(svn r6353) -Codechange: Make DestinationID a typedef of uin16, which is as large as any type of destinataion (StationID, DepotID, WaypointID) it can hold
tron
parents:
4467
diff
changeset
|
2246 |
(v->current_order.type == OT_GOTO_STATION && v->current_order.dest == station_id)) { |
555
02df8a1b7f33
(svn r955) Replace uint16 for orders with struct Order
tron
parents:
543
diff
changeset
|
2247 |
if (!(_patches.new_nonstop && v->current_order.flags & OF_NON_STOP) && |
02df8a1b7f33
(svn r955) Replace uint16 for orders with struct Order
tron
parents:
543
diff
changeset
|
2248 |
v->current_order.type != OT_LEAVESTATION && |
02df8a1b7f33
(svn r955) Replace uint16 for orders with struct Order
tron
parents:
543
diff
changeset
|
2249 |
v->last_station_visited != station_id) { |
3482
54b144f07963
(svn r4331) Replace some direction calculation magic with DiagDirection to make a bit more clear what's going on
tron
parents:
3480
diff
changeset
|
2250 |
DiagDirection dir = DirToDiagDir(v->direction); |
2989 | 2251 |
|
0 | 2252 |
x &= 0xF; |
2253 |
y &= 0xF; |
|
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
159
diff
changeset
|
2254 |
|
3482
54b144f07963
(svn r4331) Replace some direction calculation magic with DiagDirection to make a bit more clear what's going on
tron
parents:
3480
diff
changeset
|
2255 |
if (DiagDirToAxis(dir) != AXIS_X) intswap(x, y); |
3645
7f950533d510
(svn r4554) Replace magic numbers by TILE_{HEIGHT,SIZE}
tron
parents:
3636
diff
changeset
|
2256 |
if (y == TILE_SIZE / 2) { |
7f950533d510
(svn r4554) Replace magic numbers by TILE_{HEIGHT,SIZE}
tron
parents:
3636
diff
changeset
|
2257 |
if (dir != DIAGDIR_SE && dir != DIAGDIR_SW) x = TILE_SIZE - 1 - x; |
0 | 2258 |
if (x == 12) return 2 | (station_id << 8); /* enter station */ |
2259 |
if (x < 12) { |
|
2639 | 2260 |
uint16 spd; |
2261 |
||
0 | 2262 |
v->vehstatus |= VS_TRAIN_SLOWING; |
2263 |
spd = _enter_station_speedtable[x]; |
|
2639 | 2264 |
if (spd < v->cur_speed) v->cur_speed = spd; |
0 | 2265 |
} |
2266 |
} |
|
2267 |
} |
|
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
159
diff
changeset
|
2268 |
} |
0 | 2269 |
} |
2270 |
} else if (v->type == VEH_Road) { |
|
2671
2c2edd17e9cc
(svn r3213) - Codechange: Clean up handling of road stops, avoiding unnecessary use of pointers and using the *BIT() macros.
peter1138
parents:
2660
diff
changeset
|
2271 |
if (v->u.road.state < 16 && !HASBIT(v->u.road.state, 2) && v->u.road.frame == 0) { |
3334
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
2272 |
if (IsRoadStop(tile)) { |
2671
2c2edd17e9cc
(svn r3213) - Codechange: Clean up handling of road stops, avoiding unnecessary use of pointers and using the *BIT() macros.
peter1138
parents:
2660
diff
changeset
|
2273 |
/* Attempt to allocate a parking bay in a road stop */ |
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
2274 |
RoadStop *rs = GetRoadStopByTile(tile, GetRoadStopType(tile)); |
2671
2c2edd17e9cc
(svn r3213) - Codechange: Clean up handling of road stops, avoiding unnecessary use of pointers and using the *BIT() macros.
peter1138
parents:
2660
diff
changeset
|
2275 |
|
2c2edd17e9cc
(svn r3213) - Codechange: Clean up handling of road stops, avoiding unnecessary use of pointers and using the *BIT() macros.
peter1138
parents:
2660
diff
changeset
|
2276 |
/* rs->status bits 0 and 1 describe current the two parking spots. |
2c2edd17e9cc
(svn r3213) - Codechange: Clean up handling of road stops, avoiding unnecessary use of pointers and using the *BIT() macros.
peter1138
parents:
2660
diff
changeset
|
2277 |
* 0 means occupied, 1 means free. */ |
2c2edd17e9cc
(svn r3213) - Codechange: Clean up handling of road stops, avoiding unnecessary use of pointers and using the *BIT() macros.
peter1138
parents:
2660
diff
changeset
|
2278 |
|
2c2edd17e9cc
(svn r3213) - Codechange: Clean up handling of road stops, avoiding unnecessary use of pointers and using the *BIT() macros.
peter1138
parents:
2660
diff
changeset
|
2279 |
// Check if station is busy or if there are no free bays. |
2c2edd17e9cc
(svn r3213) - Codechange: Clean up handling of road stops, avoiding unnecessary use of pointers and using the *BIT() macros.
peter1138
parents:
2660
diff
changeset
|
2280 |
if (HASBIT(rs->status, 7) || GB(rs->status, 0, 2) == 0) |
0 | 2281 |
return 8; |
2282 |
||
2671
2c2edd17e9cc
(svn r3213) - Codechange: Clean up handling of road stops, avoiding unnecessary use of pointers and using the *BIT() macros.
peter1138
parents:
2660
diff
changeset
|
2283 |
v->u.road.state += 32; |
2c2edd17e9cc
(svn r3213) - Codechange: Clean up handling of road stops, avoiding unnecessary use of pointers and using the *BIT() macros.
peter1138
parents:
2660
diff
changeset
|
2284 |
|
2c2edd17e9cc
(svn r3213) - Codechange: Clean up handling of road stops, avoiding unnecessary use of pointers and using the *BIT() macros.
peter1138
parents:
2660
diff
changeset
|
2285 |
// if the first bay is free, allocate that, else the second bay must be free. |
2c2edd17e9cc
(svn r3213) - Codechange: Clean up handling of road stops, avoiding unnecessary use of pointers and using the *BIT() macros.
peter1138
parents:
2660
diff
changeset
|
2286 |
if (HASBIT(rs->status, 0)) { |
2c2edd17e9cc
(svn r3213) - Codechange: Clean up handling of road stops, avoiding unnecessary use of pointers and using the *BIT() macros.
peter1138
parents:
2660
diff
changeset
|
2287 |
CLRBIT(rs->status, 0); |
0 | 2288 |
} else { |
2671
2c2edd17e9cc
(svn r3213) - Codechange: Clean up handling of road stops, avoiding unnecessary use of pointers and using the *BIT() macros.
peter1138
parents:
2660
diff
changeset
|
2289 |
CLRBIT(rs->status, 1); |
2c2edd17e9cc
(svn r3213) - Codechange: Clean up handling of road stops, avoiding unnecessary use of pointers and using the *BIT() macros.
peter1138
parents:
2660
diff
changeset
|
2290 |
v->u.road.state += 2; |
0 | 2291 |
} |
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
2292 |
|
2671
2c2edd17e9cc
(svn r3213) - Codechange: Clean up handling of road stops, avoiding unnecessary use of pointers and using the *BIT() macros.
peter1138
parents:
2660
diff
changeset
|
2293 |
// mark the station as busy |
2c2edd17e9cc
(svn r3213) - Codechange: Clean up handling of road stops, avoiding unnecessary use of pointers and using the *BIT() macros.
peter1138
parents:
2660
diff
changeset
|
2294 |
SETBIT(rs->status, 7); |
0 | 2295 |
} |
2296 |
} |
|
2297 |
} |
|
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
159
diff
changeset
|
2298 |
|
0 | 2299 |
return 0; |
2300 |
} |
|
2301 |
||
2302 |
/* this function is called for one station each tick */ |
|
2303 |
static void StationHandleBigTick(Station *st) |
|
2304 |
{ |
|
2305 |
UpdateStationAcceptance(st, true); |
|
2306 |
||
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
2307 |
if (st->facilities == 0 && ++st->delete_ctr >= 8) delete st; |
1239
133586622b78
(svn r1743) -Fix: Multistop: Added some debug output and made sure that orphaned slots are cleared.
celestar
parents:
1231
diff
changeset
|
2308 |
|
0 | 2309 |
} |
2310 |
||
500
8e52f7797b48
(svn r793) Merge INLINE -> inline replacement (revision 376)
tron
parents:
497
diff
changeset
|
2311 |
static inline void byte_inc_sat(byte *p) { byte b = *p + 1; if (b != 0) *p = b; } |
0 | 2312 |
|
2313 |
static void UpdateStationRating(Station *st) |
|
2314 |
{ |
|
2315 |
GoodsEntry *ge; |
|
1551
b1c7df6daa63
(svn r2055) -CodeChange: Begun introducting StationID
celestar
parents:
1527
diff
changeset
|
2316 |
int rating; |
b1c7df6daa63
(svn r2055) -CodeChange: Begun introducting StationID
celestar
parents:
1527
diff
changeset
|
2317 |
StationID index; |
0 | 2318 |
int waiting; |
2319 |
bool waiting_changed = false; |
|
2320 |
||
2321 |
byte_inc_sat(&st->time_since_load); |
|
2322 |
byte_inc_sat(&st->time_since_unload); |
|
2323 |
||
2324 |
ge = st->goods; |
|
2325 |
do { |
|
1266
eccd576e322f
(svn r1770) -Fix: Hopefully last pieces of code that are containing a station-id
truelight
parents:
1265
diff
changeset
|
2326 |
if (ge->enroute_from != INVALID_STATION) { |
0 | 2327 |
byte_inc_sat(&ge->enroute_time); |
2328 |
byte_inc_sat(&ge->days_since_pickup); |
|
2329 |
||
2330 |
rating = 0; |
|
2331 |
||
2332 |
{ |
|
2333 |
int b = ge->last_speed; |
|
2334 |
if ((b-=85) >= 0) |
|
2335 |
rating += b >> 2; |
|
2336 |
} |
|
2337 |
||
2338 |
{ |
|
2339 |
byte age = ge->last_age; |
|
2340 |
(age >= 3) || |
|
2341 |
(rating += 10, age >= 2) || |
|
2342 |
(rating += 10, age >= 1) || |
|
2343 |
(rating += 13, true); |
|
2344 |
} |
|
2345 |
||
4850
93095755db8c
(svn r6776) -Codechange: Use IsValidPlayer() function to determine of a PlayerID is an
Darkvater
parents:
4848
diff
changeset
|
2346 |
if (IsValidPlayer(st->owner) && HASBIT(st->town->statues, st->owner)) rating += 26; |
0 | 2347 |
|
2348 |
{ |
|
2349 |
byte days = ge->days_since_pickup; |
|
3580
14bf6e7715c8
(svn r4466) -Fix: (FS#71) Game no longer crashes when the last vehicle serving a station has been deleted.
celestar
parents:
3576
diff
changeset
|
2350 |
if (st->last_vehicle_type == VEH_Ship) |
0 | 2351 |
days >>= 2; |
2352 |
(days > 21) || |
|
2353 |
(rating += 25, days > 12) || |
|
2354 |
(rating += 25, days > 6) || |
|
2355 |
(rating += 45, days > 3) || |
|
2356 |
(rating += 35, true); |
|
2357 |
} |
|
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
159
diff
changeset
|
2358 |
|
0 | 2359 |
{ |
2504
5ae89f643cdc
(svn r3030) More work for GB/SB, this time concerning the waiting_acceptance attribute of stations
tron
parents:
2502
diff
changeset
|
2360 |
waiting = GB(ge->waiting_acceptance, 0, 12); |
0 | 2361 |
(rating -= 90, waiting > 1500) || |
2362 |
(rating += 55, waiting > 1000) || |
|
2363 |
(rating += 35, waiting > 600) || |
|
2364 |
(rating += 10, waiting > 300) || |
|
2365 |
(rating += 20, waiting > 100) || |
|
2366 |
(rating += 10, true); |
|
2367 |
} |
|
2368 |
||
2369 |
{ |
|
5587
167d9a91ef02
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
rubidium
parents:
5584
diff
changeset
|
2370 |
int or_ = ge->rating; // old rating |
0 | 2371 |
|
2372 |
// only modify rating in steps of -2, -1, 0, 1 or 2 |
|
5587
167d9a91ef02
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
rubidium
parents:
5584
diff
changeset
|
2373 |
ge->rating = rating = or_ + clamp(clamp(rating, 0, 255) - or_, -2, 2); |
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
159
diff
changeset
|
2374 |
|
0 | 2375 |
// if rating is <= 64 and more than 200 items waiting, remove some random amount of goods from the station |
2376 |
if (rating <= 64 && waiting >= 200) { |
|
2377 |
int dec = Random() & 0x1F; |
|
2378 |
if (waiting < 400) dec &= 7; |
|
2379 |
waiting -= dec + 1; |
|
2380 |
waiting_changed = true; |
|
2381 |
} |
|
2382 |
||
2383 |
// if rating is <= 127 and there are any items waiting, maybe remove some goods. |
|
2384 |
if (rating <= 127 && waiting != 0) { |
|
2385 |
uint32 r = Random(); |
|
5660
1425b81374b8
(svn r8120) -Fix (r8055): Station cargo waiting value clamp should be signed not unsigned. This resulted in cargo magically appearing...
peter1138
parents:
5609
diff
changeset
|
2386 |
if (rating <= (int)GB(r, 0, 7)) { |
1425b81374b8
(svn r8120) -Fix (r8055): Station cargo waiting value clamp should be signed not unsigned. This resulted in cargo magically appearing...
peter1138
parents:
5609
diff
changeset
|
2387 |
waiting = max(waiting - (int)GB(r, 8, 2) - 1, 0); |
0 | 2388 |
waiting_changed = true; |
2389 |
} |
|
2390 |
} |
|
2391 |
||
2504
5ae89f643cdc
(svn r3030) More work for GB/SB, this time concerning the waiting_acceptance attribute of stations
tron
parents:
2502
diff
changeset
|
2392 |
if (waiting_changed) SB(ge->waiting_acceptance, 0, 12, waiting); |
0 | 2393 |
} |
2394 |
} |
|
2395 |
} while (++ge != endof(st->goods)); |
|
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
159
diff
changeset
|
2396 |
|
0 | 2397 |
index = st->index; |
2398 |
||
4077
d4d440dd8925
(svn r5391) Miscellaneous, mostly bracing and whitespace, nothing spectacular
tron
parents:
4066
diff
changeset
|
2399 |
if (waiting_changed) { |
0 | 2400 |
InvalidateWindow(WC_STATION_VIEW, index); |
4077
d4d440dd8925
(svn r5391) Miscellaneous, mostly bracing and whitespace, nothing spectacular
tron
parents:
4066
diff
changeset
|
2401 |
} else { |
0 | 2402 |
InvalidateWindowWidget(WC_STATION_VIEW, index, 5); |
4077
d4d440dd8925
(svn r5391) Miscellaneous, mostly bracing and whitespace, nothing spectacular
tron
parents:
4066
diff
changeset
|
2403 |
} |
0 | 2404 |
} |
2405 |
||
2406 |
/* called for every station each tick */ |
|
2407 |
static void StationHandleSmallTick(Station *st) |
|
2408 |
{ |
|
2409 |
byte b; |
|
2410 |
||
2639 | 2411 |
if (st->facilities == 0) return; |
0 | 2412 |
|
2413 |
b = st->delete_ctr + 1; |
|
2414 |
if (b >= 185) b = 0; |
|
2415 |
st->delete_ctr = b; |
|
2416 |
||
2639 | 2417 |
if (b == 0) UpdateStationRating(st); |
0 | 2418 |
} |
2419 |
||
1093
4fdc46eaf423
(svn r1594) Convert all undefined parameter lists to (void) and add the appropriate warning flags in the Makefile
tron
parents:
1078
diff
changeset
|
2420 |
void OnTick_Station(void) |
0 | 2421 |
{ |
1272
9aa073c64fc7
(svn r1776) -Add: Dynamic stations. You can now have up to 64k of stations
truelight
parents:
1266
diff
changeset
|
2422 |
uint i; |
0 | 2423 |
Station *st; |
2424 |
||
2639 | 2425 |
if (_game_mode == GM_EDITOR) return; |
0 | 2426 |
|
2427 |
i = _station_tick_ctr; |
|
5247
1f982de55b88
(svn r7372) - CodeChange: Rename all GetXXXArraySize() functions to GetNumXXX() and add GetMaxXXXIndex() functions. This prepares for the new pool interface.
matthijs
parents:
5220
diff
changeset
|
2428 |
if (++_station_tick_ctr > GetMaxStationIndex()) _station_tick_ctr = 0; |
0 | 2429 |
|
4352
6703cd8d39e0
(svn r6053) -Codechange: renamed all IsXXXIndex to IsValidXXXID
truelight
parents:
4351
diff
changeset
|
2430 |
if (IsValidStationID(i)) StationHandleBigTick(GetStation(i)); |
0 | 2431 |
|
2432 |
FOR_ALL_STATIONS(st) { |
|
4346
66105d4f6e83
(svn r6047) -Codechange: FOR_ALL now _only_ loops valid items, and skips invalid ones
truelight
parents:
4344
diff
changeset
|
2433 |
StationHandleSmallTick(st); |
0 | 2434 |
} |
2435 |
} |
|
2436 |
||
1093
4fdc46eaf423
(svn r1594) Convert all undefined parameter lists to (void) and add the appropriate warning flags in the Makefile
tron
parents:
1078
diff
changeset
|
2437 |
void StationMonthlyLoop(void) |
0 | 2438 |
{ |
2439 |
} |
|
2440 |
||
2441 |
||
2498
3ed05caa4449
(svn r3024) -Codechange: Another batch of replacements of int/uint/int16/byte/-1 with proper types and constants
tron
parents:
2493
diff
changeset
|
2442 |
void ModifyStationRatingAround(TileIndex tile, PlayerID owner, int amount, uint radius) |
0 | 2443 |
{ |
2444 |
Station *st; |
|
2445 |
||
2446 |
FOR_ALL_STATIONS(st) { |
|
4346
66105d4f6e83
(svn r6047) -Codechange: FOR_ALL now _only_ loops valid items, and skips invalid ones
truelight
parents:
4344
diff
changeset
|
2447 |
if (st->owner == owner && |
1245
3822f77cbc53
(svn r1749) Move the functions which calculate distances to map.[ch] and give the more meaningful names
tron
parents:
1239
diff
changeset
|
2448 |
DistanceManhattan(tile, st->xy) <= radius) { |
2549 | 2449 |
uint i; |
2450 |
||
2451 |
for (i = 0; i != NUM_CARGO; i++) { |
|
2452 |
GoodsEntry* ge = &st->goods[i]; |
|
2453 |
||
1266
eccd576e322f
(svn r1770) -Fix: Hopefully last pieces of code that are containing a station-id
truelight
parents:
1265
diff
changeset
|
2454 |
if (ge->enroute_from != INVALID_STATION) { |
0 | 2455 |
ge->rating = clamp(ge->rating + amount, 0, 255); |
2456 |
} |
|
2457 |
} |
|
2458 |
} |
|
2459 |
} |
|
2460 |
} |
|
2461 |
||
2462 |
static void UpdateStationWaiting(Station *st, int type, uint amount) |
|
2463 |
{ |
|
2504
5ae89f643cdc
(svn r3030) More work for GB/SB, this time concerning the waiting_acceptance attribute of stations
tron
parents:
2502
diff
changeset
|
2464 |
SB(st->goods[type].waiting_acceptance, 0, 12, |
5ae89f643cdc
(svn r3030) More work for GB/SB, this time concerning the waiting_acceptance attribute of stations
tron
parents:
2502
diff
changeset
|
2465 |
min(0xFFF, GB(st->goods[type].waiting_acceptance, 0, 12) + amount) |
5ae89f643cdc
(svn r3030) More work for GB/SB, this time concerning the waiting_acceptance attribute of stations
tron
parents:
2502
diff
changeset
|
2466 |
); |
0 | 2467 |
|
2468 |
st->goods[type].enroute_time = 0; |
|
2469 |
st->goods[type].enroute_from = st->index; |
|
5683
b027e5d5b4cd
(svn r8144) -Fix: [FS#163] When a station is removed, vehicles do not get excessive payment any longer, as the origin TILE is now stored as long as the origin STATION for the transported cargos. Basically this is only a temporary fix until cargopackets are implemented, but it fixes one of the oldest known bugs (Special Thanks to Darkvater for lots of testing)
celestar
parents:
5679
diff
changeset
|
2470 |
st->goods[type].enroute_from_xy = st->xy; |
0 | 2471 |
InvalidateWindow(WC_STATION_VIEW, st->index); |
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
2472 |
st->MarkTilesDirty(); |
0 | 2473 |
} |
2474 |
||
1786
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1784
diff
changeset
|
2475 |
/** Rename a station |
3491
35d747bb5e82
(svn r4342) Change the first two parameters of commands - virtual pixel coordinates of the tile to operate on - to a TileIndex
tron
parents:
3482
diff
changeset
|
2476 |
* @param tile unused |
1786
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1784
diff
changeset
|
2477 |
* @param p1 station ID that is to be renamed |
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1784
diff
changeset
|
2478 |
* @param p2 unused |
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1784
diff
changeset
|
2479 |
*/ |
3491
35d747bb5e82
(svn r4342) Change the first two parameters of commands - virtual pixel coordinates of the tile to operate on - to a TileIndex
tron
parents:
3482
diff
changeset
|
2480 |
int32 CmdRenameStation(TileIndex tile, uint32 flags, uint32 p1, uint32 p2) |
0 | 2481 |
{ |
2639 | 2482 |
StringID str; |
0 | 2483 |
Station *st; |
2484 |
||
4352
6703cd8d39e0
(svn r6053) -Codechange: renamed all IsXXXIndex to IsValidXXXID
truelight
parents:
4351
diff
changeset
|
2485 |
if (!IsValidStationID(p1) || _cmd_text[0] == '\0') return CMD_ERROR; |
1774
907db1b7a445
(svn r2278) When renaming a station, check if the station exists and belongs to the correct player
tron
parents:
1751
diff
changeset
|
2486 |
st = GetStation(p1); |
907db1b7a445
(svn r2278) When renaming a station, check if the station exists and belongs to the correct player
tron
parents:
1751
diff
changeset
|
2487 |
|
4352
6703cd8d39e0
(svn r6053) -Codechange: renamed all IsXXXIndex to IsValidXXXID
truelight
parents:
4351
diff
changeset
|
2488 |
if (!CheckOwnership(st->owner)) return CMD_ERROR; |
1774
907db1b7a445
(svn r2278) When renaming a station, check if the station exists and belongs to the correct player
tron
parents:
1751
diff
changeset
|
2489 |
|
1820
d03c56850dc2
(svn r2324) Introduce _cmd_text for passing strings with a command instead of abusing _decode_parameters as text buffer. This should prevent several possible buffer overruns and is a bit cleaner to use. As bonus it reduces the size of most command packets by 79 bytes.
tron
parents:
1786
diff
changeset
|
2490 |
str = AllocateNameUnique(_cmd_text, 6); |
1786
7cfd46c3fcc4
(svn r2290) - CodeChange: protect the next batch of commands. This brings us to a total of 61, which is 53% :)
Darkvater
parents:
1784
diff
changeset
|
2491 |
if (str == 0) return CMD_ERROR; |
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
159
diff
changeset
|
2492 |
|
0 | 2493 |
if (flags & DC_EXEC) { |
2639 | 2494 |
StringID old_str = st->string_id; |
2495 |
||
0 | 2496 |
st->string_id = str; |
2497 |
UpdateStationVirtCoord(st); |
|
2498 |
DeleteName(old_str); |
|
3812
e6fc916c17ab
(svn r4822) -Feature: Station List View can now be sorted and filtered (by waiting cargo type and facilities)
celestar
parents:
3789
diff
changeset
|
2499 |
ResortStationLists(); |
0 | 2500 |
MarkWholeScreenDirty(); |
2501 |
} else { |
|
2502 |
DeleteName(str); |
|
2503 |
} |
|
2504 |
||
2505 |
return 0; |
|
2506 |
} |
|
2507 |
||
2508 |
||
1977
37bbebf94434
(svn r2483) Replace almost 500 "uint tile" (and variants) with "TileIndex tile"
tron
parents:
1942
diff
changeset
|
2509 |
uint MoveGoodsToStation(TileIndex tile, int w, int h, int type, uint amount) |
0 | 2510 |
{ |
3002
0651b917cd92
(svn r3582) Restructure MoveGoodsToStation() to avoid double bookkeeping of StationIDs and station pointers
tron
parents:
3001
diff
changeset
|
2511 |
Station* around[8]; |
0651b917cd92
(svn r3582) Restructure MoveGoodsToStation() to avoid double bookkeeping of StationIDs and station pointers
tron
parents:
3001
diff
changeset
|
2512 |
uint i; |
0 | 2513 |
uint moved; |
2514 |
uint best_rating, best_rating2; |
|
2515 |
Station *st1, *st2; |
|
3000
692dd5ed9fca
(svn r3580) Some small cleanups before the real change, especially reduce the indentation by one by using continue
tron
parents:
2989
diff
changeset
|
2516 |
uint t; |
692dd5ed9fca
(svn r3580) Some small cleanups before the real change, especially reduce the indentation by one by using continue
tron
parents:
2989
diff
changeset
|
2517 |
int rad = 0; |
692dd5ed9fca
(svn r3580) Some small cleanups before the real change, especially reduce the indentation by one by using continue
tron
parents:
2989
diff
changeset
|
2518 |
int w_prod; //width and height of the "producer" of the cargo |
692dd5ed9fca
(svn r3580) Some small cleanups before the real change, especially reduce the indentation by one by using continue
tron
parents:
2989
diff
changeset
|
2519 |
int h_prod; |
568
b0d0df062880
(svn r979) Allow more realistically sized catchment areas
Celestar
parents:
555
diff
changeset
|
2520 |
int max_rad; |
b0d0df062880
(svn r979) Allow more realistically sized catchment areas
Celestar
parents:
555
diff
changeset
|
2521 |
|
3002
0651b917cd92
(svn r3582) Restructure MoveGoodsToStation() to avoid double bookkeeping of StationIDs and station pointers
tron
parents:
3001
diff
changeset
|
2522 |
for (i = 0; i < lengthof(around); i++) around[i] = NULL; |
0 | 2523 |
|
568
b0d0df062880
(svn r979) Allow more realistically sized catchment areas
Celestar
parents:
555
diff
changeset
|
2524 |
if (_patches.modified_catchment) { |
b0d0df062880
(svn r979) Allow more realistically sized catchment areas
Celestar
parents:
555
diff
changeset
|
2525 |
w_prod = w; |
b0d0df062880
(svn r979) Allow more realistically sized catchment areas
Celestar
parents:
555
diff
changeset
|
2526 |
h_prod = h; |
b0d0df062880
(svn r979) Allow more realistically sized catchment areas
Celestar
parents:
555
diff
changeset
|
2527 |
w += 16; |
b0d0df062880
(svn r979) Allow more realistically sized catchment areas
Celestar
parents:
555
diff
changeset
|
2528 |
h += 16; |
b0d0df062880
(svn r979) Allow more realistically sized catchment areas
Celestar
parents:
555
diff
changeset
|
2529 |
max_rad = 8; |
b0d0df062880
(svn r979) Allow more realistically sized catchment areas
Celestar
parents:
555
diff
changeset
|
2530 |
} else { |
3000
692dd5ed9fca
(svn r3580) Some small cleanups before the real change, especially reduce the indentation by one by using continue
tron
parents:
2989
diff
changeset
|
2531 |
w_prod = 0; |
692dd5ed9fca
(svn r3580) Some small cleanups before the real change, especially reduce the indentation by one by using continue
tron
parents:
2989
diff
changeset
|
2532 |
h_prod = 0; |
692dd5ed9fca
(svn r3580) Some small cleanups before the real change, especially reduce the indentation by one by using continue
tron
parents:
2989
diff
changeset
|
2533 |
w += 8; |
692dd5ed9fca
(svn r3580) Some small cleanups before the real change, especially reduce the indentation by one by using continue
tron
parents:
2989
diff
changeset
|
2534 |
h += 8; |
568
b0d0df062880
(svn r979) Allow more realistically sized catchment areas
Celestar
parents:
555
diff
changeset
|
2535 |
max_rad = 4; |
b0d0df062880
(svn r979) Allow more realistically sized catchment areas
Celestar
parents:
555
diff
changeset
|
2536 |
} |
b0d0df062880
(svn r979) Allow more realistically sized catchment areas
Celestar
parents:
555
diff
changeset
|
2537 |
|
1981 | 2538 |
BEGIN_TILE_LOOP(cur_tile, w, h, tile - TileDiffXY(max_rad, max_rad)) |
3002
0651b917cd92
(svn r3582) Restructure MoveGoodsToStation() to avoid double bookkeeping of StationIDs and station pointers
tron
parents:
3001
diff
changeset
|
2539 |
Station* st; |
3000
692dd5ed9fca
(svn r3580) Some small cleanups before the real change, especially reduce the indentation by one by using continue
tron
parents:
2989
diff
changeset
|
2540 |
|
0 | 2541 |
cur_tile = TILE_MASK(cur_tile); |
3000
692dd5ed9fca
(svn r3580) Some small cleanups before the real change, especially reduce the indentation by one by using continue
tron
parents:
2989
diff
changeset
|
2542 |
if (!IsTileType(cur_tile, MP_STATION)) continue; |
692dd5ed9fca
(svn r3580) Some small cleanups before the real change, especially reduce the indentation by one by using continue
tron
parents:
2989
diff
changeset
|
2543 |
|
3315
c9d989783c55
(svn r4079) Add GetSation{Index,ByTile}() to get the station index resp. the station from a tile
tron
parents:
3282
diff
changeset
|
2544 |
st = GetStationByTile(cur_tile); |
3002
0651b917cd92
(svn r3582) Restructure MoveGoodsToStation() to avoid double bookkeeping of StationIDs and station pointers
tron
parents:
3001
diff
changeset
|
2545 |
|
0651b917cd92
(svn r3582) Restructure MoveGoodsToStation() to avoid double bookkeeping of StationIDs and station pointers
tron
parents:
3001
diff
changeset
|
2546 |
for (i = 0; i != lengthof(around); i++) { |
0651b917cd92
(svn r3582) Restructure MoveGoodsToStation() to avoid double bookkeeping of StationIDs and station pointers
tron
parents:
3001
diff
changeset
|
2547 |
if (around[i] == NULL) { |
3000
692dd5ed9fca
(svn r3580) Some small cleanups before the real change, especially reduce the indentation by one by using continue
tron
parents:
2989
diff
changeset
|
2548 |
if (!IsBuoy(st) && |
692dd5ed9fca
(svn r3580) Some small cleanups before the real change, especially reduce the indentation by one by using continue
tron
parents:
2989
diff
changeset
|
2549 |
(st->town->exclusive_counter == 0 || st->town->exclusivity == st->owner) && // check exclusive transport rights |
692dd5ed9fca
(svn r3580) Some small cleanups before the real change, especially reduce the indentation by one by using continue
tron
parents:
2989
diff
changeset
|
2550 |
st->goods[type].rating != 0 && |
692dd5ed9fca
(svn r3580) Some small cleanups before the real change, especially reduce the indentation by one by using continue
tron
parents:
2989
diff
changeset
|
2551 |
(!_patches.selectgoods || st->goods[type].last_speed > 0) && // if last_speed is 0, no vehicle has been there. |
692dd5ed9fca
(svn r3580) Some small cleanups before the real change, especially reduce the indentation by one by using continue
tron
parents:
2989
diff
changeset
|
2552 |
((st->facilities & ~FACIL_BUS_STOP) != 0 || type == CT_PASSENGERS) && // if we have other fac. than a bus stop, or the cargo is passengers |
692dd5ed9fca
(svn r3580) Some small cleanups before the real change, especially reduce the indentation by one by using continue
tron
parents:
2989
diff
changeset
|
2553 |
((st->facilities & ~FACIL_TRUCK_STOP) != 0 || type != CT_PASSENGERS)) { // if we have other fac. than a cargo bay or the cargo is not passengers |
3001
f7944d55b88d
(svn r3581) Just noticed the indentation was totally off, fix it
tron
parents:
3000
diff
changeset
|
2554 |
int x_dist; |
f7944d55b88d
(svn r3581) Just noticed the indentation was totally off, fix it
tron
parents:
3000
diff
changeset
|
2555 |
int y_dist; |
f7944d55b88d
(svn r3581) Just noticed the indentation was totally off, fix it
tron
parents:
3000
diff
changeset
|
2556 |
|
f7944d55b88d
(svn r3581) Just noticed the indentation was totally off, fix it
tron
parents:
3000
diff
changeset
|
2557 |
if (_patches.modified_catchment) { |
f7944d55b88d
(svn r3581) Just noticed the indentation was totally off, fix it
tron
parents:
3000
diff
changeset
|
2558 |
// min and max coordinates of the producer relative |
f7944d55b88d
(svn r3581) Just noticed the indentation was totally off, fix it
tron
parents:
3000
diff
changeset
|
2559 |
const int x_min_prod = 9; |
f7944d55b88d
(svn r3581) Just noticed the indentation was totally off, fix it
tron
parents:
3000
diff
changeset
|
2560 |
const int x_max_prod = 8 + w_prod; |
f7944d55b88d
(svn r3581) Just noticed the indentation was totally off, fix it
tron
parents:
3000
diff
changeset
|
2561 |
const int y_min_prod = 9; |
f7944d55b88d
(svn r3581) Just noticed the indentation was totally off, fix it
tron
parents:
3000
diff
changeset
|
2562 |
const int y_max_prod = 8 + h_prod; |
f7944d55b88d
(svn r3581) Just noticed the indentation was totally off, fix it
tron
parents:
3000
diff
changeset
|
2563 |
|
f7944d55b88d
(svn r3581) Just noticed the indentation was totally off, fix it
tron
parents:
3000
diff
changeset
|
2564 |
rad = FindCatchmentRadius(st); |
f7944d55b88d
(svn r3581) Just noticed the indentation was totally off, fix it
tron
parents:
3000
diff
changeset
|
2565 |
|
f7944d55b88d
(svn r3581) Just noticed the indentation was totally off, fix it
tron
parents:
3000
diff
changeset
|
2566 |
x_dist = min(w_cur - x_min_prod, x_max_prod - w_cur); |
f7944d55b88d
(svn r3581) Just noticed the indentation was totally off, fix it
tron
parents:
3000
diff
changeset
|
2567 |
if (w_cur < x_min_prod) { |
f7944d55b88d
(svn r3581) Just noticed the indentation was totally off, fix it
tron
parents:
3000
diff
changeset
|
2568 |
x_dist = x_min_prod - w_cur; |
f7944d55b88d
(svn r3581) Just noticed the indentation was totally off, fix it
tron
parents:
3000
diff
changeset
|
2569 |
} else if (w_cur > x_max_prod) { |
f7944d55b88d
(svn r3581) Just noticed the indentation was totally off, fix it
tron
parents:
3000
diff
changeset
|
2570 |
x_dist = w_cur - x_max_prod; |
3000
692dd5ed9fca
(svn r3580) Some small cleanups before the real change, especially reduce the indentation by one by using continue
tron
parents:
2989
diff
changeset
|
2571 |
} |
3001
f7944d55b88d
(svn r3581) Just noticed the indentation was totally off, fix it
tron
parents:
3000
diff
changeset
|
2572 |
|
f7944d55b88d
(svn r3581) Just noticed the indentation was totally off, fix it
tron
parents:
3000
diff
changeset
|
2573 |
y_dist = min(h_cur - y_min_prod, y_max_prod - h_cur); |
f7944d55b88d
(svn r3581) Just noticed the indentation was totally off, fix it
tron
parents:
3000
diff
changeset
|
2574 |
if (h_cur < y_min_prod) { |
f7944d55b88d
(svn r3581) Just noticed the indentation was totally off, fix it
tron
parents:
3000
diff
changeset
|
2575 |
y_dist = y_min_prod - h_cur; |
f7944d55b88d
(svn r3581) Just noticed the indentation was totally off, fix it
tron
parents:
3000
diff
changeset
|
2576 |
} else if (h_cur > y_max_prod) { |
f7944d55b88d
(svn r3581) Just noticed the indentation was totally off, fix it
tron
parents:
3000
diff
changeset
|
2577 |
y_dist = h_cur - y_max_prod; |
f7944d55b88d
(svn r3581) Just noticed the indentation was totally off, fix it
tron
parents:
3000
diff
changeset
|
2578 |
} |
f7944d55b88d
(svn r3581) Just noticed the indentation was totally off, fix it
tron
parents:
3000
diff
changeset
|
2579 |
} else { |
f7944d55b88d
(svn r3581) Just noticed the indentation was totally off, fix it
tron
parents:
3000
diff
changeset
|
2580 |
x_dist = 0; |
f7944d55b88d
(svn r3581) Just noticed the indentation was totally off, fix it
tron
parents:
3000
diff
changeset
|
2581 |
y_dist = 0; |
f7944d55b88d
(svn r3581) Just noticed the indentation was totally off, fix it
tron
parents:
3000
diff
changeset
|
2582 |
} |
f7944d55b88d
(svn r3581) Just noticed the indentation was totally off, fix it
tron
parents:
3000
diff
changeset
|
2583 |
|
3002
0651b917cd92
(svn r3582) Restructure MoveGoodsToStation() to avoid double bookkeeping of StationIDs and station pointers
tron
parents:
3001
diff
changeset
|
2584 |
if (x_dist <= rad && y_dist <= rad) around[i] = st; |
3001
f7944d55b88d
(svn r3581) Just noticed the indentation was totally off, fix it
tron
parents:
3000
diff
changeset
|
2585 |
} |
3000
692dd5ed9fca
(svn r3580) Some small cleanups before the real change, especially reduce the indentation by one by using continue
tron
parents:
2989
diff
changeset
|
2586 |
break; |
3002
0651b917cd92
(svn r3582) Restructure MoveGoodsToStation() to avoid double bookkeeping of StationIDs and station pointers
tron
parents:
3001
diff
changeset
|
2587 |
} else if (around[i] == st) { |
3000
692dd5ed9fca
(svn r3580) Some small cleanups before the real change, especially reduce the indentation by one by using continue
tron
parents:
2989
diff
changeset
|
2588 |
break; |
0 | 2589 |
} |
2590 |
} |
|
1981 | 2591 |
END_TILE_LOOP(cur_tile, w, h, tile - TileDiffXY(max_rad, max_rad)) |
0 | 2592 |
|
2593 |
/* no stations around at all? */ |
|
3002
0651b917cd92
(svn r3582) Restructure MoveGoodsToStation() to avoid double bookkeeping of StationIDs and station pointers
tron
parents:
3001
diff
changeset
|
2594 |
if (around[0] == NULL) return 0; |
0651b917cd92
(svn r3582) Restructure MoveGoodsToStation() to avoid double bookkeeping of StationIDs and station pointers
tron
parents:
3001
diff
changeset
|
2595 |
|
0651b917cd92
(svn r3582) Restructure MoveGoodsToStation() to avoid double bookkeeping of StationIDs and station pointers
tron
parents:
3001
diff
changeset
|
2596 |
if (around[1] == NULL) { |
0 | 2597 |
/* only one station around */ |
3002
0651b917cd92
(svn r3582) Restructure MoveGoodsToStation() to avoid double bookkeeping of StationIDs and station pointers
tron
parents:
3001
diff
changeset
|
2598 |
moved = (amount * around[0]->goods[type].rating >> 8) + 1; |
0651b917cd92
(svn r3582) Restructure MoveGoodsToStation() to avoid double bookkeeping of StationIDs and station pointers
tron
parents:
3001
diff
changeset
|
2599 |
UpdateStationWaiting(around[0], type, moved); |
0 | 2600 |
return moved; |
2601 |
} |
|
2602 |
||
2603 |
/* several stations around, find the two with the highest rating */ |
|
2604 |
st2 = st1 = NULL; |
|
2605 |
best_rating = best_rating2 = 0; |
|
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
2606 |
|
3002
0651b917cd92
(svn r3582) Restructure MoveGoodsToStation() to avoid double bookkeeping of StationIDs and station pointers
tron
parents:
3001
diff
changeset
|
2607 |
for (i = 0; i != lengthof(around) && around[i] != NULL; i++) { |
0651b917cd92
(svn r3582) Restructure MoveGoodsToStation() to avoid double bookkeeping of StationIDs and station pointers
tron
parents:
3001
diff
changeset
|
2608 |
if (around[i]->goods[type].rating >= best_rating) { |
0 | 2609 |
best_rating2 = best_rating; |
2610 |
st2 = st1; |
|
2611 |
||
3002
0651b917cd92
(svn r3582) Restructure MoveGoodsToStation() to avoid double bookkeeping of StationIDs and station pointers
tron
parents:
3001
diff
changeset
|
2612 |
best_rating = around[i]->goods[type].rating; |
0651b917cd92
(svn r3582) Restructure MoveGoodsToStation() to avoid double bookkeeping of StationIDs and station pointers
tron
parents:
3001
diff
changeset
|
2613 |
st1 = around[i]; |
0651b917cd92
(svn r3582) Restructure MoveGoodsToStation() to avoid double bookkeeping of StationIDs and station pointers
tron
parents:
3001
diff
changeset
|
2614 |
} else if (around[i]->goods[type].rating >= best_rating2) { |
0651b917cd92
(svn r3582) Restructure MoveGoodsToStation() to avoid double bookkeeping of StationIDs and station pointers
tron
parents:
3001
diff
changeset
|
2615 |
best_rating2 = around[i]->goods[type].rating; |
0651b917cd92
(svn r3582) Restructure MoveGoodsToStation() to avoid double bookkeeping of StationIDs and station pointers
tron
parents:
3001
diff
changeset
|
2616 |
st2 = around[i]; |
0 | 2617 |
} |
2618 |
} |
|
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
159
diff
changeset
|
2619 |
|
0 | 2620 |
assert(st1 != NULL); |
2621 |
assert(st2 != NULL); |
|
2622 |
assert(best_rating != 0 || best_rating2 != 0); |
|
2623 |
||
2624 |
/* the 2nd highest one gets a penalty */ |
|
2625 |
best_rating2 >>= 1; |
|
2626 |
||
2627 |
/* amount given to station 1 */ |
|
2628 |
t = (best_rating * (amount + 1)) / (best_rating + best_rating2); |
|
2629 |
||
2630 |
moved = 0; |
|
2631 |
if (t != 0) { |
|
3000
692dd5ed9fca
(svn r3580) Some small cleanups before the real change, especially reduce the indentation by one by using continue
tron
parents:
2989
diff
changeset
|
2632 |
moved = t * best_rating / 256 + 1; |
0 | 2633 |
amount -= t; |
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
159
diff
changeset
|
2634 |
UpdateStationWaiting(st1, type, moved); |
0 | 2635 |
} |
2636 |
||
2637 |
if (amount != 0) { |
|
3000
692dd5ed9fca
(svn r3580) Some small cleanups before the real change, especially reduce the indentation by one by using continue
tron
parents:
2989
diff
changeset
|
2638 |
amount = amount * best_rating2 / 256 + 1; |
692dd5ed9fca
(svn r3580) Some small cleanups before the real change, especially reduce the indentation by one by using continue
tron
parents:
2989
diff
changeset
|
2639 |
moved += amount; |
0 | 2640 |
UpdateStationWaiting(st2, type, amount); |
2641 |
} |
|
2642 |
||
2643 |
return moved; |
|
2644 |
} |
|
2645 |
||
1977
37bbebf94434
(svn r2483) Replace almost 500 "uint tile" (and variants) with "TileIndex tile"
tron
parents:
1942
diff
changeset
|
2646 |
void BuildOilRig(TileIndex tile) |
0 | 2647 |
{ |
2639 | 2648 |
uint j; |
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
2649 |
Station *st = new Station(); |
2427
5312305eecdd
(svn r2953) - Fix: [ 1257766 ] Cannot make ships go to an oil platform (oilrig has no station). While it is still possible that oilrigs end up without a station, it is only the case where no more stations can be built at all
Darkvater
parents:
2425
diff
changeset
|
2650 |
|
5312305eecdd
(svn r2953) - Fix: [ 1257766 ] Cannot make ships go to an oil platform (oilrig has no station). While it is still possible that oilrigs end up without a station, it is only the case where no more stations can be built at all
Darkvater
parents:
2425
diff
changeset
|
2651 |
if (st == NULL) { |
5380
8ea58542b6e0
(svn r7565) -Codechange: Rework DEBUG functionality. Look for appropiate debugging levels to
Darkvater
parents:
5362
diff
changeset
|
2652 |
DEBUG(misc, 0, "Can't allocate station for oilrig at 0x%X, reverting to oilrig only", tile); |
2427
5312305eecdd
(svn r2953) - Fix: [ 1257766 ] Cannot make ships go to an oil platform (oilrig has no station). While it is still possible that oilrigs end up without a station, it is only the case where no more stations can be built at all
Darkvater
parents:
2425
diff
changeset
|
2653 |
return; |
0 | 2654 |
} |
2427
5312305eecdd
(svn r2953) - Fix: [ 1257766 ] Cannot make ships go to an oil platform (oilrig has no station). While it is still possible that oilrigs end up without a station, it is only the case where no more stations can be built at all
Darkvater
parents:
2425
diff
changeset
|
2655 |
if (!GenerateStationName(st, tile, 2)) { |
5380
8ea58542b6e0
(svn r7565) -Codechange: Rework DEBUG functionality. Look for appropiate debugging levels to
Darkvater
parents:
5362
diff
changeset
|
2656 |
DEBUG(misc, 0, "Can't allocate station-name for oilrig at 0x%X, reverting to oilrig only", tile); |
2427
5312305eecdd
(svn r2953) - Fix: [ 1257766 ] Cannot make ships go to an oil platform (oilrig has no station). While it is still possible that oilrigs end up without a station, it is only the case where no more stations can be built at all
Darkvater
parents:
2425
diff
changeset
|
2657 |
return; |
5312305eecdd
(svn r2953) - Fix: [ 1257766 ] Cannot make ships go to an oil platform (oilrig has no station). While it is still possible that oilrigs end up without a station, it is only the case where no more stations can be built at all
Darkvater
parents:
2425
diff
changeset
|
2658 |
} |
5312305eecdd
(svn r2953) - Fix: [ 1257766 ] Cannot make ships go to an oil platform (oilrig has no station). While it is still possible that oilrigs end up without a station, it is only the case where no more stations can be built at all
Darkvater
parents:
2425
diff
changeset
|
2659 |
|
5312305eecdd
(svn r2953) - Fix: [ 1257766 ] Cannot make ships go to an oil platform (oilrig has no station). While it is still possible that oilrigs end up without a station, it is only the case where no more stations can be built at all
Darkvater
parents:
2425
diff
changeset
|
2660 |
st->town = ClosestTownFromTile(tile, (uint)-1); |
5312305eecdd
(svn r2953) - Fix: [ 1257766 ] Cannot make ships go to an oil platform (oilrig has no station). While it is still possible that oilrigs end up without a station, it is only the case where no more stations can be built at all
Darkvater
parents:
2425
diff
changeset
|
2661 |
st->sign.width_1 = 0; |
5312305eecdd
(svn r2953) - Fix: [ 1257766 ] Cannot make ships go to an oil platform (oilrig has no station). While it is still possible that oilrigs end up without a station, it is only the case where no more stations can be built at all
Darkvater
parents:
2425
diff
changeset
|
2662 |
|
3334
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
2663 |
MakeOilrig(tile, st->index); |
2427
5312305eecdd
(svn r2953) - Fix: [ 1257766 ] Cannot make ships go to an oil platform (oilrig has no station). While it is still possible that oilrigs end up without a station, it is only the case where no more stations can be built at all
Darkvater
parents:
2425
diff
changeset
|
2664 |
|
5312305eecdd
(svn r2953) - Fix: [ 1257766 ] Cannot make ships go to an oil platform (oilrig has no station). While it is still possible that oilrigs end up without a station, it is only the case where no more stations can be built at all
Darkvater
parents:
2425
diff
changeset
|
2665 |
st->owner = OWNER_NONE; |
5312305eecdd
(svn r2953) - Fix: [ 1257766 ] Cannot make ships go to an oil platform (oilrig has no station). While it is still possible that oilrigs end up without a station, it is only the case where no more stations can be built at all
Darkvater
parents:
2425
diff
changeset
|
2666 |
st->airport_flags = 0; |
5312305eecdd
(svn r2953) - Fix: [ 1257766 ] Cannot make ships go to an oil platform (oilrig has no station). While it is still possible that oilrigs end up without a station, it is only the case where no more stations can be built at all
Darkvater
parents:
2425
diff
changeset
|
2667 |
st->airport_type = AT_OILRIG; |
5312305eecdd
(svn r2953) - Fix: [ 1257766 ] Cannot make ships go to an oil platform (oilrig has no station). While it is still possible that oilrigs end up without a station, it is only the case where no more stations can be built at all
Darkvater
parents:
2425
diff
changeset
|
2668 |
st->xy = tile; |
5312305eecdd
(svn r2953) - Fix: [ 1257766 ] Cannot make ships go to an oil platform (oilrig has no station). While it is still possible that oilrigs end up without a station, it is only the case where no more stations can be built at all
Darkvater
parents:
2425
diff
changeset
|
2669 |
st->bus_stops = NULL; |
5312305eecdd
(svn r2953) - Fix: [ 1257766 ] Cannot make ships go to an oil platform (oilrig has no station). While it is still possible that oilrigs end up without a station, it is only the case where no more stations can be built at all
Darkvater
parents:
2425
diff
changeset
|
2670 |
st->truck_stops = NULL; |
5312305eecdd
(svn r2953) - Fix: [ 1257766 ] Cannot make ships go to an oil platform (oilrig has no station). While it is still possible that oilrigs end up without a station, it is only the case where no more stations can be built at all
Darkvater
parents:
2425
diff
changeset
|
2671 |
st->airport_tile = tile; |
5312305eecdd
(svn r2953) - Fix: [ 1257766 ] Cannot make ships go to an oil platform (oilrig has no station). While it is still possible that oilrigs end up without a station, it is only the case where no more stations can be built at all
Darkvater
parents:
2425
diff
changeset
|
2672 |
st->dock_tile = tile; |
5312305eecdd
(svn r2953) - Fix: [ 1257766 ] Cannot make ships go to an oil platform (oilrig has no station). While it is still possible that oilrigs end up without a station, it is only the case where no more stations can be built at all
Darkvater
parents:
2425
diff
changeset
|
2673 |
st->train_tile = 0; |
5312305eecdd
(svn r2953) - Fix: [ 1257766 ] Cannot make ships go to an oil platform (oilrig has no station). While it is still possible that oilrigs end up without a station, it is only the case where no more stations can be built at all
Darkvater
parents:
2425
diff
changeset
|
2674 |
st->had_vehicle_of_type = 0; |
5312305eecdd
(svn r2953) - Fix: [ 1257766 ] Cannot make ships go to an oil platform (oilrig has no station). While it is still possible that oilrigs end up without a station, it is only the case where no more stations can be built at all
Darkvater
parents:
2425
diff
changeset
|
2675 |
st->time_since_load = 255; |
5312305eecdd
(svn r2953) - Fix: [ 1257766 ] Cannot make ships go to an oil platform (oilrig has no station). While it is still possible that oilrigs end up without a station, it is only the case where no more stations can be built at all
Darkvater
parents:
2425
diff
changeset
|
2676 |
st->time_since_unload = 255; |
5312305eecdd
(svn r2953) - Fix: [ 1257766 ] Cannot make ships go to an oil platform (oilrig has no station). While it is still possible that oilrigs end up without a station, it is only the case where no more stations can be built at all
Darkvater
parents:
2425
diff
changeset
|
2677 |
st->delete_ctr = 0; |
3580
14bf6e7715c8
(svn r4466) -Fix: (FS#71) Game no longer crashes when the last vehicle serving a station has been deleted.
celestar
parents:
3576
diff
changeset
|
2678 |
st->last_vehicle_type = VEH_Invalid; |
2427
5312305eecdd
(svn r2953) - Fix: [ 1257766 ] Cannot make ships go to an oil platform (oilrig has no station). While it is still possible that oilrigs end up without a station, it is only the case where no more stations can be built at all
Darkvater
parents:
2425
diff
changeset
|
2679 |
st->facilities = FACIL_AIRPORT | FACIL_DOCK; |
5312305eecdd
(svn r2953) - Fix: [ 1257766 ] Cannot make ships go to an oil platform (oilrig has no station). While it is still possible that oilrigs end up without a station, it is only the case where no more stations can be built at all
Darkvater
parents:
2425
diff
changeset
|
2680 |
st->build_date = _date; |
5312305eecdd
(svn r2953) - Fix: [ 1257766 ] Cannot make ships go to an oil platform (oilrig has no station). While it is still possible that oilrigs end up without a station, it is only the case where no more stations can be built at all
Darkvater
parents:
2425
diff
changeset
|
2681 |
|
5312305eecdd
(svn r2953) - Fix: [ 1257766 ] Cannot make ships go to an oil platform (oilrig has no station). While it is still possible that oilrigs end up without a station, it is only the case where no more stations can be built at all
Darkvater
parents:
2425
diff
changeset
|
2682 |
for (j = 0; j != NUM_CARGO; j++) { |
5312305eecdd
(svn r2953) - Fix: [ 1257766 ] Cannot make ships go to an oil platform (oilrig has no station). While it is still possible that oilrigs end up without a station, it is only the case where no more stations can be built at all
Darkvater
parents:
2425
diff
changeset
|
2683 |
st->goods[j].waiting_acceptance = 0; |
5312305eecdd
(svn r2953) - Fix: [ 1257766 ] Cannot make ships go to an oil platform (oilrig has no station). While it is still possible that oilrigs end up without a station, it is only the case where no more stations can be built at all
Darkvater
parents:
2425
diff
changeset
|
2684 |
st->goods[j].days_since_pickup = 0; |
5312305eecdd
(svn r2953) - Fix: [ 1257766 ] Cannot make ships go to an oil platform (oilrig has no station). While it is still possible that oilrigs end up without a station, it is only the case where no more stations can be built at all
Darkvater
parents:
2425
diff
changeset
|
2685 |
st->goods[j].enroute_from = INVALID_STATION; |
5683
b027e5d5b4cd
(svn r8144) -Fix: [FS#163] When a station is removed, vehicles do not get excessive payment any longer, as the origin TILE is now stored as long as the origin STATION for the transported cargos. Basically this is only a temporary fix until cargopackets are implemented, but it fixes one of the oldest known bugs (Special Thanks to Darkvater for lots of testing)
celestar
parents:
5679
diff
changeset
|
2686 |
st->goods[j].enroute_from_xy = INVALID_TILE; |
2427
5312305eecdd
(svn r2953) - Fix: [ 1257766 ] Cannot make ships go to an oil platform (oilrig has no station). While it is still possible that oilrigs end up without a station, it is only the case where no more stations can be built at all
Darkvater
parents:
2425
diff
changeset
|
2687 |
st->goods[j].rating = 175; |
5312305eecdd
(svn r2953) - Fix: [ 1257766 ] Cannot make ships go to an oil platform (oilrig has no station). While it is still possible that oilrigs end up without a station, it is only the case where no more stations can be built at all
Darkvater
parents:
2425
diff
changeset
|
2688 |
st->goods[j].last_speed = 0; |
5312305eecdd
(svn r2953) - Fix: [ 1257766 ] Cannot make ships go to an oil platform (oilrig has no station). While it is still possible that oilrigs end up without a station, it is only the case where no more stations can be built at all
Darkvater
parents:
2425
diff
changeset
|
2689 |
st->goods[j].last_age = 255; |
5312305eecdd
(svn r2953) - Fix: [ 1257766 ] Cannot make ships go to an oil platform (oilrig has no station). While it is still possible that oilrigs end up without a station, it is only the case where no more stations can be built at all
Darkvater
parents:
2425
diff
changeset
|
2690 |
} |
5312305eecdd
(svn r2953) - Fix: [ 1257766 ] Cannot make ships go to an oil platform (oilrig has no station). While it is still possible that oilrigs end up without a station, it is only the case where no more stations can be built at all
Darkvater
parents:
2425
diff
changeset
|
2691 |
|
5312305eecdd
(svn r2953) - Fix: [ 1257766 ] Cannot make ships go to an oil platform (oilrig has no station). While it is still possible that oilrigs end up without a station, it is only the case where no more stations can be built at all
Darkvater
parents:
2425
diff
changeset
|
2692 |
UpdateStationVirtCoordDirty(st); |
5312305eecdd
(svn r2953) - Fix: [ 1257766 ] Cannot make ships go to an oil platform (oilrig has no station). While it is still possible that oilrigs end up without a station, it is only the case where no more stations can be built at all
Darkvater
parents:
2425
diff
changeset
|
2693 |
UpdateStationAcceptance(st, false); |
0 | 2694 |
} |
2695 |
||
1977
37bbebf94434
(svn r2483) Replace almost 500 "uint tile" (and variants) with "TileIndex tile"
tron
parents:
1942
diff
changeset
|
2696 |
void DeleteOilRig(TileIndex tile) |
0 | 2697 |
{ |
3315
c9d989783c55
(svn r4079) Add GetSation{Index,ByTile}() to get the station index resp. the station from a tile
tron
parents:
3282
diff
changeset
|
2698 |
Station* st = GetStationByTile(tile); |
0 | 2699 |
|
5887 | 2700 |
MakeWater(tile); |
0 | 2701 |
|
2702 |
st->dock_tile = 0; |
|
2703 |
st->airport_tile = 0; |
|
2704 |
st->facilities &= ~(FACIL_AIRPORT | FACIL_DOCK); |
|
2705 |
st->airport_flags = 0; |
|
2706 |
UpdateStationVirtCoordDirty(st); |
|
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
2707 |
if (st->facilities == 0) delete st; |
0 | 2708 |
} |
2709 |
||
2436
7d5df545bd5d
(svn r2962) - const correctness for all Get* functions and most Draw* functions that don't change their pointer parameters
Darkvater
parents:
2427
diff
changeset
|
2710 |
static void ChangeTileOwner_Station(TileIndex tile, PlayerID old_player, PlayerID new_player) |
0 | 2711 |
{ |
1901
03bf9bf99319
(svn r2407) Use {Get,Is}TileOwner to get/check the owner of a tile and fix some bogus reads of _map_owner
tron
parents:
1891
diff
changeset
|
2712 |
if (!IsTileOwner(tile, old_player)) return; |
0 | 2713 |
|
4848
45f848b46222
(svn r6774) -Codechange: Rename the badly named OWNER_SPECTATOR to PLAYER_SPECTATOR and
Darkvater
parents:
4638
diff
changeset
|
2714 |
if (new_player != PLAYER_SPECTATOR) { |
3315
c9d989783c55
(svn r4079) Add GetSation{Index,ByTile}() to get the station index resp. the station from a tile
tron
parents:
3282
diff
changeset
|
2715 |
Station* st = GetStationByTile(tile); |
c9d989783c55
(svn r4079) Add GetSation{Index,ByTile}() to get the station index resp. the station from a tile
tron
parents:
3282
diff
changeset
|
2716 |
|
1902 | 2717 |
SetTileOwner(tile, new_player); |
0 | 2718 |
st->owner = new_player; |
3812
e6fc916c17ab
(svn r4822) -Feature: Station List View can now be sorted and filtered (by waiting cargo type and facilities)
celestar
parents:
3789
diff
changeset
|
2719 |
RebuildStationLists(); |
65
f9f866bc609c
(svn r66) -Fix Station list updated on station deletion/station rename
darkvater
parents:
59
diff
changeset
|
2720 |
InvalidateWindowClasses(WC_STATION_LIST); |
0 | 2721 |
} else { |
3491
35d747bb5e82
(svn r4342) Change the first two parameters of commands - virtual pixel coordinates of the tile to operate on - to a TileIndex
tron
parents:
3482
diff
changeset
|
2722 |
DoCommand(tile, 0, 0, DC_EXEC, CMD_LANDSCAPE_CLEAR); |
0 | 2723 |
} |
2724 |
} |
|
2725 |
||
1977
37bbebf94434
(svn r2483) Replace almost 500 "uint tile" (and variants) with "TileIndex tile"
tron
parents:
1942
diff
changeset
|
2726 |
static int32 ClearTile_Station(TileIndex tile, byte flags) |
37bbebf94434
(svn r2483) Replace almost 500 "uint tile" (and variants) with "TileIndex tile"
tron
parents:
1942
diff
changeset
|
2727 |
{ |
0 | 2728 |
Station *st; |
2729 |
||
2730 |
if (flags & DC_AUTO) { |
|
3334
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
2731 |
switch (GetStationType(tile)) { |
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
2732 |
case STATION_RAIL: return_cmd_error(STR_300B_MUST_DEMOLISH_RAILROAD); |
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
2733 |
case STATION_AIRPORT: return_cmd_error(STR_300E_MUST_DEMOLISH_AIRPORT_FIRST); |
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
2734 |
case STATION_TRUCK: return_cmd_error(STR_3047_MUST_DEMOLISH_TRUCK_STATION); |
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
2735 |
case STATION_BUS: return_cmd_error(STR_3046_MUST_DEMOLISH_BUS_STATION); |
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
2736 |
case STATION_BUOY: return_cmd_error(STR_306A_BUOY_IN_THE_WAY); |
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
2737 |
case STATION_DOCK: return_cmd_error(STR_304D_MUST_DEMOLISH_DOCK_FIRST); |
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
2738 |
case STATION_OILRIG: |
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
2739 |
SetDParam(0, STR_4807_OIL_RIG); |
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
2740 |
return_cmd_error(STR_4800_IN_THE_WAY); |
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
2741 |
} |
0 | 2742 |
} |
2743 |
||
3315
c9d989783c55
(svn r4079) Add GetSation{Index,ByTile}() to get the station index resp. the station from a tile
tron
parents:
3282
diff
changeset
|
2744 |
st = GetStationByTile(tile); |
0 | 2745 |
|
3334
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
2746 |
switch (GetStationType(tile)) { |
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
2747 |
case STATION_RAIL: return RemoveRailroadStation(st, tile, flags); |
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
2748 |
case STATION_AIRPORT: return RemoveAirport(st, flags); |
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
2749 |
case STATION_TRUCK: |
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
2750 |
case STATION_BUS: return RemoveRoadStop(st, flags, tile); |
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
2751 |
case STATION_BUOY: return RemoveBuoy(st, flags); |
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
2752 |
case STATION_DOCK: return RemoveDock(st, flags); |
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
2753 |
default: break; |
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
2754 |
} |
0 | 2755 |
|
2756 |
return CMD_ERROR; |
|
2757 |
} |
|
2758 |
||
1093
4fdc46eaf423
(svn r1594) Convert all undefined parameter lists to (void) and add the appropriate warning flags in the Makefile
tron
parents:
1078
diff
changeset
|
2759 |
void InitializeStations(void) |
0 | 2760 |
{ |
1272
9aa073c64fc7
(svn r1776) -Add: Dynamic stations. You can now have up to 64k of stations
truelight
parents:
1266
diff
changeset
|
2761 |
/* Clean the station pool and create 1 block in it */ |
4980 | 2762 |
CleanPool(&_Station_pool); |
2763 |
AddBlockToPool(&_Station_pool); |
|
919
544f374ee392
(svn r1407) -Codechange: changed a lot around _stations, _vehicles, _towns and _industries
truelight
parents:
909
diff
changeset
|
2764 |
|
1284
e1969eb0227b
(svn r1788) -Add: Made RoadStops dynamic. You can now create up to 64k roadstops.
truelight
parents:
1272
diff
changeset
|
2765 |
/* Clean the roadstop pool and create 1 block in it */ |
4981
44eeee2407f4
(svn r6984) Use the pool macros for the RoadStop pool
tron
parents:
4980
diff
changeset
|
2766 |
CleanPool(&_RoadStop_pool); |
44eeee2407f4
(svn r6984) Use the pool macros for the RoadStop pool
tron
parents:
4980
diff
changeset
|
2767 |
AddBlockToPool(&_RoadStop_pool); |
243
9a40daa560ae
(svn r244) -Fix: Stations were not sorted for non-player-0 players
darkvater
parents:
222
diff
changeset
|
2768 |
|
0 | 2769 |
_station_tick_ctr = 0; |
243
9a40daa560ae
(svn r244) -Fix: Stations were not sorted for non-player-0 players
darkvater
parents:
222
diff
changeset
|
2770 |
|
0 | 2771 |
} |
2772 |
||
2773 |
||
3765
a4ddbff73f9f
(svn r4757) - Newstations: add saveload support for custom station speclists
peter1138
parents:
3763
diff
changeset
|
2774 |
void AfterLoadStations(void) |
a4ddbff73f9f
(svn r4757) - Newstations: add saveload support for custom station speclists
peter1138
parents:
3763
diff
changeset
|
2775 |
{ |
a4ddbff73f9f
(svn r4757) - Newstations: add saveload support for custom station speclists
peter1138
parents:
3763
diff
changeset
|
2776 |
Station *st; |
a4ddbff73f9f
(svn r4757) - Newstations: add saveload support for custom station speclists
peter1138
parents:
3763
diff
changeset
|
2777 |
uint i; |
5395
7727da322d66
(svn r7585) -Codechange: CheckStationSpreadOut() took too much CPU. Station rectangle is now maintained instead of calculating it each time by walking through whole map. Should help with the performance issue related to AIs trying to build road stops too often. (idea by Celestar)
KUDr
parents:
5385
diff
changeset
|
2778 |
TileIndex tile; |
3765
a4ddbff73f9f
(svn r4757) - Newstations: add saveload support for custom station speclists
peter1138
parents:
3763
diff
changeset
|
2779 |
|
a4ddbff73f9f
(svn r4757) - Newstations: add saveload support for custom station speclists
peter1138
parents:
3763
diff
changeset
|
2780 |
/* Update the speclists of all stations to point to the currently loaded custom stations. */ |
a4ddbff73f9f
(svn r4757) - Newstations: add saveload support for custom station speclists
peter1138
parents:
3763
diff
changeset
|
2781 |
FOR_ALL_STATIONS(st) { |
a4ddbff73f9f
(svn r4757) - Newstations: add saveload support for custom station speclists
peter1138
parents:
3763
diff
changeset
|
2782 |
for (i = 0; i < st->num_specs; i++) { |
a4ddbff73f9f
(svn r4757) - Newstations: add saveload support for custom station speclists
peter1138
parents:
3763
diff
changeset
|
2783 |
if (st->speclist[i].grfid == 0) continue; |
a4ddbff73f9f
(svn r4757) - Newstations: add saveload support for custom station speclists
peter1138
parents:
3763
diff
changeset
|
2784 |
|
a4ddbff73f9f
(svn r4757) - Newstations: add saveload support for custom station speclists
peter1138
parents:
3763
diff
changeset
|
2785 |
st->speclist[i].spec = GetCustomStationSpecByGrf(st->speclist[i].grfid, st->speclist[i].localidx); |
a4ddbff73f9f
(svn r4757) - Newstations: add saveload support for custom station speclists
peter1138
parents:
3763
diff
changeset
|
2786 |
} |
a4ddbff73f9f
(svn r4757) - Newstations: add saveload support for custom station speclists
peter1138
parents:
3763
diff
changeset
|
2787 |
} |
5395
7727da322d66
(svn r7585) -Codechange: CheckStationSpreadOut() took too much CPU. Station rectangle is now maintained instead of calculating it each time by walking through whole map. Should help with the performance issue related to AIs trying to build road stops too often. (idea by Celestar)
KUDr
parents:
5385
diff
changeset
|
2788 |
|
7727da322d66
(svn r7585) -Codechange: CheckStationSpreadOut() took too much CPU. Station rectangle is now maintained instead of calculating it each time by walking through whole map. Should help with the performance issue related to AIs trying to build road stops too often. (idea by Celestar)
KUDr
parents:
5385
diff
changeset
|
2789 |
for (tile = 0; tile < MapSize(); tile++) { |
7727da322d66
(svn r7585) -Codechange: CheckStationSpreadOut() took too much CPU. Station rectangle is now maintained instead of calculating it each time by walking through whole map. Should help with the performance issue related to AIs trying to build road stops too often. (idea by Celestar)
KUDr
parents:
5385
diff
changeset
|
2790 |
if (GetTileType(tile) != MP_STATION) continue; |
7727da322d66
(svn r7585) -Codechange: CheckStationSpreadOut() took too much CPU. Station rectangle is now maintained instead of calculating it each time by walking through whole map. Should help with the performance issue related to AIs trying to build road stops too often. (idea by Celestar)
KUDr
parents:
5385
diff
changeset
|
2791 |
st = GetStationByTile(tile); |
5676
7a641ebbc080
(svn r8136) -Codechange: Station spread rectangle manipulators turned into StationRect::methods.
KUDr
parents:
5668
diff
changeset
|
2792 |
st->rect.BeforeAddTile(tile, StationRect::ADD_FORCE); |
5395
7727da322d66
(svn r7585) -Codechange: CheckStationSpreadOut() took too much CPU. Station rectangle is now maintained instead of calculating it each time by walking through whole map. Should help with the performance issue related to AIs trying to build road stops too often. (idea by Celestar)
KUDr
parents:
5385
diff
changeset
|
2793 |
} |
3765
a4ddbff73f9f
(svn r4757) - Newstations: add saveload support for custom station speclists
peter1138
parents:
3763
diff
changeset
|
2794 |
} |
a4ddbff73f9f
(svn r4757) - Newstations: add saveload support for custom station speclists
peter1138
parents:
3763
diff
changeset
|
2795 |
|
a4ddbff73f9f
(svn r4757) - Newstations: add saveload support for custom station speclists
peter1138
parents:
3763
diff
changeset
|
2796 |
|
5587
167d9a91ef02
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
rubidium
parents:
5584
diff
changeset
|
2797 |
extern const TileTypeProcs _tile_type_station_procs = { |
3554
86230061c3e7
(svn r4426) Code Cleaning : replacing tabs with spaces, removing obvious comments, aligning arrays etc...
belugas
parents:
3553
diff
changeset
|
2798 |
DrawTile_Station, /* draw_tile_proc */ |
86230061c3e7
(svn r4426) Code Cleaning : replacing tabs with spaces, removing obvious comments, aligning arrays etc...
belugas
parents:
3553
diff
changeset
|
2799 |
GetSlopeZ_Station, /* get_slope_z_proc */ |
86230061c3e7
(svn r4426) Code Cleaning : replacing tabs with spaces, removing obvious comments, aligning arrays etc...
belugas
parents:
3553
diff
changeset
|
2800 |
ClearTile_Station, /* clear_tile_proc */ |
86230061c3e7
(svn r4426) Code Cleaning : replacing tabs with spaces, removing obvious comments, aligning arrays etc...
belugas
parents:
3553
diff
changeset
|
2801 |
GetAcceptedCargo_Station, /* get_accepted_cargo_proc */ |
86230061c3e7
(svn r4426) Code Cleaning : replacing tabs with spaces, removing obvious comments, aligning arrays etc...
belugas
parents:
3553
diff
changeset
|
2802 |
GetTileDesc_Station, /* get_tile_desc_proc */ |
86230061c3e7
(svn r4426) Code Cleaning : replacing tabs with spaces, removing obvious comments, aligning arrays etc...
belugas
parents:
3553
diff
changeset
|
2803 |
GetTileTrackStatus_Station, /* get_tile_track_status_proc */ |
86230061c3e7
(svn r4426) Code Cleaning : replacing tabs with spaces, removing obvious comments, aligning arrays etc...
belugas
parents:
3553
diff
changeset
|
2804 |
ClickTile_Station, /* click_tile_proc */ |
86230061c3e7
(svn r4426) Code Cleaning : replacing tabs with spaces, removing obvious comments, aligning arrays etc...
belugas
parents:
3553
diff
changeset
|
2805 |
AnimateTile_Station, /* animate_tile_proc */ |
86230061c3e7
(svn r4426) Code Cleaning : replacing tabs with spaces, removing obvious comments, aligning arrays etc...
belugas
parents:
3553
diff
changeset
|
2806 |
TileLoop_Station, /* tile_loop_clear */ |
86230061c3e7
(svn r4426) Code Cleaning : replacing tabs with spaces, removing obvious comments, aligning arrays etc...
belugas
parents:
3553
diff
changeset
|
2807 |
ChangeTileOwner_Station, /* change_tile_owner_clear */ |
86230061c3e7
(svn r4426) Code Cleaning : replacing tabs with spaces, removing obvious comments, aligning arrays etc...
belugas
parents:
3553
diff
changeset
|
2808 |
NULL, /* get_produced_cargo_proc */ |
86230061c3e7
(svn r4426) Code Cleaning : replacing tabs with spaces, removing obvious comments, aligning arrays etc...
belugas
parents:
3553
diff
changeset
|
2809 |
VehicleEnter_Station, /* vehicle_enter_tile_proc */ |
86230061c3e7
(svn r4426) Code Cleaning : replacing tabs with spaces, removing obvious comments, aligning arrays etc...
belugas
parents:
3553
diff
changeset
|
2810 |
GetSlopeTileh_Station, /* get_slope_tileh_proc */ |
0 | 2811 |
}; |
2812 |
||
1881
435d39bd6ee0
(svn r2387) - CodeChange: made the saveload code more readable and also removed the 'byte' saveload arrays which means you can save an array of more than 255 elements, or bigger structs than 255 bytes. This doesn't yet solve the problem that a chunk can be a maximum of 16384 big.
Darkvater
parents:
1876
diff
changeset
|
2813 |
static const SaveLoad _roadstop_desc[] = { |
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
2814 |
SLE_VAR(RoadStop,xy, SLE_UINT32), |
5718 | 2815 |
SLE_CONDNULL(1, 0, 44), |
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
2816 |
SLE_VAR(RoadStop,status, SLE_UINT8), |
1285
4bda5c927b45
(svn r1789) -Fix: there is no need to save the index, it is done for us
truelight
parents:
1284
diff
changeset
|
2817 |
/* Index was saved in some versions, but this is not needed */ |
3222
6de22e06a1e9
(svn r3895) - Add proper SLE(G)_CONDNULL macros for the empty space reservation in savegames and update where used
Darkvater
parents:
3183
diff
changeset
|
2818 |
SLE_CONDNULL(4, 0, 8), |
5716 | 2819 |
SLE_CONDNULL(2, 0, 44), |
3479
3655a074a380
(svn r4324) Remove the unused road stop type attribute from struct RoadStop
tron
parents:
3478
diff
changeset
|
2820 |
SLE_CONDNULL(1, 0, 25), |
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
2821 |
|
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
2822 |
SLE_REF(RoadStop,next, REF_ROADSTOPS), |
5867 | 2823 |
SLE_CONDNULL(2, 0, 44), |
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
2824 |
|
3431 | 2825 |
SLE_CONDNULL(4, 0, 24), |
3475
150d89779e96
(svn r4320) -Fix/Codechange: rs->num_vehicles is no longer saved or loaded, but computed on the fly. Partly fixes FS#101
celestar
parents:
3474
diff
changeset
|
2826 |
SLE_CONDNULL(1, 25, 25), |
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
2827 |
|
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
2828 |
SLE_END() |
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
2829 |
}; |
0 | 2830 |
|
1881
435d39bd6ee0
(svn r2387) - CodeChange: made the saveload code more readable and also removed the 'byte' saveload arrays which means you can save an array of more than 255 elements, or bigger structs than 255 bytes. This doesn't yet solve the problem that a chunk can be a maximum of 16384 big.
Darkvater
parents:
1876
diff
changeset
|
2831 |
static const SaveLoad _station_desc[] = { |
4344
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
2832 |
SLE_CONDVAR(Station, xy, SLE_FILE_U16 | SLE_VAR_U32, 0, 5), |
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
2833 |
SLE_CONDVAR(Station, xy, SLE_UINT32, 6, SL_MAX_VERSION), |
5879 | 2834 |
SLE_CONDNULL(4, 0, 5), // bus/lorry tile |
4344
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
2835 |
SLE_CONDVAR(Station, train_tile, SLE_FILE_U16 | SLE_VAR_U32, 0, 5), |
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
2836 |
SLE_CONDVAR(Station, train_tile, SLE_UINT32, 6, SL_MAX_VERSION), |
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
2837 |
SLE_CONDVAR(Station, airport_tile, SLE_FILE_U16 | SLE_VAR_U32, 0, 5), |
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
2838 |
SLE_CONDVAR(Station, airport_tile, SLE_UINT32, 6, SL_MAX_VERSION), |
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
2839 |
SLE_CONDVAR(Station, dock_tile, SLE_FILE_U16 | SLE_VAR_U32, 0, 5), |
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
2840 |
SLE_CONDVAR(Station, dock_tile, SLE_UINT32, 6, SL_MAX_VERSION), |
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
2841 |
SLE_REF(Station, town, REF_TOWN), |
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
2842 |
SLE_VAR(Station, trainst_w, SLE_UINT8), |
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
2843 |
SLE_CONDVAR(Station, trainst_h, SLE_UINT8, 2, SL_MAX_VERSION), |
0 | 2844 |
|
2845 |
// alpha_order was stored here in savegame format 0 - 3 |
|
3222
6de22e06a1e9
(svn r3895) - Add proper SLE(G)_CONDNULL macros for the empty space reservation in savegames and update where used
Darkvater
parents:
3183
diff
changeset
|
2846 |
SLE_CONDNULL(1, 0, 3), |
0 | 2847 |
|
4344
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
2848 |
SLE_VAR(Station, string_id, SLE_STRINGID), |
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
2849 |
SLE_VAR(Station, had_vehicle_of_type, SLE_UINT16), |
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
2850 |
|
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
2851 |
SLE_VAR(Station, time_since_load, SLE_UINT8), |
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
2852 |
SLE_VAR(Station, time_since_unload, SLE_UINT8), |
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
2853 |
SLE_VAR(Station, delete_ctr, SLE_UINT8), |
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
2854 |
SLE_VAR(Station, owner, SLE_UINT8), |
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
2855 |
SLE_VAR(Station, facilities, SLE_UINT8), |
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
2856 |
SLE_VAR(Station, airport_type, SLE_UINT8), |
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
2857 |
|
5878 | 2858 |
SLE_CONDNULL(2, 0, 5), // Truck/bus stop status |
5877 | 2859 |
SLE_CONDNULL(1, 0, 4), // Blocked months |
4344
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
2860 |
|
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
2861 |
SLE_CONDVAR(Station, airport_flags, SLE_VAR_U32 | SLE_FILE_U16, 0, 2), |
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
2862 |
SLE_CONDVAR(Station, airport_flags, SLE_UINT32, 3, SL_MAX_VERSION), |
3554
86230061c3e7
(svn r4426) Code Cleaning : replacing tabs with spaces, removing obvious comments, aligning arrays etc...
belugas
parents:
3553
diff
changeset
|
2863 |
|
3580
14bf6e7715c8
(svn r4466) -Fix: (FS#71) Game no longer crashes when the last vehicle serving a station has been deleted.
celestar
parents:
3576
diff
changeset
|
2864 |
SLE_CONDNULL(2, 0, 25), /* Ex last-vehicle */ |
4344
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
2865 |
SLE_CONDVAR(Station, last_vehicle_type, SLE_UINT8, 26, SL_MAX_VERSION), |
3554
86230061c3e7
(svn r4426) Code Cleaning : replacing tabs with spaces, removing obvious comments, aligning arrays etc...
belugas
parents:
3553
diff
changeset
|
2866 |
|
3574
280e134ce515
(svn r4460) - Newstations: remove unused class_id / stat_id variables from the
peter1138
parents:
3568
diff
changeset
|
2867 |
// Was custom station class and id |
280e134ce515
(svn r4460) - Newstations: remove unused class_id / stat_id variables from the
peter1138
parents:
3568
diff
changeset
|
2868 |
SLE_CONDNULL(2, 3, 25), |
4344
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
2869 |
SLE_CONDVAR(Station, build_date, SLE_FILE_U16 | SLE_VAR_I32, 3, 30), |
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
2870 |
SLE_CONDVAR(Station, build_date, SLE_INT32, 31, SL_MAX_VERSION), |
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
2871 |
|
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
2872 |
SLE_CONDREF(Station, bus_stops, REF_ROADSTOPS, 6, SL_MAX_VERSION), |
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
2873 |
SLE_CONDREF(Station, truck_stops, REF_ROADSTOPS, 6, SL_MAX_VERSION), |
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
2874 |
|
3687
f421ffcfeb00
(svn r4612) - NewStations: add random bits (for graphic variation) to stations
peter1138
parents:
3682
diff
changeset
|
2875 |
/* Used by newstations for graphic variations */ |
4344
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
2876 |
SLE_CONDVAR(Station, random_bits, SLE_UINT16, 27, SL_MAX_VERSION), |
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
2877 |
SLE_CONDVAR(Station, waiting_triggers, SLE_UINT8, 27, SL_MAX_VERSION), |
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
2878 |
SLE_CONDVAR(Station, num_specs, SLE_UINT8, 27, SL_MAX_VERSION), |
3687
f421ffcfeb00
(svn r4612) - NewStations: add random bits (for graphic variation) to stations
peter1138
parents:
3682
diff
changeset
|
2879 |
|
3222
6de22e06a1e9
(svn r3895) - Add proper SLE(G)_CONDNULL macros for the empty space reservation in savegames and update where used
Darkvater
parents:
3183
diff
changeset
|
2880 |
// reserve extra space in savegame here. (currently 32 bytes) |
6de22e06a1e9
(svn r3895) - Add proper SLE(G)_CONDNULL macros for the empty space reservation in savegames and update where used
Darkvater
parents:
3183
diff
changeset
|
2881 |
SLE_CONDNULL(32, 2, SL_MAX_VERSION), |
0 | 2882 |
|
2883 |
SLE_END() |
|
2884 |
}; |
|
2885 |
||
1881
435d39bd6ee0
(svn r2387) - CodeChange: made the saveload code more readable and also removed the 'byte' saveload arrays which means you can save an array of more than 255 elements, or bigger structs than 255 bytes. This doesn't yet solve the problem that a chunk can be a maximum of 16384 big.
Darkvater
parents:
1876
diff
changeset
|
2886 |
static const SaveLoad _goods_desc[] = { |
4344
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
2887 |
SLE_VAR(GoodsEntry, waiting_acceptance, SLE_UINT16), |
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
2888 |
SLE_VAR(GoodsEntry, days_since_pickup, SLE_UINT8), |
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
2889 |
SLE_VAR(GoodsEntry, rating, SLE_UINT8), |
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
2890 |
SLE_CONDVAR(GoodsEntry, enroute_from, SLE_FILE_U8 | SLE_VAR_U16, 0, 6), |
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
2891 |
SLE_CONDVAR(GoodsEntry, enroute_from, SLE_UINT16, 7, SL_MAX_VERSION), |
5683
b027e5d5b4cd
(svn r8144) -Fix: [FS#163] When a station is removed, vehicles do not get excessive payment any longer, as the origin TILE is now stored as long as the origin STATION for the transported cargos. Basically this is only a temporary fix until cargopackets are implemented, but it fixes one of the oldest known bugs (Special Thanks to Darkvater for lots of testing)
celestar
parents:
5679
diff
changeset
|
2892 |
SLE_CONDVAR(GoodsEntry, enroute_from_xy, SLE_UINT32, 44, SL_MAX_VERSION), |
4344
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
2893 |
SLE_VAR(GoodsEntry, enroute_time, SLE_UINT8), |
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
2894 |
SLE_VAR(GoodsEntry, last_speed, SLE_UINT8), |
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
2895 |
SLE_VAR(GoodsEntry, last_age, SLE_UINT8), |
7e123fec5b0b
(svn r6045) -Cleanup: align all table-like structures using spaces, i.e. whitespace fixes only except for a few comments to make them uniform for the whole enum/struct.
rubidium
parents:
4326
diff
changeset
|
2896 |
SLE_CONDVAR(GoodsEntry, feeder_profit, SLE_INT32, 14, SL_MAX_VERSION), |
0 | 2897 |
|
2898 |
SLE_END() |
|
2899 |
}; |
|
2900 |
||
3765
a4ddbff73f9f
(svn r4757) - Newstations: add saveload support for custom station speclists
peter1138
parents:
3763
diff
changeset
|
2901 |
static const SaveLoad _station_speclist_desc[] = { |
a4ddbff73f9f
(svn r4757) - Newstations: add saveload support for custom station speclists
peter1138
parents:
3763
diff
changeset
|
2902 |
SLE_CONDVAR(StationSpecList, grfid, SLE_UINT32, 27, SL_MAX_VERSION), |
a4ddbff73f9f
(svn r4757) - Newstations: add saveload support for custom station speclists
peter1138
parents:
3763
diff
changeset
|
2903 |
SLE_CONDVAR(StationSpecList, localidx, SLE_UINT8, 27, SL_MAX_VERSION), |
a4ddbff73f9f
(svn r4757) - Newstations: add saveload support for custom station speclists
peter1138
parents:
3763
diff
changeset
|
2904 |
|
a4ddbff73f9f
(svn r4757) - Newstations: add saveload support for custom station speclists
peter1138
parents:
3763
diff
changeset
|
2905 |
SLE_END() |
a4ddbff73f9f
(svn r4757) - Newstations: add saveload support for custom station speclists
peter1138
parents:
3763
diff
changeset
|
2906 |
}; |
a4ddbff73f9f
(svn r4757) - Newstations: add saveload support for custom station speclists
peter1138
parents:
3763
diff
changeset
|
2907 |
|
0 | 2908 |
|
2909 |
static void SaveLoad_STNS(Station *st) |
|
2910 |
{ |
|
3765
a4ddbff73f9f
(svn r4757) - Newstations: add saveload support for custom station speclists
peter1138
parents:
3763
diff
changeset
|
2911 |
uint i; |
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
2912 |
|
0 | 2913 |
SlObject(st, _station_desc); |
1266
eccd576e322f
(svn r1770) -Fix: Hopefully last pieces of code that are containing a station-id
truelight
parents:
1265
diff
changeset
|
2914 |
for (i = 0; i != NUM_CARGO; i++) { |
0 | 2915 |
SlObject(&st->goods[i], _goods_desc); |
1266
eccd576e322f
(svn r1770) -Fix: Hopefully last pieces of code that are containing a station-id
truelight
parents:
1265
diff
changeset
|
2916 |
|
eccd576e322f
(svn r1770) -Fix: Hopefully last pieces of code that are containing a station-id
truelight
parents:
1265
diff
changeset
|
2917 |
/* In older versions, enroute_from had 0xFF as INVALID_STATION, is now 0xFFFF */ |
2685
805a28b7c3b7
(svn r3227) -Codechange: [Savegame] removed 'minor' version, and renamed 'major' version to just: version.
truelight
parents:
2676
diff
changeset
|
2918 |
if (CheckSavegameVersion(7) && st->goods[i].enroute_from == 0xFF) { |
2469
59a0073914d8
(svn r2995) Replace 0xFF/0xFFFF with CT_INVALID/OWNER_SPECTATOR/INVALID_STATION where appropriate
tron
parents:
2436
diff
changeset
|
2919 |
st->goods[i].enroute_from = INVALID_STATION; |
2639 | 2920 |
} |
5697
ffd6ba312a67
(svn r8161) -Fix (FS#555, r8144): enroute_from_xy was not set properly for old savegames.
rubidium
parents:
5690
diff
changeset
|
2921 |
if (CheckSavegameVersion(44)) { |
ffd6ba312a67
(svn r8161) -Fix (FS#555, r8144): enroute_from_xy was not set properly for old savegames.
rubidium
parents:
5690
diff
changeset
|
2922 |
/* Store position of the station where the goods come from, so there are no |
ffd6ba312a67
(svn r8161) -Fix (FS#555, r8144): enroute_from_xy was not set properly for old savegames.
rubidium
parents:
5690
diff
changeset
|
2923 |
* very high payments when stations get removed. However, if the station |
ffd6ba312a67
(svn r8161) -Fix (FS#555, r8144): enroute_from_xy was not set properly for old savegames.
rubidium
parents:
5690
diff
changeset
|
2924 |
* where the goods came from is already removed, the source information is |
ffd6ba312a67
(svn r8161) -Fix (FS#555, r8144): enroute_from_xy was not set properly for old savegames.
rubidium
parents:
5690
diff
changeset
|
2925 |
* lost. In that case we set it to the position of this station */ |
ffd6ba312a67
(svn r8161) -Fix (FS#555, r8144): enroute_from_xy was not set properly for old savegames.
rubidium
parents:
5690
diff
changeset
|
2926 |
st->goods[i].enroute_from_xy = IsValidStationID(st->goods[i].enroute_from) ? GetStation(st->goods[i].enroute_from)->xy : st->xy; |
ffd6ba312a67
(svn r8161) -Fix (FS#555, r8144): enroute_from_xy was not set properly for old savegames.
rubidium
parents:
5690
diff
changeset
|
2927 |
} |
1266
eccd576e322f
(svn r1770) -Fix: Hopefully last pieces of code that are containing a station-id
truelight
parents:
1265
diff
changeset
|
2928 |
} |
3765
a4ddbff73f9f
(svn r4757) - Newstations: add saveload support for custom station speclists
peter1138
parents:
3763
diff
changeset
|
2929 |
|
a4ddbff73f9f
(svn r4757) - Newstations: add saveload support for custom station speclists
peter1138
parents:
3763
diff
changeset
|
2930 |
if (st->num_specs != 0) { |
a4ddbff73f9f
(svn r4757) - Newstations: add saveload support for custom station speclists
peter1138
parents:
3763
diff
changeset
|
2931 |
/* Allocate speclist memory when loading a game */ |
5609
dc6a58930ba4
(svn r8066) - Codechange: MallocT(), CallocT(), ReallocT() now return the pointer to allocated memory instead of modifying the pointer given as parameter
KUDr
parents:
5601
diff
changeset
|
2932 |
if (st->speclist == NULL) st->speclist = CallocT<StationSpecList>(st->num_specs); |
3765
a4ddbff73f9f
(svn r4757) - Newstations: add saveload support for custom station speclists
peter1138
parents:
3763
diff
changeset
|
2933 |
for (i = 0; i < st->num_specs; i++) SlObject(&st->speclist[i], _station_speclist_desc); |
a4ddbff73f9f
(svn r4757) - Newstations: add saveload support for custom station speclists
peter1138
parents:
3763
diff
changeset
|
2934 |
} |
0 | 2935 |
} |
2936 |
||
1093
4fdc46eaf423
(svn r1594) Convert all undefined parameter lists to (void) and add the appropriate warning flags in the Makefile
tron
parents:
1078
diff
changeset
|
2937 |
static void Save_STNS(void) |
0 | 2938 |
{ |
2939 |
Station *st; |
|
919
544f374ee392
(svn r1407) -Codechange: changed a lot around _stations, _vehicles, _towns and _industries
truelight
parents:
909
diff
changeset
|
2940 |
// Write the stations |
0 | 2941 |
FOR_ALL_STATIONS(st) { |
4346
66105d4f6e83
(svn r6047) -Codechange: FOR_ALL now _only_ loops valid items, and skips invalid ones
truelight
parents:
4344
diff
changeset
|
2942 |
SlSetArrayIndex(st->index); |
66105d4f6e83
(svn r6047) -Codechange: FOR_ALL now _only_ loops valid items, and skips invalid ones
truelight
parents:
4344
diff
changeset
|
2943 |
SlAutolength((AutolengthProc*)SaveLoad_STNS, st); |
0 | 2944 |
} |
2945 |
} |
|
2946 |
||
1093
4fdc46eaf423
(svn r1594) Convert all undefined parameter lists to (void) and add the appropriate warning flags in the Makefile
tron
parents:
1078
diff
changeset
|
2947 |
static void Load_STNS(void) |
0 | 2948 |
{ |
2949 |
int index; |
|
2950 |
while ((index = SlIterateArray()) != -1) { |
|
5665
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
2951 |
Station *st = new (index) Station(); |
d6b5c720ad67
(svn r8125) -Codechange: Station is now constructed/destroyed using new/delete operators (don't worry, they still use the same memory pool). Few station related functions turned into Station::methods (just first step). All this new stuff moved from station_cmd.cpp to the new file (station.cpp).
KUDr
parents:
5660
diff
changeset
|
2952 |
|
0 | 2953 |
SaveLoad_STNS(st); |
2954 |
||
2955 |
// this means it's an oldstyle savegame without support for nonuniform stations |
|
2639 | 2956 |
if (st->train_tile != 0 && st->trainst_h == 0) { |
3033
9cba043eb38f
(svn r3613) Some more const, indentation, whitespace and similar stuff
tron
parents:
3032
diff
changeset
|
2957 |
uint w = GB(st->trainst_w, 4, 4); |
9cba043eb38f
(svn r3613) Some more const, indentation, whitespace and similar stuff
tron
parents:
3032
diff
changeset
|
2958 |
uint h = GB(st->trainst_w, 0, 4); |
9cba043eb38f
(svn r3613) Some more const, indentation, whitespace and similar stuff
tron
parents:
3032
diff
changeset
|
2959 |
|
3334
2999d2ddc0f9
(svn r4113) Moved all relevant map functions for stations to station_map.[ch]
celestar
parents:
3333
diff
changeset
|
2960 |
if (GetRailStationAxis(st->train_tile) == AXIS_Y) uintswap(w, h); |
0 | 2961 |
st->trainst_w = w; |
2962 |
st->trainst_h = h; |
|
2963 |
} |
|
2964 |
} |
|
919
544f374ee392
(svn r1407) -Codechange: changed a lot around _stations, _vehicles, _towns and _industries
truelight
parents:
909
diff
changeset
|
2965 |
|
1472
a2abe3b9d7a7
(svn r1976) Cleanups - mostly indentation and fiddling with loops
tron
parents:
1457
diff
changeset
|
2966 |
/* This is to ensure all pointers are within the limits of _stations_size */ |
5247
1f982de55b88
(svn r7372) - CodeChange: Rename all GetXXXArraySize() functions to GetNumXXX() and add GetMaxXXXIndex() functions. This prepares for the new pool interface.
matthijs
parents:
5220
diff
changeset
|
2967 |
if (_station_tick_ctr > GetMaxStationIndex()) _station_tick_ctr = 0; |
0 | 2968 |
} |
2969 |
||
2549 | 2970 |
static void Save_ROADSTOP(void) |
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
2971 |
{ |
1284
e1969eb0227b
(svn r1788) -Add: Made RoadStops dynamic. You can now create up to 64k roadstops.
truelight
parents:
1272
diff
changeset
|
2972 |
RoadStop *rs; |
e1969eb0227b
(svn r1788) -Add: Made RoadStops dynamic. You can now create up to 64k roadstops.
truelight
parents:
1272
diff
changeset
|
2973 |
|
e1969eb0227b
(svn r1788) -Add: Made RoadStops dynamic. You can now create up to 64k roadstops.
truelight
parents:
1272
diff
changeset
|
2974 |
FOR_ALL_ROADSTOPS(rs) { |
4346
66105d4f6e83
(svn r6047) -Codechange: FOR_ALL now _only_ loops valid items, and skips invalid ones
truelight
parents:
4344
diff
changeset
|
2975 |
SlSetArrayIndex(rs->index); |
66105d4f6e83
(svn r6047) -Codechange: FOR_ALL now _only_ loops valid items, and skips invalid ones
truelight
parents:
4344
diff
changeset
|
2976 |
SlObject(rs, _roadstop_desc); |
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
2977 |
} |
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
2978 |
} |
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
2979 |
|
2549 | 2980 |
static void Load_ROADSTOP(void) |
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
2981 |
{ |
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
2982 |
int index; |
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
2983 |
|
1284
e1969eb0227b
(svn r1788) -Add: Made RoadStops dynamic. You can now create up to 64k roadstops.
truelight
parents:
1272
diff
changeset
|
2984 |
while ((index = SlIterateArray()) != -1) { |
5716 | 2985 |
RoadStop *rs = new (index) RoadStop(INVALID_TILE); |
5708
4c4c5ec2bed6
(svn r8185) -Codechange: Equipped Roadstops with new/delete operators and gave them proper constructors/destructors (Thanks to KUDr for a nice interactive C++ lesson)
celestar
parents:
5697
diff
changeset
|
2986 |
|
1284
e1969eb0227b
(svn r1788) -Add: Made RoadStops dynamic. You can now create up to 64k roadstops.
truelight
parents:
1272
diff
changeset
|
2987 |
SlObject(rs, _roadstop_desc); |
e1969eb0227b
(svn r1788) -Add: Made RoadStops dynamic. You can now create up to 64k roadstops.
truelight
parents:
1272
diff
changeset
|
2988 |
} |
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
2989 |
} |
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
2990 |
|
5587
167d9a91ef02
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
rubidium
parents:
5584
diff
changeset
|
2991 |
extern const ChunkHandler _station_chunk_handlers[] = { |
1217
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
2992 |
{ 'STNS', Save_STNS, Load_STNS, CH_ARRAY }, |
59c024cfaf54
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1214
diff
changeset
|
2993 |
{ 'ROAD', Save_ROADSTOP, Load_ROADSTOP, CH_ARRAY | CH_LAST}, |
0 | 2994 |
}; |
5395
7727da322d66
(svn r7585) -Codechange: CheckStationSpreadOut() took too much CPU. Station rectangle is now maintained instead of calculating it each time by walking through whole map. Should help with the performance issue related to AIs trying to build road stops too often. (idea by Celestar)
KUDr
parents:
5385
diff
changeset
|
2995 |
|
7727da322d66
(svn r7585) -Codechange: CheckStationSpreadOut() took too much CPU. Station rectangle is now maintained instead of calculating it each time by walking through whole map. Should help with the performance issue related to AIs trying to build road stops too often. (idea by Celestar)
KUDr
parents:
5385
diff
changeset
|
2996 |