author | glx |
Fri, 22 Feb 2008 00:25:54 +0000 | |
branch | noai |
changeset 9732 | f8eb3e208514 |
parent 9724 | b39bc69bb2f2 |
child 9800 | ab08ca2a2018 |
permissions | -rw-r--r-- |
2186 | 1 |
/* $Id$ */ |
2 |
||
6449
e520244dc71e
(svn r8859) -Cleanup: doxygen changes. Mostly @files missing tags and a few comments style.
belugas
parents:
6338
diff
changeset
|
3 |
/** @file command.cpp */ |
e520244dc71e
(svn r8859) -Cleanup: doxygen changes. Mostly @files missing tags and a few comments style.
belugas
parents:
6338
diff
changeset
|
4 |
|
0 | 5 |
#include "stdafx.h" |
1891
92a3b0aa0946
(svn r2397) - CodeChange: rename all "ttd" files to "openttd" files.
Darkvater
parents:
1877
diff
changeset
|
6 |
#include "openttd.h" |
9599 | 7 |
#include "landscape.h" |
9723
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
rubidium
parents:
9722
diff
changeset
|
8 |
#include "tile_map.h" |
0 | 9 |
#include "gui.h" |
9723
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
rubidium
parents:
9722
diff
changeset
|
10 |
#include "command_func.h" |
5720
cc0ceeafaa55
(svn r7751) -Codechange: move network_* to a new network map. Furthermore move the low level network functions to network/core, so they can be reused by the masterserver and website-serverlist-updater.
rubidium
parents:
5067
diff
changeset
|
11 |
#include "network/network.h" |
2159
3b634157c3b2
(svn r2669) Shuffle some more stuff around to reduce dependencies
tron
parents:
1980
diff
changeset
|
12 |
#include "variables.h" |
4300
687a17c9c557
(svn r5946) -Add: merged the TGP branch to mainline. TGP adds:
truelight
parents:
4000
diff
changeset
|
13 |
#include "genworld.h" |
9703
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
14 |
#include "newgrf_storage.h" |
9723
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
rubidium
parents:
9722
diff
changeset
|
15 |
#include "strings_func.h" |
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
rubidium
parents:
9722
diff
changeset
|
16 |
#include "gfx_func.h" |
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
rubidium
parents:
9722
diff
changeset
|
17 |
#include "functions.h" |
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
rubidium
parents:
9722
diff
changeset
|
18 |
#include "town.h" |
9724
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
rubidium
parents:
9723
diff
changeset
|
19 |
#include "date_func.h" |
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
rubidium
parents:
9723
diff
changeset
|
20 |
#include "debug.h" |
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
rubidium
parents:
9723
diff
changeset
|
21 |
#include "player_func.h" |
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
rubidium
parents:
9723
diff
changeset
|
22 |
#include "player_base.h" |
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
rubidium
parents:
9723
diff
changeset
|
23 |
#include "signal_func.h" |
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
rubidium
parents:
9723
diff
changeset
|
24 |
|
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
rubidium
parents:
9723
diff
changeset
|
25 |
#include "table/strings.h" |
0 | 26 |
|
9703
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
27 |
const char *_cmd_text = NULL; |
9724
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
rubidium
parents:
9723
diff
changeset
|
28 |
StringID _error_message; |
1820
9b6458526480
(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:
1804
diff
changeset
|
29 |
|
9703
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
30 |
/** |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
31 |
* Helper macro to define the header of all command handler macros. |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
32 |
* |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
33 |
* This macro create the function header for a given command handler function, as |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
34 |
* all command handler functions got the parameters from the #CommandProc callback |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
35 |
* type. |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
36 |
* |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
37 |
* @param yyyy The desired function name of the new command handler function. |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
38 |
*/ |
9629 | 39 |
#define DEF_COMMAND(yyyy) CommandCost yyyy(TileIndex tile, uint32 flags, uint32 p1, uint32 p2) |
0 | 40 |
|
41 |
DEF_COMMAND(CmdBuildRailroadTrack); |
|
42 |
DEF_COMMAND(CmdRemoveRailroadTrack); |
|
43 |
DEF_COMMAND(CmdBuildSingleRail); |
|
44 |
DEF_COMMAND(CmdRemoveSingleRail); |
|
45 |
||
46 |
DEF_COMMAND(CmdLandscapeClear); |
|
47 |
||
48 |
DEF_COMMAND(CmdBuildBridge); |
|
49 |
||
50 |
DEF_COMMAND(CmdBuildRailroadStation); |
|
51 |
DEF_COMMAND(CmdRemoveFromRailroadStation); |
|
52 |
DEF_COMMAND(CmdConvertRail); |
|
53 |
||
1227
3552f20fcfcb
(svn r1731) - Fix: [ 1106930 ] BugFix: placing signals with 2x1 drags workaround is completely rewritten. Also features checks for hacked/modified clients. Thanks a lot Hackykid!
darkvater
parents:
1217
diff
changeset
|
54 |
DEF_COMMAND(CmdBuildSingleSignal); |
3552f20fcfcb
(svn r1731) - Fix: [ 1106930 ] BugFix: placing signals with 2x1 drags workaround is completely rewritten. Also features checks for hacked/modified clients. Thanks a lot Hackykid!
darkvater
parents:
1217
diff
changeset
|
55 |
DEF_COMMAND(CmdRemoveSingleSignal); |
0 | 56 |
|
57 |
DEF_COMMAND(CmdTerraformLand); |
|
58 |
||
59 |
DEF_COMMAND(CmdPurchaseLandArea); |
|
60 |
DEF_COMMAND(CmdSellLandArea); |
|
61 |
||
62 |
DEF_COMMAND(CmdBuildTunnel); |
|
63 |
||
64 |
DEF_COMMAND(CmdBuildTrainDepot); |
|
395
4c990f33dab7
(svn r587) -newgrf: Rename all /Checkpoint/i tokens to 'Waypoint's. The name actually makes some sense and is also compatible with TTDPatch (pasky).
darkvater
parents:
215
diff
changeset
|
65 |
DEF_COMMAND(CmdBuildTrainWaypoint); |
4c990f33dab7
(svn r587) -newgrf: Rename all /Checkpoint/i tokens to 'Waypoint's. The name actually makes some sense and is also compatible with TTDPatch (pasky).
darkvater
parents:
215
diff
changeset
|
66 |
DEF_COMMAND(CmdRenameWaypoint); |
4c990f33dab7
(svn r587) -newgrf: Rename all /Checkpoint/i tokens to 'Waypoint's. The name actually makes some sense and is also compatible with TTDPatch (pasky).
darkvater
parents:
215
diff
changeset
|
67 |
DEF_COMMAND(CmdRemoveTrainWaypoint); |
0 | 68 |
|
1217
ab9f02a224ab
(svn r1721) -Feature: It is now possible to build multiple road stations (up to 8) on
celestar
parents:
1093
diff
changeset
|
69 |
DEF_COMMAND(CmdBuildRoadStop); |
6338
0fb4f452873c
(svn r8735) -Feature: drive-through road stops made possible by the hard work of mart3p.
rubidium
parents:
5838
diff
changeset
|
70 |
DEF_COMMAND(CmdRemoveRoadStop); |
0 | 71 |
|
72 |
DEF_COMMAND(CmdBuildLongRoad); |
|
73 |
DEF_COMMAND(CmdRemoveLongRoad); |
|
74 |
DEF_COMMAND(CmdBuildRoad); |
|
75 |
DEF_COMMAND(CmdRemoveRoad); |
|
76 |
||
77 |
DEF_COMMAND(CmdBuildRoadDepot); |
|
78 |
||
79 |
DEF_COMMAND(CmdBuildAirport); |
|
80 |
||
81 |
DEF_COMMAND(CmdBuildDock); |
|
82 |
||
83 |
DEF_COMMAND(CmdBuildShipDepot); |
|
84 |
||
85 |
DEF_COMMAND(CmdBuildBuoy); |
|
86 |
||
87 |
DEF_COMMAND(CmdPlantTree); |
|
88 |
||
89 |
DEF_COMMAND(CmdBuildRailVehicle); |
|
90 |
DEF_COMMAND(CmdMoveRailVehicle); |
|
91 |
||
92 |
DEF_COMMAND(CmdStartStopTrain); |
|
93 |
||
94 |
DEF_COMMAND(CmdSellRailWagon); |
|
95 |
||
1794
44f9deff97ed
(svn r2298) - CodeChange: removed CmdAbuses: CmdSetTownNameType(), CmdStartNewGame(), CmdCreateScenario(), CmdSetNewLandscapeType() and CmdGenRandomNewGame().
Darkvater
parents:
1786
diff
changeset
|
96 |
DEF_COMMAND(CmdSendTrainToDepot); |
0 | 97 |
DEF_COMMAND(CmdForceTrainProceed); |
98 |
DEF_COMMAND(CmdReverseTrainDirection); |
|
99 |
||
100 |
DEF_COMMAND(CmdModifyOrder); |
|
9626 | 101 |
DEF_COMMAND(CmdSkipToOrder); |
0 | 102 |
DEF_COMMAND(CmdDeleteOrder); |
103 |
DEF_COMMAND(CmdInsertOrder); |
|
2819
710436dd4288
(svn r3367) Unify the 4 distinct CMD_CHANGE_{AIRCRAFT,ROADVEH,SHIP,TRAIN}_SERVICE_INT commands into one CMD_CHANGE_SERVICE_INT command.
tron
parents:
2809
diff
changeset
|
104 |
DEF_COMMAND(CmdChangeServiceInt); |
0 | 105 |
DEF_COMMAND(CmdRestoreOrderIndex); |
106 |
||
107 |
DEF_COMMAND(CmdBuildIndustry); |
|
108 |
||
109 |
DEF_COMMAND(CmdBuildCompanyHQ); |
|
110 |
DEF_COMMAND(CmdSetPlayerFace); |
|
111 |
DEF_COMMAND(CmdSetPlayerColor); |
|
112 |
||
113 |
DEF_COMMAND(CmdIncreaseLoan); |
|
114 |
DEF_COMMAND(CmdDecreaseLoan); |
|
115 |
||
116 |
DEF_COMMAND(CmdWantEnginePreview); |
|
117 |
||
118 |
DEF_COMMAND(CmdNameVehicle); |
|
119 |
DEF_COMMAND(CmdRenameEngine); |
|
120 |
||
121 |
DEF_COMMAND(CmdChangeCompanyName); |
|
122 |
DEF_COMMAND(CmdChangePresidentName); |
|
123 |
||
124 |
DEF_COMMAND(CmdRenameStation); |
|
125 |
||
126 |
DEF_COMMAND(CmdSellAircraft); |
|
127 |
DEF_COMMAND(CmdStartStopAircraft); |
|
128 |
DEF_COMMAND(CmdBuildAircraft); |
|
129 |
DEF_COMMAND(CmdSendAircraftToHangar); |
|
130 |
DEF_COMMAND(CmdRefitAircraft); |
|
131 |
||
132 |
DEF_COMMAND(CmdPlaceSign); |
|
133 |
DEF_COMMAND(CmdRenameSign); |
|
134 |
||
135 |
DEF_COMMAND(CmdBuildRoadVeh); |
|
136 |
DEF_COMMAND(CmdStartStopRoadVeh); |
|
137 |
DEF_COMMAND(CmdSellRoadVeh); |
|
138 |
DEF_COMMAND(CmdSendRoadVehToDepot); |
|
139 |
DEF_COMMAND(CmdTurnRoadVeh); |
|
3990
d3d23f3bcd34
(svn r5191) - NewGRF: add cargo refit support for road vehicles
peter1138
parents:
3491
diff
changeset
|
140 |
DEF_COMMAND(CmdRefitRoadVeh); |
0 | 141 |
|
142 |
DEF_COMMAND(CmdPause); |
|
143 |
||
144 |
DEF_COMMAND(CmdBuyShareInCompany); |
|
145 |
DEF_COMMAND(CmdSellShareInCompany); |
|
146 |
DEF_COMMAND(CmdBuyCompany); |
|
147 |
||
148 |
DEF_COMMAND(CmdBuildTown); |
|
149 |
||
150 |
DEF_COMMAND(CmdRenameTown); |
|
151 |
DEF_COMMAND(CmdDoTownAction); |
|
152 |
||
153 |
DEF_COMMAND(CmdSetRoadDriveSide); |
|
154 |
||
155 |
DEF_COMMAND(CmdChangeDifficultyLevel); |
|
543
e3b43338096b
(svn r942) -Merged branch/network back into the trunk
truelight
parents:
534
diff
changeset
|
156 |
DEF_COMMAND(CmdChangePatchSetting); |
0 | 157 |
|
158 |
DEF_COMMAND(CmdStartStopShip); |
|
159 |
DEF_COMMAND(CmdSellShip); |
|
160 |
DEF_COMMAND(CmdBuildShip); |
|
161 |
DEF_COMMAND(CmdSendShipToDepot); |
|
162 |
DEF_COMMAND(CmdRefitShip); |
|
163 |
||
4712
273ec3b182bf
(svn r6624) -Feature: added ability to add refit commands to vehicle orders (can only be done in goto depot orders)
bjarni
parents:
4662
diff
changeset
|
164 |
DEF_COMMAND(CmdOrderRefit); |
0 | 165 |
DEF_COMMAND(CmdCloneOrder); |
166 |
||
167 |
DEF_COMMAND(CmdClearArea); |
|
168 |
||
543
e3b43338096b
(svn r942) -Merged branch/network back into the trunk
truelight
parents:
534
diff
changeset
|
169 |
DEF_COMMAND(CmdGiveMoney); |
0 | 170 |
DEF_COMMAND(CmdMoneyCheat); |
171 |
DEF_COMMAND(CmdBuildCanal); |
|
147
d0c8100d18cf
(svn r148) -Feature: Company HQ can now be moved somewhere else (cost 1% of company value). Water floods HQ.
darkvater
parents:
58
diff
changeset
|
172 |
DEF_COMMAND(CmdBuildLock); |
0 | 173 |
|
174 |
DEF_COMMAND(CmdPlayerCtrl); |
|
175 |
||
176 |
DEF_COMMAND(CmdLevelLand); |
|
177 |
||
178 |
DEF_COMMAND(CmdRefitRailVehicle); |
|
179 |
||
1227
3552f20fcfcb
(svn r1731) - Fix: [ 1106930 ] BugFix: placing signals with 2x1 drags workaround is completely rewritten. Also features checks for hacked/modified clients. Thanks a lot Hackykid!
darkvater
parents:
1217
diff
changeset
|
180 |
DEF_COMMAND(CmdBuildSignalTrack); |
3552f20fcfcb
(svn r1731) - Fix: [ 1106930 ] BugFix: placing signals with 2x1 drags workaround is completely rewritten. Also features checks for hacked/modified clients. Thanks a lot Hackykid!
darkvater
parents:
1217
diff
changeset
|
181 |
DEF_COMMAND(CmdRemoveSignalTrack); |
58
b9fdcc9b5c90
(svn r59) -Feature: Added Autosignals, just like Autorail. Can copy signal style, convert signal<->semaphore, etc. Big thanks to betatesters Dribbel and Testman57 (Darkvater)
darkvater
parents:
0
diff
changeset
|
182 |
|
4661
59492734db06
(svn r6544) - Codechange: Rename CmdReplaceVehicle to CmdSetAutoReplace, to reflect what it does.
peter1138
parents:
4659
diff
changeset
|
183 |
DEF_COMMAND(CmdSetAutoReplace); |
812
79c99885ad00
(svn r1283) -Add: AutoRenew is now a client-side patch instead of a game-side patch
truelight
parents:
679
diff
changeset
|
184 |
|
2244 | 185 |
DEF_COMMAND(CmdCloneVehicle); |
4640
cabffc571e55
(svn r6515) -Feature: added "start all" and "stop all" buttons to the depot windows
bjarni
parents:
4300
diff
changeset
|
186 |
DEF_COMMAND(CmdMassStartStopVehicle); |
4659
2f99f35d5813
(svn r6542) -Feature: [depot window] added a "sell all vehicles in depot" button
bjarni
parents:
4640
diff
changeset
|
187 |
DEF_COMMAND(CmdDepotSellAllVehicles); |
4662
a20121e5442b
(svn r6552) -Feature: [depot window] added a "autoreplace all vehicles in depot" button
bjarni
parents:
4661
diff
changeset
|
188 |
DEF_COMMAND(CmdDepotMassAutoReplace); |
2244 | 189 |
|
9624 | 190 |
DEF_COMMAND(CmdCreateGroup); |
191 |
DEF_COMMAND(CmdRenameGroup); |
|
192 |
DEF_COMMAND(CmdDeleteGroup); |
|
193 |
DEF_COMMAND(CmdAddVehicleGroup); |
|
194 |
DEF_COMMAND(CmdAddSharedVehicleGroup); |
|
195 |
DEF_COMMAND(CmdRemoveAllVehiclesGroup); |
|
196 |
DEF_COMMAND(CmdSetGroupReplaceProtection); |
|
197 |
||
9626 | 198 |
DEF_COMMAND(CmdMoveOrder); |
9629 | 199 |
DEF_COMMAND(CmdChangeTimetable); |
200 |
DEF_COMMAND(CmdSetVehicleOnTime); |
|
201 |
DEF_COMMAND(CmdAutofillTimetable); |
|
9703
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
202 |
#undef DEF_COMMAND |
1804
7810fc0aa941
(svn r2308) - Fix: enforce server-only and/or offline commands by giving them flags in the process table. This also fixes bug "[ 1190944 ] Many commands not checked for security"
Darkvater
parents:
1802
diff
changeset
|
203 |
|
9703
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
204 |
/** |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
205 |
* The master command table |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
206 |
* |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
207 |
* This table contains all possible CommandProc functions with |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
208 |
* the flags which belongs to it. The indizes are the same |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
209 |
* as the value from the CMD_* enums. |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
210 |
*/ |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
211 |
static const Command _command_proc_table[] = { |
9732 | 212 |
{CmdBuildRailroadTrack, CMD_AUTO}, /* CMD_BUILD_RAILROAD_TRACK */ |
213 |
{CmdRemoveRailroadTrack, CMD_AUTO}, /* CMD_REMOVE_RAILROAD_TRACK */ |
|
214 |
{CmdBuildSingleRail, CMD_AUTO}, /* CMD_BUILD_SINGLE_RAIL */ |
|
215 |
{CmdRemoveSingleRail, CMD_AUTO}, /* CMD_REMOVE_SINGLE_RAIL */ |
|
216 |
{CmdLandscapeClear, 0}, /* CMD_LANDSCAPE_CLEAR */ |
|
217 |
{CmdBuildBridge, CMD_AUTO}, /* CMD_BUILD_BRIDGE */ |
|
218 |
{CmdBuildRailroadStation, CMD_AUTO}, /* CMD_BUILD_RAILROAD_STATION */ |
|
219 |
{CmdBuildTrainDepot, CMD_AUTO}, /* CMD_BUILD_TRAIN_DEPOT */ |
|
220 |
{CmdBuildSingleSignal, CMD_AUTO}, /* CMD_BUILD_SIGNALS */ |
|
221 |
{CmdRemoveSingleSignal, CMD_AUTO}, /* CMD_REMOVE_SIGNALS */ |
|
222 |
{CmdTerraformLand, CMD_AUTO}, /* CMD_TERRAFORM_LAND */ |
|
223 |
{CmdPurchaseLandArea, CMD_AUTO}, /* CMD_PURCHASE_LAND_AREA */ |
|
224 |
{CmdSellLandArea, 0}, /* CMD_SELL_LAND_AREA */ |
|
225 |
{CmdBuildTunnel, CMD_AUTO}, /* CMD_BUILD_TUNNEL */ |
|
226 |
{CmdRemoveFromRailroadStation, 0}, /* CMD_REMOVE_FROM_RAILROAD_STATION */ |
|
227 |
{CmdConvertRail, 0}, /* CMD_CONVERT_RAILD */ |
|
228 |
{CmdBuildTrainWaypoint, 0}, /* CMD_BUILD_TRAIN_WAYPOINT */ |
|
229 |
{CmdRenameWaypoint, 0}, /* CMD_RENAME_WAYPOINT */ |
|
230 |
{CmdRemoveTrainWaypoint, 0}, /* CMD_REMOVE_TRAIN_WAYPOINT */ |
|
9703
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
231 |
|
9732 | 232 |
{CmdBuildRoadStop, CMD_AUTO}, /* CMD_BUILD_ROAD_STOP */ |
233 |
{CmdRemoveRoadStop, 0}, /* CMD_REMOVE_ROAD_STOP */ |
|
234 |
{CmdBuildLongRoad, CMD_AUTO}, /* CMD_BUILD_LONG_ROAD */ |
|
235 |
{CmdRemoveLongRoad, CMD_AUTO}, /* CMD_REMOVE_LONG_ROAD */ |
|
236 |
{CmdBuildRoad, 0}, /* CMD_BUILD_ROAD */ |
|
237 |
{CmdRemoveRoad, 0}, /* CMD_REMOVE_ROAD */ |
|
238 |
{CmdBuildRoadDepot, CMD_AUTO}, /* CMD_BUILD_ROAD_DEPOT */ |
|
9703
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
239 |
|
9732 | 240 |
{CmdBuildAirport, CMD_AUTO}, /* CMD_BUILD_AIRPORT */ |
241 |
{CmdBuildDock, CMD_AUTO}, /* CMD_BUILD_DOCK */ |
|
242 |
{CmdBuildShipDepot, CMD_AUTO}, /* CMD_BUILD_SHIP_DEPOT */ |
|
243 |
{CmdBuildBuoy, CMD_AUTO}, /* CMD_BUILD_BUOY */ |
|
244 |
{CmdPlantTree, CMD_AUTO}, /* CMD_PLANT_TREE */ |
|
245 |
{CmdBuildRailVehicle, 0}, /* CMD_BUILD_RAIL_VEHICLE */ |
|
246 |
{CmdMoveRailVehicle, 0}, /* CMD_MOVE_RAIL_VEHICLE */ |
|
247 |
{CmdStartStopTrain, 0}, /* CMD_START_STOP_TRAIN */ |
|
9703
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
248 |
|
9732 | 249 |
{CmdSellRailWagon, 0}, /* CMD_SELL_RAIL_WAGON */ |
250 |
{CmdSendTrainToDepot, 0}, /* CMD_SEND_TRAIN_TO_DEPOT */ |
|
251 |
{CmdForceTrainProceed, 0}, /* CMD_FORCE_TRAIN_PROCEED */ |
|
252 |
{CmdReverseTrainDirection, 0}, /* CMD_REVERSE_TRAIN_DIRECTION */ |
|
253 |
||
254 |
{CmdModifyOrder, 0}, /* CMD_MODIFY_ORDER */ |
|
255 |
{CmdSkipToOrder, 0}, /* CMD_SKIP_TO_ORDER */ |
|
256 |
{CmdDeleteOrder, 0}, /* CMD_DELETE_ORDER */ |
|
257 |
{CmdInsertOrder, 0}, /* CMD_INSERT_ORDER */ |
|
258 |
||
259 |
{CmdChangeServiceInt, 0}, /* CMD_CHANGE_SERVICE_INT */ |
|
260 |
||
261 |
{CmdBuildIndustry, 0}, /* CMD_BUILD_INDUSTRY */ |
|
262 |
{CmdBuildCompanyHQ, CMD_AUTO}, /* CMD_BUILD_COMPANY_HQ */ |
|
263 |
{CmdSetPlayerFace, 0}, /* CMD_SET_PLAYER_FACE */ |
|
264 |
{CmdSetPlayerColor, 0}, /* CMD_SET_PLAYER_COLOR */ |
|
265 |
||
266 |
{CmdIncreaseLoan, 0}, /* CMD_INCREASE_LOAN */ |
|
267 |
{CmdDecreaseLoan, 0}, /* CMD_DECREASE_LOAN */ |
|
268 |
||
269 |
{CmdWantEnginePreview, 0}, /* CMD_WANT_ENGINE_PREVIEW */ |
|
270 |
||
271 |
{CmdNameVehicle, 0}, /* CMD_NAME_VEHICLE */ |
|
272 |
{CmdRenameEngine, 0}, /* CMD_RENAME_ENGINE */ |
|
273 |
||
274 |
{CmdChangeCompanyName, 0}, /* CMD_CHANGE_COMPANY_NAME */ |
|
275 |
{CmdChangePresidentName, 0}, /* CMD_CHANGE_PRESIDENT_NAME */ |
|
276 |
||
277 |
{CmdRenameStation, 0}, /* CMD_RENAME_STATION */ |
|
278 |
||
279 |
{CmdSellAircraft, 0}, /* CMD_SELL_AIRCRAFT */ |
|
280 |
{CmdStartStopAircraft, 0}, /* CMD_START_STOP_AIRCRAFT */ |
|
281 |
||
282 |
{CmdBuildAircraft, 0}, /* CMD_BUILD_AIRCRAFT */ |
|
283 |
{CmdSendAircraftToHangar, 0}, /* CMD_SEND_AIRCRAFT_TO_HANGAR */ |
|
284 |
{CmdRefitAircraft, 0}, /* CMD_REFIT_AIRCRAFT */ |
|
285 |
||
286 |
{CmdPlaceSign, 0}, /* CMD_PLACE_SIGN */ |
|
287 |
{CmdRenameSign, 0}, /* CMD_RENAME_SIGN */ |
|
288 |
||
289 |
{CmdBuildRoadVeh, 0}, /* CMD_BUILD_ROAD_VEH */ |
|
290 |
{CmdStartStopRoadVeh, 0}, /* CMD_START_STOP_ROADVEH */ |
|
291 |
{CmdSellRoadVeh, 0}, /* CMD_SELL_ROAD_VEH */ |
|
292 |
{CmdSendRoadVehToDepot, 0}, /* CMD_SEND_ROADVEH_TO_DEPOT */ |
|
293 |
{CmdTurnRoadVeh, 0}, /* CMD_TURN_ROADVEH */ |
|
294 |
{CmdRefitRoadVeh, 0}, /* CMD_REFIT_ROAD_VEH */ |
|
295 |
||
296 |
{CmdPause, CMD_SERVER}, /* CMD_PAUSE */ |
|
297 |
||
298 |
{CmdBuyShareInCompany, 0}, /* CMD_BUY_SHARE_IN_COMPANY */ |
|
299 |
{CmdSellShareInCompany, 0}, /* CMD_SELL_SHARE_IN_COMPANY */ |
|
300 |
{CmdBuyCompany, 0}, /* CMD_BUY_COMANY */ |
|
301 |
||
302 |
{CmdBuildTown, CMD_OFFLINE}, /* CMD_BUILD_TOWN */ |
|
303 |
{CmdRenameTown, CMD_SERVER}, /* CMD_RENAME_TOWN */ |
|
304 |
{CmdDoTownAction, 0}, /* CMD_DO_TOWN_ACTION */ |
|
305 |
||
306 |
{CmdSetRoadDriveSide, CMD_SERVER}, /* CMD_SET_ROAD_DRIVE_SIDE */ |
|
307 |
{CmdChangeDifficultyLevel, CMD_SERVER}, /* CMD_CHANGE_DIFFICULTY_LEVEL */ |
|
308 |
||
309 |
{CmdStartStopShip, 0}, /* CMD_START_STOP_SHIP */ |
|
310 |
{CmdSellShip, 0}, /* CMD_SELL_SHIP */ |
|
311 |
{CmdBuildShip, 0}, /* CMD_BUILD_SHIP */ |
|
312 |
{CmdSendShipToDepot, 0}, /* CMD_SEND_SHIP_TO_DEPOT */ |
|
313 |
{CmdRefitShip, 0}, /* CMD_REFIT_SHIP */ |
|
314 |
||
315 |
{CmdOrderRefit, 0}, /* CMD_ORDER_REFIT */ |
|
316 |
{CmdCloneOrder, 0}, /* CMD_CLONE_ORDER */ |
|
317 |
||
318 |
{CmdClearArea, 0}, /* CMD_CLEAR_AREA */ |
|
319 |
||
320 |
{CmdMoneyCheat, CMD_OFFLINE}, /* CMD_MONEY_CHEAT */ |
|
321 |
{CmdBuildCanal, CMD_AUTO}, /* CMD_BUILD_CANAL */ |
|
322 |
{CmdPlayerCtrl, 0}, /* CMD_PLAYER_CTRL */ |
|
323 |
||
324 |
{CmdLevelLand, CMD_AUTO}, /* CMD_LEVEL_LAND */ |
|
325 |
||
326 |
{CmdRefitRailVehicle, 0}, /* CMD_REFIT_RAIL_VEHICLE */ |
|
327 |
{CmdRestoreOrderIndex, 0}, /* CMD_RESTORE_ORDER_INDEX */ |
|
328 |
{CmdBuildLock, CMD_AUTO}, /* CMD_BUILD_LOCK */ |
|
329 |
||
330 |
{CmdBuildSignalTrack, CMD_AUTO}, /* CMD_BUILD_SIGNAL_TRACK */ |
|
331 |
{CmdRemoveSignalTrack, CMD_AUTO}, /* CMD_REMOVE_SIGNAL_TRACK */ |
|
332 |
||
333 |
{CmdGiveMoney, 0}, /* CMD_GIVE_MONEY */ |
|
334 |
{CmdChangePatchSetting, CMD_SERVER}, /* CMD_CHANGE_PATCH_SETTING */ |
|
335 |
{CmdSetAutoReplace, 0}, /* CMD_SET_AUTOREPLACE */ |
|
336 |
{CmdCloneVehicle, 0}, /* CMD_CLONE_VEHICLE */ |
|
337 |
{CmdMassStartStopVehicle, 0}, /* CMD_MASS_START_STOP */ |
|
338 |
{CmdDepotSellAllVehicles, 0}, /* CMD_DEPOT_SELL_ALL_VEHICLES */ |
|
339 |
{CmdDepotMassAutoReplace, 0}, /* CMD_DEPOT_MASS_AUTOREPLACE */ |
|
340 |
{CmdCreateGroup, 0}, /* CMD_CREATE_GROUP */ |
|
341 |
{CmdDeleteGroup, 0}, /* CMD_DELETE_GROUP */ |
|
342 |
{CmdRenameGroup, 0}, /* CMD_RENAME_GROUP */ |
|
343 |
{CmdAddVehicleGroup, 0}, /* CMD_ADD_VEHICLE_GROUP */ |
|
344 |
{CmdAddSharedVehicleGroup, 0}, /* CMD_ADD_SHARE_VEHICLE_GROUP */ |
|
345 |
{CmdRemoveAllVehiclesGroup, 0}, /* CMD_REMOVE_ALL_VEHICLES_GROUP */ |
|
346 |
{CmdSetGroupReplaceProtection, 0}, /* CMD_SET_GROUP_REPLACE_PROTECTION */ |
|
347 |
{CmdMoveOrder, 0}, /* CMD_MOVE_ORDER */ |
|
348 |
{CmdChangeTimetable, 0}, /* CMD_CHANGE_TIMETABLE */ |
|
349 |
{CmdSetVehicleOnTime, 0}, /* CMD_SET_VEHICLE_ON_TIME */ |
|
350 |
{CmdAutofillTimetable, 0}, /* CMD_AUTOFILL_TIMETABLE */ |
|
0 | 351 |
}; |
352 |
||
9703
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
353 |
/*! |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
354 |
* This function range-checks a cmd, and checks if the cmd is not NULL |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
355 |
* |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
356 |
* @param cmd The integervalue of a command |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
357 |
* @return true if the command is valid (and got a CommandProc function) |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
358 |
*/ |
959
b031d88c76f3
(svn r1451) Fix some of the signed/unsigned comparison warnings
tron
parents:
926
diff
changeset
|
359 |
bool IsValidCommand(uint cmd) |
903
f860c7234167
(svn r1389) -Add: [Network] Added packet protection. No longer a client or server
truelight
parents:
889
diff
changeset
|
360 |
{ |
2645
964bd8fe3ce2
(svn r3187) Simplify overly complicated ifs, especially if (foo) return false; else return true; is confusing
tron
parents:
2425
diff
changeset
|
361 |
cmd &= 0xFF; |
903
f860c7234167
(svn r1389) -Add: [Network] Added packet protection. No longer a client or server
truelight
parents:
889
diff
changeset
|
362 |
|
2645
964bd8fe3ce2
(svn r3187) Simplify overly complicated ifs, especially if (foo) return false; else return true; is confusing
tron
parents:
2425
diff
changeset
|
363 |
return |
964bd8fe3ce2
(svn r3187) Simplify overly complicated ifs, especially if (foo) return false; else return true; is confusing
tron
parents:
2425
diff
changeset
|
364 |
cmd < lengthof(_command_proc_table) && |
964bd8fe3ce2
(svn r3187) Simplify overly complicated ifs, especially if (foo) return false; else return true; is confusing
tron
parents:
2425
diff
changeset
|
365 |
_command_proc_table[cmd].proc != NULL; |
903
f860c7234167
(svn r1389) -Add: [Network] Added packet protection. No longer a client or server
truelight
parents:
889
diff
changeset
|
366 |
} |
f860c7234167
(svn r1389) -Add: [Network] Added packet protection. No longer a client or server
truelight
parents:
889
diff
changeset
|
367 |
|
9703
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
368 |
/*! |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
369 |
* This function mask the parameter with 0xFF and returns |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
370 |
* the flags which belongs to the given command. |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
371 |
* |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
372 |
* @param cmd The integer value of the command |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
373 |
* @return The flags for this command |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
374 |
* @bug integervalues which are less equals 0xFF and greater than the |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
375 |
* size of _command_proc_table can result in an index out of bounce |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
376 |
* error (which doesn't happend anyway). Check function #IsValidCommand(). (Progman) |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
377 |
*/ |
4000
bab1ebc37da0
(svn r5210) Many small changes which piled up: const, unsigned, variable scope, CSE for readability, DeMorgan, if cascades -> switch, whitespace, parentheses, bracing, misc.
tron
parents:
3991
diff
changeset
|
378 |
byte GetCommandFlags(uint cmd) |
bab1ebc37da0
(svn r5210) Many small changes which piled up: const, unsigned, variable scope, CSE for readability, DeMorgan, if cascades -> switch, whitespace, parentheses, bracing, misc.
tron
parents:
3991
diff
changeset
|
379 |
{ |
bab1ebc37da0
(svn r5210) Many small changes which piled up: const, unsigned, variable scope, CSE for readability, DeMorgan, if cascades -> switch, whitespace, parentheses, bracing, misc.
tron
parents:
3991
diff
changeset
|
380 |
return _command_proc_table[cmd & 0xFF].flags; |
bab1ebc37da0
(svn r5210) Many small changes which piled up: const, unsigned, variable scope, CSE for readability, DeMorgan, if cascades -> switch, whitespace, parentheses, bracing, misc.
tron
parents:
3991
diff
changeset
|
381 |
} |
1804
7810fc0aa941
(svn r2308) - Fix: enforce server-only and/or offline commands by giving them flags in the process table. This also fixes bug "[ 1190944 ] Many commands not checked for security"
Darkvater
parents:
1802
diff
changeset
|
382 |
|
9723
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
rubidium
parents:
9722
diff
changeset
|
383 |
static int _docommand_recursive = 0; |
2304
f3309898aeb0
(svn r2828) Only command.c needs to know about _docommand_recursive, so make it static. Tell me if there's a problem, because i removed it from network_server.c, but afaict it should be ok
tron
parents:
2244
diff
changeset
|
384 |
|
9703
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
385 |
/*! |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
386 |
* This function executes a given command with the parameters from the #CommandProc parameter list. |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
387 |
* Depending on the flags parameter it execute or test a command. |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
388 |
* |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
389 |
* @param tile The tile to apply the command on (for the #CommandProc) |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
390 |
* @param p1 Additional data for the command (for the #CommandProc) |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
391 |
* @param p2 Additional data for the command (for the #CommandProc) |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
392 |
* @param flags Flags for the command and how to execute the command |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
393 |
* @param procc The command-id to execute (a value of the CMD_* enums) |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
394 |
* @see CommandProc |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
395 |
*/ |
9723
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
rubidium
parents:
9722
diff
changeset
|
396 |
CommandCost DoCommand(TileIndex tile, uint32 p1, uint32 p2, uint32 flags, uint32 procc) |
0 | 397 |
{ |
9629 | 398 |
CommandCost res; |
0 | 399 |
CommandProc *proc; |
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
147
diff
changeset
|
400 |
|
1776
fa776997bba2
(svn r2280) - Fix: Check if the passed tile to DoCommand is within the current mapsize
Darkvater
parents:
1728
diff
changeset
|
401 |
/* Do not even think about executing out-of-bounds tile-commands */ |
9624 | 402 |
if (tile >= MapSize() || IsTileType(tile, MP_VOID)) { |
1820
9b6458526480
(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:
1804
diff
changeset
|
403 |
_cmd_text = NULL; |
9b6458526480
(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:
1804
diff
changeset
|
404 |
return CMD_ERROR; |
9b6458526480
(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:
1804
diff
changeset
|
405 |
} |
1776
fa776997bba2
(svn r2280) - Fix: Check if the passed tile to DoCommand is within the current mapsize
Darkvater
parents:
1728
diff
changeset
|
406 |
|
1804
7810fc0aa941
(svn r2308) - Fix: enforce server-only and/or offline commands by giving them flags in the process table. This also fixes bug "[ 1190944 ] Many commands not checked for security"
Darkvater
parents:
1802
diff
changeset
|
407 |
proc = _command_proc_table[procc].proc; |
0 | 408 |
|
2749
46aba09ca365
(svn r3294) - Fix: use INVALID_STRING_ID instead of -1.
Darkvater
parents:
2715
diff
changeset
|
409 |
if (_docommand_recursive == 0) _error_message = INVALID_STRING_ID; |
0 | 410 |
|
411 |
_docommand_recursive++; |
|
412 |
||
6449
e520244dc71e
(svn r8859) -Cleanup: doxygen changes. Mostly @files missing tags and a few comments style.
belugas
parents:
6338
diff
changeset
|
413 |
/* only execute the test call if it's toplevel, or we're not execing. */ |
9732 | 414 |
if (_docommand_recursive == 1 || !(flags & DC_EXEC) ) { |
9723
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
rubidium
parents:
9722
diff
changeset
|
415 |
SetTownRatingTestMode(true); |
3491
4c8427796c64
(svn r4342) Change the first two parameters of commands - virtual pixel coordinates of the tile to operate on - to a TileIndex
tron
parents:
3421
diff
changeset
|
416 |
res = proc(tile, flags & ~DC_EXEC, p1, p2); |
9723
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
rubidium
parents:
9722
diff
changeset
|
417 |
SetTownRatingTestMode(false); |
1691
fcd9fefaed02
(svn r2195) Add CmdFailed() as the One True Way(tm) to check if a command failed.
tron
parents:
1623
diff
changeset
|
418 |
if (CmdFailed(res)) { |
9629 | 419 |
res.SetGlobalErrorMessage(); |
0 | 420 |
goto error; |
421 |
} |
|
422 |
||
4000
bab1ebc37da0
(svn r5210) Many small changes which piled up: const, unsigned, variable scope, CSE for readability, DeMorgan, if cascades -> switch, whitespace, parentheses, bracing, misc.
tron
parents:
3991
diff
changeset
|
423 |
if (_docommand_recursive == 1 && |
bab1ebc37da0
(svn r5210) Many small changes which piled up: const, unsigned, variable scope, CSE for readability, DeMorgan, if cascades -> switch, whitespace, parentheses, bracing, misc.
tron
parents:
3991
diff
changeset
|
424 |
!(flags & DC_QUERY_COST) && |
9732 | 425 |
!(flags & DC_BANKRUPT) && |
9629 | 426 |
res.GetCost() != 0 && |
4000
bab1ebc37da0
(svn r5210) Many small changes which piled up: const, unsigned, variable scope, CSE for readability, DeMorgan, if cascades -> switch, whitespace, parentheses, bracing, misc.
tron
parents:
3991
diff
changeset
|
427 |
!CheckPlayerHasMoney(res)) { |
bab1ebc37da0
(svn r5210) Many small changes which piled up: const, unsigned, variable scope, CSE for readability, DeMorgan, if cascades -> switch, whitespace, parentheses, bracing, misc.
tron
parents:
3991
diff
changeset
|
428 |
goto error; |
0 | 429 |
} |
430 |
||
431 |
if (!(flags & DC_EXEC)) { |
|
432 |
_docommand_recursive--; |
|
1820
9b6458526480
(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:
1804
diff
changeset
|
433 |
_cmd_text = NULL; |
0 | 434 |
return res; |
435 |
} |
|
436 |
} |
|
437 |
||
889
7f8630bfea41
(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:
842
diff
changeset
|
438 |
/* Execute the command here. All cost-relevant functions set the expenses type |
9723
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
rubidium
parents:
9722
diff
changeset
|
439 |
* themselves to the cost object at some point */ |
3491
4c8427796c64
(svn r4342) Change the first two parameters of commands - virtual pixel coordinates of the tile to operate on - to a TileIndex
tron
parents:
3421
diff
changeset
|
440 |
res = proc(tile, flags, p1, p2); |
1691
fcd9fefaed02
(svn r2195) Add CmdFailed() as the One True Way(tm) to check if a command failed.
tron
parents:
1623
diff
changeset
|
441 |
if (CmdFailed(res)) { |
9629 | 442 |
res.SetGlobalErrorMessage(); |
0 | 443 |
error: |
444 |
_docommand_recursive--; |
|
1820
9b6458526480
(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:
1804
diff
changeset
|
445 |
_cmd_text = NULL; |
0 | 446 |
return CMD_ERROR; |
447 |
} |
|
448 |
||
6449
e520244dc71e
(svn r8859) -Cleanup: doxygen changes. Mostly @files missing tags and a few comments style.
belugas
parents:
6338
diff
changeset
|
449 |
/* if toplevel, subtract the money. */ |
9732 | 450 |
if (--_docommand_recursive == 0 && !(flags & DC_BANKRUPT)) { |
0 | 451 |
SubtractMoneyFromPlayer(res); |
6449
e520244dc71e
(svn r8859) -Cleanup: doxygen changes. Mostly @files missing tags and a few comments style.
belugas
parents:
6338
diff
changeset
|
452 |
/* XXX - Old AI hack which doesn't use DoCommandDP; update last build coord of player */ |
4850
b4e9be22945f
(svn r6776) -Codechange: Use IsValidPlayer() function to determine of a PlayerID is an
Darkvater
parents:
4848
diff
changeset
|
453 |
if (tile != 0 && IsValidPlayer(_current_player)) { |
3491
4c8427796c64
(svn r4342) Change the first two parameters of commands - virtual pixel coordinates of the tile to operate on - to a TileIndex
tron
parents:
3421
diff
changeset
|
454 |
GetPlayer(_current_player)->last_build_coordinate = tile; |
2772
96e47991fd1d
(svn r3319) - Fix (regression): "Unnamed Competitors". A result of revision r3224 which allowed AI's for multiplayer. Old AI's didn't function correctly anymore. The update of last-built tile is moved back, but to a slightly different place so it is only executed when the command is actually successfully executed. This code shouldn't be neccessary, but alas, the old AI doesn't use DoCommandDP() functions.
Darkvater
parents:
2767
diff
changeset
|
455 |
} |
0 | 456 |
} |
457 |
||
1820
9b6458526480
(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:
1804
diff
changeset
|
458 |
_cmd_text = NULL; |
0 | 459 |
return res; |
460 |
} |
|
461 |
||
9703
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
462 |
/*! |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
463 |
* This functions returns the money which can be used to execute a command. |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
464 |
* This is either the money of the current player or INT64_MAX if there |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
465 |
* is no such a player "at the moment" like the server itself. |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
466 |
* |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
467 |
* @return The available money of a player or INT64_MAX |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
468 |
*/ |
9629 | 469 |
Money GetAvailableMoneyForCommand() |
0 | 470 |
{ |
1794
44f9deff97ed
(svn r2298) - CodeChange: removed CmdAbuses: CmdSetTownNameType(), CmdStartNewGame(), CmdCreateScenario(), CmdSetNewLandscapeType() and CmdGenRandomNewGame().
Darkvater
parents:
1786
diff
changeset
|
471 |
PlayerID pid = _current_player; |
9629 | 472 |
if (!IsValidPlayer(pid)) return INT64_MAX; |
1962
51ee4f459268
(svn r2468) -Codechange: Got rid of DEREF_PLAYER and replaced it by GetPlayer
celestar
parents:
1891
diff
changeset
|
473 |
return GetPlayer(pid)->player_money; |
0 | 474 |
} |
475 |
||
9703
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
476 |
/*! |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
477 |
* Toplevel network safe docommand function for the current player. Must not be called recursively. |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
478 |
* The callback is called when the command succeeded or failed. The parameters |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
479 |
* tile, p1 and p2 are from the #CommandProc function. The paramater cmd is the command to execute. |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
480 |
* The parameter my_cmd is used to indicate if the command is from a player or the server. |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
481 |
* |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
482 |
* @param tile The tile to perform a command on (see #CommandProc) |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
483 |
* @param p1 Additional data for the command (see #CommandProc) |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
484 |
* @param p2 Additional data for the command (see #CommandProc) |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
485 |
* @param callback A callback function to call after the command is finished |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
486 |
* @param cmd The command to execute (a CMD_* value) |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
487 |
* @param my_cmd indicator if the command is from a player or server (to display error messages for a user) |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
488 |
* @return true if the command succeeded, else false |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
489 |
*/ |
9641
855e32c08c9b
(svn r10533) [NoAI] -Sync with trunk r10460:r10532.
truelight
parents:
9629
diff
changeset
|
490 |
bool DoCommandP(TileIndex tile, uint32 p1, uint32 p2, CommandCallback *callback, uint32 cmd, bool my_cmd) |
0 | 491 |
{ |
9629 | 492 |
CommandCost res, res2; |
0 | 493 |
CommandProc *proc; |
494 |
uint32 flags; |
|
495 |
bool notest; |
|
3182
0f1161388ea1
(svn r3827) Remove the global variable _error_message_2, it's only used as local variable
tron
parents:
2820
diff
changeset
|
496 |
StringID error_part1; |
0 | 497 |
|
3421
8ab76c47c72c
(svn r4246) -Codechange. Replaced about 100 occurences of '16' by TILE_SIZE
celestar
parents:
3182
diff
changeset
|
498 |
int x = TileX(tile) * TILE_SIZE; |
8ab76c47c72c
(svn r4246) -Codechange. Replaced about 100 occurences of '16' by TILE_SIZE
celestar
parents:
3182
diff
changeset
|
499 |
int y = TileY(tile) * TILE_SIZE; |
0 | 500 |
|
1776
fa776997bba2
(svn r2280) - Fix: Check if the passed tile to DoCommand is within the current mapsize
Darkvater
parents:
1728
diff
changeset
|
501 |
/* Do not even think about executing out-of-bounds tile-commands */ |
9624 | 502 |
if (tile >= MapSize() || IsTileType(tile, MP_VOID)) { |
1820
9b6458526480
(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:
1804
diff
changeset
|
503 |
_cmd_text = NULL; |
9b6458526480
(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:
1804
diff
changeset
|
504 |
return false; |
9b6458526480
(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:
1804
diff
changeset
|
505 |
} |
1776
fa776997bba2
(svn r2280) - Fix: Check if the passed tile to DoCommand is within the current mapsize
Darkvater
parents:
1728
diff
changeset
|
506 |
|
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
147
diff
changeset
|
507 |
assert(_docommand_recursive == 0); |
0 | 508 |
|
509 |
_error_message = INVALID_STRING_ID; |
|
3182
0f1161388ea1
(svn r3827) Remove the global variable _error_message_2, it's only used as local variable
tron
parents:
2820
diff
changeset
|
510 |
error_part1 = GB(cmd, 16, 16); |
0 | 511 |
_additional_cash_required = 0; |
512 |
||
5067
870dfdcef898
(svn r7125) -Fix: Several errors/glitches related to multiplayer and bankrupcy, mainly such a
Darkvater
parents:
4850
diff
changeset
|
513 |
/** Spectator has no rights except for the (dedicated) server which |
870dfdcef898
(svn r7125) -Fix: Several errors/glitches related to multiplayer and bankrupcy, mainly such a
Darkvater
parents:
4850
diff
changeset
|
514 |
* is/can be a spectator but as the server it can do anything */ |
870dfdcef898
(svn r7125) -Fix: Several errors/glitches related to multiplayer and bankrupcy, mainly such a
Darkvater
parents:
4850
diff
changeset
|
515 |
if (_current_player == PLAYER_SPECTATOR && !_network_server) { |
9641
855e32c08c9b
(svn r10533) [NoAI] -Sync with trunk r10460:r10532.
truelight
parents:
9629
diff
changeset
|
516 |
if (my_cmd) ShowErrorMessage(_error_message, error_part1, x, y); |
1820
9b6458526480
(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:
1804
diff
changeset
|
517 |
_cmd_text = NULL; |
0 | 518 |
return false; |
519 |
} |
|
520 |
||
521 |
flags = 0; |
|
522 |
if (cmd & CMD_NO_WATER) flags |= DC_NO_WATER; |
|
523 |
||
6449
e520244dc71e
(svn r8859) -Cleanup: doxygen changes. Mostly @files missing tags and a few comments style.
belugas
parents:
6338
diff
changeset
|
524 |
/* get pointer to command handler */ |
0 | 525 |
assert((cmd & 0xFF) < lengthof(_command_proc_table)); |
1804
7810fc0aa941
(svn r2308) - Fix: enforce server-only and/or offline commands by giving them flags in the process table. This also fixes bug "[ 1190944 ] Many commands not checked for security"
Darkvater
parents:
1802
diff
changeset
|
526 |
proc = _command_proc_table[cmd & 0xFF].proc; |
1877
e7318705dd04
(svn r2383) - Fix: Monkey-testing turned up some command crashes.
Darkvater
parents:
1838
diff
changeset
|
527 |
if (proc == NULL) { |
e7318705dd04
(svn r2383) - Fix: Monkey-testing turned up some command crashes.
Darkvater
parents:
1838
diff
changeset
|
528 |
_cmd_text = NULL; |
e7318705dd04
(svn r2383) - Fix: Monkey-testing turned up some command crashes.
Darkvater
parents:
1838
diff
changeset
|
529 |
return false; |
e7318705dd04
(svn r2383) - Fix: Monkey-testing turned up some command crashes.
Darkvater
parents:
1838
diff
changeset
|
530 |
} |
0 | 531 |
|
9703
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
532 |
if (GetCommandFlags(cmd) & CMD_AUTO) flags |= DC_AUTO; |
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
533 |
|
6449
e520244dc71e
(svn r8859) -Cleanup: doxygen changes. Mostly @files missing tags and a few comments style.
belugas
parents:
6338
diff
changeset
|
534 |
/* Some commands have a different output in dryrun than the realrun |
e520244dc71e
(svn r8859) -Cleanup: doxygen changes. Mostly @files missing tags and a few comments style.
belugas
parents:
6338
diff
changeset
|
535 |
* e.g.: if you demolish a whole town, the dryrun would say okay. |
e520244dc71e
(svn r8859) -Cleanup: doxygen changes. Mostly @files missing tags and a few comments style.
belugas
parents:
6338
diff
changeset
|
536 |
* but by really destroying, your rating drops and at a certain point |
e520244dc71e
(svn r8859) -Cleanup: doxygen changes. Mostly @files missing tags and a few comments style.
belugas
parents:
6338
diff
changeset
|
537 |
* it will fail. so res and res2 are different |
9723
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
rubidium
parents:
9722
diff
changeset
|
538 |
* CMD_REMOVE_LONG_ROAD: This command has special local authority |
6449
e520244dc71e
(svn r8859) -Cleanup: doxygen changes. Mostly @files missing tags and a few comments style.
belugas
parents:
6338
diff
changeset
|
539 |
* restrictions which may cause the test run to fail (the previous |
e520244dc71e
(svn r8859) -Cleanup: doxygen changes. Mostly @files missing tags and a few comments style.
belugas
parents:
6338
diff
changeset
|
540 |
* road fragments still stay there and the town won't let you |
e520244dc71e
(svn r8859) -Cleanup: doxygen changes. Mostly @files missing tags and a few comments style.
belugas
parents:
6338
diff
changeset
|
541 |
* disconnect the road system), but the exec will succeed and this |
9620
31e38d28a0af
(svn r9816) [NoAI] -Sync with trunk r9712:9815 except r9759 (MorphOS threading) because that needs special attention.
rubidium
parents:
9601
diff
changeset
|
542 |
* fact will trigger an assertion failure. --pasky |
31e38d28a0af
(svn r9816) [NoAI] -Sync with trunk r9712:9815 except r9759 (MorphOS threading) because that needs special attention.
rubidium
parents:
9601
diff
changeset
|
543 |
* CMD_CLONE_VEHICLE: Both building new vehicles and refitting them can be |
31e38d28a0af
(svn r9816) [NoAI] -Sync with trunk r9712:9815 except r9759 (MorphOS threading) because that needs special attention.
rubidium
parents:
9601
diff
changeset
|
544 |
* influenced by newgrf callbacks, which makes it impossible to accurately |
31e38d28a0af
(svn r9816) [NoAI] -Sync with trunk r9712:9815 except r9759 (MorphOS threading) because that needs special attention.
rubidium
parents:
9601
diff
changeset
|
545 |
* estimate the cost of cloning a vehicle. */ |
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
147
diff
changeset
|
546 |
notest = |
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
147
diff
changeset
|
547 |
(cmd & 0xFF) == CMD_CLEAR_AREA || |
0 | 548 |
(cmd & 0xFF) == CMD_LEVEL_LAND || |
9620
31e38d28a0af
(svn r9816) [NoAI] -Sync with trunk r9712:9815 except r9759 (MorphOS threading) because that needs special attention.
rubidium
parents:
9601
diff
changeset
|
549 |
(cmd & 0xFF) == CMD_REMOVE_LONG_ROAD || |
31e38d28a0af
(svn r9816) [NoAI] -Sync with trunk r9712:9815 except r9759 (MorphOS threading) because that needs special attention.
rubidium
parents:
9601
diff
changeset
|
550 |
(cmd & 0xFF) == CMD_CLONE_VEHICLE; |
0 | 551 |
|
552 |
_docommand_recursive = 1; |
|
553 |
||
6449
e520244dc71e
(svn r8859) -Cleanup: doxygen changes. Mostly @files missing tags and a few comments style.
belugas
parents:
6338
diff
changeset
|
554 |
/* cost estimation only? */ |
5831
de5f05e20ae9
(svn r8027) -Fix (FS#486) If a pause command is issues, it will now pause the game even if shift is pressed instead of giving a cost estimate of 0. This fixes a problem where the server does not pause_on_join when the player on the interactive server has the shift button pressed. (Thanks to pvz for the report and the fix)
celestar
parents:
5726
diff
changeset
|
555 |
if (!IsGeneratingWorld() && |
de5f05e20ae9
(svn r8027) -Fix (FS#486) If a pause command is issues, it will now pause the game even if shift is pressed instead of giving a cost estimate of 0. This fixes a problem where the server does not pause_on_join when the player on the interactive server has the shift button pressed. (Thanks to pvz for the report and the fix)
celestar
parents:
5726
diff
changeset
|
556 |
_shift_pressed && |
de5f05e20ae9
(svn r8027) -Fix (FS#486) If a pause command is issues, it will now pause the game even if shift is pressed instead of giving a cost estimate of 0. This fixes a problem where the server does not pause_on_join when the player on the interactive server has the shift button pressed. (Thanks to pvz for the report and the fix)
celestar
parents:
5726
diff
changeset
|
557 |
IsLocalPlayer() && |
de5f05e20ae9
(svn r8027) -Fix (FS#486) If a pause command is issues, it will now pause the game even if shift is pressed instead of giving a cost estimate of 0. This fixes a problem where the server does not pause_on_join when the player on the interactive server has the shift button pressed. (Thanks to pvz for the report and the fix)
celestar
parents:
5726
diff
changeset
|
558 |
!(cmd & (CMD_NETWORK_COMMAND | CMD_SHOW_NO_ERROR)) && |
de5f05e20ae9
(svn r8027) -Fix (FS#486) If a pause command is issues, it will now pause the game even if shift is pressed instead of giving a cost estimate of 0. This fixes a problem where the server does not pause_on_join when the player on the interactive server has the shift button pressed. (Thanks to pvz for the report and the fix)
celestar
parents:
5726
diff
changeset
|
559 |
(cmd & 0xFF) != CMD_PAUSE) { |
6449
e520244dc71e
(svn r8859) -Cleanup: doxygen changes. Mostly @files missing tags and a few comments style.
belugas
parents:
6338
diff
changeset
|
560 |
/* estimate the cost. */ |
9724
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
rubidium
parents:
9723
diff
changeset
|
561 |
SetTownRatingTestMode(true); |
3491
4c8427796c64
(svn r4342) Change the first two parameters of commands - virtual pixel coordinates of the tile to operate on - to a TileIndex
tron
parents:
3421
diff
changeset
|
562 |
res = proc(tile, flags, p1, p2); |
9724
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
rubidium
parents:
9723
diff
changeset
|
563 |
SetTownRatingTestMode(false); |
1691
fcd9fefaed02
(svn r2195) Add CmdFailed() as the One True Way(tm) to check if a command failed.
tron
parents:
1623
diff
changeset
|
564 |
if (CmdFailed(res)) { |
9629 | 565 |
res.SetGlobalErrorMessage(); |
3182
0f1161388ea1
(svn r3827) Remove the global variable _error_message_2, it's only used as local variable
tron
parents:
2820
diff
changeset
|
566 |
ShowErrorMessage(_error_message, error_part1, x, y); |
0 | 567 |
} else { |
9629 | 568 |
ShowEstimatedCostOrIncome(res.GetCost(), x, y); |
0 | 569 |
} |
570 |
||
571 |
_docommand_recursive = 0; |
|
1820
9b6458526480
(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:
1804
diff
changeset
|
572 |
_cmd_text = NULL; |
9703
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
573 |
ClearStorageChanges(false); |
0 | 574 |
return false; |
575 |
} |
|
576 |
||
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
147
diff
changeset
|
577 |
|
543
e3b43338096b
(svn r942) -Merged branch/network back into the trunk
truelight
parents:
534
diff
changeset
|
578 |
if (!((cmd & CMD_NO_TEST_IF_IN_NETWORK) && _networking)) { |
6449
e520244dc71e
(svn r8859) -Cleanup: doxygen changes. Mostly @files missing tags and a few comments style.
belugas
parents:
6338
diff
changeset
|
579 |
/* first test if the command can be executed. */ |
9723
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
rubidium
parents:
9722
diff
changeset
|
580 |
SetTownRatingTestMode(true); |
3491
4c8427796c64
(svn r4342) Change the first two parameters of commands - virtual pixel coordinates of the tile to operate on - to a TileIndex
tron
parents:
3421
diff
changeset
|
581 |
res = proc(tile, flags, p1, p2); |
9723
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
rubidium
parents:
9722
diff
changeset
|
582 |
SetTownRatingTestMode(false); |
1691
fcd9fefaed02
(svn r2195) Add CmdFailed() as the One True Way(tm) to check if a command failed.
tron
parents:
1623
diff
changeset
|
583 |
if (CmdFailed(res)) { |
9629 | 584 |
res.SetGlobalErrorMessage(); |
0 | 585 |
goto show_error; |
586 |
} |
|
6449
e520244dc71e
(svn r8859) -Cleanup: doxygen changes. Mostly @files missing tags and a few comments style.
belugas
parents:
6338
diff
changeset
|
587 |
/* no money? Only check if notest is off */ |
9629 | 588 |
if (!notest && res.GetCost() != 0 && !CheckPlayerHasMoney(res)) goto show_error; |
0 | 589 |
} |
590 |
||
543
e3b43338096b
(svn r942) -Merged branch/network back into the trunk
truelight
parents:
534
diff
changeset
|
591 |
#ifdef ENABLE_NETWORK |
1838
522076c550c0
(svn r2343) - Fix (regression): dedicated server caused desyncs with its commands, because the player sent over the network is OWNER_SPECTATOR as well, which on clients cannot execute anything. So *hack*hack* it into temporarily player 0.
Darkvater
parents:
1834
diff
changeset
|
592 |
/** If we are in network, and the command is not from the network |
522076c550c0
(svn r2343) - Fix (regression): dedicated server caused desyncs with its commands, because the player sent over the network is OWNER_SPECTATOR as well, which on clients cannot execute anything. So *hack*hack* it into temporarily player 0.
Darkvater
parents:
1834
diff
changeset
|
593 |
* send it to the command-queue and abort execution |
522076c550c0
(svn r2343) - Fix (regression): dedicated server caused desyncs with its commands, because the player sent over the network is OWNER_SPECTATOR as well, which on clients cannot execute anything. So *hack*hack* it into temporarily player 0.
Darkvater
parents:
1834
diff
changeset
|
594 |
* If we are a dedicated server temporarily switch local player, otherwise |
522076c550c0
(svn r2343) - Fix (regression): dedicated server caused desyncs with its commands, because the player sent over the network is OWNER_SPECTATOR as well, which on clients cannot execute anything. So *hack*hack* it into temporarily player 0.
Darkvater
parents:
1834
diff
changeset
|
595 |
* the other parties won't be able to execute our command and will desync. |
5067
870dfdcef898
(svn r7125) -Fix: Several errors/glitches related to multiplayer and bankrupcy, mainly such a
Darkvater
parents:
4850
diff
changeset
|
596 |
* We also need to do this if the server's company has gone bankrupt |
870dfdcef898
(svn r7125) -Fix: Several errors/glitches related to multiplayer and bankrupcy, mainly such a
Darkvater
parents:
4850
diff
changeset
|
597 |
* @todo Rewrite (dedicated) server to something more than a dirty hack! |
1838
522076c550c0
(svn r2343) - Fix (regression): dedicated server caused desyncs with its commands, because the player sent over the network is OWNER_SPECTATOR as well, which on clients cannot execute anything. So *hack*hack* it into temporarily player 0.
Darkvater
parents:
1834
diff
changeset
|
598 |
*/ |
543
e3b43338096b
(svn r942) -Merged branch/network back into the trunk
truelight
parents:
534
diff
changeset
|
599 |
if (_networking && !(cmd & CMD_NETWORK_COMMAND)) { |
5067
870dfdcef898
(svn r7125) -Fix: Several errors/glitches related to multiplayer and bankrupcy, mainly such a
Darkvater
parents:
4850
diff
changeset
|
600 |
PlayerID pbck = _local_player; |
5838
9c3129cb019b
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
rubidium
parents:
5835
diff
changeset
|
601 |
if (_network_dedicated || (_network_server && pbck == PLAYER_SPECTATOR)) _local_player = PLAYER_FIRST; |
543
e3b43338096b
(svn r942) -Merged branch/network back into the trunk
truelight
parents:
534
diff
changeset
|
602 |
NetworkSend_Command(tile, p1, p2, cmd, callback); |
5067
870dfdcef898
(svn r7125) -Fix: Several errors/glitches related to multiplayer and bankrupcy, mainly such a
Darkvater
parents:
4850
diff
changeset
|
603 |
if (_network_dedicated || (_network_server && pbck == PLAYER_SPECTATOR)) _local_player = pbck; |
543
e3b43338096b
(svn r942) -Merged branch/network back into the trunk
truelight
parents:
534
diff
changeset
|
604 |
_docommand_recursive = 0; |
1820
9b6458526480
(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:
1804
diff
changeset
|
605 |
_cmd_text = NULL; |
9703
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
606 |
ClearStorageChanges(false); |
543
e3b43338096b
(svn r942) -Merged branch/network back into the trunk
truelight
parents:
534
diff
changeset
|
607 |
return true; |
0 | 608 |
} |
543
e3b43338096b
(svn r942) -Merged branch/network back into the trunk
truelight
parents:
534
diff
changeset
|
609 |
#endif /* ENABLE_NETWORK */ |
9724
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
rubidium
parents:
9723
diff
changeset
|
610 |
DebugDumpCommands("ddc:cmd:%d;%d;%d;%d;%d;%d;%d;%s\n", _date, _date_fract, (int)_current_player, tile, p1, p2, cmd, _cmd_text); |
0 | 611 |
|
6449
e520244dc71e
(svn r8859) -Cleanup: doxygen changes. Mostly @files missing tags and a few comments style.
belugas
parents:
6338
diff
changeset
|
612 |
/* update last build coordinate of player. */ |
4850
b4e9be22945f
(svn r6776) -Codechange: Use IsValidPlayer() function to determine of a PlayerID is an
Darkvater
parents:
4848
diff
changeset
|
613 |
if (tile != 0 && IsValidPlayer(_current_player)) { |
4000
bab1ebc37da0
(svn r5210) Many small changes which piled up: const, unsigned, variable scope, CSE for readability, DeMorgan, if cascades -> switch, whitespace, parentheses, bracing, misc.
tron
parents:
3991
diff
changeset
|
614 |
GetPlayer(_current_player)->last_build_coordinate = tile; |
bab1ebc37da0
(svn r5210) Many small changes which piled up: const, unsigned, variable scope, CSE for readability, DeMorgan, if cascades -> switch, whitespace, parentheses, bracing, misc.
tron
parents:
3991
diff
changeset
|
615 |
} |
0 | 616 |
|
889
7f8630bfea41
(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:
842
diff
changeset
|
617 |
/* Actually try and execute the command. If no cost-type is given |
7f8630bfea41
(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:
842
diff
changeset
|
618 |
* use the construction one */ |
4000
bab1ebc37da0
(svn r5210) Many small changes which piled up: const, unsigned, variable scope, CSE for readability, DeMorgan, if cascades -> switch, whitespace, parentheses, bracing, misc.
tron
parents:
3991
diff
changeset
|
619 |
res2 = proc(tile, flags | DC_EXEC, p1, p2); |
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
147
diff
changeset
|
620 |
|
6449
e520244dc71e
(svn r8859) -Cleanup: doxygen changes. Mostly @files missing tags and a few comments style.
belugas
parents:
6338
diff
changeset
|
621 |
/* If notest is on, it means the result of the test can be different than |
e520244dc71e
(svn r8859) -Cleanup: doxygen changes. Mostly @files missing tags and a few comments style.
belugas
parents:
6338
diff
changeset
|
622 |
* the real command.. so ignore the test */ |
652
0f553238c98a
(svn r1085) -Fix: [Network] [ 1084834 ] If IF_IN_NETWORK flag was on, an error
truelight
parents:
601
diff
changeset
|
623 |
if (!notest && !((cmd & CMD_NO_TEST_IF_IN_NETWORK) && _networking)) { |
9629 | 624 |
assert(res.GetCost() == res2.GetCost() && CmdFailed(res) == CmdFailed(res2)); // sanity check |
0 | 625 |
} else { |
1702
6402cfbb9772
(svn r2206) - Regression Fix: slight typo of res2 into res, this also fixes recent bug "[ 1183396 ] Train can't find depot, it gives money in Multiplayer"
Darkvater
parents:
1701
diff
changeset
|
626 |
if (CmdFailed(res2)) { |
9629 | 627 |
res.SetGlobalErrorMessage(); |
0 | 628 |
goto show_error; |
629 |
} |
|
630 |
} |
|
631 |
||
632 |
SubtractMoneyFromPlayer(res2); |
|
633 |
||
9724
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
rubidium
parents:
9723
diff
changeset
|
634 |
/* update signals if needed */ |
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
rubidium
parents:
9723
diff
changeset
|
635 |
UpdateSignalsInBuffer(); |
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
rubidium
parents:
9723
diff
changeset
|
636 |
|
2425
99e1e8430a28
(svn r2951) - Fix: [ 1259345 ] Changing engine in netgame opens train window for everyone
Darkvater
parents:
2304
diff
changeset
|
637 |
if (IsLocalPlayer() && _game_mode != GM_EDITOR) { |
9701
d1ac22c62f64
(svn r11036) [NoAI] -Sync: with trunk r10774:11035.
rubidium
parents:
9686
diff
changeset
|
638 |
if (res2.GetCost() != 0 && tile != 0) ShowCostOrIncomeAnimation(x, y, GetSlopeZ(x, y), res2.GetCost()); |
9629 | 639 |
if (_additional_cash_required != 0) { |
534
17ab2f22ff74
(svn r901) Small step in the process to clean up the DPARAM mess:
tron
parents:
507
diff
changeset
|
640 |
SetDParam(0, _additional_cash_required); |
9641
855e32c08c9b
(svn r10533) [NoAI] -Sync with trunk r10460:r10532.
truelight
parents:
9629
diff
changeset
|
641 |
if (my_cmd) ShowErrorMessage(STR_0003_NOT_ENOUGH_CASH_REQUIRES, error_part1, x, y); |
9629 | 642 |
if (res2.GetCost() == 0) goto callb_err; |
0 | 643 |
} |
644 |
} |
|
645 |
||
646 |
_docommand_recursive = 0; |
|
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
147
diff
changeset
|
647 |
|
0 | 648 |
if (callback) callback(true, tile, p1, p2); |
1820
9b6458526480
(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:
1804
diff
changeset
|
649 |
_cmd_text = NULL; |
9703
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
650 |
ClearStorageChanges(true); |
0 | 651 |
return true; |
652 |
||
653 |
show_error: |
|
6449
e520244dc71e
(svn r8859) -Cleanup: doxygen changes. Mostly @files missing tags and a few comments style.
belugas
parents:
6338
diff
changeset
|
654 |
/* show error message if the command fails? */ |
9641
855e32c08c9b
(svn r10533) [NoAI] -Sync with trunk r10460:r10532.
truelight
parents:
9629
diff
changeset
|
655 |
if (IsLocalPlayer() && error_part1 != 0 && my_cmd) { |
9601
b499fdd106d5
(svn r9713) [NoAI] -Sync with trunk (r9631:9712).
rubidium
parents:
9599
diff
changeset
|
656 |
ShowErrorMessage(_error_message, error_part1, x, y); |
3182
0f1161388ea1
(svn r3827) Remove the global variable _error_message_2, it's only used as local variable
tron
parents:
2820
diff
changeset
|
657 |
} |
0 | 658 |
|
659 |
callb_err: |
|
660 |
_docommand_recursive = 0; |
|
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
147
diff
changeset
|
661 |
|
0 | 662 |
if (callback) callback(false, tile, p1, p2); |
1820
9b6458526480
(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:
1804
diff
changeset
|
663 |
_cmd_text = NULL; |
9703
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
rubidium
parents:
9701
diff
changeset
|
664 |
ClearStorageChanges(false); |
0 | 665 |
return false; |
666 |
} |
|
9629 | 667 |
|
668 |
||
669 |
CommandCost CommandCost::AddCost(CommandCost ret) |
|
670 |
{ |
|
671 |
this->AddCost(ret.cost); |
|
672 |
if (this->success && !ret.success) { |
|
673 |
this->message = ret.message; |
|
674 |
this->success = false; |
|
675 |
} |
|
676 |
return *this; |
|
677 |
} |
|
678 |
||
679 |
CommandCost CommandCost::AddCost(Money cost) |
|
680 |
{ |
|
9722
ebf0ece7d8f6
(svn r11503) [NoAI] -Sync: with trunk r11308:11502.
rubidium
parents:
9703
diff
changeset
|
681 |
this->cost += cost; |
9629 | 682 |
return *this; |
683 |
} |
|
684 |
||
685 |
CommandCost CommandCost::MultiplyCost(int factor) |
|
686 |
{ |
|
9722
ebf0ece7d8f6
(svn r11503) [NoAI] -Sync: with trunk r11308:11502.
rubidium
parents:
9703
diff
changeset
|
687 |
this->cost *= factor; |
9629 | 688 |
return *this; |
689 |
} |
|
690 |
||
691 |
Money CommandCost::GetCost() const |
|
692 |
{ |
|
693 |
return this->cost; |
|
694 |
} |
|
695 |
||
9723
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
rubidium
parents:
9722
diff
changeset
|
696 |
ExpensesType CommandCost::GetExpensesType() const |
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
rubidium
parents:
9722
diff
changeset
|
697 |
{ |
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
rubidium
parents:
9722
diff
changeset
|
698 |
return this->expense_type; |
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
rubidium
parents:
9722
diff
changeset
|
699 |
} |
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
rubidium
parents:
9722
diff
changeset
|
700 |
|
9629 | 701 |
void CommandCost::SetGlobalErrorMessage() const |
702 |
{ |
|
703 |
extern StringID _error_message; |
|
704 |
if (this->message != INVALID_STRING_ID) _error_message = this->message; |
|
705 |
} |
|
706 |
||
707 |
bool CommandCost::Succeeded() const |
|
708 |
{ |
|
709 |
return this->success; |
|
710 |
} |
|
711 |
||
712 |
bool CommandCost::Failed() const |
|
713 |
{ |
|
714 |
return !this->success; |
|
715 |
} |