| author | peter1138 | 
| Wed, 11 Apr 2007 21:04:03 +0000 | |
| changeset 6947 | c21859ab4493 | 
| parent 6916 | e87d54a598ea | 
| child 6949 | 72d11a1e1e60 | 
| permissions | -rw-r--r-- | 
| 2186 | 1 | /* $Id$ */ | 
| 2 | ||
| 6916 
e87d54a598ea
(svn r9556) -Documentation: doxygen and comment-style changes. 'R', 'S'.. The end of the preliminary work is near
 belugas parents: 
6903diff
changeset | 3 | /** @file ship_cmd.cpp */ | 
| 
e87d54a598ea
(svn r9556) -Documentation: doxygen and comment-style changes. 'R', 'S'.. The end of the preliminary work is near
 belugas parents: 
6903diff
changeset | 4 | |
| 0 | 5 | #include "stdafx.h" | 
| 1891 
92a3b0aa0946
(svn r2397) - CodeChange: rename all "ttd" files to "openttd" files.
 Darkvater parents: 
1802diff
changeset | 6 | #include "openttd.h" | 
| 3961 
e2783f244ac6
(svn r5120) Add IsShipInDepot{Stopped,}() and remove some redundant checks
 tron parents: 
3955diff
changeset | 7 | #include "ship.h" | 
| 507 
8aa8100b0b22
(svn r815) Include strings.h only in the files which need it.
 tron parents: 
445diff
changeset | 8 | #include "table/strings.h" | 
| 2163 
637ec3c361f5
(svn r2673) Include functions.h directly, not globally via openttd.h
 tron parents: 
2159diff
changeset | 9 | #include "functions.h" | 
| 679 
e959706a3e4d
(svn r1117) Move map arrays and some related macros into their own files map.c and map.h
 tron parents: 
593diff
changeset | 10 | #include "map.h" | 
| 1209 
a1ac96655b79
(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: 
1206diff
changeset | 11 | #include "tile.h" | 
| 0 | 12 | #include "vehicle.h" | 
| 13 | #include "command.h" | |
| 14 | #include "pathfind.h" | |
| 3442 
c494e7246d7b
(svn r4272) -Codechange: Moved the map-accessing stuff from station.h into station_map.h
 celestar parents: 
3421diff
changeset | 15 | #include "station_map.h" | 
| 0 | 16 | #include "station.h" | 
| 17 | #include "news.h" | |
| 18 | #include "engine.h" | |
| 19 | #include "player.h" | |
| 337 
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
 tron parents: 
297diff
changeset | 20 | #include "sound.h" | 
| 1247 | 21 | #include "npf.h" | 
| 1313 
bba6afb8a995
(svn r1817) -Codechange: Moved depot-functions to depot.c
 truelight parents: 
1282diff
changeset | 22 | #include "depot.h" | 
| 2159 
3b634157c3b2
(svn r2669) Shuffle some more stuff around to reduce dependencies
 tron parents: 
2150diff
changeset | 23 | #include "vehicle_gui.h" | 
| 2962 
dbd168a4703a
(svn r3524) - Split newgrf features from engine.[ch] into newgrf_engine.[ch], and add the new files to project files.
 peter1138 parents: 
2916diff
changeset | 24 | #include "newgrf_engine.h" | 
| 3454 
c2447e8c1e23
(svn r4289) -Codechange: Make use of water_map accessors for ships. Make a mental note to clean ship_cmd
 celestar parents: 
3442diff
changeset | 25 | #include "water_map.h" | 
| 3900 
4984308f9125
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
 KUDr parents: 
3870diff
changeset | 26 | #include "yapf/yapf.h" | 
| 
4984308f9125
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
 KUDr parents: 
3870diff
changeset | 27 | #include "debug.h" | 
| 3989 
a5d50d90fd21
(svn r5188) - NewGRF: check refit capacity callback when refitting a ship
 peter1138 parents: 
3961diff
changeset | 28 | #include "newgrf_callbacks.h" | 
| 4244 
44dcec623504
(svn r5822) - NewGRF: add support for callback 31, vehicle start/stop check. This allows a set to disallow a vehicle from being started, i.e. to not be able to leave the depot. This is almost a partner to callback 1D.
 peter1138 parents: 
4242diff
changeset | 29 | #include "newgrf_text.h" | 
| 4656 
acffecd6f484
(svn r6532) - Feature: Add support for NewGRF sound effects. Currently sound priority isn't supported.
 peter1138 parents: 
4574diff
changeset | 30 | #include "newgrf_sound.h" | 
| 4261 
2ec8f5a9747b
(svn r5887) -Cleanup: move date related functions, defines and variables to date.[ch]
 rubidium parents: 
4244diff
changeset | 31 | #include "date.h" | 
| 6223 
92d2073c3d7e
(svn r8661) -Fix: [depot windows] Enlarge the blocks in the depot window if a sprite is too big to fit (ships and aircraft only)
 bjarni parents: 
6195diff
changeset | 32 | #include "spritecache.h" | 
| 0 | 33 | |
| 34 | static const uint16 _ship_sprites[] = {0x0E5D, 0x0E55, 0x0E65, 0x0E6D};
 | |
| 35 | ||
| 5838 
9c3129cb019b
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
 rubidium parents: 
5835diff
changeset | 36 | static const TrackBits _ship_sometracks[4] = {
 | 
| 
9c3129cb019b
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
 rubidium parents: 
5835diff
changeset | 37 | TRACK_BIT_X | TRACK_BIT_LOWER | TRACK_BIT_LEFT, // 0x19, // DIAGDIR_NE | 
| 
9c3129cb019b
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
 rubidium parents: 
5835diff
changeset | 38 | TRACK_BIT_Y | TRACK_BIT_UPPER | TRACK_BIT_LEFT, // 0x16, // DIAGDIR_SE | 
| 
9c3129cb019b
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
 rubidium parents: 
5835diff
changeset | 39 | TRACK_BIT_X | TRACK_BIT_UPPER | TRACK_BIT_RIGHT, // 0x25, // DIAGDIR_SW | 
| 
9c3129cb019b
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
 rubidium parents: 
5835diff
changeset | 40 | TRACK_BIT_Y | TRACK_BIT_LOWER | TRACK_BIT_RIGHT, // 0x2A, // DIAGDIR_NW | 
| 
9c3129cb019b
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
 rubidium parents: 
5835diff
changeset | 41 | }; | 
| 
9c3129cb019b
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
 rubidium parents: 
5835diff
changeset | 42 | |
| 
9c3129cb019b
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
 rubidium parents: 
5835diff
changeset | 43 | static TrackBits GetTileShipTrackStatus(TileIndex tile) | 
| 1977 
4392ae3d8e31
(svn r2483) Replace almost 500 "uint tile" (and variants) with "TileIndex tile"
 tron parents: 
1942diff
changeset | 44 | {
 | 
| 159 
139cf78bfb28
(svn r160) -Codechange: made GetTileTrackStatus more readable (blathijs)
 truelight parents: 
156diff
changeset | 45 | uint32 r = GetTileTrackStatus(tile, TRANSPORT_WATER); | 
| 5838 
9c3129cb019b
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
 rubidium parents: 
5835diff
changeset | 46 | return TrackdirBitsToTrackBits((TrackdirBits)(TRACKDIR_BIT_MASK & (r | r >> 8))); | 
| 0 | 47 | } | 
| 48 | ||
| 5919 
2b58160d667d
(svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
 peter1138 parents: 
5902diff
changeset | 49 | void DrawShipEngine(int x, int y, EngineID engine, SpriteID pal) | 
| 0 | 50 | {
 | 
| 538 
5dd99f3b7eca
(svn r920) Replace vehicle info macros with inline functions and add asserts to check limits
 tron parents: 
534diff
changeset | 51 | int spritenum = ShipVehInfo(engine)->image_index; | 
| 0 | 52 | |
| 53 | 	if (is_custom_sprite(spritenum)) {
 | |
| 3186 
5798593c2d95
(svn r3832) Replace some magic numbers by (Diag)Direction enums
 tron parents: 
3157diff
changeset | 54 | int sprite = GetCustomVehicleIcon(engine, DIR_W); | 
| 0 | 55 | |
| 2639 | 56 | 		if (sprite != 0) {
 | 
| 5919 
2b58160d667d
(svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
 peter1138 parents: 
5902diff
changeset | 57 | DrawSprite(sprite, pal, x, y); | 
| 0 | 58 | return; | 
| 59 | } | |
| 2464 
3dee59d241c0
(svn r2990) Remove _engine_original_sprites and replace all uses with references to our (new) original engine/vehicle tables.
 peter1138 parents: 
2214diff
changeset | 60 | spritenum = orig_ship_vehicle_info[engine - SHIP_ENGINES_INDEX].image_index; | 
| 0 | 61 | } | 
| 5919 
2b58160d667d
(svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
 peter1138 parents: 
5902diff
changeset | 62 | DrawSprite(6 + _ship_sprites[spritenum], pal, x, y); | 
| 0 | 63 | } | 
| 64 | ||
| 6223 
92d2073c3d7e
(svn r8661) -Fix: [depot windows] Enlarge the blocks in the depot window if a sprite is too big to fit (ships and aircraft only)
 bjarni parents: 
6195diff
changeset | 65 | /** Get the size of the sprite of a ship sprite heading west (used for lists) | 
| 
92d2073c3d7e
(svn r8661) -Fix: [depot windows] Enlarge the blocks in the depot window if a sprite is too big to fit (ships and aircraft only)
 bjarni parents: 
6195diff
changeset | 66 | * @param engine The engine to get the sprite from | 
| 6916 
e87d54a598ea
(svn r9556) -Documentation: doxygen and comment-style changes. 'R', 'S'.. The end of the preliminary work is near
 belugas parents: 
6903diff
changeset | 67 | * @param width The width of the sprite | 
| 
e87d54a598ea
(svn r9556) -Documentation: doxygen and comment-style changes. 'R', 'S'.. The end of the preliminary work is near
 belugas parents: 
6903diff
changeset | 68 | * @param height The height of the sprite | 
| 6223 
92d2073c3d7e
(svn r8661) -Fix: [depot windows] Enlarge the blocks in the depot window if a sprite is too big to fit (ships and aircraft only)
 bjarni parents: 
6195diff
changeset | 69 | */ | 
| 
92d2073c3d7e
(svn r8661) -Fix: [depot windows] Enlarge the blocks in the depot window if a sprite is too big to fit (ships and aircraft only)
 bjarni parents: 
6195diff
changeset | 70 | void GetShipSpriteSize(EngineID engine, uint &width, uint &height) | 
| 
92d2073c3d7e
(svn r8661) -Fix: [depot windows] Enlarge the blocks in the depot window if a sprite is too big to fit (ships and aircraft only)
 bjarni parents: 
6195diff
changeset | 71 | {
 | 
| 
92d2073c3d7e
(svn r8661) -Fix: [depot windows] Enlarge the blocks in the depot window if a sprite is too big to fit (ships and aircraft only)
 bjarni parents: 
6195diff
changeset | 72 | SpriteID spritenum = ShipVehInfo(engine)->image_index; | 
| 
92d2073c3d7e
(svn r8661) -Fix: [depot windows] Enlarge the blocks in the depot window if a sprite is too big to fit (ships and aircraft only)
 bjarni parents: 
6195diff
changeset | 73 | SpriteID custom_sprite = 0; | 
| 
92d2073c3d7e
(svn r8661) -Fix: [depot windows] Enlarge the blocks in the depot window if a sprite is too big to fit (ships and aircraft only)
 bjarni parents: 
6195diff
changeset | 74 | |
| 
92d2073c3d7e
(svn r8661) -Fix: [depot windows] Enlarge the blocks in the depot window if a sprite is too big to fit (ships and aircraft only)
 bjarni parents: 
6195diff
changeset | 75 | 	if (is_custom_sprite(spritenum)) {
 | 
| 
92d2073c3d7e
(svn r8661) -Fix: [depot windows] Enlarge the blocks in the depot window if a sprite is too big to fit (ships and aircraft only)
 bjarni parents: 
6195diff
changeset | 76 | custom_sprite = GetCustomVehicleIcon(engine, DIR_W); | 
| 
92d2073c3d7e
(svn r8661) -Fix: [depot windows] Enlarge the blocks in the depot window if a sprite is too big to fit (ships and aircraft only)
 bjarni parents: 
6195diff
changeset | 77 | spritenum = orig_ship_vehicle_info[engine - SHIP_ENGINES_INDEX].image_index; | 
| 
92d2073c3d7e
(svn r8661) -Fix: [depot windows] Enlarge the blocks in the depot window if a sprite is too big to fit (ships and aircraft only)
 bjarni parents: 
6195diff
changeset | 78 | } | 
| 
92d2073c3d7e
(svn r8661) -Fix: [depot windows] Enlarge the blocks in the depot window if a sprite is too big to fit (ships and aircraft only)
 bjarni parents: 
6195diff
changeset | 79 | 	if (custom_sprite == 0) {
 | 
| 
92d2073c3d7e
(svn r8661) -Fix: [depot windows] Enlarge the blocks in the depot window if a sprite is too big to fit (ships and aircraft only)
 bjarni parents: 
6195diff
changeset | 80 | spritenum = 6 + _ship_sprites[spritenum]; | 
| 
92d2073c3d7e
(svn r8661) -Fix: [depot windows] Enlarge the blocks in the depot window if a sprite is too big to fit (ships and aircraft only)
 bjarni parents: 
6195diff
changeset | 81 | 	} else {
 | 
| 
92d2073c3d7e
(svn r8661) -Fix: [depot windows] Enlarge the blocks in the depot window if a sprite is too big to fit (ships and aircraft only)
 bjarni parents: 
6195diff
changeset | 82 | spritenum = custom_sprite; | 
| 
92d2073c3d7e
(svn r8661) -Fix: [depot windows] Enlarge the blocks in the depot window if a sprite is too big to fit (ships and aircraft only)
 bjarni parents: 
6195diff
changeset | 83 | } | 
| 
92d2073c3d7e
(svn r8661) -Fix: [depot windows] Enlarge the blocks in the depot window if a sprite is too big to fit (ships and aircraft only)
 bjarni parents: 
6195diff
changeset | 84 | |
| 
92d2073c3d7e
(svn r8661) -Fix: [depot windows] Enlarge the blocks in the depot window if a sprite is too big to fit (ships and aircraft only)
 bjarni parents: 
6195diff
changeset | 85 | const Sprite *spr = GetSprite(spritenum); | 
| 
92d2073c3d7e
(svn r8661) -Fix: [depot windows] Enlarge the blocks in the depot window if a sprite is too big to fit (ships and aircraft only)
 bjarni parents: 
6195diff
changeset | 86 | |
| 
92d2073c3d7e
(svn r8661) -Fix: [depot windows] Enlarge the blocks in the depot window if a sprite is too big to fit (ships and aircraft only)
 bjarni parents: 
6195diff
changeset | 87 | width = spr->width; | 
| 
92d2073c3d7e
(svn r8661) -Fix: [depot windows] Enlarge the blocks in the depot window if a sprite is too big to fit (ships and aircraft only)
 bjarni parents: 
6195diff
changeset | 88 | height = spr->height; | 
| 
92d2073c3d7e
(svn r8661) -Fix: [depot windows] Enlarge the blocks in the depot window if a sprite is too big to fit (ships and aircraft only)
 bjarni parents: 
6195diff
changeset | 89 | } | 
| 
92d2073c3d7e
(svn r8661) -Fix: [depot windows] Enlarge the blocks in the depot window if a sprite is too big to fit (ships and aircraft only)
 bjarni parents: 
6195diff
changeset | 90 | |
| 3157 
40de8616c04c
(svn r3783) Replace further ints and magic numbers by Direction, DiagDirection and friends
 tron parents: 
3147diff
changeset | 91 | int GetShipImage(const Vehicle* v, Direction direction) | 
| 0 | 92 | {
 | 
| 93 | int spritenum = v->spritenum; | |
| 94 | ||
| 95 | 	if (is_custom_sprite(spritenum)) {
 | |
| 96 | int sprite = GetCustomVehicleSprite(v, direction); | |
| 97 | ||
| 2639 | 98 | if (sprite != 0) return sprite; | 
| 2464 
3dee59d241c0
(svn r2990) Remove _engine_original_sprites and replace all uses with references to our (new) original engine/vehicle tables.
 peter1138 parents: 
2214diff
changeset | 99 | spritenum = orig_ship_vehicle_info[v->engine_type - SHIP_ENGINES_INDEX].image_index; | 
| 0 | 100 | } | 
| 101 | return _ship_sprites[spritenum] + direction; | |
| 102 | } | |
| 103 | ||
| 2630 | 104 | static const Depot* FindClosestShipDepot(const Vehicle* v) | 
| 0 | 105 | {
 | 
| 2630 | 106 | const Depot* depot; | 
| 107 | const Depot* best_depot = NULL; | |
| 1977 
4392ae3d8e31
(svn r2483) Replace almost 500 "uint tile" (and variants) with "TileIndex tile"
 tron parents: 
1942diff
changeset | 108 | uint dist; | 
| 
4392ae3d8e31
(svn r2483) Replace almost 500 "uint tile" (and variants) with "TileIndex tile"
 tron parents: 
1942diff
changeset | 109 | uint best_dist = (uint)-1; | 
| 
4392ae3d8e31
(svn r2483) Replace almost 500 "uint tile" (and variants) with "TileIndex tile"
 tron parents: 
1942diff
changeset | 110 | TileIndex tile; | 
| 
4392ae3d8e31
(svn r2483) Replace almost 500 "uint tile" (and variants) with "TileIndex tile"
 tron parents: 
1942diff
changeset | 111 | TileIndex tile2 = v->tile; | 
| 0 | 112 | |
| 1247 | 113 | 	if (_patches.new_pathfinding_all) {
 | 
| 114 | NPFFoundTargetData ftd; | |
| 5838 
9c3129cb019b
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
 rubidium parents: 
5835diff
changeset | 115 | Trackdir trackdir = GetVehicleTrackdir(v); | 
| 2006 
324916f22a8a
(svn r2514) - Codechange: [NPF] Move the checking of railtype into a funciton IsCompatibleRail().
 matthijs parents: 
1998diff
changeset | 116 | ftd = NPFRouteToDepotTrialError(v->tile, trackdir, TRANSPORT_WATER, v->owner, INVALID_RAILTYPE); | 
| 2639 | 117 | 		if (ftd.best_bird_dist == 0) {
 | 
| 1313 
bba6afb8a995
(svn r1817) -Codechange: Moved depot-functions to depot.c
 truelight parents: 
1282diff
changeset | 118 | best_depot = GetDepotByTile(ftd.node.tile); /* Found target */ | 
| 2639 | 119 | 		} else {
 | 
| 1313 
bba6afb8a995
(svn r1817) -Codechange: Moved depot-functions to depot.c
 truelight parents: 
1282diff
changeset | 120 | best_depot = NULL; /* Did not find target */ | 
| 2639 | 121 | } | 
| 1247 | 122 | 	} else {
 | 
| 1313 
bba6afb8a995
(svn r1817) -Codechange: Moved depot-functions to depot.c
 truelight parents: 
1282diff
changeset | 123 | 		FOR_ALL_DEPOTS(depot) {
 | 
| 
bba6afb8a995
(svn r1817) -Codechange: Moved depot-functions to depot.c
 truelight parents: 
1282diff
changeset | 124 | tile = depot->xy; | 
| 4346 
3f00094f2670
(svn r6047) -Codechange: FOR_ALL now _only_ loops valid items, and skips invalid ones
 truelight parents: 
4344diff
changeset | 125 | 			if (IsTileDepotType(tile, TRANSPORT_WATER) && IsTileOwner(tile, v->owner)) {
 | 
| 1247 | 126 | dist = DistanceManhattan(tile, tile2); | 
| 127 | 				if (dist < best_dist) {
 | |
| 128 | best_dist = dist; | |
| 1313 
bba6afb8a995
(svn r1817) -Codechange: Moved depot-functions to depot.c
 truelight parents: 
1282diff
changeset | 129 | best_depot = depot; | 
| 1247 | 130 | } | 
| 0 | 131 | } | 
| 132 | } | |
| 133 | } | |
| 134 | return best_depot; | |
| 135 | } | |
| 136 | ||
| 137 | static void CheckIfShipNeedsService(Vehicle *v) | |
| 138 | {
 | |
| 2630 | 139 | const Depot* depot; | 
| 0 | 140 | |
| 2639 | 141 | if (_patches.servint_ships == 0) return; | 
| 142 | if (!VehicleNeedsService(v)) return; | |
| 143 | if (v->vehstatus & VS_STOPPED) return; | |
| 193 
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
 truelight parents: 
164diff
changeset | 144 | |
| 555 
eec6c0294435
(svn r955) Replace uint16 for orders with struct Order
 tron parents: 
541diff
changeset | 145 | if (v->current_order.type == OT_GOTO_DEPOT && | 
| 1530 
caa16c506a22
(svn r2034) -Codechange: Replaced the rather meaningless LOAD and UNLOAD flags for depots by something more meaningful
 celestar parents: 
1520diff
changeset | 146 | v->current_order.flags & OF_HALT_IN_DEPOT) | 
| 0 | 147 | return; | 
| 148 | ||
| 2639 | 149 | if (_patches.gotodepot && VehicleHasDepotOrders(v)) return; | 
| 0 | 150 | |
| 4529 
2bfac24af02a
(svn r6356) -Fix: FS#263 planes come out of hangar and drive back into hangar
 bjarni parents: 
4527diff
changeset | 151 | 	if (IsShipInDepot(v)) {
 | 
| 
2bfac24af02a
(svn r6356) -Fix: FS#263 planes come out of hangar and drive back into hangar
 bjarni parents: 
4527diff
changeset | 152 | VehicleServiceInDepot(v); | 
| 
2bfac24af02a
(svn r6356) -Fix: FS#263 planes come out of hangar and drive back into hangar
 bjarni parents: 
4527diff
changeset | 153 | return; | 
| 
2bfac24af02a
(svn r6356) -Fix: FS#263 planes come out of hangar and drive back into hangar
 bjarni parents: 
4527diff
changeset | 154 | } | 
| 
2bfac24af02a
(svn r6356) -Fix: FS#263 planes come out of hangar and drive back into hangar
 bjarni parents: 
4527diff
changeset | 155 | |
| 1313 
bba6afb8a995
(svn r1817) -Codechange: Moved depot-functions to depot.c
 truelight parents: 
1282diff
changeset | 156 | depot = FindClosestShipDepot(v); | 
| 0 | 157 | |
| 1313 
bba6afb8a995
(svn r1817) -Codechange: Moved depot-functions to depot.c
 truelight parents: 
1282diff
changeset | 158 | 	if (depot == NULL || DistanceManhattan(v->tile, depot->xy) > 12) {
 | 
| 555 
eec6c0294435
(svn r955) Replace uint16 for orders with struct Order
 tron parents: 
541diff
changeset | 159 | 		if (v->current_order.type == OT_GOTO_DEPOT) {
 | 
| 
eec6c0294435
(svn r955) Replace uint16 for orders with struct Order
 tron parents: 
541diff
changeset | 160 | v->current_order.type = OT_DUMMY; | 
| 
eec6c0294435
(svn r955) Replace uint16 for orders with struct Order
 tron parents: 
541diff
changeset | 161 | v->current_order.flags = 0; | 
| 755 
823358e83abf
(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: 
679diff
changeset | 162 | InvalidateWindowWidget(WC_VEHICLE_VIEW, v->index, STATUS_BAR); | 
| 0 | 163 | } | 
| 164 | return; | |
| 165 | } | |
| 166 | ||
| 555 
eec6c0294435
(svn r955) Replace uint16 for orders with struct Order
 tron parents: 
541diff
changeset | 167 | v->current_order.type = OT_GOTO_DEPOT; | 
| 
eec6c0294435
(svn r955) Replace uint16 for orders with struct Order
 tron parents: 
541diff
changeset | 168 | v->current_order.flags = OF_NON_STOP; | 
| 4527 
b18634a31a4a
(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: 
4526diff
changeset | 169 | v->current_order.dest = depot->index; | 
| 1313 
bba6afb8a995
(svn r1817) -Codechange: Moved depot-functions to depot.c
 truelight parents: 
1282diff
changeset | 170 | v->dest_tile = depot->xy; | 
| 755 
823358e83abf
(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: 
679diff
changeset | 171 | InvalidateWindowWidget(WC_VEHICLE_VIEW, v->index, STATUS_BAR); | 
| 0 | 172 | } | 
| 173 | ||
| 174 | void OnNewDay_Ship(Vehicle *v) | |
| 175 | {
 | |
| 176 | int32 cost; | |
| 177 | ||
| 178 | if ((++v->day_counter & 7) == 0) | |
| 179 | DecreaseVehicleValue(v); | |
| 180 | ||
| 181 | CheckVehicleBreakdown(v); | |
| 182 | AgeVehicle(v); | |
| 183 | CheckIfShipNeedsService(v); | |
| 184 | ||
| 3140 
69cb681c6d86
(svn r3758) Remove the news validation callback. It is superseded by r3757.
 tron parents: 
3139diff
changeset | 185 | CheckOrders(v); | 
| 193 
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
 truelight parents: 
164diff
changeset | 186 | |
| 2639 | 187 | if (v->vehstatus & VS_STOPPED) return; | 
| 19 
6080d2b6a959
(svn r20) Feature: warning when a vehicle has invalid orders (celestar)
 dominik parents: 
11diff
changeset | 188 | |
| 538 
5dd99f3b7eca
(svn r920) Replace vehicle info macros with inline functions and add asserts to check limits
 tron parents: 
534diff
changeset | 189 | cost = ShipVehInfo(v->engine_type)->running_cost * _price.ship_running / 364; | 
| 0 | 190 | v->profit_this_year -= cost >> 8; | 
| 191 | ||
| 192 | SET_EXPENSES_TYPE(EXPENSES_SHIP_RUN); | |
| 193 | SubtractMoneyFromPlayerFract(v->owner, cost); | |
| 194 | ||
| 195 | InvalidateWindow(WC_VEHICLE_DETAILS, v->index); | |
| 6916 
e87d54a598ea
(svn r9556) -Documentation: doxygen and comment-style changes. 'R', 'S'.. The end of the preliminary work is near
 belugas parents: 
6903diff
changeset | 196 | /* we need this for the profit */ | 
| 1055 
3aae1d6f12aa
(svn r1556) -Fix: Vehicle list updates should now really work
 Celestar parents: 
1053diff
changeset | 197 | InvalidateWindowClasses(WC_SHIPS_LIST); | 
| 0 | 198 | } | 
| 199 | ||
| 200 | static void HandleBrokenShip(Vehicle *v) | |
| 201 | {
 | |
| 202 | 	if (v->breakdown_ctr != 1) {
 | |
| 203 | v->breakdown_ctr = 1; | |
| 204 | v->cur_speed = 0; | |
| 205 | ||
| 206 | if (v->breakdowns_since_last_service != 255) | |
| 207 | v->breakdowns_since_last_service++; | |
| 193 
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
 truelight parents: 
164diff
changeset | 208 | |
| 0 | 209 | InvalidateWindow(WC_VEHICLE_VIEW, v->index); | 
| 210 | InvalidateWindow(WC_VEHICLE_DETAILS, v->index); | |
| 193 
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
 truelight parents: 
164diff
changeset | 211 | |
| 4656 
acffecd6f484
(svn r6532) - Feature: Add support for NewGRF sound effects. Currently sound priority isn't supported.
 peter1138 parents: 
4574diff
changeset | 212 | 		if (!PlayVehicleSound(v, VSE_BREAKDOWN)) {
 | 
| 6683 
7ec558346172
(svn r9400) -Codechange: Use some more representative enum names for landscape types.
 belugas parents: 
6642diff
changeset | 213 | SndPlayVehicleFx((_opt.landscape != LT_TOYLAND) ? | 
| 4656 
acffecd6f484
(svn r6532) - Feature: Add support for NewGRF sound effects. Currently sound priority isn't supported.
 peter1138 parents: 
4574diff
changeset | 214 | SND_10_TRAIN_BREAKDOWN : SND_3A_COMEDY_BREAKDOWN_2, v); | 
| 
acffecd6f484
(svn r6532) - Feature: Add support for NewGRF sound effects. Currently sound priority isn't supported.
 peter1138 parents: 
4574diff
changeset | 215 | } | 
| 0 | 216 | |
| 217 | 		if (!(v->vehstatus & VS_HIDDEN)) {
 | |
| 218 | Vehicle *u = CreateEffectVehicleRel(v, 4, 4, 5, EV_BREAKDOWN_SMOKE); | |
| 2639 | 219 | if (u != NULL) u->u.special.unk0 = v->breakdown_delay * 2; | 
| 0 | 220 | } | 
| 221 | } | |
| 222 | ||
| 223 | 	if (!(v->tick_counter & 1)) {
 | |
| 224 | 		if (!--v->breakdown_delay) {
 | |
| 225 | v->breakdown_ctr = 0; | |
| 1151 
614cbcb5b9fe
(svn r1652) Fix: train and road vehicle lists are now redrawn when vehicles enters/leaves a depot (Hackykid)
 bjarni parents: 
1128diff
changeset | 226 | InvalidateWindow(WC_VEHICLE_VIEW, v->index); | 
| 0 | 227 | } | 
| 228 | } | |
| 229 | } | |
| 230 | ||
| 231 | static void MarkShipDirty(Vehicle *v) | |
| 232 | {
 | |
| 233 | v->cur_image = GetShipImage(v, v->direction); | |
| 234 | MarkAllViewportsDirty(v->left_coord, v->top_coord, v->right_coord + 1, v->bottom_coord + 1); | |
| 235 | } | |
| 236 | ||
| 237 | static void PlayShipSound(Vehicle *v) | |
| 238 | {
 | |
| 4656 
acffecd6f484
(svn r6532) - Feature: Add support for NewGRF sound effects. Currently sound priority isn't supported.
 peter1138 parents: 
4574diff
changeset | 239 | 	if (!PlayVehicleSound(v, VSE_START)) {
 | 
| 
acffecd6f484
(svn r6532) - Feature: Add support for NewGRF sound effects. Currently sound priority isn't supported.
 peter1138 parents: 
4574diff
changeset | 240 | SndPlayVehicleFx(ShipVehInfo(v->engine_type)->sfx, v); | 
| 
acffecd6f484
(svn r6532) - Feature: Add support for NewGRF sound effects. Currently sound priority isn't supported.
 peter1138 parents: 
4574diff
changeset | 241 | } | 
| 0 | 242 | } | 
| 243 | ||
| 244 | static void ProcessShipOrder(Vehicle *v) | |
| 245 | {
 | |
| 1024 
9b06b01490a4
(svn r1525) -Codechange: rewrote the _order_array, now it can be made dynamic.
 truelight parents: 
1020diff
changeset | 246 | const Order *order; | 
| 0 | 247 | |
| 3005 
db4007baa0ab
(svn r3585) Similar changes to the order handlers of the other vehicle types like r3584
 tron parents: 
2962diff
changeset | 248 | 	switch (v->current_order.type) {
 | 
| 
db4007baa0ab
(svn r3585) Similar changes to the order handlers of the other vehicle types like r3584
 tron parents: 
2962diff
changeset | 249 | case OT_GOTO_DEPOT: | 
| 
db4007baa0ab
(svn r3585) Similar changes to the order handlers of the other vehicle types like r3584
 tron parents: 
2962diff
changeset | 250 | if (!(v->current_order.flags & OF_PART_OF_ORDERS)) return; | 
| 
db4007baa0ab
(svn r3585) Similar changes to the order handlers of the other vehicle types like r3584
 tron parents: 
2962diff
changeset | 251 | if (v->current_order.flags & OF_SERVICE_IF_NEEDED && | 
| 
db4007baa0ab
(svn r3585) Similar changes to the order handlers of the other vehicle types like r3584
 tron parents: 
2962diff
changeset | 252 | 					!VehicleNeedsService(v)) {
 | 
| 
db4007baa0ab
(svn r3585) Similar changes to the order handlers of the other vehicle types like r3584
 tron parents: 
2962diff
changeset | 253 | v->cur_order_index++; | 
| 
db4007baa0ab
(svn r3585) Similar changes to the order handlers of the other vehicle types like r3584
 tron parents: 
2962diff
changeset | 254 | } | 
| 
db4007baa0ab
(svn r3585) Similar changes to the order handlers of the other vehicle types like r3584
 tron parents: 
2962diff
changeset | 255 | break; | 
| 
db4007baa0ab
(svn r3585) Similar changes to the order handlers of the other vehicle types like r3584
 tron parents: 
2962diff
changeset | 256 | |
| 
db4007baa0ab
(svn r3585) Similar changes to the order handlers of the other vehicle types like r3584
 tron parents: 
2962diff
changeset | 257 | case OT_LOADING: | 
| 
db4007baa0ab
(svn r3585) Similar changes to the order handlers of the other vehicle types like r3584
 tron parents: 
2962diff
changeset | 258 | case OT_LEAVESTATION: | 
| 0 | 259 | return; | 
| 4351 
63ae31104f07
(svn r6052) -Codechange: change OrderType (order->type) in a typedef
 truelight parents: 
4346diff
changeset | 260 | |
| 
63ae31104f07
(svn r6052) -Codechange: change OrderType (order->type) in a typedef
 truelight parents: 
4346diff
changeset | 261 | default: break; | 
| 0 | 262 | } | 
| 263 | ||
| 3005 
db4007baa0ab
(svn r3585) Similar changes to the order handlers of the other vehicle types like r3584
 tron parents: 
2962diff
changeset | 264 | if (v->cur_order_index >= v->num_orders) v->cur_order_index = 0; | 
| 0 | 265 | |
| 1024 
9b06b01490a4
(svn r1525) -Codechange: rewrote the _order_array, now it can be made dynamic.
 truelight parents: 
1020diff
changeset | 266 | order = GetVehicleOrder(v, v->cur_order_index); | 
| 0 | 267 | |
| 1024 
9b06b01490a4
(svn r1525) -Codechange: rewrote the _order_array, now it can be made dynamic.
 truelight parents: 
1020diff
changeset | 268 | 	if (order == NULL) {
 | 
| 6589 
addf4b6946d0
(svn r9072) -Codechange: [Orders] added methods to orders to free them and check if they are in use
 bjarni parents: 
6585diff
changeset | 269 | v->current_order.Free(); | 
| 0 | 270 | v->dest_tile = 0; | 
| 271 | return; | |
| 272 | } | |
| 273 | ||
| 4527 
b18634a31a4a
(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: 
4526diff
changeset | 274 | if (order->type == v->current_order.type && | 
| 
b18634a31a4a
(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: 
4526diff
changeset | 275 | order->flags == v->current_order.flags && | 
| 
b18634a31a4a
(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: 
4526diff
changeset | 276 | order->dest == v->current_order.dest) | 
| 0 | 277 | return; | 
| 278 | ||
| 1024 
9b06b01490a4
(svn r1525) -Codechange: rewrote the _order_array, now it can be made dynamic.
 truelight parents: 
1020diff
changeset | 279 | v->current_order = *order; | 
| 0 | 280 | |
| 1024 
9b06b01490a4
(svn r1525) -Codechange: rewrote the _order_array, now it can be made dynamic.
 truelight parents: 
1020diff
changeset | 281 | 	if (order->type == OT_GOTO_STATION) {
 | 
| 
9b06b01490a4
(svn r1525) -Codechange: rewrote the _order_array, now it can be made dynamic.
 truelight parents: 
1020diff
changeset | 282 | const Station *st; | 
| 
9b06b01490a4
(svn r1525) -Codechange: rewrote the _order_array, now it can be made dynamic.
 truelight parents: 
1020diff
changeset | 283 | |
| 4527 
b18634a31a4a
(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: 
4526diff
changeset | 284 | if (order->dest == v->last_station_visited) | 
| 1266 
9dc5638fe8cc
(svn r1770) -Fix: Hopefully last pieces of code that are containing a station-id
 truelight parents: 
1247diff
changeset | 285 | v->last_station_visited = INVALID_STATION; | 
| 193 
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
 truelight parents: 
164diff
changeset | 286 | |
| 4527 
b18634a31a4a
(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: 
4526diff
changeset | 287 | st = GetStation(order->dest); | 
| 0 | 288 | 		if (st->dock_tile != 0) {
 | 
| 3472 
7ef2b2d6a632
(svn r4317) -Codechange: More map accessors for ship_cmd. it is now map-access free, but still requires a huge cleanup
 celestar parents: 
3454diff
changeset | 289 | v->dest_tile = TILE_ADD(st->dock_tile, ToTileIndexDiff(GetDockOffset(st->dock_tile))); | 
| 0 | 290 | } | 
| 1024 
9b06b01490a4
(svn r1525) -Codechange: rewrote the _order_array, now it can be made dynamic.
 truelight parents: 
1020diff
changeset | 291 | 	} else if (order->type == OT_GOTO_DEPOT) {
 | 
| 4527 
b18634a31a4a
(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: 
4526diff
changeset | 292 | v->dest_tile = GetDepot(order->dest)->xy; | 
| 0 | 293 | 	} else {
 | 
| 294 | v->dest_tile = 0; | |
| 295 | } | |
| 1024 
9b06b01490a4
(svn r1525) -Codechange: rewrote the _order_array, now it can be made dynamic.
 truelight parents: 
1020diff
changeset | 296 | |
| 
9b06b01490a4
(svn r1525) -Codechange: rewrote the _order_array, now it can be made dynamic.
 truelight parents: 
1020diff
changeset | 297 | InvalidateVehicleOrder(v); | 
| 1020 
1223cd937174
(svn r1521) -Fix: Ship Vehicle Lists are now redrawn correctly
 celestar parents: 
926diff
changeset | 298 | |
| 1055 
3aae1d6f12aa
(svn r1556) -Fix: Vehicle list updates should now really work
 Celestar parents: 
1053diff
changeset | 299 | InvalidateWindowClasses(WC_SHIPS_LIST); | 
| 0 | 300 | } | 
| 301 | ||
| 302 | static void HandleShipLoading(Vehicle *v) | |
| 303 | {
 | |
| 6107 | 304 | 	switch (v->current_order.type) {
 | 
| 6109 
2361013ddd68
(svn r8434) -Fix (r8430): Missing braces caused compilation failure for some (most?) compilers...
 peter1138 parents: 
6107diff
changeset | 305 | 		case OT_LOADING: {
 | 
| 6107 | 306 | if (--v->load_unload_time_rem) return; | 
| 0 | 307 | |
| 6107 | 308 | if (CanFillVehicle(v) && ( | 
| 309 | v->current_order.flags & OF_FULL_LOAD || | |
| 6501 
1e95e8d993ff
(svn r8945) -Codechange: Rename v->load_status to v->vehicle_flags so it can be used for more than just the gradual loading status.
 maedhros parents: 
6479diff
changeset | 310 | (_patches.gradual_loading && !HASBIT(v->vehicle_flags, VF_LOADING_FINISHED)) | 
| 6107 | 311 | 					)) {
 | 
| 312 | SET_EXPENSES_TYPE(EXPENSES_SHIP_INC); | |
| 313 | 				if (LoadUnloadVehicle(v, false)) {
 | |
| 314 | InvalidateWindow(WC_SHIPS_LIST, v->owner); | |
| 315 | MarkShipDirty(v); | |
| 316 | } | |
| 317 | return; | |
| 0 | 318 | } | 
| 6107 | 319 | PlayShipSound(v); | 
| 193 
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
 truelight parents: 
164diff
changeset | 320 | |
| 555 
eec6c0294435
(svn r955) Replace uint16 for orders with struct Order
 tron parents: 
541diff
changeset | 321 | Order b = v->current_order; | 
| 5902 
906fea1535ab
(svn r8110) -Codechange: direct Vehicle::current_order.type changes (to OT_LOADING and OT_LEAVESTATION) replaced by v->BeginLoading() and v->LeaveStation() calls. This should allow easy hooking of those state transitions in order to maintain vehicle loading queue.
 KUDr parents: 
5849diff
changeset | 322 | v->LeaveStation(); | 
| 2639 | 323 | if (!(b.flags & OF_NON_STOP)) return; | 
| 6107 | 324 | break; | 
| 6109 
2361013ddd68
(svn r8434) -Fix (r8430): Missing braces caused compilation failure for some (most?) compilers...
 peter1138 parents: 
6107diff
changeset | 325 | } | 
| 6107 | 326 | |
| 327 | case OT_DUMMY: break; | |
| 328 | ||
| 329 | default: return; | |
| 0 | 330 | } | 
| 331 | ||
| 332 | v->cur_order_index++; | |
| 1024 
9b06b01490a4
(svn r1525) -Codechange: rewrote the _order_array, now it can be made dynamic.
 truelight parents: 
1020diff
changeset | 333 | InvalidateVehicleOrder(v); | 
| 0 | 334 | } | 
| 335 | ||
| 336 | static void UpdateShipDeltaXY(Vehicle *v, int dir) | |
| 337 | {
 | |
| 338 | #define MKIT(d,c,b,a) ((a&0xFF)<<24) | ((b&0xFF)<<16) | ((c&0xFF)<<8) | ((d&0xFF)<<0) | |
| 339 | 	static const uint32 _delta_xy_table[8] = {
 | |
| 4344 
5d0e40cd67b9
(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: 
4329diff
changeset | 340 | MKIT( -3, -3, 6, 6), | 
| 
5d0e40cd67b9
(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: 
4329diff
changeset | 341 | MKIT(-16, -3, 32, 6), | 
| 
5d0e40cd67b9
(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: 
4329diff
changeset | 342 | MKIT( -3, -3, 6, 6), | 
| 
5d0e40cd67b9
(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: 
4329diff
changeset | 343 | MKIT( -3, -16, 6, 32), | 
| 
5d0e40cd67b9
(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: 
4329diff
changeset | 344 | MKIT( -3, -3, 6, 6), | 
| 
5d0e40cd67b9
(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: 
4329diff
changeset | 345 | MKIT(-16, -3, 32, 6), | 
| 
5d0e40cd67b9
(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: 
4329diff
changeset | 346 | MKIT( -3, -3, 6, 6), | 
| 
5d0e40cd67b9
(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: 
4329diff
changeset | 347 | MKIT( -3, -16, 6, 32), | 
| 0 | 348 | }; | 
| 349 | #undef MKIT | |
| 350 | uint32 x = _delta_xy_table[dir]; | |
| 2150 
010d923a81a9
(svn r2660) Get rid of some more shifting/anding/casting
 tron parents: 
2049diff
changeset | 351 | v->x_offs = GB(x, 0, 8); | 
| 
010d923a81a9
(svn r2660) Get rid of some more shifting/anding/casting
 tron parents: 
2049diff
changeset | 352 | v->y_offs = GB(x, 8, 8); | 
| 
010d923a81a9
(svn r2660) Get rid of some more shifting/anding/casting
 tron parents: 
2049diff
changeset | 353 | v->sprite_width = GB(x, 16, 8); | 
| 
010d923a81a9
(svn r2660) Get rid of some more shifting/anding/casting
 tron parents: 
2049diff
changeset | 354 | v->sprite_height = GB(x, 24, 8); | 
| 0 | 355 | } | 
| 356 | ||
| 4725 
f7284b86833f
(svn r6637) -Codechange: merged all (vehicle type)EnterDepot into VehicleEnterDepot()
 bjarni parents: 
4712diff
changeset | 357 | void RecalcShipStuff(Vehicle *v) | 
| 0 | 358 | {
 | 
| 359 | UpdateShipDeltaXY(v, v->direction); | |
| 360 | v->cur_image = GetShipImage(v, v->direction); | |
| 361 | MarkShipDirty(v); | |
| 362 | InvalidateWindow(WC_VEHICLE_DEPOT, v->tile); | |
| 363 | } | |
| 364 | ||
| 909 
81bc9ef93f50
(svn r1396) Introduce TileIndexDiffC - the compile time version of TileIndexDiff
 tron parents: 
900diff
changeset | 365 | static const TileIndexDiffC _ship_leave_depot_offs[] = {
 | 
| 
81bc9ef93f50
(svn r1396) Introduce TileIndexDiffC - the compile time version of TileIndexDiff
 tron parents: 
900diff
changeset | 366 | 	{-1,  0},
 | 
| 
81bc9ef93f50
(svn r1396) Introduce TileIndexDiffC - the compile time version of TileIndexDiff
 tron parents: 
900diff
changeset | 367 | 	{ 0, -1}
 | 
| 0 | 368 | }; | 
| 369 | ||
| 370 | static void CheckShipLeaveDepot(Vehicle *v) | |
| 371 | {
 | |
| 1977 
4392ae3d8e31
(svn r2483) Replace almost 500 "uint tile" (and variants) with "TileIndex tile"
 tron parents: 
1942diff
changeset | 372 | TileIndex tile; | 
| 3454 
c2447e8c1e23
(svn r4289) -Codechange: Make use of water_map accessors for ships. Make a mental note to clean ship_cmd
 celestar parents: 
3442diff
changeset | 373 | Axis axis; | 
| 0 | 374 | uint m; | 
| 375 | ||
| 3961 
e2783f244ac6
(svn r5120) Add IsShipInDepot{Stopped,}() and remove some redundant checks
 tron parents: 
3955diff
changeset | 376 | if (!IsShipInDepot(v)) return; | 
| 0 | 377 | |
| 378 | tile = v->tile; | |
| 3454 
c2447e8c1e23
(svn r4289) -Codechange: Make use of water_map accessors for ships. Make a mental note to clean ship_cmd
 celestar parents: 
3442diff
changeset | 379 | axis = GetShipDepotAxis(tile); | 
| 0 | 380 | |
| 6916 
e87d54a598ea
(svn r9556) -Documentation: doxygen and comment-style changes. 'R', 'S'.. The end of the preliminary work is near
 belugas parents: 
6903diff
changeset | 381 | /* Check first side */ | 
| 3454 
c2447e8c1e23
(svn r4289) -Codechange: Make use of water_map accessors for ships. Make a mental note to clean ship_cmd
 celestar parents: 
3442diff
changeset | 382 | 	if (_ship_sometracks[axis] & GetTileShipTrackStatus(TILE_ADD(tile, ToTileIndexDiff(_ship_leave_depot_offs[axis])))) {
 | 
| 
c2447e8c1e23
(svn r4289) -Codechange: Make use of water_map accessors for ships. Make a mental note to clean ship_cmd
 celestar parents: 
3442diff
changeset | 383 | m = (axis == AXIS_X) ? 0x101 : 0x207; | 
| 6916 
e87d54a598ea
(svn r9556) -Documentation: doxygen and comment-style changes. 'R', 'S'.. The end of the preliminary work is near
 belugas parents: 
6903diff
changeset | 384 | /* Check second side */ | 
| 3454 
c2447e8c1e23
(svn r4289) -Codechange: Make use of water_map accessors for ships. Make a mental note to clean ship_cmd
 celestar parents: 
3442diff
changeset | 385 | 	} else if (_ship_sometracks[axis + 2] & GetTileShipTrackStatus(TILE_ADD(tile, -2 * ToTileIndexDiff(_ship_leave_depot_offs[axis])))) {
 | 
| 
c2447e8c1e23
(svn r4289) -Codechange: Make use of water_map accessors for ships. Make a mental note to clean ship_cmd
 celestar parents: 
3442diff
changeset | 386 | m = (axis == AXIS_X) ? 0x105 : 0x203; | 
| 0 | 387 | 	} else {
 | 
| 388 | return; | |
| 389 | } | |
| 5838 
9c3129cb019b
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
 rubidium parents: 
5835diff
changeset | 390 | v->direction = (Direction)GB(m, 0, 8); | 
| 
9c3129cb019b
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
 rubidium parents: 
5835diff
changeset | 391 | v->u.ship.state = (TrackBits)GB(m, 8, 8); | 
| 0 | 392 | v->vehstatus &= ~VS_HIDDEN; | 
| 393 | ||
| 394 | v->cur_speed = 0; | |
| 395 | RecalcShipStuff(v); | |
| 396 | ||
| 397 | PlayShipSound(v); | |
| 578 
86e352980acd
(svn r998) now vehicles are serviced both when entering and when leaving depots to prevent that vehicles might need service when leaving after a long stay (ln--)
 bjarni parents: 
555diff
changeset | 398 | VehicleServiceInDepot(v); | 
| 4739 
bd535b408617
(svn r6651) -Coding feature: added the windowevent WE_INVALIDATE_DATA
 bjarni parents: 
4725diff
changeset | 399 | InvalidateWindowData(WC_VEHICLE_DEPOT, v->tile); | 
| 1055 
3aae1d6f12aa
(svn r1556) -Fix: Vehicle list updates should now really work
 Celestar parents: 
1053diff
changeset | 400 | InvalidateWindowClasses(WC_SHIPS_LIST); | 
| 0 | 401 | } | 
| 402 | ||
| 403 | static bool ShipAccelerate(Vehicle *v) | |
| 404 | {
 | |
| 405 | uint spd; | |
| 406 | byte t; | |
| 407 | ||
| 408 | spd = min(v->cur_speed + 1, v->max_speed); | |
| 409 | ||
| 6916 
e87d54a598ea
(svn r9556) -Documentation: doxygen and comment-style changes. 'R', 'S'.. The end of the preliminary work is near
 belugas parents: 
6903diff
changeset | 410 | /*updates statusbar only if speed have changed to save CPU time */ | 
| 0 | 411 | 	if (spd != v->cur_speed) {
 | 
| 193 
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
 truelight parents: 
164diff
changeset | 412 | v->cur_speed = spd; | 
| 0 | 413 | if (_patches.vehicle_speed) | 
| 755 
823358e83abf
(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: 
679diff
changeset | 414 | InvalidateWindowWidget(WC_VEHICLE_VIEW, v->index, STATUS_BAR); | 
| 0 | 415 | } | 
| 416 | ||
| 6916 
e87d54a598ea
(svn r9556) -Documentation: doxygen and comment-style changes. 'R', 'S'.. The end of the preliminary work is near
 belugas parents: 
6903diff
changeset | 417 | /* Decrease somewhat when turning */ | 
| 2639 | 418 | if (!(v->direction & 1)) spd = spd * 3 / 4; | 
| 0 | 419 | |
| 2639 | 420 | if (spd == 0) return false; | 
| 421 | if ((byte)++spd == 0) return true; | |
| 0 | 422 | |
| 423 | v->progress = (t = v->progress) - (byte)spd; | |
| 424 | ||
| 425 | return (t < v->progress); | |
| 426 | } | |
| 427 | ||
| 2817 | 428 | static int32 EstimateShipCost(EngineID engine_type) | 
| 1793 
8ac8a8c9ec0f
(svn r2297) - CodeChange: server-check the next batch of commands.
 Darkvater parents: 
1790diff
changeset | 429 | {
 | 
| 
8ac8a8c9ec0f
(svn r2297) - CodeChange: server-check the next batch of commands.
 Darkvater parents: 
1790diff
changeset | 430 | return ShipVehInfo(engine_type)->base_cost * (_price.ship_base>>3)>>5; | 
| 
8ac8a8c9ec0f
(svn r2297) - CodeChange: server-check the next batch of commands.
 Darkvater parents: 
1790diff
changeset | 431 | } | 
| 0 | 432 | |
| 2630 | 433 | static void ShipArrivesAt(const Vehicle* v, Station* st) | 
| 0 | 434 | {
 | 
| 435 | /* Check if station was ever visited before */ | |
| 436 | 	if (!(st->had_vehicle_of_type & HVOT_SHIP)) {
 | |
| 437 | uint32 flags; | |
| 2639 | 438 | |
| 0 | 439 | st->had_vehicle_of_type |= HVOT_SHIP; | 
| 2639 | 440 | |
| 534 
17ab2f22ff74
(svn r901) Small step in the process to clean up the DPARAM mess:
 tron parents: 
507diff
changeset | 441 | SetDParam(0, st->index); | 
| 0 | 442 | flags = (v->owner == _local_player) ? NEWS_FLAGS(NM_THIN, NF_VIEWPORT|NF_VEHICLE, NT_ARRIVAL_PLAYER, 0) : NEWS_FLAGS(NM_THIN, NF_VIEWPORT|NF_VEHICLE, NT_ARRIVAL_OTHER, 0); | 
| 443 | AddNewsItem( | |
| 444 | STR_9833_CITIZENS_CELEBRATE_FIRST, | |
| 445 | flags, | |
| 446 | v->index, | |
| 447 | 0); | |
| 448 | } | |
| 449 | } | |
| 450 | ||
| 6574 
e1d1a12faaf7
(svn r9051) -Codechange: typedef [enum|struct] Y {} X; -> [enum|struct] X {};
 rubidium parents: 
6573diff
changeset | 451 | struct PathFindShip {
 | 
| 1977 
4392ae3d8e31
(svn r2483) Replace almost 500 "uint tile" (and variants) with "TileIndex tile"
 tron parents: 
1942diff
changeset | 452 | TileIndex skiptile; | 
| 
4392ae3d8e31
(svn r2483) Replace almost 500 "uint tile" (and variants) with "TileIndex tile"
 tron parents: 
1942diff
changeset | 453 | TileIndex dest_coords; | 
| 0 | 454 | uint best_bird_dist; | 
| 455 | uint best_length; | |
| 6574 
e1d1a12faaf7
(svn r9051) -Codechange: typedef [enum|struct] Y {} X; -> [enum|struct] X {};
 rubidium parents: 
6573diff
changeset | 456 | }; | 
| 0 | 457 | |
| 1977 
4392ae3d8e31
(svn r2483) Replace almost 500 "uint tile" (and variants) with "TileIndex tile"
 tron parents: 
1942diff
changeset | 458 | static bool ShipTrackFollower(TileIndex tile, PathFindShip *pfs, int track, uint length, byte *state) | 
| 0 | 459 | {
 | 
| 6916 
e87d54a598ea
(svn r9556) -Documentation: doxygen and comment-style changes. 'R', 'S'.. The end of the preliminary work is near
 belugas parents: 
6903diff
changeset | 460 | /* Found dest? */ | 
| 0 | 461 | 	if (tile == pfs->dest_coords) {
 | 
| 462 | pfs->best_bird_dist = 0; | |
| 193 
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
 truelight parents: 
164diff
changeset | 463 | |
| 0 | 464 | pfs->best_length = minu(pfs->best_length, length); | 
| 465 | return true; | |
| 466 | } | |
| 467 | ||
| 6916 
e87d54a598ea
(svn r9556) -Documentation: doxygen and comment-style changes. 'R', 'S'.. The end of the preliminary work is near
 belugas parents: 
6903diff
changeset | 468 | /* Skip this tile in the calculation */ | 
| 0 | 469 | 	if (tile != pfs->skiptile) {
 | 
| 1245 
768d9bc95aaa
(svn r1749) Move the functions which calculate distances to map.[ch] and give the more meaningful names
 tron parents: 
1237diff
changeset | 470 | pfs->best_bird_dist = minu(pfs->best_bird_dist, DistanceMaxPlusManhattan(pfs->dest_coords, tile)); | 
| 0 | 471 | } | 
| 193 
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
 truelight parents: 
164diff
changeset | 472 | |
| 0 | 473 | return false; | 
| 474 | } | |
| 475 | ||
| 476 | static const byte _ship_search_directions[6][4] = {
 | |
| 477 | 	{ 0, 9, 2, 9 },
 | |
| 478 | 	{ 9, 1, 9, 3 },
 | |
| 479 | 	{ 9, 0, 3, 9 },
 | |
| 480 | 	{ 1, 9, 9, 2 },
 | |
| 481 | 	{ 3, 2, 9, 9 },
 | |
| 482 | 	{ 9, 9, 1, 0 },
 | |
| 483 | }; | |
| 484 | ||
| 485 | static const byte _pick_shiptrack_table[6] = {1, 3, 2, 2, 0, 0};
 | |
| 486 | ||
| 5838 
9c3129cb019b
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
 rubidium parents: 
5835diff
changeset | 487 | static uint FindShipTrack(Vehicle *v, TileIndex tile, DiagDirection dir, TrackBits bits, TileIndex skiptile, Track *track) | 
| 0 | 488 | {
 | 
| 489 | PathFindShip pfs; | |
| 5838 
9c3129cb019b
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
 rubidium parents: 
5835diff
changeset | 490 | Track i, best_track; | 
| 0 | 491 | uint best_bird_dist = 0; | 
| 492 | uint best_length = 0; | |
| 493 | uint r; | |
| 494 | byte ship_dir = v->direction & 3; | |
| 495 | ||
| 496 | pfs.dest_coords = v->dest_tile; | |
| 497 | pfs.skiptile = skiptile; | |
| 498 | ||
| 5838 
9c3129cb019b
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
 rubidium parents: 
5835diff
changeset | 499 | best_track = INVALID_TRACK; | 
| 0 | 500 | |
| 501 | 	do {
 | |
| 5849 
58039c9dc565
(svn r8052) - Codechange: RemoveFirstTrack() and RemoveFirstTrackdir() now accept pointer to TrackBits/TrackdirBits instead of reference.
 KUDr parents: 
5838diff
changeset | 502 | i = RemoveFirstTrack(&bits); | 
| 193 
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
 truelight parents: 
164diff
changeset | 503 | |
| 0 | 504 | pfs.best_bird_dist = (uint)-1; | 
| 505 | pfs.best_length = (uint)-1; | |
| 506 | ||
| 5838 
9c3129cb019b
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
 rubidium parents: 
5835diff
changeset | 507 | FollowTrack(tile, 0x3800 | TRANSPORT_WATER, (DiagDirection)_ship_search_directions[i][dir], (TPFEnumProc*)ShipTrackFollower, NULL, &pfs); | 
| 193 
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
 truelight parents: 
164diff
changeset | 508 | |
| 5838 
9c3129cb019b
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
 rubidium parents: 
5835diff
changeset | 509 | 		if (best_track != INVALID_TRACK) {
 | 
| 0 | 510 | 			if (pfs.best_bird_dist != 0) {
 | 
| 511 | /* neither reached the destination, pick the one with the smallest bird dist */ | |
| 512 | if (pfs.best_bird_dist > best_bird_dist) goto bad; | |
| 513 | if (pfs.best_bird_dist < best_bird_dist) goto good; | |
| 514 | 			} else {
 | |
| 515 | if (pfs.best_length > best_length) goto bad; | |
| 516 | if (pfs.best_length < best_length) goto good; | |
| 517 | } | |
| 193 
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
 truelight parents: 
164diff
changeset | 518 | |
| 
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
 truelight parents: 
164diff
changeset | 519 | /* if we reach this position, there's two paths of equal value so far. | 
| 0 | 520 | * pick one randomly. */ | 
| 2150 
010d923a81a9
(svn r2660) Get rid of some more shifting/anding/casting
 tron parents: 
2049diff
changeset | 521 | r = GB(Random(), 0, 8); | 
| 0 | 522 | if (_pick_shiptrack_table[i] == ship_dir) r += 80; | 
| 523 | if (_pick_shiptrack_table[best_track] == ship_dir) r -= 80; | |
| 524 | if (r <= 127) goto bad; | |
| 525 | } | |
| 526 | good:; | |
| 527 | best_track = i; | |
| 528 | best_bird_dist = pfs.best_bird_dist; | |
| 529 | best_length = pfs.best_length; | |
| 530 | bad:; | |
| 531 | ||
| 532 | } while (bits != 0); | |
| 533 | ||
| 534 | *track = best_track; | |
| 535 | return best_bird_dist; | |
| 536 | } | |
| 537 | ||
| 3900 
4984308f9125
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
 KUDr parents: 
3870diff
changeset | 538 | static inline NPFFoundTargetData PerfNPFRouteToStationOrTile(TileIndex tile, Trackdir trackdir, NPFFindStationOrTileData* target, TransportType type, Owner owner, RailTypeMask railtypes) | 
| 
4984308f9125
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
 KUDr parents: 
3870diff
changeset | 539 | {
 | 
| 
4984308f9125
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
 KUDr parents: 
3870diff
changeset | 540 | |
| 
4984308f9125
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
 KUDr parents: 
3870diff
changeset | 541 | void* perf = NpfBeginInterval(); | 
| 
4984308f9125
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
 KUDr parents: 
3870diff
changeset | 542 | NPFFoundTargetData ret = NPFRouteToStationOrTile(tile, trackdir, target, type, owner, railtypes); | 
| 
4984308f9125
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
 KUDr parents: 
3870diff
changeset | 543 | int t = NpfEndInterval(perf); | 
| 5568 
75f13d7bfaed
(svn r7565) -Codechange: Rework DEBUG functionality. Look for appropiate debugging levels to
 Darkvater parents: 
5259diff
changeset | 544 | DEBUG(yapf, 4, "[NPFW] %d us - %d rounds - %d open - %d closed -- ", t, 0, _aystar_stats_open_size, _aystar_stats_closed_size); | 
| 3900 
4984308f9125
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
 KUDr parents: 
3870diff
changeset | 545 | return ret; | 
| 
4984308f9125
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
 KUDr parents: 
3870diff
changeset | 546 | } | 
| 
4984308f9125
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
 KUDr parents: 
3870diff
changeset | 547 | |
| 6916 
e87d54a598ea
(svn r9556) -Documentation: doxygen and comment-style changes. 'R', 'S'.. The end of the preliminary work is near
 belugas parents: 
6903diff
changeset | 548 | /** returns the track to choose on the next tile, or -1 when it's better to | 
| 1247 | 549 | * reverse. The tile given is the tile we are about to enter, enterdir is the | 
| 550 | * direction in which we are entering the tile */ | |
| 5838 
9c3129cb019b
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
 rubidium parents: 
5835diff
changeset | 551 | static Track ChooseShipTrack(Vehicle *v, TileIndex tile, DiagDirection enterdir, TrackBits tracks) | 
| 0 | 552 | {
 | 
| 1247 | 553 | assert(enterdir>=0 && enterdir<=3); | 
| 0 | 554 | |
| 3900 
4984308f9125
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
 KUDr parents: 
3870diff
changeset | 555 | 	if (_patches.yapf.ship_use_yapf) {
 | 
| 
4984308f9125
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
 KUDr parents: 
3870diff
changeset | 556 | Trackdir trackdir = YapfChooseShipTrack(v, tile, enterdir, tracks); | 
| 5838 
9c3129cb019b
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
 rubidium parents: 
5835diff
changeset | 557 | return (trackdir != INVALID_TRACKDIR) ? TrackdirToTrack(trackdir) : INVALID_TRACK; | 
| 3900 
4984308f9125
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
 KUDr parents: 
3870diff
changeset | 558 | 	} else if (_patches.new_pathfinding_all) {
 | 
| 1247 | 559 | NPFFindStationOrTileData fstd; | 
| 560 | NPFFoundTargetData ftd; | |
| 4559 
c853d2440065
(svn r6406) -Codechange: Rename TileOffsByDir to TileOffsByDiagDir because it accepts
 Darkvater parents: 
4546diff
changeset | 561 | TileIndex src_tile = TILE_ADD(tile, TileOffsByDiagDir(ReverseDiagDir(enterdir))); | 
| 5838 
9c3129cb019b
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
 rubidium parents: 
5835diff
changeset | 562 | Trackdir trackdir = GetVehicleTrackdir(v); | 
| 6916 
e87d54a598ea
(svn r9556) -Documentation: doxygen and comment-style changes. 'R', 'S'.. The end of the preliminary work is near
 belugas parents: 
6903diff
changeset | 563 | assert(trackdir != INVALID_TRACKDIR); // Check that we are not in a depot | 
| 1247 | 564 | |
| 565 | NPFFillWithOrderData(&fstd, v); | |
| 566 | ||
| 3900 
4984308f9125
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
 KUDr parents: 
3870diff
changeset | 567 | ftd = PerfNPFRouteToStationOrTile(src_tile, trackdir, &fstd, TRANSPORT_WATER, v->owner, INVALID_RAILTYPE); | 
| 1247 | 568 | |
| 2639 | 569 | 		if (ftd.best_trackdir != 0xff) {
 | 
| 1698 
bf364c664a60
(svn r2202) - Fix: [NPF] When a vehicle could not reach its target, it would choose a random direction. It will now try to get as close as possible.
 matthijs parents: 
1530diff
changeset | 570 | /* If ftd.best_bird_dist is 0, we found our target and ftd.best_trackdir contains | 
| 
bf364c664a60
(svn r2202) - Fix: [NPF] When a vehicle could not reach its target, it would choose a random direction. It will now try to get as close as possible.
 matthijs parents: 
1530diff
changeset | 571 | the direction we need to take to get there, if ftd.best_bird_dist is not 0, | 
| 
bf364c664a60
(svn r2202) - Fix: [NPF] When a vehicle could not reach its target, it would choose a random direction. It will now try to get as close as possible.
 matthijs parents: 
1530diff
changeset | 572 | we did not find our target, but ftd.best_trackdir contains the direction leading | 
| 
bf364c664a60
(svn r2202) - Fix: [NPF] When a vehicle could not reach its target, it would choose a random direction. It will now try to get as close as possible.
 matthijs parents: 
1530diff
changeset | 573 | to the tile closest to our target. */ | 
| 5838 
9c3129cb019b
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
 rubidium parents: 
5835diff
changeset | 574 | return TrackdirToTrack(ftd.best_trackdir); /* TODO: Wrapper function? */ | 
| 2639 | 575 | 		} else {
 | 
| 5838 
9c3129cb019b
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
 rubidium parents: 
5835diff
changeset | 576 | return INVALID_TRACK; /* Already at target, reverse? */ | 
| 2639 | 577 | } | 
| 1247 | 578 | 	} else {
 | 
| 579 | uint tot_dist, dist; | |
| 5838 
9c3129cb019b
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
 rubidium parents: 
5835diff
changeset | 580 | Track track; | 
| 1977 
4392ae3d8e31
(svn r2483) Replace almost 500 "uint tile" (and variants) with "TileIndex tile"
 tron parents: 
1942diff
changeset | 581 | TileIndex tile2; | 
| 1247 | 582 | |
| 4559 
c853d2440065
(svn r6406) -Codechange: Rename TileOffsByDir to TileOffsByDiagDir because it accepts
 Darkvater parents: 
4546diff
changeset | 583 | tile2 = TILE_ADD(tile, -TileOffsByDiagDir(enterdir)); | 
| 1247 | 584 | tot_dist = (uint)-1; | 
| 585 | ||
| 586 | /* Let's find out how far it would be if we would reverse first */ | |
| 5838 
9c3129cb019b
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
 rubidium parents: 
5835diff
changeset | 587 | TrackBits b = GetTileShipTrackStatus(tile2) & _ship_sometracks[ReverseDiagDir(enterdir)] & v->u.ship.state; | 
| 1247 | 588 | 		if (b != 0) {
 | 
| 3147 
0a09ce6d651a
(svn r3767) Move all direction related enums and functions to a separate header
 tron parents: 
3140diff
changeset | 589 | dist = FindShipTrack(v, tile2, ReverseDiagDir(enterdir), b, tile, &track); | 
| 1247 | 590 | if (dist != (uint)-1) | 
| 591 | tot_dist = dist + 1; | |
| 592 | } | |
| 593 | /* And if we would not reverse? */ | |
| 594 | dist = FindShipTrack(v, tile, enterdir, tracks, 0, &track); | |
| 595 | if (dist > tot_dist) | |
| 596 | /* We could better reverse */ | |
| 5838 
9c3129cb019b
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
 rubidium parents: 
5835diff
changeset | 597 | return INVALID_TRACK; | 
| 1247 | 598 | return track; | 
| 0 | 599 | } | 
| 600 | } | |
| 601 | ||
| 3157 
40de8616c04c
(svn r3783) Replace further ints and magic numbers by Direction, DiagDirection and friends
 tron parents: 
3147diff
changeset | 602 | static const Direction _new_vehicle_direction_table[] = {
 | 
| 5838 
9c3129cb019b
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
 rubidium parents: 
5835diff
changeset | 603 | DIR_N , DIR_NW, DIR_W , INVALID_DIR, | 
| 
9c3129cb019b
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
 rubidium parents: 
5835diff
changeset | 604 | DIR_NE, DIR_N , DIR_SW, INVALID_DIR, | 
| 3157 
40de8616c04c
(svn r3783) Replace further ints and magic numbers by Direction, DiagDirection and friends
 tron parents: 
3147diff
changeset | 605 | DIR_E , DIR_SE, DIR_S | 
| 0 | 606 | }; | 
| 607 | ||
| 5838 
9c3129cb019b
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
 rubidium parents: 
5835diff
changeset | 608 | static Direction ShipGetNewDirectionFromTiles(TileIndex new_tile, TileIndex old_tile) | 
| 0 | 609 | {
 | 
| 926 
bd4312619522
(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: 
919diff
changeset | 610 | uint offs = (TileY(new_tile) - TileY(old_tile) + 1) * 4 + | 
| 
bd4312619522
(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: 
919diff
changeset | 611 | TileX(new_tile) - TileX(old_tile) + 1; | 
| 0 | 612 | assert(offs < 11 && offs != 3 && offs != 7); | 
| 613 | return _new_vehicle_direction_table[offs]; | |
| 614 | } | |
| 615 | ||
| 5838 
9c3129cb019b
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
 rubidium parents: 
5835diff
changeset | 616 | static Direction ShipGetNewDirection(Vehicle *v, int x, int y) | 
| 0 | 617 | {
 | 
| 618 | uint offs = (y - v->y_pos + 1) * 4 + (x - v->x_pos + 1); | |
| 619 | assert(offs < 11 && offs != 3 && offs != 7); | |
| 620 | return _new_vehicle_direction_table[offs]; | |
| 621 | } | |
| 622 | ||
| 5838 
9c3129cb019b
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
 rubidium parents: 
5835diff
changeset | 623 | static TrackBits GetAvailShipTracks(TileIndex tile, int dir) | 
| 0 | 624 | {
 | 
| 159 
139cf78bfb28
(svn r160) -Codechange: made GetTileTrackStatus more readable (blathijs)
 truelight parents: 
156diff
changeset | 625 | uint32 r = GetTileTrackStatus(tile, TRANSPORT_WATER); | 
| 5838 
9c3129cb019b
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
 rubidium parents: 
5835diff
changeset | 626 | return (TrackBits)((r | r >> 8) & _ship_sometracks[dir]); | 
| 0 | 627 | } | 
| 628 | ||
| 629 | static const byte _ship_subcoord[4][6][3] = {
 | |
| 630 | 	{
 | |
| 631 | 		{15, 8, 1},
 | |
| 632 | 		{ 0, 0, 0},
 | |
| 633 | 		{ 0, 0, 0},
 | |
| 634 | 		{15, 8, 2},
 | |
| 635 | 		{15, 7, 0},
 | |
| 636 | 		{ 0, 0, 0},
 | |
| 637 | }, | |
| 638 | 	{
 | |
| 639 | 		{ 0, 0, 0},
 | |
| 640 | 		{ 8, 0, 3},
 | |
| 641 | 		{ 7, 0, 2},
 | |
| 642 | 		{ 0, 0, 0},
 | |
| 643 | 		{ 8, 0, 4},
 | |
| 644 | 		{ 0, 0, 0},
 | |
| 645 | }, | |
| 646 | 	{
 | |
| 647 | 		{ 0, 8, 5},
 | |
| 648 | 		{ 0, 0, 0},
 | |
| 649 | 		{ 0, 7, 6},
 | |
| 650 | 		{ 0, 0, 0},
 | |
| 651 | 		{ 0, 0, 0},
 | |
| 652 | 		{ 0, 8, 4},
 | |
| 653 | }, | |
| 654 | 	{
 | |
| 655 | 		{ 0, 0, 0},
 | |
| 656 | 		{ 8,15, 7},
 | |
| 657 | 		{ 0, 0, 0},
 | |
| 658 | 		{ 8,15, 6},
 | |
| 659 | 		{ 0, 0, 0},
 | |
| 660 | 		{ 7,15, 0},
 | |
| 661 | } | |
| 662 | }; | |
| 663 | ||
| 664 | static void ShipController(Vehicle *v) | |
| 665 | {
 | |
| 666 | uint32 r; | |
| 667 | const byte *b; | |
| 3157 
40de8616c04c
(svn r3783) Replace further ints and magic numbers by Direction, DiagDirection and friends
 tron parents: 
3147diff
changeset | 668 | Direction dir; | 
| 5838 
9c3129cb019b
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
 rubidium parents: 
5835diff
changeset | 669 | Track track; | 
| 
9c3129cb019b
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
 rubidium parents: 
5835diff
changeset | 670 | TrackBits tracks; | 
| 0 | 671 | |
| 672 | v->tick_counter++; | |
| 673 | ||
| 674 | 	if (v->breakdown_ctr != 0) {
 | |
| 675 | 		if (v->breakdown_ctr <= 2) {
 | |
| 676 | HandleBrokenShip(v); | |
| 677 | return; | |
| 678 | } | |
| 679 | v->breakdown_ctr--; | |
| 680 | } | |
| 681 | ||
| 2639 | 682 | if (v->vehstatus & VS_STOPPED) return; | 
| 0 | 683 | |
| 684 | ProcessShipOrder(v); | |
| 685 | HandleShipLoading(v); | |
| 686 | ||
| 2639 | 687 | if (v->current_order.type == OT_LOADING) return; | 
| 0 | 688 | |
| 689 | CheckShipLeaveDepot(v); | |
| 690 | ||
| 2639 | 691 | if (!ShipAccelerate(v)) return; | 
| 0 | 692 | |
| 693 | BeginVehicleMove(v); | |
| 694 | ||
| 6479 | 695 | GetNewVehiclePosResult gp = GetNewVehiclePos(v); | 
| 6478 | 696 | 	if (gp.old_tile == gp.new_tile) {
 | 
| 6320 
5fc5a089b147
(svn r8703) -Codechange/cleanup: some magic numbers -> enums and other small coding style changes to the ShipController and TrainController.
 rubidium parents: 
6319diff
changeset | 697 | /* Staying in tile */ | 
| 3961 
e2783f244ac6
(svn r5120) Add IsShipInDepot{Stopped,}() and remove some redundant checks
 tron parents: 
3955diff
changeset | 698 | 		if (IsShipInDepot(v)) {
 | 
| 0 | 699 | gp.x = v->x_pos; | 
| 700 | gp.y = v->y_pos; | |
| 701 | 		} else {
 | |
| 6320 
5fc5a089b147
(svn r8703) -Codechange/cleanup: some magic numbers -> enums and other small coding style changes to the ShipController and TrainController.
 rubidium parents: 
6319diff
changeset | 702 | /* Not inside depot */ | 
| 0 | 703 | r = VehicleEnterTile(v, gp.new_tile, gp.x, gp.y); | 
| 6317 
c73bda71ac16
(svn r8698) -Codechange: enumify the returns of VehicleEnterTile
 rubidium parents: 
6223diff
changeset | 704 | if (HASBIT(r, VETS_CANNOT_ENTER)) goto reverse_direction; | 
| 0 | 705 | |
| 1751 
954dd2900ac9
(svn r2255) - Fix: [ 9680363 ] [NPF] Broken buoy handling for ships
 matthijs parents: 
1698diff
changeset | 706 | /* A leave station order only needs one tick to get processed, so we can | 
| 
954dd2900ac9
(svn r2255) - Fix: [ 9680363 ] [NPF] Broken buoy handling for ships
 matthijs parents: 
1698diff
changeset | 707 | * always skip ahead. */ | 
| 555 
eec6c0294435
(svn r955) Replace uint16 for orders with struct Order
 tron parents: 
541diff
changeset | 708 | 			if (v->current_order.type == OT_LEAVESTATION) {
 | 
| 6589 
addf4b6946d0
(svn r9072) -Codechange: [Orders] added methods to orders to free them and check if they are in use
 bjarni parents: 
6585diff
changeset | 709 | v->current_order.Free(); | 
| 755 
823358e83abf
(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: 
679diff
changeset | 710 | InvalidateWindowWidget(WC_VEHICLE_VIEW, v->index, STATUS_BAR); | 
| 1751 
954dd2900ac9
(svn r2255) - Fix: [ 9680363 ] [NPF] Broken buoy handling for ships
 matthijs parents: 
1698diff
changeset | 711 | 			} else if (v->dest_tile != 0) {
 | 
| 
954dd2900ac9
(svn r2255) - Fix: [ 9680363 ] [NPF] Broken buoy handling for ships
 matthijs parents: 
1698diff
changeset | 712 | /* We have a target, let's see if we reached it... */ | 
| 
954dd2900ac9
(svn r2255) - Fix: [ 9680363 ] [NPF] Broken buoy handling for ships
 matthijs parents: 
1698diff
changeset | 713 | if (v->current_order.type == OT_GOTO_STATION && | 
| 
954dd2900ac9
(svn r2255) - Fix: [ 9680363 ] [NPF] Broken buoy handling for ships
 matthijs parents: 
1698diff
changeset | 714 | IsBuoyTile(v->dest_tile) && | 
| 
954dd2900ac9
(svn r2255) - Fix: [ 9680363 ] [NPF] Broken buoy handling for ships
 matthijs parents: 
1698diff
changeset | 715 | 						DistanceManhattan(v->dest_tile, gp.new_tile) <= 3) {
 | 
| 
954dd2900ac9
(svn r2255) - Fix: [ 9680363 ] [NPF] Broken buoy handling for ships
 matthijs parents: 
1698diff
changeset | 716 | /* We got within 3 tiles of our target buoy, so let's skip to our | 
| 
954dd2900ac9
(svn r2255) - Fix: [ 9680363 ] [NPF] Broken buoy handling for ships
 matthijs parents: 
1698diff
changeset | 717 | * next order */ | 
| 
954dd2900ac9
(svn r2255) - Fix: [ 9680363 ] [NPF] Broken buoy handling for ships
 matthijs parents: 
1698diff
changeset | 718 | v->cur_order_index++; | 
| 
954dd2900ac9
(svn r2255) - Fix: [ 9680363 ] [NPF] Broken buoy handling for ships
 matthijs parents: 
1698diff
changeset | 719 | v->current_order.type = OT_DUMMY; | 
| 
954dd2900ac9
(svn r2255) - Fix: [ 9680363 ] [NPF] Broken buoy handling for ships
 matthijs parents: 
1698diff
changeset | 720 | InvalidateVehicleOrder(v); | 
| 
954dd2900ac9
(svn r2255) - Fix: [ 9680363 ] [NPF] Broken buoy handling for ships
 matthijs parents: 
1698diff
changeset | 721 | 				} else {
 | 
| 
954dd2900ac9
(svn r2255) - Fix: [ 9680363 ] [NPF] Broken buoy handling for ships
 matthijs parents: 
1698diff
changeset | 722 | /* Non-buoy orders really need to reach the tile */ | 
| 
954dd2900ac9
(svn r2255) - Fix: [ 9680363 ] [NPF] Broken buoy handling for ships
 matthijs parents: 
1698diff
changeset | 723 | 					if (v->dest_tile == gp.new_tile) {
 | 
| 
954dd2900ac9
(svn r2255) - Fix: [ 9680363 ] [NPF] Broken buoy handling for ships
 matthijs parents: 
1698diff
changeset | 724 | 						if (v->current_order.type == OT_GOTO_DEPOT) {
 | 
| 6320 
5fc5a089b147
(svn r8703) -Codechange/cleanup: some magic numbers -> enums and other small coding style changes to the ShipController and TrainController.
 rubidium parents: 
6319diff
changeset | 725 | 							if ((gp.x & 0xF) == 8 && (gp.y & 0xF) == 8) {
 | 
| 4725 
f7284b86833f
(svn r6637) -Codechange: merged all (vehicle type)EnterDepot into VehicleEnterDepot()
 bjarni parents: 
4712diff
changeset | 726 | VehicleEnterDepot(v); | 
| 1751 
954dd2900ac9
(svn r2255) - Fix: [ 9680363 ] [NPF] Broken buoy handling for ships
 matthijs parents: 
1698diff
changeset | 727 | return; | 
| 
954dd2900ac9
(svn r2255) - Fix: [ 9680363 ] [NPF] Broken buoy handling for ships
 matthijs parents: 
1698diff
changeset | 728 | } | 
| 
954dd2900ac9
(svn r2255) - Fix: [ 9680363 ] [NPF] Broken buoy handling for ships
 matthijs parents: 
1698diff
changeset | 729 | 						} else if (v->current_order.type == OT_GOTO_STATION) {
 | 
| 
954dd2900ac9
(svn r2255) - Fix: [ 9680363 ] [NPF] Broken buoy handling for ships
 matthijs parents: 
1698diff
changeset | 730 | Station *st; | 
| 
954dd2900ac9
(svn r2255) - Fix: [ 9680363 ] [NPF] Broken buoy handling for ships
 matthijs parents: 
1698diff
changeset | 731 | |
| 4527 
b18634a31a4a
(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: 
4526diff
changeset | 732 | v->last_station_visited = v->current_order.dest; | 
| 1751 
954dd2900ac9
(svn r2255) - Fix: [ 9680363 ] [NPF] Broken buoy handling for ships
 matthijs parents: 
1698diff
changeset | 733 | |
| 
954dd2900ac9
(svn r2255) - Fix: [ 9680363 ] [NPF] Broken buoy handling for ships
 matthijs parents: 
1698diff
changeset | 734 | /* Process station in the orderlist. */ | 
| 4527 
b18634a31a4a
(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: 
4526diff
changeset | 735 | st = GetStation(v->current_order.dest); | 
| 6916 
e87d54a598ea
(svn r9556) -Documentation: doxygen and comment-style changes. 'R', 'S'.. The end of the preliminary work is near
 belugas parents: 
6903diff
changeset | 736 | 							if (st->facilities & FACIL_DOCK) { // ugly, ugly workaround for problem with ships able to drop off cargo at wrong stations
 | 
| 5902 
906fea1535ab
(svn r8110) -Codechange: direct Vehicle::current_order.type changes (to OT_LOADING and OT_LEAVESTATION) replaced by v->BeginLoading() and v->LeaveStation() calls. This should allow easy hooking of those state transitions in order to maintain vehicle loading queue.
 KUDr parents: 
5849diff
changeset | 737 | v->BeginLoading(); | 
| 3610 
d33499b2250c
(svn r4505) -Fix (FS#94) Ships can now be used to set up feeders as well.
 celestar parents: 
3491diff
changeset | 738 | v->current_order.flags &= OF_FULL_LOAD | OF_UNLOAD | OF_TRANSFER; | 
| 1751 
954dd2900ac9
(svn r2255) - Fix: [ 9680363 ] [NPF] Broken buoy handling for ships
 matthijs parents: 
1698diff
changeset | 739 | v->current_order.flags |= OF_NON_STOP; | 
| 
954dd2900ac9
(svn r2255) - Fix: [ 9680363 ] [NPF] Broken buoy handling for ships
 matthijs parents: 
1698diff
changeset | 740 | ShipArrivesAt(v, st); | 
| 
954dd2900ac9
(svn r2255) - Fix: [ 9680363 ] [NPF] Broken buoy handling for ships
 matthijs parents: 
1698diff
changeset | 741 | |
| 
954dd2900ac9
(svn r2255) - Fix: [ 9680363 ] [NPF] Broken buoy handling for ships
 matthijs parents: 
1698diff
changeset | 742 | SET_EXPENSES_TYPE(EXPENSES_SHIP_INC); | 
| 5211 
651c9272ad22
(svn r7326) -Feature: Add support for gradual (un)loading of vehicles (Maedhros)
 peter1138 parents: 
5198diff
changeset | 743 | 								if (LoadUnloadVehicle(v, true)) {
 | 
| 1751 
954dd2900ac9
(svn r2255) - Fix: [ 9680363 ] [NPF] Broken buoy handling for ships
 matthijs parents: 
1698diff
changeset | 744 | InvalidateWindow(WC_SHIPS_LIST, v->owner); | 
| 
954dd2900ac9
(svn r2255) - Fix: [ 9680363 ] [NPF] Broken buoy handling for ships
 matthijs parents: 
1698diff
changeset | 745 | MarkShipDirty(v); | 
| 
954dd2900ac9
(svn r2255) - Fix: [ 9680363 ] [NPF] Broken buoy handling for ships
 matthijs parents: 
1698diff
changeset | 746 | } | 
| 
954dd2900ac9
(svn r2255) - Fix: [ 9680363 ] [NPF] Broken buoy handling for ships
 matthijs parents: 
1698diff
changeset | 747 | InvalidateWindowWidget(WC_VEHICLE_VIEW, v->index, STATUS_BAR); | 
| 6916 
e87d54a598ea
(svn r9556) -Documentation: doxygen and comment-style changes. 'R', 'S'.. The end of the preliminary work is near
 belugas parents: 
6903diff
changeset | 748 | 							} else { // leave stations without docks right aways
 | 
| 1751 
954dd2900ac9
(svn r2255) - Fix: [ 9680363 ] [NPF] Broken buoy handling for ships
 matthijs parents: 
1698diff
changeset | 749 | v->current_order.type = OT_LEAVESTATION; | 
| 
954dd2900ac9
(svn r2255) - Fix: [ 9680363 ] [NPF] Broken buoy handling for ships
 matthijs parents: 
1698diff
changeset | 750 | v->cur_order_index++; | 
| 
954dd2900ac9
(svn r2255) - Fix: [ 9680363 ] [NPF] Broken buoy handling for ships
 matthijs parents: 
1698diff
changeset | 751 | InvalidateVehicleOrder(v); | 
| 
954dd2900ac9
(svn r2255) - Fix: [ 9680363 ] [NPF] Broken buoy handling for ships
 matthijs parents: 
1698diff
changeset | 752 | } | 
| 
954dd2900ac9
(svn r2255) - Fix: [ 9680363 ] [NPF] Broken buoy handling for ships
 matthijs parents: 
1698diff
changeset | 753 | } | 
| 
954dd2900ac9
(svn r2255) - Fix: [ 9680363 ] [NPF] Broken buoy handling for ships
 matthijs parents: 
1698diff
changeset | 754 | } | 
| 
954dd2900ac9
(svn r2255) - Fix: [ 9680363 ] [NPF] Broken buoy handling for ships
 matthijs parents: 
1698diff
changeset | 755 | } | 
| 0 | 756 | } | 
| 757 | } | |
| 758 | 	} else {
 | |
| 3157 
40de8616c04c
(svn r3783) Replace further ints and magic numbers by Direction, DiagDirection and friends
 tron parents: 
3147diff
changeset | 759 | DiagDirection diagdir; | 
| 6320 
5fc5a089b147
(svn r8703) -Codechange/cleanup: some magic numbers -> enums and other small coding style changes to the ShipController and TrainController.
 rubidium parents: 
6319diff
changeset | 760 | /* New tile */ | 
| 
5fc5a089b147
(svn r8703) -Codechange/cleanup: some magic numbers -> enums and other small coding style changes to the ShipController and TrainController.
 rubidium parents: 
6319diff
changeset | 761 | 		if (TileX(gp.new_tile) >= MapMaxX() || TileY(gp.new_tile) >= MapMaxY()) {
 | 
| 926 
bd4312619522
(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: 
919diff
changeset | 762 | goto reverse_direction; | 
| 6320 
5fc5a089b147
(svn r8703) -Codechange/cleanup: some magic numbers -> enums and other small coding style changes to the ShipController and TrainController.
 rubidium parents: 
6319diff
changeset | 763 | } | 
| 0 | 764 | |
| 765 | dir = ShipGetNewDirectionFromTiles(gp.new_tile, gp.old_tile); | |
| 3157 
40de8616c04c
(svn r3783) Replace further ints and magic numbers by Direction, DiagDirection and friends
 tron parents: 
3147diff
changeset | 766 | assert(dir == DIR_NE || dir == DIR_SE || dir == DIR_SW || dir == DIR_NW); | 
| 
40de8616c04c
(svn r3783) Replace further ints and magic numbers by Direction, DiagDirection and friends
 tron parents: 
3147diff
changeset | 767 | diagdir = DirToDiagDir(dir); | 
| 
40de8616c04c
(svn r3783) Replace further ints and magic numbers by Direction, DiagDirection and friends
 tron parents: 
3147diff
changeset | 768 | tracks = GetAvailShipTracks(gp.new_tile, diagdir); | 
| 6320 
5fc5a089b147
(svn r8703) -Codechange/cleanup: some magic numbers -> enums and other small coding style changes to the ShipController and TrainController.
 rubidium parents: 
6319diff
changeset | 769 | if (tracks == TRACK_BIT_NONE) goto reverse_direction; | 
| 0 | 770 | |
| 6320 
5fc5a089b147
(svn r8703) -Codechange/cleanup: some magic numbers -> enums and other small coding style changes to the ShipController and TrainController.
 rubidium parents: 
6319diff
changeset | 771 | /* Choose a direction, and continue if we find one */ | 
| 3157 
40de8616c04c
(svn r3783) Replace further ints and magic numbers by Direction, DiagDirection and friends
 tron parents: 
3147diff
changeset | 772 | track = ChooseShipTrack(v, gp.new_tile, diagdir, tracks); | 
| 6320 
5fc5a089b147
(svn r8703) -Codechange/cleanup: some magic numbers -> enums and other small coding style changes to the ShipController and TrainController.
 rubidium parents: 
6319diff
changeset | 773 | if (track == INVALID_TRACK) goto reverse_direction; | 
| 0 | 774 | |
| 3157 
40de8616c04c
(svn r3783) Replace further ints and magic numbers by Direction, DiagDirection and friends
 tron parents: 
3147diff
changeset | 775 | b = _ship_subcoord[diagdir][track]; | 
| 193 
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
 truelight parents: 
164diff
changeset | 776 | |
| 6320 
5fc5a089b147
(svn r8703) -Codechange/cleanup: some magic numbers -> enums and other small coding style changes to the ShipController and TrainController.
 rubidium parents: 
6319diff
changeset | 777 | gp.x = (gp.x & ~0xF) | b[0]; | 
| 
5fc5a089b147
(svn r8703) -Codechange/cleanup: some magic numbers -> enums and other small coding style changes to the ShipController and TrainController.
 rubidium parents: 
6319diff
changeset | 778 | gp.y = (gp.y & ~0xF) | b[1]; | 
| 0 | 779 | |
| 780 | /* Call the landscape function and tell it that the vehicle entered the tile */ | |
| 781 | r = VehicleEnterTile(v, gp.new_tile, gp.x, gp.y); | |
| 6317 
c73bda71ac16
(svn r8698) -Codechange: enumify the returns of VehicleEnterTile
 rubidium parents: 
6223diff
changeset | 782 | if (HASBIT(r, VETS_CANNOT_ENTER)) goto reverse_direction; | 
| 0 | 783 | |
| 6317 
c73bda71ac16
(svn r8698) -Codechange: enumify the returns of VehicleEnterTile
 rubidium parents: 
6223diff
changeset | 784 | 		if (!HASBIT(r, VETS_ENTERED_WORMHOLE)) {
 | 
| 0 | 785 | v->tile = gp.new_tile; | 
| 5838 
9c3129cb019b
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
 rubidium parents: 
5835diff
changeset | 786 | v->u.ship.state = TrackToTrackBits(track); | 
| 0 | 787 | } | 
| 788 | ||
| 5838 
9c3129cb019b
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
 rubidium parents: 
5835diff
changeset | 789 | v->direction = (Direction)b[2]; | 
| 0 | 790 | } | 
| 791 | ||
| 792 | /* update image of ship, as well as delta XY */ | |
| 793 | dir = ShipGetNewDirection(v, gp.x, gp.y); | |
| 794 | v->x_pos = gp.x; | |
| 795 | v->y_pos = gp.y; | |
| 796 | v->z_pos = GetSlopeZ(gp.x, gp.y); | |
| 797 | ||
| 798 | getout: | |
| 799 | UpdateShipDeltaXY(v, dir); | |
| 800 | v->cur_image = GetShipImage(v, dir); | |
| 801 | VehiclePositionChanged(v); | |
| 802 | EndVehicleMove(v); | |
| 803 | return; | |
| 804 | ||
| 805 | reverse_direction: | |
| 3157 
40de8616c04c
(svn r3783) Replace further ints and magic numbers by Direction, DiagDirection and friends
 tron parents: 
3147diff
changeset | 806 | dir = ReverseDir(v->direction); | 
| 0 | 807 | v->direction = dir; | 
| 808 | goto getout; | |
| 809 | } | |
| 810 | ||
| 811 | static void AgeShipCargo(Vehicle *v) | |
| 812 | {
 | |
| 2639 | 813 | if (_age_cargo_skip_counter != 0) return; | 
| 814 | if (v->cargo_days != 255) v->cargo_days++; | |
| 0 | 815 | } | 
| 816 | ||
| 817 | void Ship_Tick(Vehicle *v) | |
| 818 | {
 | |
| 819 | AgeShipCargo(v); | |
| 820 | ShipController(v); | |
| 821 | } | |
| 822 | ||
| 823 | ||
| 6573 | 824 | void ShipsYearlyLoop() | 
| 0 | 825 | {
 | 
| 826 | Vehicle *v; | |
| 827 | ||
| 828 | 	FOR_ALL_VEHICLES(v) {
 | |
| 6585 
7da94b26498a
(svn r9068) -Codechange: capitalize the VEH_Train etc. enums to match the coding style (and rest of the code).
 rubidium parents: 
6574diff
changeset | 829 | 		if (v->type == VEH_SHIP) {
 | 
| 0 | 830 | v->profit_last_year = v->profit_this_year; | 
| 831 | v->profit_this_year = 0; | |
| 832 | InvalidateWindow(WC_VEHICLE_DETAILS, v->index); | |
| 833 | } | |
| 834 | } | |
| 835 | } | |
| 836 | ||
| 1793 
8ac8a8c9ec0f
(svn r2297) - CodeChange: server-check the next batch of commands.
 Darkvater parents: 
1790diff
changeset | 837 | /** Build a ship. | 
| 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: 
3476diff
changeset | 838 | * @param tile tile of depot where ship is built | 
| 6916 
e87d54a598ea
(svn r9556) -Documentation: doxygen and comment-style changes. 'R', 'S'.. The end of the preliminary work is near
 belugas parents: 
6903diff
changeset | 839 | * @param flags type of operation | 
| 1793 
8ac8a8c9ec0f
(svn r2297) - CodeChange: server-check the next batch of commands.
 Darkvater parents: 
1790diff
changeset | 840 | * @param p1 ship type being built (engine) | 
| 3816 
2cdb29b57c1f
(svn r4826) -Fix: [autoreplace] fixed possible problem when autoreplacing and was number of vehicles (of a type, not total) was reached
 bjarni parents: 
3645diff
changeset | 841 | * @param p2 bit 0 when set, the unitnumber will be 0, otherwise it will be a free number | 
| 1793 
8ac8a8c9ec0f
(svn r2297) - CodeChange: server-check the next batch of commands.
 Darkvater parents: 
1790diff
changeset | 842 | */ | 
| 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: 
3476diff
changeset | 843 | int32 CmdBuildShip(TileIndex tile, uint32 flags, uint32 p1, uint32 p2) | 
| 0 | 844 | {
 | 
| 845 | int32 value; | |
| 846 | Vehicle *v; | |
| 1282 
e7a73ee62d2f
(svn r1786) -Fix: unitnumber is increased to 16bit, so now you can have up to 5000
 truelight parents: 
1266diff
changeset | 847 | UnitID unit_num; | 
| 0 | 848 | Engine *e; | 
| 193 
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
 truelight parents: 
164diff
changeset | 849 | |
| 6903 
0b3d43bd1fdb
(svn r9543) -Fix [FS#691]: Split up STR_ENGINE_NOT_BUILDABLE into four strings so it can be
 maedhros parents: 
6683diff
changeset | 850 | if (!IsEngineBuildable(p1, VEH_SHIP, _current_player)) return_cmd_error(STR_SHIP_NOT_AVAILABLE); | 
| 1196 
115f46e3807d
(svn r1700) - Fix: Hacked clients can no longer be used to build vehicles that are not available yet (Hackykid)
 bjarni parents: 
1151diff
changeset | 851 | |
| 0 | 852 | SET_EXPENSES_TYPE(EXPENSES_NEW_VEHICLES); | 
| 853 | ||
| 854 | value = EstimateShipCost(p1); | |
| 1793 
8ac8a8c9ec0f
(svn r2297) - CodeChange: server-check the next batch of commands.
 Darkvater parents: 
1790diff
changeset | 855 | if (flags & DC_QUERY_COST) return value; | 
| 0 | 856 | |
| 1443 
d9c101f7634b
(svn r1947) As in r1946, permit DC_QUERY_COST even on non-depot tiles - so that it works for the ai_new. It is de iure not a bug yet but let's be safe against future annoying headaches. Signed-Off-By: TrueLight
 pasky parents: 
1401diff
changeset | 857 | /* The ai_new queries the vehicle cost before building the route, | 
| 
d9c101f7634b
(svn r1947) As in r1946, permit DC_QUERY_COST even on non-depot tiles - so that it works for the ai_new. It is de iure not a bug yet but let's be safe against future annoying headaches. Signed-Off-By: TrueLight
 pasky parents: 
1401diff
changeset | 858 | * so we must check against cheaters no sooner than now. --pasky */ | 
| 
d9c101f7634b
(svn r1947) As in r1946, permit DC_QUERY_COST even on non-depot tiles - so that it works for the ai_new. It is de iure not a bug yet but let's be safe against future annoying headaches. Signed-Off-By: TrueLight
 pasky parents: 
1401diff
changeset | 859 | if (!IsTileDepotType(tile, TRANSPORT_WATER)) return CMD_ERROR; | 
| 1901 
fb05044cf5c3
(svn r2407) Use {Get,Is}TileOwner to get/check the owner of a tile and fix some bogus reads of _map_owner
 tron parents: 
1891diff
changeset | 860 | if (!IsTileOwner(tile, _current_player)) return CMD_ERROR; | 
| 1443 
d9c101f7634b
(svn r1947) As in r1946, permit DC_QUERY_COST even on non-depot tiles - so that it works for the ai_new. It is de iure not a bug yet but let's be safe against future annoying headaches. Signed-Off-By: TrueLight
 pasky parents: 
1401diff
changeset | 861 | |
| 0 | 862 | v = AllocateVehicle(); | 
| 6585 
7da94b26498a
(svn r9068) -Codechange: capitalize the VEH_Train etc. enums to match the coding style (and rest of the code).
 rubidium parents: 
6574diff
changeset | 863 | unit_num = HASBIT(p2, 0) ? 0 : GetFreeUnitNumber(VEH_SHIP); | 
| 3816 
2cdb29b57c1f
(svn r4826) -Fix: [autoreplace] fixed possible problem when autoreplacing and was number of vehicles (of a type, not total) was reached
 bjarni parents: 
3645diff
changeset | 864 | |
| 6173 | 865 | if (v == NULL || unit_num > _patches.max_ships) | 
| 0 | 866 | return_cmd_error(STR_00E1_TOO_MANY_VEHICLES_IN_GAME); | 
| 193 
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
 truelight parents: 
164diff
changeset | 867 | |
| 0 | 868 | 	if (flags & DC_EXEC) {
 | 
| 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: 
3476diff
changeset | 869 | int x; | 
| 
4c8427796c64
(svn r4342) Change the first two parameters of commands - virtual pixel coordinates of the tile to operate on - to a TileIndex
 tron parents: 
3476diff
changeset | 870 | int y; | 
| 
4c8427796c64
(svn r4342) Change the first two parameters of commands - virtual pixel coordinates of the tile to operate on - to a TileIndex
 tron parents: 
3476diff
changeset | 871 | |
| 538 
5dd99f3b7eca
(svn r920) Replace vehicle info macros with inline functions and add asserts to check limits
 tron parents: 
534diff
changeset | 872 | const ShipVehicleInfo *svi = ShipVehInfo(p1); | 
| 
5dd99f3b7eca
(svn r920) Replace vehicle info macros with inline functions and add asserts to check limits
 tron parents: 
534diff
changeset | 873 | |
| 0 | 874 | v->unitnumber = unit_num; | 
| 875 | ||
| 876 | v->owner = _current_player; | |
| 877 | v->tile = tile; | |
| 3645 
86af43f87885
(svn r4554) Replace magic numbers by TILE_{HEIGHT,SIZE}
 tron parents: 
3610diff
changeset | 878 | x = TileX(tile) * TILE_SIZE + TILE_SIZE / 2; | 
| 
86af43f87885
(svn r4554) Replace magic numbers by TILE_{HEIGHT,SIZE}
 tron parents: 
3610diff
changeset | 879 | y = TileY(tile) * TILE_SIZE + TILE_SIZE / 2; | 
| 0 | 880 | v->x_pos = x; | 
| 881 | v->y_pos = y; | |
| 882 | v->z_pos = GetSlopeZ(x,y); | |
| 883 | ||
| 884 | v->z_height = 6; | |
| 885 | v->sprite_width = 6; | |
| 886 | v->sprite_height = 6; | |
| 887 | v->x_offs = -3; | |
| 888 | v->y_offs = -3; | |
| 889 | v->vehstatus = VS_HIDDEN | VS_STOPPED | VS_DEFPAL; | |
| 193 
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
 truelight parents: 
164diff
changeset | 890 | |
| 538 
5dd99f3b7eca
(svn r920) Replace vehicle info macros with inline functions and add asserts to check limits
 tron parents: 
534diff
changeset | 891 | v->spritenum = svi->image_index; | 
| 
5dd99f3b7eca
(svn r920) Replace vehicle info macros with inline functions and add asserts to check limits
 tron parents: 
534diff
changeset | 892 | v->cargo_type = svi->cargo_type; | 
| 3870 
766d7bd6c299
(svn r4910) - NewGRF: add and initialize cargo subtype for vehicle visual variations
 peter1138 parents: 
3816diff
changeset | 893 | v->cargo_subtype = 0; | 
| 538 
5dd99f3b7eca
(svn r920) Replace vehicle info macros with inline functions and add asserts to check limits
 tron parents: 
534diff
changeset | 894 | v->cargo_cap = svi->capacity; | 
| 0 | 895 | v->value = value; | 
| 193 
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
 truelight parents: 
164diff
changeset | 896 | |
| 1266 
9dc5638fe8cc
(svn r1770) -Fix: Hopefully last pieces of code that are containing a station-id
 truelight parents: 
1247diff
changeset | 897 | v->last_station_visited = INVALID_STATION; | 
| 538 
5dd99f3b7eca
(svn r920) Replace vehicle info macros with inline functions and add asserts to check limits
 tron parents: 
534diff
changeset | 898 | v->max_speed = svi->max_speed; | 
| 2477 
d454d5152386
(svn r3003) Change int, uint, uin16 and byte to EngineID where appropriate, plus some related changes (mostly casts)
 tron parents: 
2464diff
changeset | 899 | v->engine_type = p1; | 
| 0 | 900 | |
| 1926 
68d60188a22f
(svn r2432) Use GetEngine() instead of DEREF_ENGINE() or even _engines[]
 tron parents: 
1901diff
changeset | 901 | e = GetEngine(p1); | 
| 0 | 902 | v->reliability = e->reliability; | 
| 903 | v->reliability_spd_dec = e->reliability_spd_dec; | |
| 904 | v->max_age = e->lifelength * 366; | |
| 2564 | 905 | _new_vehicle_id = v->index; | 
| 0 | 906 | |
| 907 | v->string_id = STR_SV_SHIP_NAME; | |
| 6319 
27e68b914d3d
(svn r8701) -Codechange: replace magic numbers with enums for u.rail.track.
 rubidium parents: 
6317diff
changeset | 908 | v->u.ship.state = TRACK_BIT_DEPOT; | 
| 0 | 909 | |
| 910 | v->service_interval = _patches.servint_ships; | |
| 911 | v->date_of_last_service = _date; | |
| 4329 
9759d5c52010
(svn r6002) -Cleanup: remove the now redundant BASE_YEAR constant.
 rubidium parents: 
4293diff
changeset | 912 | v->build_year = _cur_year; | 
| 0 | 913 | v->cur_image = 0x0E5E; | 
| 6585 
7da94b26498a
(svn r9068) -Codechange: capitalize the VEH_Train etc. enums to match the coding style (and rest of the code).
 rubidium parents: 
6574diff
changeset | 914 | v->type = VEH_SHIP; | 
| 2804 
b932fe148d36
(svn r3352) - NewGRF: Move initialization of vehicle random_bits to DC_EXEC blocks to allow use of Random() instead of InteractiveRandom(), which will alleviate some possible network desyncs.
 peter1138 parents: 
2791diff
changeset | 915 | v->random_bits = VehicleRandomBits(); | 
| 0 | 916 | |
| 6502 
7ca154aca2b7
(svn r8946) -Feature: [NewGRF] Add support for vehicle variables 0xFE and 0xFF bit 10,
 maedhros parents: 
6501diff
changeset | 917 | v->vehicle_flags = 0; | 
| 
7ca154aca2b7
(svn r8946) -Feature: [NewGRF] Add support for vehicle variables 0xFE and 0xFF bit 10,
 maedhros parents: 
6501diff
changeset | 918 | if (e->flags & ENGINE_EXCLUSIVE_PREVIEW) SETBIT(v->vehicle_flags, VF_BUILT_AS_PROTOTYPE); | 
| 
7ca154aca2b7
(svn r8946) -Feature: [NewGRF] Add support for vehicle variables 0xFE and 0xFF bit 10,
 maedhros parents: 
6501diff
changeset | 919 | |
| 0 | 920 | VehiclePositionChanged(v); | 
| 921 | ||
| 4739 
bd535b408617
(svn r6651) -Coding feature: added the windowevent WE_INVALIDATE_DATA
 bjarni parents: 
4725diff
changeset | 922 | InvalidateWindowData(WC_VEHICLE_DEPOT, v->tile); | 
| 588 | 923 | RebuildVehicleLists(); | 
| 0 | 924 | InvalidateWindow(WC_COMPANY, v->owner); | 
| 2618 
7546b838230b
(svn r3156) -Fix: removed some cases where autoreplace windows were redrawn when nothing was changed
 bjarni parents: 
2574diff
changeset | 925 | if (IsLocalPlayer()) | 
| 6585 
7da94b26498a
(svn r9068) -Codechange: capitalize the VEH_Train etc. enums to match the coding style (and rest of the code).
 rubidium parents: 
6574diff
changeset | 926 | InvalidateAutoreplaceWindow(VEH_SHIP); // updates the replace Ship window | 
| 6195 
b90cf92697b9
(svn r8610) -Codechange/Feature: rewrote the list handling in the autoreplace window
 bjarni parents: 
6173diff
changeset | 927 | |
| 
b90cf92697b9
(svn r8610) -Codechange/Feature: rewrote the list handling in the autoreplace window
 bjarni parents: 
6173diff
changeset | 928 | GetPlayer(_current_player)->num_engines[p1]++; | 
| 0 | 929 | } | 
| 193 
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
 truelight parents: 
164diff
changeset | 930 | |
| 0 | 931 | return value; | 
| 932 | } | |
| 933 | ||
| 1793 
8ac8a8c9ec0f
(svn r2297) - CodeChange: server-check the next batch of commands.
 Darkvater parents: 
1790diff
changeset | 934 | /** Sell a ship. | 
| 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: 
3476diff
changeset | 935 | * @param tile unused | 
| 6916 
e87d54a598ea
(svn r9556) -Documentation: doxygen and comment-style changes. 'R', 'S'.. The end of the preliminary work is near
 belugas parents: 
6903diff
changeset | 936 | * @param flags type of operation | 
| 1793 
8ac8a8c9ec0f
(svn r2297) - CodeChange: server-check the next batch of commands.
 Darkvater parents: 
1790diff
changeset | 937 | * @param p1 vehicle ID to be sold | 
| 
8ac8a8c9ec0f
(svn r2297) - CodeChange: server-check the next batch of commands.
 Darkvater parents: 
1790diff
changeset | 938 | * @param p2 unused | 
| 
8ac8a8c9ec0f
(svn r2297) - CodeChange: server-check the next batch of commands.
 Darkvater parents: 
1790diff
changeset | 939 | */ | 
| 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: 
3476diff
changeset | 940 | int32 CmdSellShip(TileIndex tile, uint32 flags, uint32 p1, uint32 p2) | 
| 0 | 941 | {
 | 
| 942 | Vehicle *v; | |
| 943 | ||
| 4352 
8ddb01bc6075
(svn r6053) -Codechange: renamed all IsXXXIndex to IsValidXXXID
 truelight parents: 
4351diff
changeset | 944 | if (!IsValidVehicleID(p1)) return CMD_ERROR; | 
| 193 
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
 truelight parents: 
164diff
changeset | 945 | |
| 919 
b0d6c7642f99
(svn r1407) -Codechange: changed a lot around _stations, _vehicles, _towns and _industries
 truelight parents: 
915diff
changeset | 946 | v = GetVehicle(p1); | 
| 0 | 947 | |
| 6585 
7da94b26498a
(svn r9068) -Codechange: capitalize the VEH_Train etc. enums to match the coding style (and rest of the code).
 rubidium parents: 
6574diff
changeset | 948 | if (v->type != VEH_SHIP || !CheckOwnership(v->owner)) return CMD_ERROR; | 
| 0 | 949 | |
| 1237 
0a1ce05c3d45
(svn r1741) - Fix: added IsVehicleIndex() so it's possible to protect GetVehicle() from reading an invalid vehicle index
 bjarni parents: 
1235diff
changeset | 950 | SET_EXPENSES_TYPE(EXPENSES_NEW_VEHICLES); | 
| 
0a1ce05c3d45
(svn r1741) - Fix: added IsVehicleIndex() so it's possible to protect GetVehicle() from reading an invalid vehicle index
 bjarni parents: 
1235diff
changeset | 951 | |
| 3961 
e2783f244ac6
(svn r5120) Add IsShipInDepot{Stopped,}() and remove some redundant checks
 tron parents: 
3955diff
changeset | 952 | 	if (!IsShipInDepotStopped(v)) {
 | 
| 0 | 953 | return_cmd_error(STR_980B_SHIP_MUST_BE_STOPPED_IN); | 
| 3961 
e2783f244ac6
(svn r5120) Add IsShipInDepot{Stopped,}() and remove some redundant checks
 tron parents: 
3955diff
changeset | 954 | } | 
| 193 
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
 truelight parents: 
164diff
changeset | 955 | |
| 0 | 956 | 	if (flags & DC_EXEC) {
 | 
| 957 | InvalidateWindow(WC_VEHICLE_DEPOT, v->tile); | |
| 588 | 958 | RebuildVehicleLists(); | 
| 0 | 959 | InvalidateWindow(WC_COMPANY, v->owner); | 
| 960 | DeleteWindowById(WC_VEHICLE_VIEW, v->index); | |
| 5256 
90226d8da8fb
(svn r7386) -Codechange r7385: moved deletion of the vehicle highlight from DeleteVehicle to the sell commands as they are not called as often
 bjarni parents: 
5215diff
changeset | 961 | DeleteDepotHighlightOfVehicle(v); | 
| 0 | 962 | DeleteVehicle(v); | 
| 963 | } | |
| 193 
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
 truelight parents: 
164diff
changeset | 964 | |
| 0 | 965 | return -(int32)v->value; | 
| 966 | } | |
| 967 | ||
| 1793 
8ac8a8c9ec0f
(svn r2297) - CodeChange: server-check the next batch of commands.
 Darkvater parents: 
1790diff
changeset | 968 | /** Start/Stop a ship. | 
| 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: 
3476diff
changeset | 969 | * @param tile unused | 
| 6916 
e87d54a598ea
(svn r9556) -Documentation: doxygen and comment-style changes. 'R', 'S'.. The end of the preliminary work is near
 belugas parents: 
6903diff
changeset | 970 | * @param flags type of operation | 
| 1793 
8ac8a8c9ec0f
(svn r2297) - CodeChange: server-check the next batch of commands.
 Darkvater parents: 
1790diff
changeset | 971 | * @param p1 ship ID to start/stop | 
| 
8ac8a8c9ec0f
(svn r2297) - CodeChange: server-check the next batch of commands.
 Darkvater parents: 
1790diff
changeset | 972 | * @param p2 unused | 
| 
8ac8a8c9ec0f
(svn r2297) - CodeChange: server-check the next batch of commands.
 Darkvater parents: 
1790diff
changeset | 973 | */ | 
| 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: 
3476diff
changeset | 974 | int32 CmdStartStopShip(TileIndex tile, uint32 flags, uint32 p1, uint32 p2) | 
| 0 | 975 | {
 | 
| 976 | Vehicle *v; | |
| 4244 
44dcec623504
(svn r5822) - NewGRF: add support for callback 31, vehicle start/stop check. This allows a set to disallow a vehicle from being started, i.e. to not be able to leave the depot. This is almost a partner to callback 1D.
 peter1138 parents: 
4242diff
changeset | 977 | uint16 callback; | 
| 0 | 978 | |
| 4352 
8ddb01bc6075
(svn r6053) -Codechange: renamed all IsXXXIndex to IsValidXXXID
 truelight parents: 
4351diff
changeset | 979 | if (!IsValidVehicleID(p1)) return CMD_ERROR; | 
| 1237 
0a1ce05c3d45
(svn r1741) - Fix: added IsVehicleIndex() so it's possible to protect GetVehicle() from reading an invalid vehicle index
 bjarni parents: 
1235diff
changeset | 980 | |
| 919 
b0d6c7642f99
(svn r1407) -Codechange: changed a lot around _stations, _vehicles, _towns and _industries
 truelight parents: 
915diff
changeset | 981 | v = GetVehicle(p1); | 
| 0 | 982 | |
| 6585 
7da94b26498a
(svn r9068) -Codechange: capitalize the VEH_Train etc. enums to match the coding style (and rest of the code).
 rubidium parents: 
6574diff
changeset | 983 | if (v->type != VEH_SHIP || !CheckOwnership(v->owner)) return CMD_ERROR; | 
| 0 | 984 | |
| 4244 
44dcec623504
(svn r5822) - NewGRF: add support for callback 31, vehicle start/stop check. This allows a set to disallow a vehicle from being started, i.e. to not be able to leave the depot. This is almost a partner to callback 1D.
 peter1138 parents: 
4242diff
changeset | 985 | /* Check if this ship can be started/stopped. The callback will fail or | 
| 
44dcec623504
(svn r5822) - NewGRF: add support for callback 31, vehicle start/stop check. This allows a set to disallow a vehicle from being started, i.e. to not be able to leave the depot. This is almost a partner to callback 1D.
 peter1138 parents: 
4242diff
changeset | 986 | * return 0xFF if it can. */ | 
| 
44dcec623504
(svn r5822) - NewGRF: add support for callback 31, vehicle start/stop check. This allows a set to disallow a vehicle from being started, i.e. to not be able to leave the depot. This is almost a partner to callback 1D.
 peter1138 parents: 
4242diff
changeset | 987 | callback = GetVehicleCallback(CBID_VEHICLE_START_STOP_CHECK, 0, 0, v->engine_type, v); | 
| 
44dcec623504
(svn r5822) - NewGRF: add support for callback 31, vehicle start/stop check. This allows a set to disallow a vehicle from being started, i.e. to not be able to leave the depot. This is almost a partner to callback 1D.
 peter1138 parents: 
4242diff
changeset | 988 | 	if (callback != CALLBACK_FAILED && callback != 0xFF) {
 | 
| 
44dcec623504
(svn r5822) - NewGRF: add support for callback 31, vehicle start/stop check. This allows a set to disallow a vehicle from being started, i.e. to not be able to leave the depot. This is almost a partner to callback 1D.
 peter1138 parents: 
4242diff
changeset | 989 | StringID error = GetGRFStringID(GetEngineGRFID(v->engine_type), 0xD000 + callback); | 
| 
44dcec623504
(svn r5822) - NewGRF: add support for callback 31, vehicle start/stop check. This allows a set to disallow a vehicle from being started, i.e. to not be able to leave the depot. This is almost a partner to callback 1D.
 peter1138 parents: 
4242diff
changeset | 990 | return_cmd_error(error); | 
| 
44dcec623504
(svn r5822) - NewGRF: add support for callback 31, vehicle start/stop check. This allows a set to disallow a vehicle from being started, i.e. to not be able to leave the depot. This is almost a partner to callback 1D.
 peter1138 parents: 
4242diff
changeset | 991 | } | 
| 
44dcec623504
(svn r5822) - NewGRF: add support for callback 31, vehicle start/stop check. This allows a set to disallow a vehicle from being started, i.e. to not be able to leave the depot. This is almost a partner to callback 1D.
 peter1138 parents: 
4242diff
changeset | 992 | |
| 0 | 993 | 	if (flags & DC_EXEC) {
 | 
| 3961 
e2783f244ac6
(svn r5120) Add IsShipInDepot{Stopped,}() and remove some redundant checks
 tron parents: 
3955diff
changeset | 994 | 		if (IsShipInDepotStopped(v)) {
 | 
| 3139 
4c950c7ec5c9
(svn r3757) -Feature: Delete news items about vehicles, when they get stale
 tron parents: 
3005diff
changeset | 995 | DeleteVehicleNews(p1, STR_981C_SHIP_IS_WAITING_IN_DEPOT); | 
| 
4c950c7ec5c9
(svn r3757) -Feature: Delete news items about vehicles, when they get stale
 tron parents: 
3005diff
changeset | 996 | } | 
| 
4c950c7ec5c9
(svn r3757) -Feature: Delete news items about vehicles, when they get stale
 tron parents: 
3005diff
changeset | 997 | |
| 0 | 998 | v->vehstatus ^= VS_STOPPED; | 
| 755 
823358e83abf
(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: 
679diff
changeset | 999 | InvalidateWindowWidget(WC_VEHICLE_VIEW, v->index, STATUS_BAR); | 
| 0 | 1000 | InvalidateWindow(WC_VEHICLE_DEPOT, v->tile); | 
| 1793 
8ac8a8c9ec0f
(svn r2297) - CodeChange: server-check the next batch of commands.
 Darkvater parents: 
1790diff
changeset | 1001 | InvalidateWindowClasses(WC_SHIPS_LIST); | 
| 0 | 1002 | } | 
| 1003 | ||
| 1004 | return 0; | |
| 1005 | } | |
| 1006 | ||
| 1793 
8ac8a8c9ec0f
(svn r2297) - CodeChange: server-check the next batch of commands.
 Darkvater parents: 
1790diff
changeset | 1007 | /** Send a ship to the depot. | 
| 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: 
3476diff
changeset | 1008 | * @param tile unused | 
| 6916 
e87d54a598ea
(svn r9556) -Documentation: doxygen and comment-style changes. 'R', 'S'.. The end of the preliminary work is near
 belugas parents: 
6903diff
changeset | 1009 | * @param flags type of operation | 
| 1793 
8ac8a8c9ec0f
(svn r2297) - CodeChange: server-check the next batch of commands.
 Darkvater parents: 
1790diff
changeset | 1010 | * @param p1 vehicle ID to send to the depot | 
| 4451 
66603f0f732e
(svn r6229) -Feature: Shared order lists now got a "goto depot" button
 bjarni parents: 
4412diff
changeset | 1011 | * @param p2 various bitmasked elements | 
| 4506 
0d8fcc0a4e49
(svn r6291) -Feature: Vehicle lists from the station window now also got the goto depot button
 bjarni parents: 
4463diff
changeset | 1012 | * - p2 bit 0-3 - DEPOT_ flags (see vehicle.h) | 
| 
0d8fcc0a4e49
(svn r6291) -Feature: Vehicle lists from the station window now also got the goto depot button
 bjarni parents: 
4463diff
changeset | 1013 | * - p2 bit 8-10 - VLW flag (for mass goto depot) | 
| 1793 
8ac8a8c9ec0f
(svn r2297) - CodeChange: server-check the next batch of commands.
 Darkvater parents: 
1790diff
changeset | 1014 | */ | 
| 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: 
3476diff
changeset | 1015 | int32 CmdSendShipToDepot(TileIndex tile, uint32 flags, uint32 p1, uint32 p2) | 
| 0 | 1016 | {
 | 
| 1017 | Vehicle *v; | |
| 1793 
8ac8a8c9ec0f
(svn r2297) - CodeChange: server-check the next batch of commands.
 Darkvater parents: 
1790diff
changeset | 1018 | const Depot *dep; | 
| 0 | 1019 | |
| 4506 
0d8fcc0a4e49
(svn r6291) -Feature: Vehicle lists from the station window now also got the goto depot button
 bjarni parents: 
4463diff
changeset | 1020 | 	if (p2 & DEPOT_MASS_SEND) {
 | 
| 
0d8fcc0a4e49
(svn r6291) -Feature: Vehicle lists from the station window now also got the goto depot button
 bjarni parents: 
4463diff
changeset | 1021 | /* Mass goto depot requested */ | 
| 4546 
9345e0569655
(svn r6378) -Codechange: Rename VLW_FLAGS to VLW_MASK as it is a mask
 Darkvater parents: 
4544diff
changeset | 1022 | if (!ValidVLWFlags(p2 & VLW_MASK)) return CMD_ERROR; | 
| 6585 
7da94b26498a
(svn r9068) -Codechange: capitalize the VEH_Train etc. enums to match the coding style (and rest of the code).
 rubidium parents: 
6574diff
changeset | 1023 | return SendAllVehiclesToDepot(VEH_SHIP, flags, p2 & DEPOT_SERVICE, _current_player, (p2 & VLW_MASK), p1); | 
| 4463 
3a70624c40eb
(svn r6246) -Feature: added the many times requested "send all vehicle to depot" button
 bjarni parents: 
4451diff
changeset | 1024 | } | 
| 
3a70624c40eb
(svn r6246) -Feature: added the many times requested "send all vehicle to depot" button
 bjarni parents: 
4451diff
changeset | 1025 | |
| 4506 
0d8fcc0a4e49
(svn r6291) -Feature: Vehicle lists from the station window now also got the goto depot button
 bjarni parents: 
4463diff
changeset | 1026 | if (!IsValidVehicleID(p1)) return CMD_ERROR; | 
| 1237 
0a1ce05c3d45
(svn r1741) - Fix: added IsVehicleIndex() so it's possible to protect GetVehicle() from reading an invalid vehicle index
 bjarni parents: 
1235diff
changeset | 1027 | |
| 919 
b0d6c7642f99
(svn r1407) -Codechange: changed a lot around _stations, _vehicles, _towns and _industries
 truelight parents: 
915diff
changeset | 1028 | v = GetVehicle(p1); | 
| 0 | 1029 | |
| 6585 
7da94b26498a
(svn r9068) -Codechange: capitalize the VEH_Train etc. enums to match the coding style (and rest of the code).
 rubidium parents: 
6574diff
changeset | 1030 | if (v->type != VEH_SHIP || !CheckOwnership(v->owner)) return CMD_ERROR; | 
| 0 | 1031 | |
| 4506 
0d8fcc0a4e49
(svn r6291) -Feature: Vehicle lists from the station window now also got the goto depot button
 bjarni parents: 
4463diff
changeset | 1032 | if (v->vehstatus & VS_CRASHED) return CMD_ERROR; | 
| 1757 
b179d50241dc
(svn r2261) - Fix: When crashed vehicles try to find a depot for servicing, openttd asserts.
 matthijs parents: 
1752diff
changeset | 1033 | |
| 4526 | 1034 | if (IsShipInDepot(v)) return CMD_ERROR; | 
| 1035 | ||
| 1793 
8ac8a8c9ec0f
(svn r2297) - CodeChange: server-check the next batch of commands.
 Darkvater parents: 
1790diff
changeset | 1036 | /* If the current orders are already goto-depot */ | 
| 555 
eec6c0294435
(svn r955) Replace uint16 for orders with struct Order
 tron parents: 
541diff
changeset | 1037 | 	if (v->current_order.type == OT_GOTO_DEPOT) {
 | 
| 4519 
1437b1e7416c
(svn r6304) -Codechange r6295: Use !! instead of (bool) in commands to send vehicles to depots
 bjarni parents: 
4510diff
changeset | 1038 | 		if (!!(p2 & DEPOT_SERVICE) == HASBIT(v->current_order.flags, OFB_HALT_IN_DEPOT)) {
 | 
| 4510 
071bca98c577
(svn r6295) -Feature: using goto depot with a different control selection will now alter the service/stopping in depot flag instead of cancelling the goto depot order
 bjarni parents: 
4506diff
changeset | 1039 | /* We called with a different DEPOT_SERVICE setting. | 
| 
071bca98c577
(svn r6295) -Feature: using goto depot with a different control selection will now alter the service/stopping in depot flag instead of cancelling the goto depot order
 bjarni parents: 
4506diff
changeset | 1040 | * Now we change the setting to apply the new one and let the vehicle head for the same depot. | 
| 
071bca98c577
(svn r6295) -Feature: using goto depot with a different control selection will now alter the service/stopping in depot flag instead of cancelling the goto depot order
 bjarni parents: 
4506diff
changeset | 1041 | * Note: the if is (true for requesting service == true for ordered to stop in depot) */ | 
| 
071bca98c577
(svn r6295) -Feature: using goto depot with a different control selection will now alter the service/stopping in depot flag instead of cancelling the goto depot order
 bjarni parents: 
4506diff
changeset | 1042 | 			if (flags & DC_EXEC) {
 | 
| 
071bca98c577
(svn r6295) -Feature: using goto depot with a different control selection will now alter the service/stopping in depot flag instead of cancelling the goto depot order
 bjarni parents: 
4506diff
changeset | 1043 | TOGGLEBIT(v->current_order.flags, OFB_HALT_IN_DEPOT); | 
| 
071bca98c577
(svn r6295) -Feature: using goto depot with a different control selection will now alter the service/stopping in depot flag instead of cancelling the goto depot order
 bjarni parents: 
4506diff
changeset | 1044 | InvalidateWindowWidget(WC_VEHICLE_VIEW, v->index, STATUS_BAR); | 
| 
071bca98c577
(svn r6295) -Feature: using goto depot with a different control selection will now alter the service/stopping in depot flag instead of cancelling the goto depot order
 bjarni parents: 
4506diff
changeset | 1045 | } | 
| 
071bca98c577
(svn r6295) -Feature: using goto depot with a different control selection will now alter the service/stopping in depot flag instead of cancelling the goto depot order
 bjarni parents: 
4506diff
changeset | 1046 | return 0; | 
| 
071bca98c577
(svn r6295) -Feature: using goto depot with a different control selection will now alter the service/stopping in depot flag instead of cancelling the goto depot order
 bjarni parents: 
4506diff
changeset | 1047 | } | 
| 
071bca98c577
(svn r6295) -Feature: using goto depot with a different control selection will now alter the service/stopping in depot flag instead of cancelling the goto depot order
 bjarni parents: 
4506diff
changeset | 1048 | |
| 4506 
0d8fcc0a4e49
(svn r6291) -Feature: Vehicle lists from the station window now also got the goto depot button
 bjarni parents: 
4463diff
changeset | 1049 | if (p2 & DEPOT_DONT_CANCEL) return CMD_ERROR; // Requested no cancelation of depot orders | 
| 0 | 1050 | 		if (flags & DC_EXEC) {
 | 
| 1793 
8ac8a8c9ec0f
(svn r2297) - CodeChange: server-check the next batch of commands.
 Darkvater parents: 
1790diff
changeset | 1051 | /* If the orders to 'goto depot' are in the orders list (forced servicing), | 
| 
8ac8a8c9ec0f
(svn r2297) - CodeChange: server-check the next batch of commands.
 Darkvater parents: 
1790diff
changeset | 1052 | * then skip to the next order; effectively cancelling this forced service */ | 
| 1530 
caa16c506a22
(svn r2034) -Codechange: Replaced the rather meaningless LOAD and UNLOAD flags for depots by something more meaningful
 celestar parents: 
1520diff
changeset | 1053 | if (HASBIT(v->current_order.flags, OFB_PART_OF_ORDERS)) | 
| 
caa16c506a22
(svn r2034) -Codechange: Replaced the rather meaningless LOAD and UNLOAD flags for depots by something more meaningful
 celestar parents: 
1520diff
changeset | 1054 | v->cur_order_index++; | 
| 
caa16c506a22
(svn r2034) -Codechange: Replaced the rather meaningless LOAD and UNLOAD flags for depots by something more meaningful
 celestar parents: 
1520diff
changeset | 1055 | |
| 555 
eec6c0294435
(svn r955) Replace uint16 for orders with struct Order
 tron parents: 
541diff
changeset | 1056 | v->current_order.type = OT_DUMMY; | 
| 
eec6c0294435
(svn r955) Replace uint16 for orders with struct Order
 tron parents: 
541diff
changeset | 1057 | v->current_order.flags = 0; | 
| 755 
823358e83abf
(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: 
679diff
changeset | 1058 | InvalidateWindowWidget(WC_VEHICLE_VIEW, v->index, STATUS_BAR); | 
| 0 | 1059 | } | 
| 1793 
8ac8a8c9ec0f
(svn r2297) - CodeChange: server-check the next batch of commands.
 Darkvater parents: 
1790diff
changeset | 1060 | return 0; | 
| 
8ac8a8c9ec0f
(svn r2297) - CodeChange: server-check the next batch of commands.
 Darkvater parents: 
1790diff
changeset | 1061 | } | 
| 0 | 1062 | |
| 1793 
8ac8a8c9ec0f
(svn r2297) - CodeChange: server-check the next batch of commands.
 Darkvater parents: 
1790diff
changeset | 1063 | dep = FindClosestShipDepot(v); | 
| 4506 
0d8fcc0a4e49
(svn r6291) -Feature: Vehicle lists from the station window now also got the goto depot button
 bjarni parents: 
4463diff
changeset | 1064 | if (dep == NULL) return_cmd_error(STR_981A_UNABLE_TO_FIND_LOCAL_DEPOT); | 
| 1793 
8ac8a8c9ec0f
(svn r2297) - CodeChange: server-check the next batch of commands.
 Darkvater parents: 
1790diff
changeset | 1065 | |
| 
8ac8a8c9ec0f
(svn r2297) - CodeChange: server-check the next batch of commands.
 Darkvater parents: 
1790diff
changeset | 1066 | 	if (flags & DC_EXEC) {
 | 
| 
8ac8a8c9ec0f
(svn r2297) - CodeChange: server-check the next batch of commands.
 Darkvater parents: 
1790diff
changeset | 1067 | v->dest_tile = dep->xy; | 
| 
8ac8a8c9ec0f
(svn r2297) - CodeChange: server-check the next batch of commands.
 Darkvater parents: 
1790diff
changeset | 1068 | v->current_order.type = OT_GOTO_DEPOT; | 
| 4412 
945e8a9bb89a
(svn r6165) -Feature: control click Goto Depot will now make the vehicle service
 bjarni parents: 
4389diff
changeset | 1069 | v->current_order.flags = OF_NON_STOP; | 
| 4506 
0d8fcc0a4e49
(svn r6291) -Feature: Vehicle lists from the station window now also got the goto depot button
 bjarni parents: 
4463diff
changeset | 1070 | if (!(p2 & DEPOT_SERVICE)) SETBIT(v->current_order.flags, OFB_HALT_IN_DEPOT); | 
| 5259 
08336337aae0
(svn r7389) -Fix: when forcing a vehicle to go to a depot, clear refit orders from current orders (caused refit error popup when not having no orders)
 bjarni parents: 
5256diff
changeset | 1071 | v->current_order.refit_cargo = CT_INVALID; | 
| 4527 
b18634a31a4a
(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: 
4526diff
changeset | 1072 | v->current_order.dest = dep->index; | 
| 1793 
8ac8a8c9ec0f
(svn r2297) - CodeChange: server-check the next batch of commands.
 Darkvater parents: 
1790diff
changeset | 1073 | InvalidateWindowWidget(WC_VEHICLE_VIEW, v->index, STATUS_BAR); | 
| 0 | 1074 | } | 
| 1075 | ||
| 1076 | return 0; | |
| 1077 | } | |
| 1078 | ||
| 1079 | ||
| 1802 
448f187042d3
(svn r2306) - CodeChange: Check the last commands; refits. This needed an extensive rewrite and global/local-cargo ID juggling and bitmasking. However with this done it looks better as well and is compatible with newgrf handling. Big thanks to HackyKid for doing most of the work. This also closes patch "[ 1199277 ] Command checks"
 Darkvater parents: 
1793diff
changeset | 1080 | /** Refits a ship to the specified cargo type. | 
| 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: 
3476diff
changeset | 1081 | * @param tile unused | 
| 6916 
e87d54a598ea
(svn r9556) -Documentation: doxygen and comment-style changes. 'R', 'S'.. The end of the preliminary work is near
 belugas parents: 
6903diff
changeset | 1082 | * @param flags type of operation | 
| 1802 
448f187042d3
(svn r2306) - CodeChange: Check the last commands; refits. This needed an extensive rewrite and global/local-cargo ID juggling and bitmasking. However with this done it looks better as well and is compatible with newgrf handling. Big thanks to HackyKid for doing most of the work. This also closes patch "[ 1199277 ] Command checks"
 Darkvater parents: 
1793diff
changeset | 1083 | * @param p1 vehicle ID of the ship to refit | 
| 
448f187042d3
(svn r2306) - CodeChange: Check the last commands; refits. This needed an extensive rewrite and global/local-cargo ID juggling and bitmasking. However with this done it looks better as well and is compatible with newgrf handling. Big thanks to HackyKid for doing most of the work. This also closes patch "[ 1199277 ] Command checks"
 Darkvater parents: 
1793diff
changeset | 1084 | * @param p2 various bitstuffed elements | 
| 
448f187042d3
(svn r2306) - CodeChange: Check the last commands; refits. This needed an extensive rewrite and global/local-cargo ID juggling and bitmasking. However with this done it looks better as well and is compatible with newgrf handling. Big thanks to HackyKid for doing most of the work. This also closes patch "[ 1199277 ] Command checks"
 Darkvater parents: 
1793diff
changeset | 1085 | * - p2 = (bit 0-7) - the new cargo type to refit to (p2 & 0xFF) | 
| 3954 
634cd5e35803
(svn r5103) - Add cargo subtype parameter to refit commands (mart3p)
 peter1138 parents: 
3948diff
changeset | 1086 | * - p2 = (bit 8-15) - the new cargo subtype to refit to | 
| 1802 
448f187042d3
(svn r2306) - CodeChange: Check the last commands; refits. This needed an extensive rewrite and global/local-cargo ID juggling and bitmasking. However with this done it looks better as well and is compatible with newgrf handling. Big thanks to HackyKid for doing most of the work. This also closes patch "[ 1199277 ] Command checks"
 Darkvater parents: 
1793diff
changeset | 1087 | */ | 
| 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: 
3476diff
changeset | 1088 | int32 CmdRefitShip(TileIndex tile, uint32 flags, uint32 p1, uint32 p2) | 
| 0 | 1089 | {
 | 
| 1090 | Vehicle *v; | |
| 1091 | int32 cost; | |
| 3954 
634cd5e35803
(svn r5103) - Add cargo subtype parameter to refit commands (mart3p)
 peter1138 parents: 
3948diff
changeset | 1092 | CargoID new_cid = GB(p2, 0, 8); //gets the cargo number | 
| 
634cd5e35803
(svn r5103) - Add cargo subtype parameter to refit commands (mart3p)
 peter1138 parents: 
3948diff
changeset | 1093 | byte new_subtype = GB(p2, 8, 8); | 
| 3989 
a5d50d90fd21
(svn r5188) - NewGRF: check refit capacity callback when refitting a ship
 peter1138 parents: 
3961diff
changeset | 1094 | uint16 capacity = CALLBACK_FAILED; | 
| 1237 
0a1ce05c3d45
(svn r1741) - Fix: added IsVehicleIndex() so it's possible to protect GetVehicle() from reading an invalid vehicle index
 bjarni parents: 
1235diff
changeset | 1095 | |
| 4352 
8ddb01bc6075
(svn r6053) -Codechange: renamed all IsXXXIndex to IsValidXXXID
 truelight parents: 
4351diff
changeset | 1096 | if (!IsValidVehicleID(p1)) return CMD_ERROR; | 
| 193 
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
 truelight parents: 
164diff
changeset | 1097 | |
| 919 
b0d6c7642f99
(svn r1407) -Codechange: changed a lot around _stations, _vehicles, _towns and _industries
 truelight parents: 
915diff
changeset | 1098 | v = GetVehicle(p1); | 
| 1237 
0a1ce05c3d45
(svn r1741) - Fix: added IsVehicleIndex() so it's possible to protect GetVehicle() from reading an invalid vehicle index
 bjarni parents: 
1235diff
changeset | 1099 | |
| 6585 
7da94b26498a
(svn r9068) -Codechange: capitalize the VEH_Train etc. enums to match the coding style (and rest of the code).
 rubidium parents: 
6574diff
changeset | 1100 | if (v->type != VEH_SHIP || !CheckOwnership(v->owner)) return CMD_ERROR; | 
| 2567 
735280bafe7a
(svn r3104) -Codechange: [refit] removed now obsolite code that the old autoreplace needed
 bjarni parents: 
2564diff
changeset | 1101 | |
| 3961 
e2783f244ac6
(svn r5120) Add IsShipInDepot{Stopped,}() and remove some redundant checks
 tron parents: 
3955diff
changeset | 1102 | 	if (!IsShipInDepotStopped(v)) {
 | 
| 
e2783f244ac6
(svn r5120) Add IsShipInDepot{Stopped,}() and remove some redundant checks
 tron parents: 
3955diff
changeset | 1103 | return_cmd_error(STR_980B_SHIP_MUST_BE_STOPPED_IN); | 
| 
e2783f244ac6
(svn r5120) Add IsShipInDepot{Stopped,}() and remove some redundant checks
 tron parents: 
3955diff
changeset | 1104 | } | 
| 0 | 1105 | |
| 1802 
448f187042d3
(svn r2306) - CodeChange: Check the last commands; refits. This needed an extensive rewrite and global/local-cargo ID juggling and bitmasking. However with this done it looks better as well and is compatible with newgrf handling. Big thanks to HackyKid for doing most of the work. This also closes patch "[ 1199277 ] Command checks"
 Darkvater parents: 
1793diff
changeset | 1106 | /* Check cargo */ | 
| 
448f187042d3
(svn r2306) - CodeChange: Check the last commands; refits. This needed an extensive rewrite and global/local-cargo ID juggling and bitmasking. However with this done it looks better as well and is compatible with newgrf handling. Big thanks to HackyKid for doing most of the work. This also closes patch "[ 1199277 ] Command checks"
 Darkvater parents: 
1793diff
changeset | 1107 | if (!ShipVehInfo(v->engine_type)->refittable) return CMD_ERROR; | 
| 6642 
2e690e6fdc03
(svn r9259) -Codechange: NUM_CARGO isn't a valid cargo type...
 peter1138 parents: 
6589diff
changeset | 1108 | if (new_cid >= NUM_CARGO || !CanRefitTo(v->engine_type, new_cid)) return CMD_ERROR; | 
| 915 | 1109 | |
| 1237 
0a1ce05c3d45
(svn r1741) - Fix: added IsVehicleIndex() so it's possible to protect GetVehicle() from reading an invalid vehicle index
 bjarni parents: 
1235diff
changeset | 1110 | SET_EXPENSES_TYPE(EXPENSES_SHIP_RUN); | 
| 
0a1ce05c3d45
(svn r1741) - Fix: added IsVehicleIndex() so it's possible to protect GetVehicle() from reading an invalid vehicle index
 bjarni parents: 
1235diff
changeset | 1111 | |
| 3989 
a5d50d90fd21
(svn r5188) - NewGRF: check refit capacity callback when refitting a ship
 peter1138 parents: 
3961diff
changeset | 1112 | /* Check the refit capacity callback */ | 
| 
a5d50d90fd21
(svn r5188) - NewGRF: check refit capacity callback when refitting a ship
 peter1138 parents: 
3961diff
changeset | 1113 | 	if (HASBIT(EngInfo(v->engine_type)->callbackmask, CBM_REFIT_CAPACITY)) {
 | 
| 
a5d50d90fd21
(svn r5188) - NewGRF: check refit capacity callback when refitting a ship
 peter1138 parents: 
3961diff
changeset | 1114 | /* Back up the existing cargo type */ | 
| 
a5d50d90fd21
(svn r5188) - NewGRF: check refit capacity callback when refitting a ship
 peter1138 parents: 
3961diff
changeset | 1115 | CargoID temp_cid = v->cargo_type; | 
| 
a5d50d90fd21
(svn r5188) - NewGRF: check refit capacity callback when refitting a ship
 peter1138 parents: 
3961diff
changeset | 1116 | byte temp_subtype = v->cargo_subtype; | 
| 
a5d50d90fd21
(svn r5188) - NewGRF: check refit capacity callback when refitting a ship
 peter1138 parents: 
3961diff
changeset | 1117 | v->cargo_type = new_cid; | 
| 
a5d50d90fd21
(svn r5188) - NewGRF: check refit capacity callback when refitting a ship
 peter1138 parents: 
3961diff
changeset | 1118 | v->cargo_subtype = new_subtype; | 
| 
a5d50d90fd21
(svn r5188) - NewGRF: check refit capacity callback when refitting a ship
 peter1138 parents: 
3961diff
changeset | 1119 | |
| 
a5d50d90fd21
(svn r5188) - NewGRF: check refit capacity callback when refitting a ship
 peter1138 parents: 
3961diff
changeset | 1120 | capacity = GetVehicleCallback(CBID_VEHICLE_REFIT_CAPACITY, 0, 0, v->engine_type, v); | 
| 
a5d50d90fd21
(svn r5188) - NewGRF: check refit capacity callback when refitting a ship
 peter1138 parents: 
3961diff
changeset | 1121 | |
| 
a5d50d90fd21
(svn r5188) - NewGRF: check refit capacity callback when refitting a ship
 peter1138 parents: 
3961diff
changeset | 1122 | /* Restore the cargo type */ | 
| 
a5d50d90fd21
(svn r5188) - NewGRF: check refit capacity callback when refitting a ship
 peter1138 parents: 
3961diff
changeset | 1123 | v->cargo_type = temp_cid; | 
| 
a5d50d90fd21
(svn r5188) - NewGRF: check refit capacity callback when refitting a ship
 peter1138 parents: 
3961diff
changeset | 1124 | v->cargo_subtype = temp_subtype; | 
| 
a5d50d90fd21
(svn r5188) - NewGRF: check refit capacity callback when refitting a ship
 peter1138 parents: 
3961diff
changeset | 1125 | } | 
| 
a5d50d90fd21
(svn r5188) - NewGRF: check refit capacity callback when refitting a ship
 peter1138 parents: 
3961diff
changeset | 1126 | |
| 
a5d50d90fd21
(svn r5188) - NewGRF: check refit capacity callback when refitting a ship
 peter1138 parents: 
3961diff
changeset | 1127 | 	if (capacity == CALLBACK_FAILED) {
 | 
| 
a5d50d90fd21
(svn r5188) - NewGRF: check refit capacity callback when refitting a ship
 peter1138 parents: 
3961diff
changeset | 1128 | capacity = ShipVehInfo(v->engine_type)->capacity; | 
| 
a5d50d90fd21
(svn r5188) - NewGRF: check refit capacity callback when refitting a ship
 peter1138 parents: 
3961diff
changeset | 1129 | } | 
| 
a5d50d90fd21
(svn r5188) - NewGRF: check refit capacity callback when refitting a ship
 peter1138 parents: 
3961diff
changeset | 1130 | _returned_refit_capacity = capacity; | 
| 
a5d50d90fd21
(svn r5188) - NewGRF: check refit capacity callback when refitting a ship
 peter1138 parents: 
3961diff
changeset | 1131 | |
| 0 | 1132 | cost = 0; | 
| 4845 
49105d3b5a9a
(svn r6771) -Codechange: Replace two macros with functions. IS_HUMAN_PLAYER and
 Darkvater parents: 
4739diff
changeset | 1133 | 	if (IsHumanPlayer(v->owner) && new_cid != v->cargo_type) {
 | 
| 4544 
b2d5ad597e4d
(svn r6376) -Codechange: [vehicle refit] moved all refit cost calculations into GetRefitCost()
 bjarni parents: 
4529diff
changeset | 1134 | cost = GetRefitCost(v->engine_type); | 
| 0 | 1135 | } | 
| 1136 | ||
| 1137 | 	if (flags & DC_EXEC) {
 | |
| 3989 
a5d50d90fd21
(svn r5188) - NewGRF: check refit capacity callback when refitting a ship
 peter1138 parents: 
3961diff
changeset | 1138 | v->cargo_cap = capacity; | 
| 3955 
81e7e25e4599
(svn r5104) - When refitting a vehicle to its existing cargo type, don't lose the cargo onboard (useful when adding wagons to a train)
 peter1138 parents: 
3954diff
changeset | 1139 | v->cargo_count = (v->cargo_type == new_cid) ? min(v->cargo_cap, v->cargo_count) : 0; | 
| 1802 
448f187042d3
(svn r2306) - CodeChange: Check the last commands; refits. This needed an extensive rewrite and global/local-cargo ID juggling and bitmasking. However with this done it looks better as well and is compatible with newgrf handling. Big thanks to HackyKid for doing most of the work. This also closes patch "[ 1199277 ] Command checks"
 Darkvater parents: 
1793diff
changeset | 1140 | v->cargo_type = new_cid; | 
| 3954 
634cd5e35803
(svn r5103) - Add cargo subtype parameter to refit commands (mart3p)
 peter1138 parents: 
3948diff
changeset | 1141 | v->cargo_subtype = new_subtype; | 
| 0 | 1142 | InvalidateWindow(WC_VEHICLE_DETAILS, v->index); | 
| 3954 
634cd5e35803
(svn r5103) - Add cargo subtype parameter to refit commands (mart3p)
 peter1138 parents: 
3948diff
changeset | 1143 | InvalidateWindow(WC_VEHICLE_DEPOT, v->tile); | 
| 
634cd5e35803
(svn r5103) - Add cargo subtype parameter to refit commands (mart3p)
 peter1138 parents: 
3948diff
changeset | 1144 | RebuildVehicleLists(); | 
| 0 | 1145 | } | 
| 1146 | ||
| 1147 | return cost; | |
| 1148 | ||
| 1149 | } |