| author | truebrain | 
| Mon, 31 Mar 2008 09:25:03 +0000 | |
| branch | noai | 
| changeset 9841 | f931a10242c9 | 
| parent 9826 | 9707ad4c9b60 | 
| child 9869 | 6404afe43575 | 
| permissions | -rw-r--r-- | 
| 2186 | 1 | /* $Id$ */ | 
| 2 | ||
| 9574 | 3 | /** @file road_cmd.cpp */ | 
| 4 | ||
| 0 | 5 | #include "stdafx.h" | 
| 1891 
92a3b0aa0946
(svn r2397) - CodeChange: rename all "ttd" files to "openttd" files.
 Darkvater parents: 
1785diff
changeset | 6 | #include "openttd.h" | 
| 3189 
1af302c5abd0
(svn r3846) Add functions to set the type of stuff (clear, water, rail, road) under bridges
 tron parents: 
3176diff
changeset | 7 | #include "bridge_map.h" | 
| 6486 
4f8af35b11eb
(svn r8908) -Codechange: declaration of DrawBridgeMiddle does not belong in a map accessors header.
 rubidium parents: 
6460diff
changeset | 8 | #include "bridge.h" | 
| 6460 | 9 | #include "cmd_helper.h" | 
| 3101 
e2fdb8802c2f
(svn r3696) Add functions to turn a tile into a normal rail tile/depot/waypoint. This is just a tiny step, the rail code needs way more love and caring
 tron parents: 
3100diff
changeset | 10 | #include "rail_map.h" | 
| 3144 
426b825578f9
(svn r3763) Adapt to the new 'map accessors go in foo_map.h'-scheme
 tron parents: 
3104diff
changeset | 11 | #include "road_map.h" | 
| 9723 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 12 | #include "road_internal.h" | 
| 4232 
628628eaa4fc
(svn r5796) Use DrawTileSprites/DrawTileSeqStruct for road depot drawing data, too
 tron parents: 
4231diff
changeset | 13 | #include "sprite.h" | 
| 9723 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 14 | #include "tile_cmd.h" | 
| 9505 | 15 | #include "landscape.h" | 
| 3319 
7d04847e4689
(svn r4085) Add GetTown{Index,ByTile}() to get the town index resp. the town from a tile
 tron parents: 
3286diff
changeset | 16 | #include "town_map.h" | 
| 9723 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 17 | #include "viewport_func.h" | 
| 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 18 | #include "command_func.h" | 
| 0 | 19 | #include "town.h" | 
| 3900 
4984308f9125
(svn r4987) Feature: Merged YAPF into trunk. Thanks to devs for continuous support and users for testing.
 KUDr parents: 
3884diff
changeset | 20 | #include "yapf/yapf.h" | 
| 1313 
bba6afb8a995
(svn r1817) -Codechange: Moved depot-functions to depot.c
 truelight parents: 
1281diff
changeset | 21 | #include "depot.h" | 
| 9620 
31e38d28a0af
(svn r9816) [NoAI] -Sync with trunk r9712:9815 except r9759 (MorphOS threading) because that needs special attention.
 rubidium parents: 
9601diff
changeset | 22 | #include "newgrf.h" | 
| 9624 | 23 | #include "station_map.h" | 
| 24 | #include "tunnel_map.h" | |
| 9694 
e72987579514
(svn r10775) [NoAI] -Sync: with trunk r10535:r10774.
 rubidium parents: 
9686diff
changeset | 25 | #include "misc/autoptr.hpp" | 
| 9723 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 26 | #include "variables.h" | 
| 9703 
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
 rubidium parents: 
9701diff
changeset | 27 | #include "autoslope.h" | 
| 9722 
ebf0ece7d8f6
(svn r11503) [NoAI] -Sync: with trunk r11308:11502.
 rubidium parents: 
9718diff
changeset | 28 | #include "transparency.h" | 
| 9723 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 29 | #include "tunnelbridge_map.h" | 
| 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 30 | #include "window_func.h" | 
| 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 31 | #include "strings_func.h" | 
| 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 32 | #include "vehicle_func.h" | 
| 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 33 | #include "vehicle_base.h" | 
| 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 34 | #include "sound_func.h" | 
| 9724 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 35 | #include "road_func.h" | 
| 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 36 | #include "tunnelbridge.h" | 
| 9723 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 37 | |
| 9724 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 38 | #include "table/sprites.h" | 
| 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 39 | #include "table/strings.h" | 
| 9703 
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
 rubidium parents: 
9701diff
changeset | 40 | |
| 
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
 rubidium parents: 
9701diff
changeset | 41 | #define M(x) (1 << (x)) | 
| 
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
 rubidium parents: 
9701diff
changeset | 42 | /* Level crossings may only be built on these slopes */ | 
| 
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
 rubidium parents: 
9701diff
changeset | 43 | static const uint32 VALID_LEVEL_CROSSING_SLOPES = (M(SLOPE_SEN) | M(SLOPE_ENW) | M(SLOPE_NWS) | M(SLOPE_NS) | M(SLOPE_WSE) | M(SLOPE_EW) | M(SLOPE_FLAT)); | 
| 
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
 rubidium parents: 
9701diff
changeset | 44 | #undef M | 
| 0 | 45 | |
| 9826 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 46 | /* Invalid RoadBits on slopes */ | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 47 | static const RoadBits _invalid_tileh_slopes_road[2][15] = {
 | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 48 | /* The inverse of the mixable RoadBits on a leveled slope */ | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 49 | 	{
 | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 50 | ROAD_NONE, // SLOPE_FLAT | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 51 | ROAD_NE | ROAD_SE, // SLOPE_W | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 52 | ROAD_NE | ROAD_NW, // SLOPE_S | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 53 | |
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 54 | ROAD_NE, // SLOPE_SW | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 55 | ROAD_NW | ROAD_SW, // SLOPE_E | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 56 | ROAD_NONE, // SLOPE_EW | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 57 | |
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 58 | ROAD_NW, // SLOPE_SE | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 59 | ROAD_NONE, // SLOPE_WSE | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 60 | ROAD_SE | ROAD_SW, // SLOPE_N | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 61 | |
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 62 | ROAD_SE, // SLOPE_NW | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 63 | ROAD_NONE, // SLOPE_NS | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 64 | ROAD_NONE, // SLOPE_ENW | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 65 | |
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 66 | ROAD_SW, // SLOPE_NE | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 67 | ROAD_NONE, // SLOPE_SEN | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 68 | ROAD_NONE // SLOPE_NWS | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 69 | }, | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 70 | /* The inverse of the allowed straight roads on a slope | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 71 | * (with and without a foundation). */ | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 72 | 	{
 | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 73 | ROAD_NONE, // SLOPE_FLAT | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 74 | ROAD_NONE, // SLOPE_W Foundation | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 75 | ROAD_NONE, // SLOPE_S Foundation | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 76 | |
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 77 | ROAD_Y, // SLOPE_SW | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 78 | ROAD_NONE, // SLOPE_E Foundation | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 79 | ROAD_ALL, // SLOPE_EW | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 80 | |
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 81 | ROAD_X, // SLOPE_SE | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 82 | ROAD_ALL, // SLOPE_WSE | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 83 | ROAD_NONE, // SLOPE_N Foundation | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 84 | |
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 85 | ROAD_X, // SLOPE_NW | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 86 | ROAD_ALL, // SLOPE_NS | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 87 | ROAD_ALL, // SLOPE_ENW | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 88 | |
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 89 | ROAD_Y, // SLOPE_NE | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 90 | ROAD_ALL, // SLOPE_SEN | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 91 | ROAD_ALL // SLOPE_NW | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 92 | } | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 93 | }; | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 94 | |
| 9724 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 95 | Foundation GetRoadFoundation(Slope tileh, RoadBits bits); | 
| 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 96 | |
| 9624 | 97 | bool CheckAllowRemoveRoad(TileIndex tile, RoadBits remove, Owner owner, bool *edge_road, RoadType rt) | 
| 0 | 98 | {
 | 
| 99 | *edge_road = true; | |
| 100 | ||
| 9624 | 101 | if (_game_mode == GM_EDITOR || remove == ROAD_NONE) return true; | 
| 0 | 102 | |
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 103 | /* Water can always flood and towns can always remove "normal" road pieces. | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 104 | * Towns are not be allowed to remove non "normal" road pieces, like tram | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 105 | * tracks as that would result in trams that cannot turn. */ | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 106 | if (_current_player == OWNER_WATER || | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 107 | (rt == ROADTYPE_ROAD && !IsValidPlayer(_current_player))) return true; | 
| 0 | 108 | |
| 9574 | 109 | /* Only do the special processing if the road is owned | 
| 110 | * by a town */ | |
| 4849 
9a3c3ae7f62f
(svn r6775) -Codechange: Use some more proper types, especially Owner and PlayerID as
 Darkvater parents: 
4848diff
changeset | 111 | if (owner != OWNER_TOWN) return (owner == OWNER_NONE) || CheckOwnership(owner); | 
| 0 | 112 | |
| 3017 
915fae59d5e0
(svn r3597) Miscellaneous (I like that word) changes: Fix some indentation, add consts, reduce indentation level by short-circuit logic, convert if cascades to switch, whitespace, bracing, plus some minor stuff
 tron parents: 
2989diff
changeset | 113 | if (_cheats.magic_bulldozer.value) return true; | 
| 0 | 114 | |
| 9574 | 115 | /* Get a bitmask of which neighbouring roads has a tile */ | 
| 9826 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 116 | RoadBits n = ROAD_NONE; | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 117 | RoadBits present = GetAnyRoadBits(tile, rt); | 
| 9624 | 118 | if (present & ROAD_NE && GetAnyRoadBits(TILE_ADDXY(tile, -1, 0), rt) & ROAD_SW) n |= ROAD_NE; | 
| 119 | if (present & ROAD_SE && GetAnyRoadBits(TILE_ADDXY(tile, 0, 1), rt) & ROAD_NW) n |= ROAD_SE; | |
| 120 | if (present & ROAD_SW && GetAnyRoadBits(TILE_ADDXY(tile, 1, 0), rt) & ROAD_NE) n |= ROAD_SW; | |
| 121 | if (present & ROAD_NW && GetAnyRoadBits(TILE_ADDXY(tile, 0, -1), rt) & ROAD_SE) n |= ROAD_NW; | |
| 201 
c40d343115f8
(svn r202) -Codechange: I missed some files with trailing spaces.. this should be
 truelight parents: 
159diff
changeset | 122 | |
| 9574 | 123 | /* If 0 or 1 bits are set in n, or if no bits that match the bits to remove, | 
| 124 | * then allow it */ | |
| 9826 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 125 | 	if (KillFirstBit(n) != ROAD_NONE && (n & remove) != ROAD_NONE) {
 | 
| 0 | 126 | *edge_road = false; | 
| 9574 | 127 | /* you can remove all kind of roads with extra dynamite */ | 
| 3017 
915fae59d5e0
(svn r3597) Miscellaneous (I like that word) changes: Fix some indentation, add consts, reduce indentation level by short-circuit logic, convert if cascades to switch, whitespace, bracing, plus some minor stuff
 tron parents: 
2989diff
changeset | 128 | if (_patches.extra_dynamite) return true; | 
| 0 | 129 | |
| 9826 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 130 | const Town *t = ClosestTownFromTile(tile, (uint)-1); | 
| 1638 
aae181b00846
(svn r2142) - Fix: Game no longer crashes when you want to remove a piece of road under a bridge that belongs to the town. TODO: railcrossings store owner somewhere else, put it into _map_owner[]!
 Darkvater parents: 
1398diff
changeset | 131 | |
| 534 
17ab2f22ff74
(svn r901) Small step in the process to clean up the DPARAM mess:
 tron parents: 
507diff
changeset | 132 | SetDParam(0, t->index); | 
| 0 | 133 | _error_message = STR_2009_LOCAL_AUTHORITY_REFUSES; | 
| 134 | return false; | |
| 135 | } | |
| 136 | ||
| 137 | return true; | |
| 138 | } | |
| 139 | ||
| 9624 | 140 | static bool CheckAllowRemoveRoad(TileIndex tile, RoadBits remove, bool *edge_road, RoadType rt) | 
| 6442 
10b44714b85d
(svn r8852) -Fix (r8735): make the dynamite tool for drive through road stops as if it were removing a normal road tile (consider the local authority and such).
 rubidium parents: 
6317diff
changeset | 141 | {
 | 
| 9624 | 142 | return CheckAllowRemoveRoad(tile, remove, GetRoadOwner(tile, rt), edge_road, rt); | 
| 6442 
10b44714b85d
(svn r8852) -Fix (r8735): make the dynamite tool for drive through road stops as if it were removing a normal road tile (consider the local authority and such).
 rubidium parents: 
6317diff
changeset | 143 | } | 
| 0 | 144 | |
| 9724 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 145 | |
| 1784 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 146 | /** Delete a piece of road. | 
| 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: 
3435diff
changeset | 147 | * @param tile tile where to remove road from | 
| 9601 
b499fdd106d5
(svn r9713) [NoAI] -Sync with trunk (r9631:9712).
 rubidium parents: 
9574diff
changeset | 148 | * @param flags operation to perform | 
| 9724 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 149 | * @param pieces roadbits to remove | 
| 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 150 | * @param rt roadtype to remove | 
| 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 151 | * @param crossing_check should we check if there is a tram track when we are removing road from crossing? | 
| 0 | 152 | */ | 
| 9724 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 153 | static CommandCost RemoveRoad(TileIndex tile, uint32 flags, RoadBits pieces, RoadType rt, bool crossing_check) | 
| 0 | 154 | {
 | 
| 9574 | 155 | /* cost for removing inner/edge -roads */ | 
| 1638 
aae181b00846
(svn r2142) - Fix: Game no longer crashes when you want to remove a piece of road under a bridge that belongs to the town. TODO: railcrossings store owner somewhere else, put it into _map_owner[]!
 Darkvater parents: 
1398diff
changeset | 156 | 	static const uint16 road_remove_cost[2] = {50, 18};
 | 
| 
aae181b00846
(svn r2142) - Fix: Game no longer crashes when you want to remove a piece of road under a bridge that belongs to the town. TODO: railcrossings store owner somewhere else, put it into _map_owner[]!
 Darkvater parents: 
1398diff
changeset | 157 | |
| 1784 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 158 | /* true if the roadpiece was always removeable, | 
| 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 159 | * false if it was a center piece. Affects town ratings drop */ | 
| 0 | 160 | bool edge_road; | 
| 201 
c40d343115f8
(svn r202) -Codechange: I missed some files with trailing spaces.. this should be
 truelight parents: 
159diff
changeset | 161 | |
| 9641 
855e32c08c9b
(svn r10533) [NoAI] -Sync with trunk r10460:r10532.
 truelight parents: 
9629diff
changeset | 162 | Town *t = NULL; | 
| 9624 | 163 | 	switch (GetTileType(tile)) {
 | 
| 9694 
e72987579514
(svn r10775) [NoAI] -Sync: with trunk r10535:r10774.
 rubidium parents: 
9686diff
changeset | 164 | case MP_ROAD: | 
| 9641 
855e32c08c9b
(svn r10533) [NoAI] -Sync with trunk r10460:r10532.
 truelight parents: 
9629diff
changeset | 165 | if (_game_mode != GM_EDITOR && GetRoadOwner(tile, rt) == OWNER_TOWN) t = GetTownByTile(tile); | 
| 9723 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 166 | if (!EnsureNoVehicleOnGround(tile)) return CMD_ERROR; | 
| 9624 | 167 | break; | 
| 168 | ||
| 169 | case MP_STATION: | |
| 170 | if (!IsDriveThroughStopTile(tile)) return CMD_ERROR; | |
| 9723 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 171 | if (!EnsureNoVehicleOnGround(tile)) return CMD_ERROR; | 
| 9624 | 172 | break; | 
| 173 | ||
| 174 | case MP_TUNNELBRIDGE: | |
| 9724 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 175 | if (GetTunnelBridgeTransportType(tile) != TRANSPORT_ROAD) return CMD_ERROR; | 
| 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 176 | if (GetVehicleTunnelBridge(tile, GetOtherTunnelBridgeEnd(tile)) != NULL) return CMD_ERROR; | 
| 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 177 | break; | 
| 9624 | 178 | |
| 179 | default: | |
| 180 | return CMD_ERROR; | |
| 181 | } | |
| 1638 
aae181b00846
(svn r2142) - Fix: Game no longer crashes when you want to remove a piece of road under a bridge that belongs to the town. TODO: railcrossings store owner somewhere else, put it into _map_owner[]!
 Darkvater parents: 
1398diff
changeset | 182 | |
| 9624 | 183 | RoadTypes rts = GetRoadTypes(tile); | 
| 184 | /* The tile doesn't have the given road type */ | |
| 9722 
ebf0ece7d8f6
(svn r11503) [NoAI] -Sync: with trunk r11308:11502.
 rubidium parents: 
9718diff
changeset | 185 | if (!HasBit(rts, rt)) return CMD_ERROR; | 
| 6460 | 186 | |
| 9624 | 187 | if (!CheckAllowRemoveRoad(tile, pieces, &edge_road, rt)) return CMD_ERROR; | 
| 0 | 188 | |
| 9574 | 189 | /* check if you're allowed to remove the street owned by a town | 
| 190 | * removal allowance depends on difficulty setting */ | |
| 5573 
afa6f92a71fd
(svn r7573) -Merged the bridge branch. Allows to build bridges of arbitrary rail/road combinations (including signals)
 celestar parents: 
5212diff
changeset | 191 | if (!CheckforTownRating(flags, t, ROAD_REMOVE)) return CMD_ERROR; | 
| 
afa6f92a71fd
(svn r7573) -Merged the bridge branch. Allows to build bridges of arbitrary rail/road combinations (including signals)
 celestar parents: 
5212diff
changeset | 192 | |
| 9694 
e72987579514
(svn r10775) [NoAI] -Sync: with trunk r10535:r10774.
 rubidium parents: 
9686diff
changeset | 193 | 	if (!IsTileType(tile, MP_ROAD)) {
 | 
| 9624 | 194 | /* If it's the last roadtype, just clear the whole tile */ | 
| 195 | if (rts == RoadTypeToRoadTypes(rt)) return DoCommand(tile, 0, 0, flags, CMD_LANDSCAPE_CLEAR); | |
| 196 | ||
| 9723 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 197 | CommandCost cost(EXPENSES_CONSTRUCTION); | 
| 9624 | 198 | 		if (IsTileType(tile, MP_TUNNELBRIDGE)) {
 | 
| 9723 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 199 | TileIndex other_end = GetOtherTunnelBridgeEnd(tile); | 
| 9624 | 200 | /* Pay for *every* tile of the bridge or tunnel */ | 
| 9724 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 201 | cost.AddCost((GetTunnelBridgeLength(other_end, tile) + 2) * _price.remove_road); | 
| 9624 | 202 | 			if (flags & DC_EXEC) {
 | 
| 203 | SetRoadTypes(other_end, GetRoadTypes(other_end) & ~RoadTypeToRoadTypes(rt)); | |
| 204 | SetRoadTypes(tile, GetRoadTypes(tile) & ~RoadTypeToRoadTypes(rt)); | |
| 205 | ||
| 206 | /* Mark tiles diry that have been repaved */ | |
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 207 | MarkTileDirtyByTile(tile); | 
| 9624 | 208 | MarkTileDirtyByTile(other_end); | 
| 209 | 				if (IsBridge(tile)) {
 | |
| 9723 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 210 | TileIndexDiff delta = TileOffsByDiagDir(GetTunnelBridgeDirection(tile)); | 
| 9624 | 211 | |
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 212 | for (TileIndex t = tile + delta; t != other_end; t += delta) MarkTileDirtyByTile(t); | 
| 9624 | 213 | } | 
| 214 | } | |
| 215 | 		} else {
 | |
| 9629 | 216 | cost.AddCost(_price.remove_road); | 
| 9624 | 217 | 			if (flags & DC_EXEC) {
 | 
| 218 | SetRoadTypes(tile, GetRoadTypes(tile) & ~RoadTypeToRoadTypes(rt)); | |
| 219 | MarkTileDirtyByTile(tile); | |
| 220 | } | |
| 221 | } | |
| 9723 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 222 | return cost; | 
| 9624 | 223 | } | 
| 224 | ||
| 5573 
afa6f92a71fd
(svn r7573) -Merged the bridge branch. Allows to build bridges of arbitrary rail/road combinations (including signals)
 celestar parents: 
5212diff
changeset | 225 | 	switch (GetRoadTileType(tile)) {
 | 
| 
afa6f92a71fd
(svn r7573) -Merged the bridge branch. Allows to build bridges of arbitrary rail/road combinations (including signals)
 celestar parents: 
5212diff
changeset | 226 | 		case ROAD_TILE_NORMAL: {
 | 
| 9826 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 227 | const Slope tileh = GetTileSlope(tile, NULL); | 
| 9624 | 228 | RoadBits present = GetRoadBits(tile, rt); | 
| 9826 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 229 | const RoadBits other = GetOtherRoadBits(tile, rt); | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 230 | const Foundation f = GetRoadFoundation(tileh, present); | 
| 5573 
afa6f92a71fd
(svn r7573) -Merged the bridge branch. Allows to build bridges of arbitrary rail/road combinations (including signals)
 celestar parents: 
5212diff
changeset | 231 | |
| 
afa6f92a71fd
(svn r7573) -Merged the bridge branch. Allows to build bridges of arbitrary rail/road combinations (including signals)
 celestar parents: 
5212diff
changeset | 232 | if (HasRoadWorks(tile)) return_cmd_error(STR_ROAD_WORKS_IN_PROGRESS); | 
| 
afa6f92a71fd
(svn r7573) -Merged the bridge branch. Allows to build bridges of arbitrary rail/road combinations (including signals)
 celestar parents: 
5212diff
changeset | 233 | |
| 9826 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 234 | /* Autocomplete to a straight road | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 235 | * @li on steep slopes | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 236 | * @li if the bits of the other roadtypes result in another foundation | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 237 | * @li if build on slopes is disabled */ | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 238 | if (IsSteepSlope(tileh) || (IsStraightRoad(other) && | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 239 | (other & _invalid_tileh_slopes_road[0][tileh & SLOPE_ELEVATED]) != ROAD_NONE) || | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 240 | 					(tileh != SLOPE_FLAT && !_patches.build_on_slopes)) {
 | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 241 | pieces |= MirrorRoadBits(pieces); | 
| 5573 
afa6f92a71fd
(svn r7573) -Merged the bridge branch. Allows to build bridges of arbitrary rail/road combinations (including signals)
 celestar parents: 
5212diff
changeset | 242 | } | 
| 
afa6f92a71fd
(svn r7573) -Merged the bridge branch. Allows to build bridges of arbitrary rail/road combinations (including signals)
 celestar parents: 
5212diff
changeset | 243 | |
| 9574 | 244 | /* limit the bits to delete to the existing bits. */ | 
| 9826 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 245 | pieces &= present; | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 246 | if (pieces == ROAD_NONE) return CMD_ERROR; | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 247 | |
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 248 | /* Now set present what it will be after the remove */ | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 249 | present ^= pieces; | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 250 | |
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 251 | /* Check for invalid RoadBit combinations on slopes */ | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 252 | if (tileh != SLOPE_FLAT && present != ROAD_NONE && | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 253 | 					(present & _invalid_tileh_slopes_road[0][tileh & SLOPE_ELEVATED]) == present) {
 | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 254 | return CMD_ERROR; | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 255 | } | 
| 5573 
afa6f92a71fd
(svn r7573) -Merged the bridge branch. Allows to build bridges of arbitrary rail/road combinations (including signals)
 celestar parents: 
5212diff
changeset | 256 | |
| 9723 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 257 | ChangeTownRating(t, -road_remove_cost[(byte)edge_road], RATING_ROAD_MINIMUM); | 
| 5573 
afa6f92a71fd
(svn r7573) -Merged the bridge branch. Allows to build bridges of arbitrary rail/road combinations (including signals)
 celestar parents: 
5212diff
changeset | 258 | 			if (flags & DC_EXEC) {
 | 
| 9624 | 259 | 				if (present == ROAD_NONE) {
 | 
| 260 | RoadTypes rts = GetRoadTypes(tile) & ComplementRoadTypes(RoadTypeToRoadTypes(rt)); | |
| 261 | 					if (rts == ROADTYPES_NONE) {
 | |
| 9703 
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
 rubidium parents: 
9701diff
changeset | 262 | /* Includes MarkTileDirtyByTile() */ | 
| 9624 | 263 | DoClearSquare(tile); | 
| 264 | 					} else {
 | |
| 265 | SetRoadBits(tile, ROAD_NONE, rt); | |
| 266 | SetRoadTypes(tile, rts); | |
| 9703 
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
 rubidium parents: 
9701diff
changeset | 267 | MarkTileDirtyByTile(tile); | 
| 9624 | 268 | } | 
| 5573 
afa6f92a71fd
(svn r7573) -Merged the bridge branch. Allows to build bridges of arbitrary rail/road combinations (including signals)
 celestar parents: 
5212diff
changeset | 269 | 				} else {
 | 
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 270 | /* When bits are removed, you *always* end up with something that | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 271 | * is not a complete straight road tile. However, trams do not have | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 272 | * onewayness, so they cannot remove it either. */ | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 273 | if (rt != ROADTYPE_TRAM) SetDisallowedRoadDirections(tile, DRD_NONE); | 
| 9624 | 274 | SetRoadBits(tile, present, rt); | 
| 5573 
afa6f92a71fd
(svn r7573) -Merged the bridge branch. Allows to build bridges of arbitrary rail/road combinations (including signals)
 celestar parents: 
5212diff
changeset | 275 | MarkTileDirtyByTile(tile); | 
| 
afa6f92a71fd
(svn r7573) -Merged the bridge branch. Allows to build bridges of arbitrary rail/road combinations (including signals)
 celestar parents: 
5212diff
changeset | 276 | } | 
| 
afa6f92a71fd
(svn r7573) -Merged the bridge branch. Allows to build bridges of arbitrary rail/road combinations (including signals)
 celestar parents: 
5212diff
changeset | 277 | } | 
| 9826 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 278 | |
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 279 | /* If we change the foundation we have to pay for it. */ | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 280 | return CommandCost(EXPENSES_CONSTRUCTION, CountBits(pieces) * _price.remove_road + | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 281 | ((GetRoadFoundation(tileh, present) != f) ? _price.terraform : (Money)0)); | 
| 5573 
afa6f92a71fd
(svn r7573) -Merged the bridge branch. Allows to build bridges of arbitrary rail/road combinations (including signals)
 celestar parents: 
5212diff
changeset | 282 | } | 
| 
afa6f92a71fd
(svn r7573) -Merged the bridge branch. Allows to build bridges of arbitrary rail/road combinations (including signals)
 celestar parents: 
5212diff
changeset | 283 | |
| 
afa6f92a71fd
(svn r7573) -Merged the bridge branch. Allows to build bridges of arbitrary rail/road combinations (including signals)
 celestar parents: 
5212diff
changeset | 284 | 		case ROAD_TILE_CROSSING: {
 | 
| 
afa6f92a71fd
(svn r7573) -Merged the bridge branch. Allows to build bridges of arbitrary rail/road combinations (including signals)
 celestar parents: 
5212diff
changeset | 285 | 			if (pieces & ComplementRoadBits(GetCrossingRoadBits(tile))) {
 | 
| 3176 | 286 | return CMD_ERROR; | 
| 0 | 287 | } | 
| 288 | ||
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 289 | /* Don't allow road to be removed from the crossing when there is tram; | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 290 | * we can't draw the crossing without trambits ;) */ | 
| 9732 | 291 | if (rt == ROADTYPE_ROAD && HasTileRoadType(tile, ROADTYPE_TRAM) && (flags & DC_EXEC || crossing_check)) return CMD_ERROR; | 
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 292 | |
| 9723 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 293 | 			if (rt == ROADTYPE_ROAD) {
 | 
| 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 294 | ChangeTownRating(t, -road_remove_cost[(byte)edge_road], RATING_ROAD_MINIMUM); | 
| 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 295 | } | 
| 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 296 | |
| 0 | 297 | 			if (flags & DC_EXEC) {
 | 
| 9624 | 298 | RoadTypes rts = GetRoadTypes(tile) & ComplementRoadTypes(RoadTypeToRoadTypes(rt)); | 
| 299 | 				if (rts == ROADTYPES_NONE) {
 | |
| 300 | MakeRailNormal(tile, GetTileOwner(tile), GetCrossingRailBits(tile), GetRailType(tile)); | |
| 301 | 				} else {
 | |
| 302 | SetRoadTypes(tile, rts); | |
| 303 | } | |
| 3060 | 304 | MarkTileDirtyByTile(tile); | 
| 5838 
9c3129cb019b
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
 rubidium parents: 
5835diff
changeset | 305 | YapfNotifyTrackLayoutChange(tile, FindFirstTrack(GetTrackBits(tile))); | 
| 0 | 306 | } | 
| 9723 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 307 | return CommandCost(EXPENSES_CONSTRUCTION, _price.remove_road * 2); | 
| 5573 
afa6f92a71fd
(svn r7573) -Merged the bridge branch. Allows to build bridges of arbitrary rail/road combinations (including signals)
 celestar parents: 
5212diff
changeset | 308 | } | 
| 3977 
edb5b94e2094
(svn r5155) - Remove the bridge branch merge (revision r5070)
 tron parents: 
3933diff
changeset | 309 | |
| 5573 
afa6f92a71fd
(svn r7573) -Merged the bridge branch. Allows to build bridges of arbitrary rail/road combinations (including signals)
 celestar parents: 
5212diff
changeset | 310 | default: | 
| 
afa6f92a71fd
(svn r7573) -Merged the bridge branch. Allows to build bridges of arbitrary rail/road combinations (including signals)
 celestar parents: 
5212diff
changeset | 311 | case ROAD_TILE_DEPOT: | 
| 
afa6f92a71fd
(svn r7573) -Merged the bridge branch. Allows to build bridges of arbitrary rail/road combinations (including signals)
 celestar parents: 
5212diff
changeset | 312 | return CMD_ERROR; | 
| 0 | 313 | } | 
| 314 | } | |
| 315 | ||
| 316 | ||
| 9724 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 317 | /** Delete a piece of road. | 
| 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 318 | * @param tile tile where to remove road from | 
| 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 319 | * @param flags operation to perform | 
| 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 320 | * @param p1 bit 0..3 road pieces to remove (RoadBits) | 
| 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 321 | * bit 4..5 road type | 
| 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 322 | * @param p2 unused | 
| 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 323 | */ | 
| 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 324 | CommandCost CmdRemoveRoad(TileIndex tile, uint32 flags, uint32 p1, uint32 p2) | 
| 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 325 | {
 | 
| 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 326 | RoadType rt = (RoadType)GB(p1, 4, 2); | 
| 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 327 | if (!IsValidRoadType(rt)) return CMD_ERROR; | 
| 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 328 | |
| 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 329 | RoadBits pieces = Extract<RoadBits, 0>(p1); | 
| 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 330 | |
| 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 331 | return RemoveRoad(tile, flags, pieces, rt, true); | 
| 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 332 | } | 
| 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 333 | |
| 9704 | 334 | /** | 
| 335 | * Calculate the costs for roads on slopes | |
| 336 | * Aside modify the RoadBits to fit on the slopes | |
| 337 | * | |
| 338 | * @note The RoadBits are modified too! | |
| 339 | * @param tileh The current slope | |
| 340 | * @param pieces The RoadBits we want to add | |
| 9826 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 341 | * @param existing The existent RoadBits of the current type | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 342 | * @param other The other existent RoadBits | 
| 9704 | 343 | * @return The costs for these RoadBits on this slope | 
| 344 | */ | |
| 9826 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 345 | static CommandCost CheckRoadSlope(Slope tileh, RoadBits* pieces, RoadBits existing, RoadBits other) | 
| 0 | 346 | {
 | 
| 9826 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 347 | /* Remove already build pieces */ | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 348 | CLRBITS(*pieces, existing); | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 349 | |
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 350 | /* If we can't build anything stop here */ | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 351 | if (*pieces == ROAD_NONE) return CMD_ERROR; | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 352 | |
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 353 | /* All RoadBit combos are valid on flat land */ | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 354 | if (tileh == SLOPE_FLAT) return CommandCost(); | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 355 | |
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 356 | /* Proceed steep Slopes first to reduce lookup table size */ | 
| 4246 
14a8849c32df
(svn r5833) -Feature: Allow building of (certain) rails, roads and bridge ramps on steep sloped tiles
 tron parents: 
4232diff
changeset | 357 | 	if (IsSteepSlope(tileh)) {
 | 
| 9704 | 358 | /* Force straight roads. */ | 
| 359 | *pieces |= MirrorRoadBits(*pieces); | |
| 9694 
e72987579514
(svn r10775) [NoAI] -Sync: with trunk r10535:r10774.
 rubidium parents: 
9686diff
changeset | 360 | |
| 9826 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 361 | /* Use existing as all existing since only straight | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 362 | * roads are allowed here. */ | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 363 | existing |= other; | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 364 | |
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 365 | 		if ((existing == ROAD_NONE || existing == *pieces) && IsStraightRoad(*pieces)) {
 | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 366 | return CommandCost(EXPENSES_CONSTRUCTION, _price.terraform); | 
| 4246 
14a8849c32df
(svn r5833) -Feature: Allow building of (certain) rails, roads and bridge ramps on steep sloped tiles
 tron parents: 
4232diff
changeset | 367 | } | 
| 
14a8849c32df
(svn r5833) -Feature: Allow building of (certain) rails, roads and bridge ramps on steep sloped tiles
 tron parents: 
4232diff
changeset | 368 | return CMD_ERROR; | 
| 
14a8849c32df
(svn r5833) -Feature: Allow building of (certain) rails, roads and bridge ramps on steep sloped tiles
 tron parents: 
4232diff
changeset | 369 | } | 
| 9704 | 370 | |
| 9826 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 371 | /* Save the merge of all bits of the current type */ | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 372 | RoadBits type_bits = existing | *pieces; | 
| 9704 | 373 | |
| 9826 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 374 | /* Roads on slopes */ | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 375 | 	if (_patches.build_on_slopes && (_invalid_tileh_slopes_road[0][tileh] & (other | type_bits)) == ROAD_NONE) {
 | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 376 | |
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 377 | /* If we add leveling we've got to pay for it */ | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 378 | if ((other | existing) == ROAD_NONE) return CommandCost(EXPENSES_CONSTRUCTION, _price.terraform); | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 379 | |
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 380 | return CommandCost(); | 
| 9704 | 381 | } | 
| 0 | 382 | |
| 9826 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 383 | /* Autocomplete uphill roads */ | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 384 | *pieces |= MirrorRoadBits(*pieces); | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 385 | type_bits = existing | *pieces; | 
| 3381 
ebdcc12845c7
(svn r4187) Simplify the code for building/removing a piece of road a bit
 tron parents: 
3379diff
changeset | 386 | |
| 9826 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 387 | /* Uphill roads */ | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 388 | if (IsStraightRoad(type_bits) && (other == type_bits || other == ROAD_NONE) && | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 389 | 			(_invalid_tileh_slopes_road[1][tileh] & (other | type_bits)) == ROAD_NONE) {
 | 
| 3381 
ebdcc12845c7
(svn r4187) Simplify the code for building/removing a piece of road a bit
 tron parents: 
3379diff
changeset | 390 | |
| 9826 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 391 | /* Slopes with foundation ? */ | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 392 | 		if (IsSlopeWithOneCornerRaised(tileh)) {
 | 
| 9694 
e72987579514
(svn r10775) [NoAI] -Sync: with trunk r10535:r10774.
 rubidium parents: 
9686diff
changeset | 393 | |
| 9826 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 394 | /* Prevent build on slopes if it isn't allowed */ | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 395 | 			if (_patches.build_on_slopes) {
 | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 396 | |
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 397 | /* If we add foundation we've got to pay for it */ | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 398 | if ((other | existing) == ROAD_NONE) return CommandCost(EXPENSES_CONSTRUCTION, _price.terraform); | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 399 | |
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 400 | return CommandCost(); | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 401 | } | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 402 | 		} else {
 | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 403 | if (CountBits(existing) == 1) return CommandCost(EXPENSES_CONSTRUCTION, _price.terraform); | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 404 | return CommandCost(); | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 405 | } | 
| 0 | 406 | } | 
| 407 | return CMD_ERROR; | |
| 408 | } | |
| 409 | ||
| 1784 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 410 | /** Build a piece of road. | 
| 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: 
3435diff
changeset | 411 | * @param tile tile where to build road | 
| 9601 
b499fdd106d5
(svn r9713) [NoAI] -Sync with trunk (r9631:9712).
 rubidium parents: 
9574diff
changeset | 412 | * @param flags operation to perform | 
| 6460 | 413 | * @param p1 bit 0..3 road pieces to build (RoadBits) | 
| 9624 | 414 | * bit 4..5 road type | 
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 415 | * bit 6..7 disallowed directions to toggle | 
| 1784 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 416 | * @param p2 the town that is building the road (0 if not applicable) | 
| 0 | 417 | */ | 
| 9629 | 418 | CommandCost CmdBuildRoad(TileIndex tile, uint32 flags, uint32 p1, uint32 p2) | 
| 0 | 419 | {
 | 
| 9723 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 420 | CommandCost cost(EXPENSES_CONSTRUCTION); | 
| 9629 | 421 | CommandCost ret; | 
| 5838 
9c3129cb019b
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
 rubidium parents: 
5835diff
changeset | 422 | RoadBits existing = ROAD_NONE; | 
| 9826 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 423 | RoadBits other_bits = ROAD_NONE; | 
| 201 
c40d343115f8
(svn r202) -Codechange: I missed some files with trailing spaces.. this should be
 truelight parents: 
159diff
changeset | 424 | |
| 1784 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 425 | /* Road pieces are max 4 bitset values (NE, NW, SE, SW) and town can only be non-zero | 
| 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 426 | * if a non-player is building the road */ | 
| 6460 | 427 | if ((IsValidPlayer(_current_player) && p2 != 0) || (_current_player == OWNER_TOWN && !IsValidTownID(p2))) return CMD_ERROR; | 
| 428 | ||
| 429 | RoadBits pieces = Extract<RoadBits, 0>(p1); | |
| 1784 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 430 | |
| 9826 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 431 | /* do not allow building 'zero' road bits, code wouldn't handle it */ | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 432 | if (pieces == ROAD_NONE) return CMD_ERROR; | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 433 | |
| 9624 | 434 | RoadType rt = (RoadType)GB(p1, 4, 2); | 
| 9722 
ebf0ece7d8f6
(svn r11503) [NoAI] -Sync: with trunk r11308:11502.
 rubidium parents: 
9718diff
changeset | 435 | if (!IsValidRoadType(rt) || !ValParamRoadType(rt)) return CMD_ERROR; | 
| 9624 | 436 | |
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 437 | DisallowedRoadDirections toggle_drd = (DisallowedRoadDirections)GB(p1, 6, 2); | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 438 | |
| 9826 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 439 | Slope tileh = GetTileSlope(tile, NULL); | 
| 0 | 440 | |
| 3434 
21094a78dcdb
(svn r4263) -Codechange: Road building no longer uses FindLandscapeHeight. Last occurence of FindLandscapeTile in the tile-specific functions gone. Thanks to Tron for doing lots of work in this direction
 celestar parents: 
3430diff
changeset | 441 | 	switch (GetTileType(tile)) {
 | 
| 9694 
e72987579514
(svn r10775) [NoAI] -Sync: with trunk r10535:r10774.
 rubidium parents: 
9686diff
changeset | 442 | case MP_ROAD: | 
| 3793 
33cdb5bf7b21
(svn r4789) - Codechange: rename RoadType to RoadTileType and ROAD_{NORMAL,CROSSING,DEPOT} to ROAD_TILE_* for consistency
 rubidium parents: 
3792diff
changeset | 443 | 			switch (GetRoadTileType(tile)) {
 | 
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 444 | 				case ROAD_TILE_NORMAL: {
 | 
| 4046 
566de0b02064
(svn r5315) -Fix: Prohibit altering a road tile while road works are in progress
 tron parents: 
4000diff
changeset | 445 | if (HasRoadWorks(tile)) return_cmd_error(STR_ROAD_WORKS_IN_PROGRESS); | 
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 446 | |
| 9826 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 447 | other_bits = GetOtherRoadBits(tile, rt); | 
| 9732 | 448 | if (!HasTileRoadType(tile, rt)) break; | 
| 4046 
566de0b02064
(svn r5315) -Fix: Prohibit altering a road tile while road works are in progress
 tron parents: 
4000diff
changeset | 449 | |
| 9624 | 450 | existing = GetRoadBits(tile, rt); | 
| 9826 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 451 | bool crossing = !IsStraightRoad(existing | pieces); | 
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 452 | 					if (rt != ROADTYPE_TRAM && (GetDisallowedRoadDirections(tile) != DRD_NONE || toggle_drd != DRD_NONE) && crossing) {
 | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 453 | /* Junctions cannot be one-way */ | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 454 | return_cmd_error(STR_ERR_ONEWAY_ROADS_CAN_T_HAVE_JUNCTION); | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 455 | } | 
| 3150 
025fe8cd7104
(svn r3773) Shove some semantics down ottd's throat by replacing ints and magic numbers by enums and some related changes
 tron parents: 
3149diff
changeset | 456 | 					if ((existing & pieces) == pieces) {
 | 
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 457 | /* We only want to set the (dis)allowed road directions */ | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 458 | 						if (toggle_drd != DRD_NONE && rt != ROADTYPE_TRAM && GetRoadOwner(tile, ROADTYPE_ROAD) == _current_player) {
 | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 459 | if (crossing) return_cmd_error(STR_ERR_ONEWAY_ROADS_CAN_T_HAVE_JUNCTION); | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 460 | |
| 9732 | 461 | if (!EnsureNoVehicleOnGround(tile)) return CMD_ERROR; | 
| 462 | ||
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 463 | /* Ignore half built tiles */ | 
| 9826 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 464 | 							if (flags & DC_EXEC && rt != ROADTYPE_TRAM && IsStraightRoad(existing)) {
 | 
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 465 | SetDisallowedRoadDirections(tile, GetDisallowedRoadDirections(tile) ^ toggle_drd); | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 466 | MarkTileDirtyByTile(tile); | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 467 | } | 
| 9629 | 468 | return CommandCost(); | 
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 469 | } | 
| 3066 
0d34dff23d98
(svn r3655) Simplify a boolean expression and turn 3 if-cascades into switches
 tron parents: 
3061diff
changeset | 470 | return_cmd_error(STR_1007_ALREADY_BUILT); | 
| 
0d34dff23d98
(svn r3655) Simplify a boolean expression and turn 3 if-cascades into switches
 tron parents: 
3061diff
changeset | 471 | } | 
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 472 | } break; | 
| 3066 
0d34dff23d98
(svn r3655) Simplify a boolean expression and turn 3 if-cascades into switches
 tron parents: 
3061diff
changeset | 473 | |
| 3793 
33cdb5bf7b21
(svn r4789) - Codechange: rename RoadType to RoadTileType and ROAD_{NORMAL,CROSSING,DEPOT} to ROAD_TILE_* for consistency
 rubidium parents: 
3792diff
changeset | 474 | case ROAD_TILE_CROSSING: | 
| 9732 | 475 | if (HasTileRoadType(tile, rt)) return_cmd_error(STR_1007_ALREADY_BUILT); | 
| 9826 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 476 | other_bits = GetCrossingRoadBits(tile); | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 477 | if (pieces & ComplementRoadBits(other_bits)) goto do_clear; | 
| 9624 | 478 | break; | 
| 3066 
0d34dff23d98
(svn r3655) Simplify a boolean expression and turn 3 if-cascades into switches
 tron parents: 
3061diff
changeset | 479 | |
| 3069 
0e6aca11c3da
(svn r3658) Add functions and symbolic names to retrieve road tile types and road pieces
 tron parents: 
3068diff
changeset | 480 | default: | 
| 3793 
33cdb5bf7b21
(svn r4789) - Codechange: rename RoadType to RoadTileType and ROAD_{NORMAL,CROSSING,DEPOT} to ROAD_TILE_* for consistency
 rubidium parents: 
3792diff
changeset | 481 | case ROAD_TILE_DEPOT: | 
| 3066 
0d34dff23d98
(svn r3655) Simplify a boolean expression and turn 3 if-cascades into switches
 tron parents: 
3061diff
changeset | 482 | goto do_clear; | 
| 3060 | 483 | } | 
| 484 | break; | |
| 0 | 485 | |
| 3060 | 486 | 		case MP_RAILWAY: {
 | 
| 3099 
374e275300e3
(svn r3689) Add functions to turn a tile into either a normal road tile, a level crossing or a road depot
 tron parents: 
3098diff
changeset | 487 | Axis roaddir; | 
| 13 
3e7c1f74a996
(svn r14) Fix: railroad crossings on slopes are now possible
 dominik parents: 
0diff
changeset | 488 | |
| 3636 
d87b21df2944
(svn r4541) Add a type for slopes and replace many magic numbers by the appropriate enums
 tron parents: 
3560diff
changeset | 489 | 			if (IsSteepSlope(tileh)) {
 | 
| 3060 | 490 | return_cmd_error(STR_1000_LAND_SLOPED_IN_WRONG_DIRECTION); | 
| 491 | } | |
| 492 | ||
| 3104 
106ca8c3d959
(svn r3699) Replace some magic numbers for checking for a suitable slope for a level crossing by some less magic numbers
 tron parents: 
3103diff
changeset | 493 | /* Level crossings may only be built on these slopes */ | 
| 9722 
ebf0ece7d8f6
(svn r11503) [NoAI] -Sync: with trunk r11308:11502.
 rubidium parents: 
9718diff
changeset | 494 | 			if (!HasBit(VALID_LEVEL_CROSSING_SLOPES, tileh)) {
 | 
| 3060 | 495 | return_cmd_error(STR_1000_LAND_SLOPED_IN_WRONG_DIRECTION); | 
| 496 | } | |
| 497 | ||
| 3792 
2eb8388731bf
(svn r4788) - Codechange: RAILTYPE_{NORMAL,ELECTRIC,...} and RAIL_TYPE_{NORMAL,SIGNAL,...} have nearly the same name, rename RAIL_TYPE_* to RAIL_TILE_* of extra clarity
 rubidium parents: 
3673diff
changeset | 498 | if (GetRailTileType(tile) != RAIL_TILE_NORMAL) goto do_clear; | 
| 3269 
95e7bffcb3c5
(svn r3981) More work for the rail accessing functions and enums
 tron parents: 
3267diff
changeset | 499 | 			switch (GetTrackBits(tile)) {
 | 
| 
95e7bffcb3c5
(svn r3981) More work for the rail accessing functions and enums
 tron parents: 
3267diff
changeset | 500 | case TRACK_BIT_X: | 
| 
95e7bffcb3c5
(svn r3981) More work for the rail accessing functions and enums
 tron parents: 
3267diff
changeset | 501 | if (pieces & ROAD_X) goto do_clear; | 
| 
95e7bffcb3c5
(svn r3981) More work for the rail accessing functions and enums
 tron parents: 
3267diff
changeset | 502 | roaddir = AXIS_Y; | 
| 
95e7bffcb3c5
(svn r3981) More work for the rail accessing functions and enums
 tron parents: 
3267diff
changeset | 503 | break; | 
| 
95e7bffcb3c5
(svn r3981) More work for the rail accessing functions and enums
 tron parents: 
3267diff
changeset | 504 | |
| 
95e7bffcb3c5
(svn r3981) More work for the rail accessing functions and enums
 tron parents: 
3267diff
changeset | 505 | case TRACK_BIT_Y: | 
| 
95e7bffcb3c5
(svn r3981) More work for the rail accessing functions and enums
 tron parents: 
3267diff
changeset | 506 | if (pieces & ROAD_Y) goto do_clear; | 
| 
95e7bffcb3c5
(svn r3981) More work for the rail accessing functions and enums
 tron parents: 
3267diff
changeset | 507 | roaddir = AXIS_X; | 
| 
95e7bffcb3c5
(svn r3981) More work for the rail accessing functions and enums
 tron parents: 
3267diff
changeset | 508 | break; | 
| 
95e7bffcb3c5
(svn r3981) More work for the rail accessing functions and enums
 tron parents: 
3267diff
changeset | 509 | |
| 
95e7bffcb3c5
(svn r3981) More work for the rail accessing functions and enums
 tron parents: 
3267diff
changeset | 510 | default: goto do_clear; | 
| 3060 | 511 | } | 
| 512 | ||
| 9574 | 513 | if (!EnsureNoVehicleOnGround(tile)) return CMD_ERROR; | 
| 3381 
ebdcc12845c7
(svn r4187) Simplify the code for building/removing a piece of road a bit
 tron parents: 
3379diff
changeset | 514 | |
| 3060 | 515 | 			if (flags & DC_EXEC) {
 | 
| 5838 
9c3129cb019b
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
 rubidium parents: 
5835diff
changeset | 516 | YapfNotifyTrackLayoutChange(tile, FindFirstTrack(GetTrackBits(tile))); | 
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 517 | /* Always add road to the roadtypes (can't draw without it) */ | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 518 | MakeRoadCrossing(tile, _current_player, _current_player, _current_player, GetTileOwner(tile), roaddir, GetRailType(tile), RoadTypeToRoadTypes(rt) | ROADTYPES_ROAD, p2); | 
| 9724 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 519 | UpdateLevelCrossing(tile, false); | 
| 3100 
552cf19c49cb
(svn r3695) Add 2 MarkTileByTile() which I forgot in r3689 (noticed by Belugas)
 tron parents: 
3099diff
changeset | 520 | MarkTileDirtyByTile(tile); | 
| 3060 | 521 | } | 
| 9723 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 522 | return CommandCost(EXPENSES_CONSTRUCTION, _price.build_road * (rt == ROADTYPE_ROAD ? 2 : 4)); | 
| 3017 
915fae59d5e0
(svn r3597) Miscellaneous (I like that word) changes: Fix some indentation, add consts, reduce indentation level by short-circuit logic, convert if cascades to switch, whitespace, bracing, plus some minor stuff
 tron parents: 
2989diff
changeset | 523 | } | 
| 0 | 524 | |
| 9624 | 525 | case MP_STATION: | 
| 526 | if (!IsDriveThroughStopTile(tile)) return CMD_ERROR; | |
| 9732 | 527 | if (HasTileRoadType(tile, rt)) return_cmd_error(STR_1007_ALREADY_BUILT); | 
| 9624 | 528 | break; | 
| 529 | ||
| 530 | case MP_TUNNELBRIDGE: | |
| 9724 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 531 | if (GetTunnelBridgeTransportType(tile) != TRANSPORT_ROAD) return CMD_ERROR; | 
| 9732 | 532 | if (HasTileRoadType(tile, rt)) return_cmd_error(STR_1007_ALREADY_BUILT); | 
| 9724 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 533 | /* Don't allow adding roadtype to the bridge/tunnel when vehicles are already driving on it */ | 
| 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 534 | if (GetVehicleTunnelBridge(tile, GetOtherTunnelBridgeEnd(tile)) != NULL) return CMD_ERROR; | 
| 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 535 | break; | 
| 9624 | 536 | |
| 3060 | 537 | default: | 
| 0 | 538 | do_clear:; | 
| 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: 
3435diff
changeset | 539 | ret = DoCommand(tile, 0, 0, flags, CMD_LANDSCAPE_CLEAR); | 
| 3381 
ebdcc12845c7
(svn r4187) Simplify the code for building/removing a piece of road a bit
 tron parents: 
3379diff
changeset | 540 | if (CmdFailed(ret)) return ret; | 
| 9629 | 541 | cost.AddCost(ret); | 
| 0 | 542 | } | 
| 543 | ||
| 9826 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 544 | 	if (other_bits != pieces) {
 | 
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 545 | /* Check the foundation/slopes when adding road/tram bits */ | 
| 9826 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 546 | ret = CheckRoadSlope(tileh, &pieces, existing, other_bits); | 
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 547 | /* Return an error if we need to build a foundation (ret != 0) but the | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 548 | * current patch-setting is turned off (or stupid AI@work) */ | 
| 9629 | 549 | 		if (CmdFailed(ret) || (ret.GetCost() != 0 && !_patches.build_on_slopes)) {
 | 
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 550 | return_cmd_error(STR_1000_LAND_SLOPED_IN_WRONG_DIRECTION); | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 551 | } | 
| 9629 | 552 | cost.AddCost(ret); | 
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 553 | } | 
| 0 | 554 | |
| 9694 
e72987579514
(svn r10775) [NoAI] -Sync: with trunk r10535:r10774.
 rubidium parents: 
9686diff
changeset | 555 | 	if (IsTileType(tile, MP_ROAD)) {
 | 
| 9574 | 556 | /* Don't put the pieces that already exist */ | 
| 3150 
025fe8cd7104
(svn r3773) Shove some semantics down ottd's throat by replacing ints and magic numbers by enums and some related changes
 tron parents: 
3149diff
changeset | 557 | pieces &= ComplementRoadBits(existing); | 
| 9724 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 558 | |
| 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 559 | /* Check if new road bits will have the same foundation as other existing road types */ | 
| 9732 | 560 | 		if (IsNormalRoad(tile)) {
 | 
| 9724 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 561 | Slope slope = GetTileSlope(tile, NULL); | 
| 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 562 | Foundation found_new = GetRoadFoundation(slope, pieces | existing); | 
| 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 563 | |
| 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 564 | /* Test if all other roadtypes can be built at that foundation */ | 
| 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 565 | 			for (RoadType rtest = ROADTYPE_ROAD; rtest < ROADTYPE_END; rtest++) {
 | 
| 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 566 | 				if (rtest != rt) { // check only other road types
 | 
| 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 567 | RoadBits bits = GetRoadBits(tile, rtest); | 
| 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 568 | /* do not check if there are not road bits of given type */ | 
| 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 569 | 					if (bits != ROAD_NONE && GetRoadFoundation(slope, bits) != found_new) {
 | 
| 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 570 | return_cmd_error(STR_1000_LAND_SLOPED_IN_WRONG_DIRECTION); | 
| 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 571 | } | 
| 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 572 | } | 
| 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 573 | } | 
| 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 574 | } | 
| 0 | 575 | } | 
| 576 | ||
| 9732 | 577 | if (!EnsureNoVehicleOnGround(tile)) return CMD_ERROR; | 
| 578 | ||
| 9722 
ebf0ece7d8f6
(svn r11503) [NoAI] -Sync: with trunk r11308:11502.
 rubidium parents: 
9718diff
changeset | 579 | cost.AddCost(CountBits(pieces) * _price.build_road); | 
| 9624 | 580 | 	if (IsTileType(tile, MP_TUNNELBRIDGE)) {
 | 
| 581 | /* Pay for *every* tile of the bridge or tunnel */ | |
| 9724 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 582 | cost.MultiplyCost(GetTunnelBridgeLength(GetOtherTunnelBridgeEnd(tile), tile) + 2); | 
| 9624 | 583 | } | 
| 0 | 584 | |
| 585 | 	if (flags & DC_EXEC) {
 | |
| 9624 | 586 | 		switch (GetTileType(tile)) {
 | 
| 9694 
e72987579514
(svn r10775) [NoAI] -Sync: with trunk r10535:r10774.
 rubidium parents: 
9686diff
changeset | 587 | 			case MP_ROAD: {
 | 
| 9624 | 588 | RoadTileType rtt = GetRoadTileType(tile); | 
| 589 | 				if (existing == ROAD_NONE || rtt == ROAD_TILE_CROSSING) {
 | |
| 590 | SetRoadTypes(tile, GetRoadTypes(tile) | RoadTypeToRoadTypes(rt)); | |
| 591 | SetRoadOwner(tile, rt, _current_player); | |
| 9629 | 592 | if (_current_player == OWNER_TOWN && rt == ROADTYPE_ROAD) SetTownIndex(tile, p2); | 
| 9624 | 593 | } | 
| 594 | if (rtt != ROAD_TILE_CROSSING) SetRoadBits(tile, existing | pieces, rt); | |
| 595 | } break; | |
| 596 | ||
| 597 | 			case MP_TUNNELBRIDGE: {
 | |
| 9723 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 598 | TileIndex other_end = GetOtherTunnelBridgeEnd(tile); | 
| 9624 | 599 | |
| 600 | SetRoadTypes(other_end, GetRoadTypes(other_end) | RoadTypeToRoadTypes(rt)); | |
| 601 | SetRoadTypes(tile, GetRoadTypes(tile) | RoadTypeToRoadTypes(rt)); | |
| 602 | ||
| 603 | /* Mark tiles diry that have been repaved */ | |
| 604 | MarkTileDirtyByTile(other_end); | |
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 605 | MarkTileDirtyByTile(tile); | 
| 9624 | 606 | 				if (IsBridge(tile)) {
 | 
| 9723 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 607 | TileIndexDiff delta = TileOffsByDiagDir(GetTunnelBridgeDirection(tile)); | 
| 9624 | 608 | |
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 609 | for (TileIndex t = tile + delta; t != other_end; t += delta) MarkTileDirtyByTile(t); | 
| 9624 | 610 | } | 
| 611 | } break; | |
| 612 | ||
| 613 | case MP_STATION: | |
| 614 | SetRoadTypes(tile, GetRoadTypes(tile) | RoadTypeToRoadTypes(rt)); | |
| 615 | break; | |
| 616 | ||
| 617 | default: | |
| 618 | MakeRoadNormal(tile, pieces, RoadTypeToRoadTypes(rt), p2, _current_player, _current_player, _current_player); | |
| 619 | break; | |
| 0 | 620 | } | 
| 621 | ||
| 9732 | 622 | 		if (rt != ROADTYPE_TRAM && IsNormalRoadTile(tile)) {
 | 
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 623 | existing |= pieces; | 
| 9826 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 624 | SetDisallowedRoadDirections(tile, IsStraightRoad(existing) ? | 
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 625 | GetDisallowedRoadDirections(tile) ^ toggle_drd : DRD_NONE); | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 626 | } | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 627 | |
| 0 | 628 | MarkTileDirtyByTile(tile); | 
| 629 | } | |
| 630 | return cost; | |
| 631 | } | |
| 632 | ||
| 1784 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 633 | /** Build a long piece of road. | 
| 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: 
3435diff
changeset | 634 | * @param end_tile end tile of drag | 
| 9601 
b499fdd106d5
(svn r9713) [NoAI] -Sync with trunk (r9631:9712).
 rubidium parents: 
9574diff
changeset | 635 | * @param flags operation to perform | 
| 1784 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 636 | * @param p1 start tile of drag | 
| 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 637 | * @param p2 various bitstuffed elements | 
| 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 638 | * - p2 = (bit 0) - start tile starts in the 2nd half of tile (p2 & 1) | 
| 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 639 | * - p2 = (bit 1) - end tile starts in the 2nd half of tile (p2 & 2) | 
| 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 640 | * - p2 = (bit 2) - direction: 0 = along x-axis, 1 = along y-axis (p2 & 4) | 
| 9624 | 641 | * - p2 = (bit 3 + 4) - road type | 
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 642 | * - p2 = (bit 5) - set road direction | 
| 1784 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 643 | */ | 
| 9629 | 644 | CommandCost CmdBuildLongRoad(TileIndex end_tile, uint32 flags, uint32 p1, uint32 p2) | 
| 0 | 645 | {
 | 
| 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: 
3435diff
changeset | 646 | TileIndex start_tile, tile; | 
| 9723 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 647 | CommandCost ret, cost(EXPENSES_CONSTRUCTION); | 
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 648 | bool had_bridge = false; | 
| 9701 
d1ac22c62f64
(svn r11036) [NoAI] -Sync: with trunk r10774:11035.
 rubidium parents: 
9694diff
changeset | 649 | bool had_tunnel = false; | 
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 650 | bool had_success = false; | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 651 | DisallowedRoadDirections drd = DRD_NORTHBOUND; | 
| 0 | 652 | |
| 9732 | 653 | _error_message = INVALID_STRING_ID; | 
| 654 | ||
| 2934 
3b7eef9871f8
(svn r3490) -Fix: A bunch (10) of off-by-one errors when checking if a TileIndex points to a tile on the map
 tron parents: 
2916diff
changeset | 655 | if (p1 >= MapSize()) return CMD_ERROR; | 
| 1784 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 656 | |
| 0 | 657 | start_tile = p1; | 
| 9624 | 658 | RoadType rt = (RoadType)GB(p2, 3, 2); | 
| 9722 
ebf0ece7d8f6
(svn r11503) [NoAI] -Sync: with trunk r11308:11502.
 rubidium parents: 
9718diff
changeset | 659 | if (!IsValidRoadType(rt) || !ValParamRoadType(rt)) return CMD_ERROR; | 
| 0 | 660 | |
| 1784 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 661 | /* Only drag in X or Y direction dictated by the direction variable */ | 
| 9722 
ebf0ece7d8f6
(svn r11503) [NoAI] -Sync: with trunk r11308:11502.
 rubidium parents: 
9718diff
changeset | 662 | if (!HasBit(p2, 2) && TileY(start_tile) != TileY(end_tile)) return CMD_ERROR; // x-axis | 
| 
ebf0ece7d8f6
(svn r11503) [NoAI] -Sync: with trunk r11308:11502.
 rubidium parents: 
9718diff
changeset | 663 | if (HasBit(p2, 2) && TileX(start_tile) != TileX(end_tile)) return CMD_ERROR; // y-axis | 
| 1784 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 664 | |
| 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 665 | /* Swap start and ending tile, also the half-tile drag var (bit 0 and 1) */ | 
| 9722 
ebf0ece7d8f6
(svn r11503) [NoAI] -Sync: with trunk r11308:11502.
 rubidium parents: 
9718diff
changeset | 666 | 	if (start_tile > end_tile || (start_tile == end_tile && HasBit(p2, 0))) {
 | 
| 1784 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 667 | TileIndex t = start_tile; | 
| 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 668 | start_tile = end_tile; | 
| 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 669 | end_tile = t; | 
| 9723 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 670 | p2 ^= IsInsideMM(p2 & 3, 1, 3) ? 3 : 0; | 
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 671 | drd = DRD_SOUTHBOUND; | 
| 0 | 672 | } | 
| 673 | ||
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 674 | /* On the X-axis, we have to swap the initial bits, so they | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 675 | * will be interpreted correctly in the GTTS. Futhermore | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 676 | * when you just 'click' on one tile to build them. */ | 
| 9722 
ebf0ece7d8f6
(svn r11503) [NoAI] -Sync: with trunk r11308:11502.
 rubidium parents: 
9718diff
changeset | 677 | if (HasBit(p2, 2) == (start_tile == end_tile && HasBit(p2, 0) == HasBit(p2, 1))) drd ^= DRD_BOTH; | 
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 678 | /* No disallowed direction bits have to be toggled */ | 
| 9722 
ebf0ece7d8f6
(svn r11503) [NoAI] -Sync: with trunk r11308:11502.
 rubidium parents: 
9718diff
changeset | 679 | if (!HasBit(p2, 5)) drd = DRD_NONE; | 
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 680 | |
| 0 | 681 | tile = start_tile; | 
| 9574 | 682 | /* Start tile is the small number. */ | 
| 1784 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 683 | 	for (;;) {
 | 
| 9722 
ebf0ece7d8f6
(svn r11503) [NoAI] -Sync: with trunk r11308:11502.
 rubidium parents: 
9718diff
changeset | 684 | RoadBits bits = HasBit(p2, 2) ? ROAD_Y : ROAD_X; | 
| 3098 
4c1320da876d
(svn r3687) Complete some bits I missed whenn adding accessor functions for road types and pieces
 tron parents: 
3097diff
changeset | 685 | |
| 9722 
ebf0ece7d8f6
(svn r11503) [NoAI] -Sync: with trunk r11308:11502.
 rubidium parents: 
9718diff
changeset | 686 | if (tile == end_tile && !HasBit(p2, 1)) bits &= ROAD_NW | ROAD_NE; | 
| 
ebf0ece7d8f6
(svn r11503) [NoAI] -Sync: with trunk r11308:11502.
 rubidium parents: 
9718diff
changeset | 687 | if (tile == start_tile && HasBit(p2, 0)) bits &= ROAD_SE | ROAD_SW; | 
| 0 | 688 | |
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 689 | ret = DoCommand(tile, drd << 6 | rt << 4 | bits, 0, flags, CMD_BUILD_ROAD); | 
| 1784 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 690 | 		if (CmdFailed(ret)) {
 | 
| 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 691 | if (_error_message != STR_1007_ALREADY_BUILT) return CMD_ERROR; | 
| 2549 | 692 | 		} else {
 | 
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 693 | had_success = true; | 
| 9701 
d1ac22c62f64
(svn r11036) [NoAI] -Sync: with trunk r10774:11035.
 rubidium parents: 
9694diff
changeset | 694 | /* Only pay for the upgrade on one side of the bridges and tunnels */ | 
| 
d1ac22c62f64
(svn r11036) [NoAI] -Sync: with trunk r10774:11035.
 rubidium parents: 
9694diff
changeset | 695 | 			if (IsTileType(tile, MP_TUNNELBRIDGE)) {
 | 
| 
d1ac22c62f64
(svn r11036) [NoAI] -Sync: with trunk r10774:11035.
 rubidium parents: 
9694diff
changeset | 696 | 				if (IsBridge(tile)) {
 | 
| 9723 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 697 | 					if ((!had_bridge || GetTunnelBridgeDirection(tile) == DIAGDIR_SE || GetTunnelBridgeDirection(tile) == DIAGDIR_SW)) {
 | 
| 9701 
d1ac22c62f64
(svn r11036) [NoAI] -Sync: with trunk r10774:11035.
 rubidium parents: 
9694diff
changeset | 698 | cost.AddCost(ret); | 
| 
d1ac22c62f64
(svn r11036) [NoAI] -Sync: with trunk r10774:11035.
 rubidium parents: 
9694diff
changeset | 699 | } | 
| 
d1ac22c62f64
(svn r11036) [NoAI] -Sync: with trunk r10774:11035.
 rubidium parents: 
9694diff
changeset | 700 | had_bridge = true; | 
| 9724 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 701 | 				} else { // IsTunnel(tile)
 | 
| 9723 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 702 | 					if ((!had_tunnel || GetTunnelBridgeDirection(tile) == DIAGDIR_SE || GetTunnelBridgeDirection(tile) == DIAGDIR_SW)) {
 | 
| 9701 
d1ac22c62f64
(svn r11036) [NoAI] -Sync: with trunk r10774:11035.
 rubidium parents: 
9694diff
changeset | 703 | cost.AddCost(ret); | 
| 
d1ac22c62f64
(svn r11036) [NoAI] -Sync: with trunk r10774:11035.
 rubidium parents: 
9694diff
changeset | 704 | } | 
| 
d1ac22c62f64
(svn r11036) [NoAI] -Sync: with trunk r10774:11035.
 rubidium parents: 
9694diff
changeset | 705 | had_tunnel = true; | 
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 706 | } | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 707 | 			} else {
 | 
| 9629 | 708 | cost.AddCost(ret); | 
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 709 | } | 
| 2549 | 710 | } | 
| 0 | 711 | |
| 1784 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 712 | if (tile == end_tile) break; | 
| 0 | 713 | |
| 9722 
ebf0ece7d8f6
(svn r11503) [NoAI] -Sync: with trunk r11308:11502.
 rubidium parents: 
9718diff
changeset | 714 | tile += HasBit(p2, 2) ? TileDiffXY(0, 1) : TileDiffXY(1, 0); | 
| 0 | 715 | } | 
| 716 | ||
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 717 | return !had_success ? CMD_ERROR : cost; | 
| 0 | 718 | } | 
| 719 | ||
| 1784 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 720 | /** Remove a long piece of road. | 
| 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: 
3435diff
changeset | 721 | * @param end_tile end tile of drag | 
| 9601 
b499fdd106d5
(svn r9713) [NoAI] -Sync with trunk (r9631:9712).
 rubidium parents: 
9574diff
changeset | 722 | * @param flags operation to perform | 
| 1784 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 723 | * @param p1 start tile of drag | 
| 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 724 | * @param p2 various bitstuffed elements | 
| 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 725 | * - p2 = (bit 0) - start tile starts in the 2nd half of tile (p2 & 1) | 
| 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 726 | * - p2 = (bit 1) - end tile starts in the 2nd half of tile (p2 & 2) | 
| 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 727 | * - p2 = (bit 2) - direction: 0 = along x-axis, 1 = along y-axis (p2 & 4) | 
| 9624 | 728 | * - p2 = (bit 3 + 4) - road type | 
| 1784 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 729 | */ | 
| 9629 | 730 | CommandCost CmdRemoveLongRoad(TileIndex end_tile, uint32 flags, uint32 p1, uint32 p2) | 
| 0 | 731 | {
 | 
| 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: 
3435diff
changeset | 732 | TileIndex start_tile, tile; | 
| 9723 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 733 | CommandCost ret, cost(EXPENSES_CONSTRUCTION); | 
| 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 734 | Money money; | 
| 889 
7f8630bfea41
(svn r1375) -Fix: [1050990] Buying trains sometimes accounted for incorrectly. Was the result of the cost getting reset in a recursive call of docommand. That is fixed. In addition all cost-commands are typed explicitely. Please do not forget to do so or your costs will be credited to construction if you are unlucky.
 darkvater parents: 
817diff
changeset | 735 | |
| 2934 
3b7eef9871f8
(svn r3490) -Fix: A bunch (10) of off-by-one errors when checking if a TileIndex points to a tile on the map
 tron parents: 
2916diff
changeset | 736 | if (p1 >= MapSize()) return CMD_ERROR; | 
| 1784 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 737 | |
| 0 | 738 | start_tile = p1; | 
| 9624 | 739 | RoadType rt = (RoadType)GB(p2, 3, 2); | 
| 740 | if (!IsValidRoadType(rt)) return CMD_ERROR; | |
| 0 | 741 | |
| 1784 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 742 | /* Only drag in X or Y direction dictated by the direction variable */ | 
| 9722 
ebf0ece7d8f6
(svn r11503) [NoAI] -Sync: with trunk r11308:11502.
 rubidium parents: 
9718diff
changeset | 743 | if (!HasBit(p2, 2) && TileY(start_tile) != TileY(end_tile)) return CMD_ERROR; // x-axis | 
| 
ebf0ece7d8f6
(svn r11503) [NoAI] -Sync: with trunk r11308:11502.
 rubidium parents: 
9718diff
changeset | 744 | if (HasBit(p2, 2) && TileX(start_tile) != TileX(end_tile)) return CMD_ERROR; // y-axis | 
| 1784 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 745 | |
| 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 746 | /* Swap start and ending tile, also the half-tile drag var (bit 0 and 1) */ | 
| 9722 
ebf0ece7d8f6
(svn r11503) [NoAI] -Sync: with trunk r11308:11502.
 rubidium parents: 
9718diff
changeset | 747 | 	if (start_tile > end_tile || (start_tile == end_tile && HasBit(p2, 0))) {
 | 
| 1784 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 748 | TileIndex t = start_tile; | 
| 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 749 | start_tile = end_tile; | 
| 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 750 | end_tile = t; | 
| 9723 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 751 | p2 ^= IsInsideMM(p2 & 3, 1, 3) ? 3 : 0; | 
| 0 | 752 | } | 
| 753 | ||
| 9723 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 754 | money = GetAvailableMoneyForCommand(); | 
| 0 | 755 | tile = start_tile; | 
| 9574 | 756 | /* Start tile is the small number. */ | 
| 1784 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 757 | 	for (;;) {
 | 
| 9722 
ebf0ece7d8f6
(svn r11503) [NoAI] -Sync: with trunk r11308:11502.
 rubidium parents: 
9718diff
changeset | 758 | RoadBits bits = HasBit(p2, 2) ? ROAD_Y : ROAD_X; | 
| 3098 
4c1320da876d
(svn r3687) Complete some bits I missed whenn adding accessor functions for road types and pieces
 tron parents: 
3097diff
changeset | 759 | |
| 9722 
ebf0ece7d8f6
(svn r11503) [NoAI] -Sync: with trunk r11308:11502.
 rubidium parents: 
9718diff
changeset | 760 | if (tile == end_tile && !HasBit(p2, 1)) bits &= ROAD_NW | ROAD_NE; | 
| 
ebf0ece7d8f6
(svn r11503) [NoAI] -Sync: with trunk r11308:11502.
 rubidium parents: 
9718diff
changeset | 761 | if (tile == start_tile && HasBit(p2, 0)) bits &= ROAD_SE | ROAD_SW; | 
| 201 
c40d343115f8
(svn r202) -Codechange: I missed some files with trailing spaces.. this should be
 truelight parents: 
159diff
changeset | 762 | |
| 9574 | 763 | /* try to remove the halves. */ | 
| 3098 
4c1320da876d
(svn r3687) Complete some bits I missed whenn adding accessor functions for road types and pieces
 tron parents: 
3097diff
changeset | 764 | 		if (bits != 0) {
 | 
| 9724 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 765 | ret = RemoveRoad(tile, flags & ~DC_EXEC, bits, rt, true); | 
| 9701 
d1ac22c62f64
(svn r11036) [NoAI] -Sync: with trunk r10774:11035.
 rubidium parents: 
9694diff
changeset | 766 | 			if (CmdSucceeded(ret)) {
 | 
| 
d1ac22c62f64
(svn r11036) [NoAI] -Sync: with trunk r10774:11035.
 rubidium parents: 
9694diff
changeset | 767 | 				if (flags & DC_EXEC) {
 | 
| 9723 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 768 | money -= ret.GetCost(); | 
| 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 769 | 					if (money < 0) {
 | 
| 9701 
d1ac22c62f64
(svn r11036) [NoAI] -Sync: with trunk r10774:11035.
 rubidium parents: 
9694diff
changeset | 770 | _additional_cash_required = DoCommand(end_tile, start_tile, p2, flags & ~DC_EXEC, CMD_REMOVE_LONG_ROAD).GetCost(); | 
| 
d1ac22c62f64
(svn r11036) [NoAI] -Sync: with trunk r10774:11035.
 rubidium parents: 
9694diff
changeset | 771 | return cost; | 
| 
d1ac22c62f64
(svn r11036) [NoAI] -Sync: with trunk r10774:11035.
 rubidium parents: 
9694diff
changeset | 772 | } | 
| 9724 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 773 | RemoveRoad(tile, flags, bits, rt, true); | 
| 9701 
d1ac22c62f64
(svn r11036) [NoAI] -Sync: with trunk r10774:11035.
 rubidium parents: 
9694diff
changeset | 774 | } | 
| 
d1ac22c62f64
(svn r11036) [NoAI] -Sync: with trunk r10774:11035.
 rubidium parents: 
9694diff
changeset | 775 | cost.AddCost(ret); | 
| 
d1ac22c62f64
(svn r11036) [NoAI] -Sync: with trunk r10774:11035.
 rubidium parents: 
9694diff
changeset | 776 | } | 
| 0 | 777 | } | 
| 778 | ||
| 1784 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 779 | if (tile == end_tile) break; | 
| 0 | 780 | |
| 9722 
ebf0ece7d8f6
(svn r11503) [NoAI] -Sync: with trunk r11308:11502.
 rubidium parents: 
9718diff
changeset | 781 | tile += HasBit(p2, 2) ? TileDiffXY(0, 1) : TileDiffXY(1, 0); | 
| 0 | 782 | } | 
| 783 | ||
| 9629 | 784 | return (cost.GetCost() == 0) ? CMD_ERROR : cost; | 
| 0 | 785 | } | 
| 786 | ||
| 1784 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 787 | /** Build a road 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: 
3435diff
changeset | 788 | * @param tile tile where to build the depot | 
| 9601 
b499fdd106d5
(svn r9713) [NoAI] -Sync with trunk (r9631:9712).
 rubidium parents: 
9574diff
changeset | 789 | * @param flags operation to perform | 
| 6460 | 790 | * @param p1 bit 0..1 entrance direction (DiagDirection) | 
| 9624 | 791 | * bit 2..3 road type | 
| 1784 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 792 | * @param p2 unused | 
| 2085 
ae9e92ffe168
(svn r2595) -Codechange: Introduced "IsSteepTileh" to find whether a tile is steep
 celestar parents: 
2074diff
changeset | 793 | * | 
| 
ae9e92ffe168
(svn r2595) -Codechange: Introduced "IsSteepTileh" to find whether a tile is steep
 celestar parents: 
2074diff
changeset | 794 | * @todo When checking for the tile slope, | 
| 
ae9e92ffe168
(svn r2595) -Codechange: Introduced "IsSteepTileh" to find whether a tile is steep
 celestar parents: 
2074diff
changeset | 795 | * distingush between "Flat land required" and "land sloped in wrong direction" | 
| 0 | 796 | */ | 
| 9629 | 797 | CommandCost CmdBuildRoadDepot(TileIndex tile, uint32 flags, uint32 p1, uint32 p2) | 
| 0 | 798 | {
 | 
| 9629 | 799 | CommandCost cost; | 
| 3636 
d87b21df2944
(svn r4541) Add a type for slopes and replace many magic numbers by the appropriate enums
 tron parents: 
3560diff
changeset | 800 | Slope tileh; | 
| 0 | 801 | |
| 6460 | 802 | DiagDirection dir = Extract<DiagDirection, 0>(p1); | 
| 9624 | 803 | RoadType rt = (RoadType)GB(p1, 2, 2); | 
| 804 | ||
| 9722 
ebf0ece7d8f6
(svn r11503) [NoAI] -Sync: with trunk r11308:11502.
 rubidium parents: 
9718diff
changeset | 805 | if (!IsValidRoadType(rt) || !ValParamRoadType(rt)) return CMD_ERROR; | 
| 1784 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 806 | |
| 3055 
25fd76668365
(svn r3644) Don't use FindLandscapeHeightByTile() when it's overkill - often it was just a complicated way of writing GetTileSlope(tile, NULL)
 tron parents: 
3017diff
changeset | 807 | tileh = GetTileSlope(tile, NULL); | 
| 3636 
d87b21df2944
(svn r4541) Add a type for slopes and replace many magic numbers by the appropriate enums
 tron parents: 
3560diff
changeset | 808 | if (tileh != SLOPE_FLAT && ( | 
| 2549 | 809 | !_patches.build_on_slopes || | 
| 3636 
d87b21df2944
(svn r4541) Add a type for slopes and replace many magic numbers by the appropriate enums
 tron parents: 
3560diff
changeset | 810 | IsSteepSlope(tileh) || | 
| 6460 | 811 | !CanBuildDepotByTileh(dir, tileh) | 
| 2549 | 812 | 			)) {
 | 
| 813 | return_cmd_error(STR_0007_FLAT_LAND_REQUIRED); | |
| 0 | 814 | } | 
| 815 | ||
| 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: 
3435diff
changeset | 816 | cost = DoCommand(tile, 0, 0, flags, CMD_LANDSCAPE_CLEAR); | 
| 1784 
6eb3ab1bc33c
(svn r2288) - CodeChange: protected the next batch of commands (41 so far, out of 115).
 Darkvater parents: 
1638diff
changeset | 817 | if (CmdFailed(cost)) return CMD_ERROR; | 
| 0 | 818 | |
| 5573 
afa6f92a71fd
(svn r7573) -Merged the bridge branch. Allows to build bridges of arbitrary rail/road combinations (including signals)
 celestar parents: 
5212diff
changeset | 819 | if (MayHaveBridgeAbove(tile) && IsBridgeAbove(tile)) return_cmd_error(STR_5007_MUST_DEMOLISH_BRIDGE_FIRST); | 
| 
afa6f92a71fd
(svn r7573) -Merged the bridge branch. Allows to build bridges of arbitrary rail/road combinations (including signals)
 celestar parents: 
5212diff
changeset | 820 | |
| 9694 
e72987579514
(svn r10775) [NoAI] -Sync: with trunk r10535:r10774.
 rubidium parents: 
9686diff
changeset | 821 | Depot *dep = new Depot(tile); | 
| 2549 | 822 | if (dep == NULL) return CMD_ERROR; | 
| 9694 
e72987579514
(svn r10775) [NoAI] -Sync: with trunk r10535:r10774.
 rubidium parents: 
9686diff
changeset | 823 | AutoPtrT<Depot> d_auto_delete = dep; | 
| 0 | 824 | |
| 201 
c40d343115f8
(svn r202) -Codechange: I missed some files with trailing spaces.. this should be
 truelight parents: 
159diff
changeset | 825 | 	if (flags & DC_EXEC) {
 | 
| 0 | 826 | dep->town_index = ClosestTownFromTile(tile, (uint)-1)->index; | 
| 827 | ||
| 9624 | 828 | MakeRoadDepot(tile, _current_player, dir, rt); | 
| 3100 
552cf19c49cb
(svn r3695) Add 2 MarkTileByTile() which I forgot in r3689 (noticed by Belugas)
 tron parents: 
3099diff
changeset | 829 | MarkTileDirtyByTile(tile); | 
| 9694 
e72987579514
(svn r10775) [NoAI] -Sync: with trunk r10535:r10774.
 rubidium parents: 
9686diff
changeset | 830 | d_auto_delete.Detach(); | 
| 0 | 831 | } | 
| 9629 | 832 | return cost.AddCost(_price.build_road_depot); | 
| 0 | 833 | } | 
| 834 | ||
| 9629 | 835 | static CommandCost RemoveRoadDepot(TileIndex tile, uint32 flags) | 
| 0 | 836 | {
 | 
| 149 
5f7d4b21df01
(svn r150) -Fix: [1010833] Turning on the magic bulldozer removes oil rigs
 darkvater parents: 
84diff
changeset | 837 | if (!CheckTileOwnership(tile) && _current_player != OWNER_WATER) | 
| 0 | 838 | return CMD_ERROR; | 
| 839 | ||
| 9718 
f82a4facea8b
(svn r11309) [NoAI] -Sync: with trunk r11145:11308.
 truelight parents: 
9704diff
changeset | 840 | if (!EnsureNoVehicleOnGround(tile)) return CMD_ERROR; | 
| 0 | 841 | |
| 9694 
e72987579514
(svn r10775) [NoAI] -Sync: with trunk r10535:r10774.
 rubidium parents: 
9686diff
changeset | 842 | 	if (flags & DC_EXEC) {
 | 
| 
e72987579514
(svn r10775) [NoAI] -Sync: with trunk r10535:r10774.
 rubidium parents: 
9686diff
changeset | 843 | DoClearSquare(tile); | 
| 
e72987579514
(svn r10775) [NoAI] -Sync: with trunk r10535:r10774.
 rubidium parents: 
9686diff
changeset | 844 | delete GetDepotByTile(tile); | 
| 
e72987579514
(svn r10775) [NoAI] -Sync: with trunk r10535:r10774.
 rubidium parents: 
9686diff
changeset | 845 | } | 
| 0 | 846 | |
| 9723 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 847 | return CommandCost(EXPENSES_CONSTRUCTION, _price.remove_road_depot); | 
| 0 | 848 | } | 
| 849 | ||
| 9629 | 850 | static CommandCost ClearTile_Road(TileIndex tile, byte flags) | 
| 1977 
4392ae3d8e31
(svn r2483) Replace almost 500 "uint tile" (and variants) with "TileIndex tile"
 tron parents: 
1942diff
changeset | 851 | {
 | 
| 3793 
33cdb5bf7b21
(svn r4789) - Codechange: rename RoadType to RoadTileType and ROAD_{NORMAL,CROSSING,DEPOT} to ROAD_TILE_* for consistency
 rubidium parents: 
3792diff
changeset | 852 | 	switch (GetRoadTileType(tile)) {
 | 
| 
33cdb5bf7b21
(svn r4789) - Codechange: rename RoadType to RoadTileType and ROAD_{NORMAL,CROSSING,DEPOT} to ROAD_TILE_* for consistency
 rubidium parents: 
3792diff
changeset | 853 | 		case ROAD_TILE_NORMAL: {
 | 
| 9624 | 854 | RoadBits b = GetAllRoadBits(tile); | 
| 0 | 855 | |
| 5888 
3117320a611b
(svn r8096) -Codechange: Invert the check if you are allowed to clear a road tile so there are not so many negations (too confusing) and added some comments to further clarify what happens.
 Darkvater parents: 
5838diff
changeset | 856 | /* Clear the road if only one piece is on the tile OR the AI tries | 
| 
3117320a611b
(svn r8096) -Codechange: Invert the check if you are allowed to clear a road tile so there are not so many negations (too confusing) and added some comments to further clarify what happens.
 Darkvater parents: 
5838diff
changeset | 857 | * to clear town road OR we are not using the DC_AUTO flag */ | 
| 9722 
ebf0ece7d8f6
(svn r11503) [NoAI] -Sync: with trunk r11308:11502.
 rubidium parents: 
9718diff
changeset | 858 | if ((CountBits(b) == 1 && GetRoadBits(tile, ROADTYPE_TRAM) == ROAD_NONE) || | 
| 9704 | 859 | IsTileOwner(tile, OWNER_TOWN) || !(flags & DC_AUTO) | 
| 860 | 				) {
 | |
| 9624 | 861 | RoadTypes rts = GetRoadTypes(tile); | 
| 9723 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 862 | CommandCost ret(EXPENSES_CONSTRUCTION); | 
| 9624 | 863 | 				for (RoadType rt = ROADTYPE_ROAD; rt < ROADTYPE_END; rt++) {
 | 
| 9722 
ebf0ece7d8f6
(svn r11503) [NoAI] -Sync: with trunk r11308:11502.
 rubidium parents: 
9718diff
changeset | 864 | 					if (HasBit(rts, rt)) {
 | 
| 9724 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 865 | CommandCost tmp_ret = RemoveRoad(tile, flags, GetRoadBits(tile, rt), rt, true); | 
| 9624 | 866 | if (CmdFailed(tmp_ret)) return tmp_ret; | 
| 9629 | 867 | ret.AddCost(tmp_ret); | 
| 9624 | 868 | } | 
| 869 | } | |
| 870 | return ret; | |
| 3060 | 871 | } | 
| 5888 
3117320a611b
(svn r8096) -Codechange: Invert the check if you are allowed to clear a road tile so there are not so many negations (too confusing) and added some comments to further clarify what happens.
 Darkvater parents: 
5838diff
changeset | 872 | return_cmd_error(STR_1801_MUST_REMOVE_ROAD_FIRST); | 
| 5894 
eb5ff472c10f
(svn r8102) -Cleanup: Remove unreachable code (r8096), useless cast
 Darkvater parents: 
5888diff
changeset | 873 | } | 
| 0 | 874 | |
| 3793 
33cdb5bf7b21
(svn r4789) - Codechange: rename RoadType to RoadTileType and ROAD_{NORMAL,CROSSING,DEPOT} to ROAD_TILE_* for consistency
 rubidium parents: 
3792diff
changeset | 875 | 		case ROAD_TILE_CROSSING: {
 | 
| 9626 | 876 | RoadTypes rts = GetRoadTypes(tile); | 
| 9723 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 877 | CommandCost ret(EXPENSES_CONSTRUCTION); | 
| 3060 | 878 | |
| 3069 
0e6aca11c3da
(svn r3658) Add functions and symbolic names to retrieve road tile types and road pieces
 tron parents: 
3068diff
changeset | 879 | if (flags & DC_AUTO) return_cmd_error(STR_1801_MUST_REMOVE_ROAD_FIRST); | 
| 3060 | 880 | |
| 9626 | 881 | /* Must iterate over the roadtypes in a reverse manner because | 
| 882 | * tram tracks must be removed before the road bits. */ | |
| 883 | 			for (RoadType rt = ROADTYPE_HWAY; rt >= ROADTYPE_ROAD; rt--) {
 | |
| 9722 
ebf0ece7d8f6
(svn r11503) [NoAI] -Sync: with trunk r11308:11502.
 rubidium parents: 
9718diff
changeset | 884 | 				if (HasBit(rts, rt)) {
 | 
| 9724 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 885 | CommandCost tmp_ret = RemoveRoad(tile, flags, GetCrossingRoadBits(tile), rt, false); | 
| 9626 | 886 | if (CmdFailed(tmp_ret)) return tmp_ret; | 
| 9629 | 887 | ret.AddCost(tmp_ret); | 
| 9626 | 888 | } | 
| 889 | } | |
| 3060 | 890 | |
| 891 | 			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: 
3435diff
changeset | 892 | DoCommand(tile, 0, 0, flags, CMD_LANDSCAPE_CLEAR); | 
| 3060 | 893 | } | 
| 894 | return ret; | |
| 895 | } | |
| 896 | ||
| 3069 
0e6aca11c3da
(svn r3658) Add functions and symbolic names to retrieve road tile types and road pieces
 tron parents: 
3068diff
changeset | 897 | default: | 
| 3793 
33cdb5bf7b21
(svn r4789) - Codechange: rename RoadType to RoadTileType and ROAD_{NORMAL,CROSSING,DEPOT} to ROAD_TILE_* for consistency
 rubidium parents: 
3792diff
changeset | 898 | case ROAD_TILE_DEPOT: | 
| 3060 | 899 | 			if (flags & DC_AUTO) {
 | 
| 900 | return_cmd_error(STR_2004_BUILDING_MUST_BE_DEMOLISHED); | |
| 901 | } | |
| 902 | return RemoveRoadDepot(tile, flags); | |
| 0 | 903 | } | 
| 904 | } | |
| 905 | ||
| 906 | ||
| 6574 
e1d1a12faaf7
(svn r9051) -Codechange: typedef [enum|struct] Y {} X; -> [enum|struct] X {};
 rubidium parents: 
6498diff
changeset | 907 | struct DrawRoadTileStruct {
 | 
| 0 | 908 | uint16 image; | 
| 909 | byte subcoord_x; | |
| 910 | byte subcoord_y; | |
| 6574 
e1d1a12faaf7
(svn r9051) -Codechange: typedef [enum|struct] Y {} X; -> [enum|struct] X {};
 rubidium parents: 
6498diff
changeset | 911 | }; | 
| 0 | 912 | |
| 913 | #include "table/road_land.h" | |
| 914 | ||
| 9826 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 915 | /** | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 916 | * Get the foundationtype of a RoadBits Slope combination | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 917 | * | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 918 | * @param tileh The Slope part | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 919 | * @param bits The RoadBits part | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 920 | * @return The resulting Foundation | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 921 | */ | 
| 9694 
e72987579514
(svn r10775) [NoAI] -Sync: with trunk r10535:r10774.
 rubidium parents: 
9686diff
changeset | 922 | Foundation GetRoadFoundation(Slope tileh, RoadBits bits) | 
| 2548 
97ada3bd2702
(svn r3077) static, const, bracing, indentation, 0 -> '\0'/NULL, typos in comments, excess empty lines, minor other changes
 tron parents: 
2544diff
changeset | 923 | {
 | 
| 9826 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 924 | /* Flat land and land without a road doesn't require a foundation */ | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 925 | if (tileh == SLOPE_FLAT || bits == ROAD_NONE) return FOUNDATION_NONE; | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 926 | |
| 9694 
e72987579514
(svn r10775) [NoAI] -Sync: with trunk r10535:r10774.
 rubidium parents: 
9686diff
changeset | 927 | 	if (!IsSteepSlope(tileh)) {
 | 
| 9826 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 928 | /* Leveled RoadBits on a slope */ | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 929 | if ((_invalid_tileh_slopes_road[0][tileh] & bits) == ROAD_NONE) return FOUNDATION_LEVELED; | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 930 | |
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 931 | /* Straight roads without foundation on a slope */ | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 932 | if (!IsSlopeWithOneCornerRaised(tileh) && | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 933 | (_invalid_tileh_slopes_road[1][tileh] & bits) == ROAD_NONE) | 
| 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 934 | return FOUNDATION_NONE; | 
| 4246 
14a8849c32df
(svn r5833) -Feature: Allow building of (certain) rails, roads and bridge ramps on steep sloped tiles
 tron parents: 
4232diff
changeset | 935 | } | 
| 0 | 936 | |
| 9826 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 937 | /* Roads on steep Slopes or on Slopes with one corner raised */ | 
| 9694 
e72987579514
(svn r10775) [NoAI] -Sync: with trunk r10535:r10774.
 rubidium parents: 
9686diff
changeset | 938 | return (bits == ROAD_X ? FOUNDATION_INCLINED_X : FOUNDATION_INCLINED_Y); | 
| 0 | 939 | } | 
| 940 | ||
| 941 | const byte _road_sloped_sprites[14] = {
 | |
| 942 | 0, 0, 2, 0, | |
| 943 | 0, 1, 0, 0, | |
| 944 | 3, 0, 0, 0, | |
| 945 | 0, 0 | |
| 946 | }; | |
| 947 | ||
| 2471 
14109854e818
(svn r2997) -Codechange: Split road drawing code off from DrawTile_Road into a separate function to be used elsewhere.
 peter1138 parents: 
2469diff
changeset | 948 | /** | 
| 9620 
31e38d28a0af
(svn r9816) [NoAI] -Sync with trunk r9712:9815 except r9759 (MorphOS threading) because that needs special attention.
 rubidium parents: 
9601diff
changeset | 949 | * Whether to draw unpaved roads regardless of the town zone. | 
| 
31e38d28a0af
(svn r9816) [NoAI] -Sync with trunk r9712:9815 except r9759 (MorphOS threading) because that needs special attention.
 rubidium parents: 
9601diff
changeset | 950 | * By default, OpenTTD always draws roads as unpaved if they are on a desert | 
| 
31e38d28a0af
(svn r9816) [NoAI] -Sync with trunk r9712:9815 except r9759 (MorphOS threading) because that needs special attention.
 rubidium parents: 
9601diff
changeset | 951 | * tile or above the snowline. Newgrf files, however, can set a bit that allows | 
| 
31e38d28a0af
(svn r9816) [NoAI] -Sync with trunk r9712:9815 except r9759 (MorphOS threading) because that needs special attention.
 rubidium parents: 
9601diff
changeset | 952 | * paved roads to be built on desert tiles as they would be on grassy tiles. | 
| 
31e38d28a0af
(svn r9816) [NoAI] -Sync with trunk r9712:9815 except r9759 (MorphOS threading) because that needs special attention.
 rubidium parents: 
9601diff
changeset | 953 | * | 
| 
31e38d28a0af
(svn r9816) [NoAI] -Sync with trunk r9712:9815 except r9759 (MorphOS threading) because that needs special attention.
 rubidium parents: 
9601diff
changeset | 954 | * @param tile The tile the road is on | 
| 
31e38d28a0af
(svn r9816) [NoAI] -Sync with trunk r9712:9815 except r9759 (MorphOS threading) because that needs special attention.
 rubidium parents: 
9601diff
changeset | 955 | * @param roadside What sort of road this is | 
| 
31e38d28a0af
(svn r9816) [NoAI] -Sync with trunk r9712:9815 except r9759 (MorphOS threading) because that needs special attention.
 rubidium parents: 
9601diff
changeset | 956 | * @return True if the road should be drawn unpaved regardless of the roadside. | 
| 
31e38d28a0af
(svn r9816) [NoAI] -Sync with trunk r9712:9815 except r9759 (MorphOS threading) because that needs special attention.
 rubidium parents: 
9601diff
changeset | 957 | */ | 
| 
31e38d28a0af
(svn r9816) [NoAI] -Sync with trunk r9712:9815 except r9759 (MorphOS threading) because that needs special attention.
 rubidium parents: 
9601diff
changeset | 958 | static bool AlwaysDrawUnpavedRoads(TileIndex tile, Roadside roadside) | 
| 
31e38d28a0af
(svn r9816) [NoAI] -Sync with trunk r9712:9815 except r9759 (MorphOS threading) because that needs special attention.
 rubidium parents: 
9601diff
changeset | 959 | {
 | 
| 
31e38d28a0af
(svn r9816) [NoAI] -Sync with trunk r9712:9815 except r9759 (MorphOS threading) because that needs special attention.
 rubidium parents: 
9601diff
changeset | 960 | return (IsOnSnow(tile) && | 
| 
31e38d28a0af
(svn r9816) [NoAI] -Sync with trunk r9712:9815 except r9759 (MorphOS threading) because that needs special attention.
 rubidium parents: 
9601diff
changeset | 961 | !(_opt.landscape == LT_TROPIC && HasGrfMiscBit(GMB_DESERT_PAVED_ROADS) && | 
| 
31e38d28a0af
(svn r9816) [NoAI] -Sync with trunk r9712:9815 except r9759 (MorphOS threading) because that needs special attention.
 rubidium parents: 
9601diff
changeset | 962 | roadside != ROADSIDE_BARREN && roadside != ROADSIDE_GRASS && roadside != ROADSIDE_GRASS_ROAD_WORKS)); | 
| 
31e38d28a0af
(svn r9816) [NoAI] -Sync with trunk r9712:9815 except r9759 (MorphOS threading) because that needs special attention.
 rubidium parents: 
9601diff
changeset | 963 | } | 
| 
31e38d28a0af
(svn r9816) [NoAI] -Sync with trunk r9712:9815 except r9759 (MorphOS threading) because that needs special attention.
 rubidium parents: 
9601diff
changeset | 964 | |
| 
31e38d28a0af
(svn r9816) [NoAI] -Sync with trunk r9712:9815 except r9759 (MorphOS threading) because that needs special attention.
 rubidium parents: 
9601diff
changeset | 965 | /** | 
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 966 | * Draws the catenary for the given tile | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 967 | * @param ti information about the tile (slopes, height etc) | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 968 | * @param tram the roadbits for the tram | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 969 | */ | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 970 | void DrawTramCatenary(TileInfo *ti, RoadBits tram) | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 971 | {
 | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 972 | /* Don't draw the catenary under a low bridge */ | 
| 9732 | 973 | 	if (MayHaveBridgeAbove(ti->tile) && IsBridgeAbove(ti->tile) && !IsTransparencySet(TO_CATENARY)) {
 | 
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 974 | uint height = GetBridgeHeight(GetNorthernBridgeEnd(ti->tile)); | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 975 | |
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 976 | if (height <= GetTileMaxZ(ti->tile) + TILE_HEIGHT) return; | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 977 | } | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 978 | |
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 979 | SpriteID front; | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 980 | SpriteID back; | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 981 | |
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 982 | 	if (ti->tileh != SLOPE_FLAT) {
 | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 983 | back = SPR_TRAMWAY_BACK_WIRES_SLOPED + _road_sloped_sprites[ti->tileh - 1]; | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 984 | front = SPR_TRAMWAY_FRONT_WIRES_SLOPED + _road_sloped_sprites[ti->tileh - 1]; | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 985 | 	} else {
 | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 986 | back = SPR_TRAMWAY_BASE + _road_backpole_sprites_1[tram]; | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 987 | front = SPR_TRAMWAY_BASE + _road_frontwire_sprites_1[tram]; | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 988 | } | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 989 | |
| 9732 | 990 | AddSortableSpriteToDraw(back, PAL_NONE, ti->x, ti->y, 16, 16, TILE_HEIGHT + BB_HEIGHT_UNDER_BRIDGE, ti->z, IsTransparencySet(TO_CATENARY)); | 
| 991 | AddSortableSpriteToDraw(front, PAL_NONE, ti->x, ti->y, 16, 16, TILE_HEIGHT + BB_HEIGHT_UNDER_BRIDGE, ti->z, IsTransparencySet(TO_CATENARY)); | |
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 992 | } | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 993 | |
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 994 | /** | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 995 | * Draws details on/around the road | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 996 | * @param img the sprite to draw | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 997 | * @param ti the tile to draw on | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 998 | * @param dx the offset from the top of the BB of the tile | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 999 | * @param dy the offset from the top of the BB of the tile | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1000 | * @param h the height of the sprite to draw | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1001 | */ | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1002 | static void DrawRoadDetail(SpriteID img, TileInfo *ti, int dx, int dy, int h) | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1003 | {
 | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1004 | int x = ti->x | dx; | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1005 | int y = ti->y | dy; | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1006 | byte z = ti->z; | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1007 | if (ti->tileh != SLOPE_FLAT) z = GetSlopeZ(x, y); | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1008 | AddSortableSpriteToDraw(img, PAL_NONE, x, y, 2, 2, h, z); | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1009 | } | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1010 | |
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1011 | /** | 
| 2471 
14109854e818
(svn r2997) -Codechange: Split road drawing code off from DrawTile_Road into a separate function to be used elsewhere.
 peter1138 parents: 
2469diff
changeset | 1012 | * Draw ground sprite and road pieces | 
| 
14109854e818
(svn r2997) -Codechange: Split road drawing code off from DrawTile_Road into a separate function to be used elsewhere.
 peter1138 parents: 
2469diff
changeset | 1013 | * @param ti TileInfo | 
| 
14109854e818
(svn r2997) -Codechange: Split road drawing code off from DrawTile_Road into a separate function to be used elsewhere.
 peter1138 parents: 
2469diff
changeset | 1014 | */ | 
| 4081 | 1015 | static void DrawRoadBits(TileInfo* ti) | 
| 2471 
14109854e818
(svn r2997) -Codechange: Split road drawing code off from DrawTile_Road into a separate function to be used elsewhere.
 peter1138 parents: 
2469diff
changeset | 1016 | {
 | 
| 9624 | 1017 | RoadBits road = GetRoadBits(ti->tile, ROADTYPE_ROAD); | 
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1018 | RoadBits tram = GetRoadBits(ti->tile, ROADTYPE_TRAM); | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1019 | |
| 2471 
14109854e818
(svn r2997) -Codechange: Split road drawing code off from DrawTile_Road into a separate function to be used elsewhere.
 peter1138 parents: 
2469diff
changeset | 1020 | const DrawRoadTileStruct *drts; | 
| 5919 
2b58160d667d
(svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
 peter1138 parents: 
5894diff
changeset | 1021 | SpriteID image = 0; | 
| 
2b58160d667d
(svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
 peter1138 parents: 
5894diff
changeset | 1022 | SpriteID pal = PAL_NONE; | 
| 4048 | 1023 | Roadside roadside; | 
| 2471 
14109854e818
(svn r2997) -Codechange: Split road drawing code off from DrawTile_Road into a separate function to be used elsewhere.
 peter1138 parents: 
2469diff
changeset | 1024 | |
| 3636 
d87b21df2944
(svn r4541) Add a type for slopes and replace many magic numbers by the appropriate enums
 tron parents: 
3560diff
changeset | 1025 | 	if (ti->tileh != SLOPE_FLAT) {
 | 
| 9694 
e72987579514
(svn r10775) [NoAI] -Sync: with trunk r10535:r10774.
 rubidium parents: 
9686diff
changeset | 1026 | DrawFoundation(ti, GetRoadFoundation(ti->tileh, road | tram)); | 
| 2471 
14109854e818
(svn r2997) -Codechange: Split road drawing code off from DrawTile_Road into a separate function to be used elsewhere.
 peter1138 parents: 
2469diff
changeset | 1027 | |
| 9574 | 1028 | /* DrawFoundation() modifies ti. | 
| 1029 | * Default sloped sprites.. */ | |
| 3636 
d87b21df2944
(svn r4541) Add a type for slopes and replace many magic numbers by the appropriate enums
 tron parents: 
3560diff
changeset | 1030 | if (ti->tileh != SLOPE_FLAT) image = _road_sloped_sprites[ti->tileh - 1] + 0x53F; | 
| 2471 
14109854e818
(svn r2997) -Codechange: Split road drawing code off from DrawTile_Road into a separate function to be used elsewhere.
 peter1138 parents: 
2469diff
changeset | 1031 | } | 
| 
14109854e818
(svn r2997) -Codechange: Split road drawing code off from DrawTile_Road into a separate function to be used elsewhere.
 peter1138 parents: 
2469diff
changeset | 1032 | |
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1033 | if (image == 0) image = _road_tile_sprites_1[road != ROAD_NONE ? road : tram]; | 
| 2471 
14109854e818
(svn r2997) -Codechange: Split road drawing code off from DrawTile_Road into a separate function to be used elsewhere.
 peter1138 parents: 
2469diff
changeset | 1034 | |
| 4048 | 1035 | roadside = GetRoadside(ti->tile); | 
| 2471 
14109854e818
(svn r2997) -Codechange: Split road drawing code off from DrawTile_Road into a separate function to be used elsewhere.
 peter1138 parents: 
2469diff
changeset | 1036 | |
| 9620 
31e38d28a0af
(svn r9816) [NoAI] -Sync with trunk r9712:9815 except r9759 (MorphOS threading) because that needs special attention.
 rubidium parents: 
9601diff
changeset | 1037 | 	if (AlwaysDrawUnpavedRoads(ti->tile, roadside)) {
 | 
| 2471 
14109854e818
(svn r2997) -Codechange: Split road drawing code off from DrawTile_Road into a separate function to be used elsewhere.
 peter1138 parents: 
2469diff
changeset | 1038 | image += 19; | 
| 4048 | 1039 | 	} else {
 | 
| 1040 | 		switch (roadside) {
 | |
| 5919 
2b58160d667d
(svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
 peter1138 parents: 
5894diff
changeset | 1041 | case ROADSIDE_BARREN: pal = PALETTE_TO_BARE_LAND; break; | 
| 4048 | 1042 | case ROADSIDE_GRASS: break; | 
| 1043 | case ROADSIDE_GRASS_ROAD_WORKS: break; | |
| 1044 | default: image -= 19; break; // Paved | |
| 1045 | } | |
| 2471 
14109854e818
(svn r2997) -Codechange: Split road drawing code off from DrawTile_Road into a separate function to be used elsewhere.
 peter1138 parents: 
2469diff
changeset | 1046 | } | 
| 
14109854e818
(svn r2997) -Codechange: Split road drawing code off from DrawTile_Road into a separate function to be used elsewhere.
 peter1138 parents: 
2469diff
changeset | 1047 | |
| 5919 
2b58160d667d
(svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
 peter1138 parents: 
5894diff
changeset | 1048 | DrawGroundSprite(image, pal); | 
| 2471 
14109854e818
(svn r2997) -Codechange: Split road drawing code off from DrawTile_Road into a separate function to be used elsewhere.
 peter1138 parents: 
2469diff
changeset | 1049 | |
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1050 | /* For tram we overlay the road graphics with either tram tracks only | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1051 | * (when there is actual road beneath the trams) or with tram tracks | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1052 | * and some dirts which hides the road graphics */ | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1053 | 	if (tram != ROAD_NONE) {
 | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1054 | 		if (ti->tileh != SLOPE_FLAT) {
 | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1055 | image = _road_sloped_sprites[ti->tileh - 1] + SPR_TRAMWAY_SLOPED_OFFSET; | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1056 | 		} else {
 | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1057 | image = _road_tile_sprites_1[tram] - SPR_ROAD_Y; | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1058 | } | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1059 | image += (road == ROAD_NONE) ? SPR_TRAMWAY_TRAM : SPR_TRAMWAY_OVERLAY; | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1060 | DrawGroundSprite(image, pal); | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1061 | } | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1062 | |
| 9629 | 1063 | 	if (road != ROAD_NONE) {
 | 
| 1064 | DisallowedRoadDirections drd = GetDisallowedRoadDirections(ti->tile); | |
| 1065 | 		if (drd != DRD_NONE) {
 | |
| 1066 | DrawRoadDetail(SPR_ONEWAY_BASE + drd - 1 + ((road == ROAD_X) ? 0 : 3), ti, 8, 8, 0); | |
| 1067 | } | |
| 1068 | } | |
| 1069 | ||
| 3430 
b283bb956a36
(svn r4258) -Codechange: Add and make use of map accessors dealing with road ground types (including roadworks).
 celestar parents: 
3421diff
changeset | 1070 | 	if (HasRoadWorks(ti->tile)) {
 | 
| 9574 | 1071 | /* Road works */ | 
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1072 | DrawGroundSprite((road | tram) & ROAD_X ? SPR_EXCAVATION_X : SPR_EXCAVATION_Y, PAL_NONE); | 
| 2471 
14109854e818
(svn r2997) -Codechange: Split road drawing code off from DrawTile_Road into a separate function to be used elsewhere.
 peter1138 parents: 
2469diff
changeset | 1073 | return; | 
| 
14109854e818
(svn r2997) -Codechange: Split road drawing code off from DrawTile_Road into a separate function to be used elsewhere.
 peter1138 parents: 
2469diff
changeset | 1074 | } | 
| 
14109854e818
(svn r2997) -Codechange: Split road drawing code off from DrawTile_Road into a separate function to be used elsewhere.
 peter1138 parents: 
2469diff
changeset | 1075 | |
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1076 | if (tram != ROAD_NONE) DrawTramCatenary(ti, tram); | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1077 | |
| 9574 | 1078 | /* Return if full detail is disabled, or we are zoomed fully out. */ | 
| 9722 
ebf0ece7d8f6
(svn r11503) [NoAI] -Sync: with trunk r11308:11502.
 rubidium parents: 
9718diff
changeset | 1079 | if (!HasBit(_display_opt, DO_FULL_DETAIL) || _cur_dpi->zoom > ZOOM_LVL_DETAIL) return; | 
| 5148 
00b593a6bae5
(svn r7240) -Fix: Always display the excavation of roadworks even when fully zoomed out (they are quite noticable) or "full details" are off (they are part of the game mechanics)
 tron parents: 
5116diff
changeset | 1080 | |
| 9732 | 1081 | /* Do not draw details (street lights, trees) under low bridge */ | 
| 1082 | 	if (MayHaveBridgeAbove(ti->tile) && IsBridgeAbove(ti->tile) && (roadside == ROADSIDE_TREES || roadside == ROADSIDE_STREET_LIGHTS)) {
 | |
| 1083 | uint height = GetBridgeHeight(GetNorthernBridgeEnd(ti->tile)); | |
| 1084 | uint minz = GetTileMaxZ(ti->tile) + 2 * TILE_HEIGHT; | |
| 1085 | ||
| 1086 | if (roadside == ROADSIDE_TREES) minz += TILE_HEIGHT; | |
| 1087 | ||
| 1088 | if (height < minz) return; | |
| 1089 | } | |
| 1090 | ||
| 9800 | 1091 | /* If there are no road bits, return, as there is nothing left to do */ | 
| 1092 | if (CountBits(road) < 2) return; | |
| 1093 | ||
| 9574 | 1094 | /* Draw extra details. */ | 
| 9800 | 1095 | 	for (drts = _road_display_table[roadside][road | tram]; drts->image != 0; drts++) {
 | 
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1096 | DrawRoadDetail(drts->image, ti, drts->subcoord_x, drts->subcoord_y, 0x10); | 
| 2471 
14109854e818
(svn r2997) -Codechange: Split road drawing code off from DrawTile_Road into a separate function to be used elsewhere.
 peter1138 parents: 
2469diff
changeset | 1097 | } | 
| 
14109854e818
(svn r2997) -Codechange: Split road drawing code off from DrawTile_Road into a separate function to be used elsewhere.
 peter1138 parents: 
2469diff
changeset | 1098 | } | 
| 
14109854e818
(svn r2997) -Codechange: Split road drawing code off from DrawTile_Road into a separate function to be used elsewhere.
 peter1138 parents: 
2469diff
changeset | 1099 | |
| 0 | 1100 | static void DrawTile_Road(TileInfo *ti) | 
| 1101 | {
 | |
| 3793 
33cdb5bf7b21
(svn r4789) - Codechange: rename RoadType to RoadTileType and ROAD_{NORMAL,CROSSING,DEPOT} to ROAD_TILE_* for consistency
 rubidium parents: 
3792diff
changeset | 1102 | 	switch (GetRoadTileType(ti->tile)) {
 | 
| 
33cdb5bf7b21
(svn r4789) - Codechange: rename RoadType to RoadTileType and ROAD_{NORMAL,CROSSING,DEPOT} to ROAD_TILE_* for consistency
 rubidium parents: 
3792diff
changeset | 1103 | case ROAD_TILE_NORMAL: | 
| 4081 | 1104 | DrawRoadBits(ti); | 
| 3060 | 1105 | break; | 
| 0 | 1106 | |
| 3793 
33cdb5bf7b21
(svn r4789) - Codechange: rename RoadType to RoadTileType and ROAD_{NORMAL,CROSSING,DEPOT} to ROAD_TILE_* for consistency
 rubidium parents: 
3792diff
changeset | 1107 | 		case ROAD_TILE_CROSSING: {
 | 
| 5919 
2b58160d667d
(svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
 peter1138 parents: 
5894diff
changeset | 1108 | SpriteID image; | 
| 
2b58160d667d
(svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
 peter1138 parents: 
5894diff
changeset | 1109 | SpriteID pal = PAL_NONE; | 
| 9620 
31e38d28a0af
(svn r9816) [NoAI] -Sync with trunk r9712:9815 except r9759 (MorphOS threading) because that needs special attention.
 rubidium parents: 
9601diff
changeset | 1110 | Roadside roadside = GetRoadside(ti->tile); | 
| 4000 
bab1ebc37da0
(svn r5210) Many small changes which piled up: const, unsigned, variable scope, CSE for readability, DeMorgan, if cascades -> switch, whitespace, parentheses, bracing, misc.
 tron parents: 
3977diff
changeset | 1111 | |
| 9694 
e72987579514
(svn r10775) [NoAI] -Sync: with trunk r10535:r10774.
 rubidium parents: 
9686diff
changeset | 1112 | if (ti->tileh != SLOPE_FLAT) DrawFoundation(ti, FOUNDATION_LEVELED); | 
| 0 | 1113 | |
| 6498 
aff910a05c6e
(svn r8935) -Codechange: unification of track type between road and rail tiles, unification of ground type between normal rail tiles and depots/waypoints and removing the need for RailTileSubType.
 rubidium parents: 
6486diff
changeset | 1114 | image = GetRailTypeInfo(GetRailType(ti->tile))->base_sprites.crossing; | 
| 3060 | 1115 | |
| 3272 
7e556f209503
(svn r3984) Add a function to get the road axis of a level crossing
 tron parents: 
3269diff
changeset | 1116 | if (GetCrossingRoadAxis(ti->tile) == AXIS_X) image++; | 
| 3322 
fa5d46929db9
(svn r4088) -Codechange: Introduce {Unb,B}arCrossing and IsCrossingBarred to put and get the status of a level crossing
 celestar parents: 
3319diff
changeset | 1117 | if (IsCrossingBarred(ti->tile)) image += 2; | 
| 3060 | 1118 | |
| 9620 
31e38d28a0af
(svn r9816) [NoAI] -Sync with trunk r9712:9815 except r9759 (MorphOS threading) because that needs special attention.
 rubidium parents: 
9601diff
changeset | 1119 | 			if (AlwaysDrawUnpavedRoads(ti->tile, roadside)) {
 | 
| 3060 | 1120 | image += 8; | 
| 1121 | 			} else {
 | |
| 9620 
31e38d28a0af
(svn r9816) [NoAI] -Sync with trunk r9712:9815 except r9759 (MorphOS threading) because that needs special attention.
 rubidium parents: 
9601diff
changeset | 1122 | 				switch (roadside) {
 | 
| 5919 
2b58160d667d
(svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
 peter1138 parents: 
5894diff
changeset | 1123 | case ROADSIDE_BARREN: pal = PALETTE_TO_BARE_LAND; break; | 
| 4048 | 1124 | case ROADSIDE_GRASS: break; | 
| 1125 | default: image += 4; break; // Paved | |
| 1126 | } | |
| 3060 | 1127 | } | 
| 1128 | ||
| 5919 
2b58160d667d
(svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
 peter1138 parents: 
5894diff
changeset | 1129 | DrawGroundSprite(image, pal); | 
| 9732 | 1130 | 			if (HasTileRoadType(ti->tile, ROADTYPE_TRAM)) {
 | 
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1131 | DrawGroundSprite(SPR_TRAMWAY_OVERLAY + (GetCrossingRoadAxis(ti->tile) ^ 1), pal); | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1132 | DrawTramCatenary(ti, GetCrossingRoadBits(ti->tile)); | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1133 | } | 
| 9826 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 1134 | if (HasCatenary(GetRailType(ti->tile))) DrawCatenary(ti); | 
| 3060 | 1135 | break; | 
| 0 | 1136 | } | 
| 1137 | ||
| 3098 
4c1320da876d
(svn r3687) Complete some bits I missed whenn adding accessor functions for road types and pieces
 tron parents: 
3097diff
changeset | 1138 | default: | 
| 3793 
33cdb5bf7b21
(svn r4789) - Codechange: rename RoadType to RoadTileType and ROAD_{NORMAL,CROSSING,DEPOT} to ROAD_TILE_* for consistency
 rubidium parents: 
3792diff
changeset | 1139 | 		case ROAD_TILE_DEPOT: {
 | 
| 4232 
628628eaa4fc
(svn r5796) Use DrawTileSprites/DrawTileSeqStruct for road depot drawing data, too
 tron parents: 
4231diff
changeset | 1140 | const DrawTileSprites* dts; | 
| 
628628eaa4fc
(svn r5796) Use DrawTileSprites/DrawTileSeqStruct for road depot drawing data, too
 tron parents: 
4231diff
changeset | 1141 | const DrawTileSeqStruct* dtss; | 
| 5919 
2b58160d667d
(svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
 peter1138 parents: 
5894diff
changeset | 1142 | SpriteID palette; | 
| 0 | 1143 | |
| 9694 
e72987579514
(svn r10775) [NoAI] -Sync: with trunk r10535:r10774.
 rubidium parents: 
9686diff
changeset | 1144 | if (ti->tileh != SLOPE_FLAT) DrawFoundation(ti, FOUNDATION_LEVELED); | 
| 1398 | 1145 | |
| 4226 
3926da9dc486
(svn r5772) Road depots always have an player as owner, so remove an useless check
 tron parents: 
4212diff
changeset | 1146 | palette = PLAYER_SPRITE_COLOR(GetTileOwner(ti->tile)); | 
| 0 | 1147 | |
| 9732 | 1148 | 			if (HasTileRoadType(ti->tile, ROADTYPE_TRAM)) {
 | 
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1149 | dts = &_tram_depot[GetRoadDepotDirection(ti->tile)]; | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1150 | 			} else {
 | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1151 | dts = &_road_depot[GetRoadDepotDirection(ti->tile)]; | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1152 | } | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1153 | |
| 9732 | 1154 | DrawGroundSprite(dts->ground.sprite, PAL_NONE); | 
| 3060 | 1155 | |
| 9732 | 1156 | 			for (dtss = dts->seq; dtss->image.sprite != 0; dtss++) {
 | 
| 1157 | SpriteID image = dtss->image.sprite; | |
| 5919 
2b58160d667d
(svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
 peter1138 parents: 
5894diff
changeset | 1158 | SpriteID pal; | 
| 3060 | 1159 | |
| 9722 
ebf0ece7d8f6
(svn r11503) [NoAI] -Sync: with trunk r11308:11502.
 rubidium parents: 
9718diff
changeset | 1160 | 				if (!IsTransparencySet(TO_BUILDINGS) && HasBit(image, PALETTE_MODIFIER_COLOR)) {
 | 
| 5919 
2b58160d667d
(svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
 peter1138 parents: 
5894diff
changeset | 1161 | pal = palette; | 
| 
2b58160d667d
(svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
 peter1138 parents: 
5894diff
changeset | 1162 | 				} else {
 | 
| 
2b58160d667d
(svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
 peter1138 parents: 
5894diff
changeset | 1163 | pal = PAL_NONE; | 
| 4226 
3926da9dc486
(svn r5772) Road depots always have an player as owner, so remove an useless check
 tron parents: 
4212diff
changeset | 1164 | } | 
| 3060 | 1165 | |
| 4077 
d3022f976946
(svn r5391) Miscellaneous, mostly bracing and whitespace, nothing spectacular
 tron parents: 
4048diff
changeset | 1166 | AddSortableSpriteToDraw( | 
| 5919 
2b58160d667d
(svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
 peter1138 parents: 
5894diff
changeset | 1167 | image, pal, | 
| 4232 
628628eaa4fc
(svn r5796) Use DrawTileSprites/DrawTileSeqStruct for road depot drawing data, too
 tron parents: 
4231diff
changeset | 1168 | ti->x + dtss->delta_x, ti->y + dtss->delta_y, | 
| 
628628eaa4fc
(svn r5796) Use DrawTileSprites/DrawTileSeqStruct for road depot drawing data, too
 tron parents: 
4231diff
changeset | 1169 | dtss->size_x, dtss->size_y, | 
| 9694 
e72987579514
(svn r10775) [NoAI] -Sync: with trunk r10535:r10774.
 rubidium parents: 
9686diff
changeset | 1170 | dtss->size_z, ti->z, | 
| 9722 
ebf0ece7d8f6
(svn r11503) [NoAI] -Sync: with trunk r11308:11502.
 rubidium parents: 
9718diff
changeset | 1171 | IsTransparencySet(TO_BUILDINGS) | 
| 3060 | 1172 | ); | 
| 1173 | } | |
| 1174 | break; | |
| 0 | 1175 | } | 
| 1176 | } | |
| 5573 
afa6f92a71fd
(svn r7573) -Merged the bridge branch. Allows to build bridges of arbitrary rail/road combinations (including signals)
 celestar parents: 
5212diff
changeset | 1177 | DrawBridgeMiddle(ti); | 
| 0 | 1178 | } | 
| 1179 | ||
| 9624 | 1180 | void DrawRoadDepotSprite(int x, int y, DiagDirection dir, RoadType rt) | 
| 0 | 1181 | {
 | 
| 5919 
2b58160d667d
(svn r8128) -Codechange: Split sprite and palette remap into separate 32 bit values.
 peter1138 parents: 
5894diff
changeset | 1182 | SpriteID palette = PLAYER_SPRITE_COLOR(_local_player); | 
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1183 | const DrawTileSprites* dts = (rt == ROADTYPE_TRAM) ? &_tram_depot[dir] : &_road_depot[dir]; | 
| 4232 
628628eaa4fc
(svn r5796) Use DrawTileSprites/DrawTileSeqStruct for road depot drawing data, too
 tron parents: 
4231diff
changeset | 1184 | const DrawTileSeqStruct* dtss; | 
| 0 | 1185 | |
| 2639 | 1186 | x += 33; | 
| 1187 | y += 17; | |
| 0 | 1188 | |
| 9732 | 1189 | DrawSprite(dts->ground.sprite, PAL_NONE, x, y); | 
| 0 | 1190 | |
| 9732 | 1191 | 	for (dtss = dts->seq; dtss->image.sprite != 0; dtss++) {
 | 
| 4232 
628628eaa4fc
(svn r5796) Use DrawTileSprites/DrawTileSeqStruct for road depot drawing data, too
 tron parents: 
4231diff
changeset | 1192 | Point pt = RemapCoords(dtss->delta_x, dtss->delta_y, dtss->delta_z); | 
| 9732 | 1193 | SpriteID image = dtss->image.sprite; | 
| 201 
c40d343115f8
(svn r202) -Codechange: I missed some files with trailing spaces.. this should be
 truelight parents: 
159diff
changeset | 1194 | |
| 9722 
ebf0ece7d8f6
(svn r11503) [NoAI] -Sync: with trunk r11308:11502.
 rubidium parents: 
9718diff
changeset | 1195 | DrawSprite(image, HasBit(image, PALETTE_MODIFIER_COLOR) ? palette : PAL_NONE, x + pt.x, y + pt.y); | 
| 0 | 1196 | } | 
| 1197 | } | |
| 1198 | ||
| 4231 
dea6a63dd058
(svn r5794) Pass the TileIndex plus x and y coordinates into GetSlopeZ_* instead of a TileInfo
 tron parents: 
4226diff
changeset | 1199 | static uint GetSlopeZ_Road(TileIndex tile, uint x, uint y) | 
| 0 | 1200 | {
 | 
| 4231 
dea6a63dd058
(svn r5794) Pass the TileIndex plus x and y coordinates into GetSlopeZ_* instead of a TileInfo
 tron parents: 
4226diff
changeset | 1201 | uint z; | 
| 
dea6a63dd058
(svn r5794) Pass the TileIndex plus x and y coordinates into GetSlopeZ_* instead of a TileInfo
 tron parents: 
4226diff
changeset | 1202 | Slope tileh = GetTileSlope(tile, &z); | 
| 3098 
4c1320da876d
(svn r3687) Complete some bits I missed whenn adding accessor functions for road types and pieces
 tron parents: 
3097diff
changeset | 1203 | |
| 3636 
d87b21df2944
(svn r4541) Add a type for slopes and replace many magic numbers by the appropriate enums
 tron parents: 
3560diff
changeset | 1204 | if (tileh == SLOPE_FLAT) return z; | 
| 9732 | 1205 | 	if (IsNormalRoad(tile)) {
 | 
| 9694 
e72987579514
(svn r10775) [NoAI] -Sync: with trunk r10535:r10774.
 rubidium parents: 
9686diff
changeset | 1206 | Foundation f = GetRoadFoundation(tileh, GetAllRoadBits(tile)); | 
| 
e72987579514
(svn r10775) [NoAI] -Sync: with trunk r10535:r10774.
 rubidium parents: 
9686diff
changeset | 1207 | z += ApplyFoundationToSlope(f, &tileh); | 
| 4231 
dea6a63dd058
(svn r5794) Pass the TileIndex plus x and y coordinates into GetSlopeZ_* instead of a TileInfo
 tron parents: 
4226diff
changeset | 1208 | return z + GetPartialZ(x & 0xF, y & 0xF, tileh); | 
| 3286 
3250f1488eb2
(svn r4000) Rewrite GetSlope{Tileh,Z}_{Road,Track} in a less confusing way
 tron parents: 
3277diff
changeset | 1209 | 	} else {
 | 
| 3645 
86af43f87885
(svn r4554) Replace magic numbers by TILE_{HEIGHT,SIZE}
 tron parents: 
3637diff
changeset | 1210 | return z + TILE_HEIGHT; | 
| 0 | 1211 | } | 
| 39 | 1212 | } | 
| 1213 | ||
| 9694 
e72987579514
(svn r10775) [NoAI] -Sync: with trunk r10535:r10774.
 rubidium parents: 
9686diff
changeset | 1214 | static Foundation GetFoundation_Road(TileIndex tile, Slope tileh) | 
| 39 | 1215 | {
 | 
| 9732 | 1216 | 	if (IsNormalRoad(tile)) {
 | 
| 9694 
e72987579514
(svn r10775) [NoAI] -Sync: with trunk r10535:r10774.
 rubidium parents: 
9686diff
changeset | 1217 | return GetRoadFoundation(tileh, GetAllRoadBits(tile)); | 
| 3286 
3250f1488eb2
(svn r4000) Rewrite GetSlope{Tileh,Z}_{Road,Track} in a less confusing way
 tron parents: 
3277diff
changeset | 1218 | 	} else {
 | 
| 9694 
e72987579514
(svn r10775) [NoAI] -Sync: with trunk r10535:r10774.
 rubidium parents: 
9686diff
changeset | 1219 | return FlatteningFoundation(tileh); | 
| 39 | 1220 | } | 
| 0 | 1221 | } | 
| 1222 | ||
| 1977 
4392ae3d8e31
(svn r2483) Replace almost 500 "uint tile" (and variants) with "TileIndex tile"
 tron parents: 
1942diff
changeset | 1223 | static void GetAcceptedCargo_Road(TileIndex tile, AcceptedCargo ac) | 
| 0 | 1224 | {
 | 
| 1225 | /* not used */ | |
| 1226 | } | |
| 1227 | ||
| 1977 
4392ae3d8e31
(svn r2483) Replace almost 500 "uint tile" (and variants) with "TileIndex tile"
 tron parents: 
1942diff
changeset | 1228 | static void AnimateTile_Road(TileIndex tile) | 
| 0 | 1229 | {
 | 
| 2639 | 1230 | if (IsLevelCrossing(tile)) MarkTileDirtyByTile(tile); | 
| 0 | 1231 | } | 
| 1232 | ||
| 4048 | 1233 | |
| 1234 | static const Roadside _town_road_types[][2] = {
 | |
| 1235 | 	{ ROADSIDE_GRASS,         ROADSIDE_GRASS },
 | |
| 1236 | 	{ ROADSIDE_PAVED,         ROADSIDE_PAVED },
 | |
| 1237 | 	{ ROADSIDE_PAVED,         ROADSIDE_PAVED },
 | |
| 1238 | 	{ ROADSIDE_TREES,         ROADSIDE_TREES },
 | |
| 1239 | 	{ ROADSIDE_STREET_LIGHTS, ROADSIDE_PAVED }
 | |
| 0 | 1240 | }; | 
| 1241 | ||
| 4048 | 1242 | static const Roadside _town_road_types_2[][2] = {
 | 
| 1243 | 	{ ROADSIDE_GRASS,         ROADSIDE_GRASS },
 | |
| 1244 | 	{ ROADSIDE_PAVED,         ROADSIDE_PAVED },
 | |
| 1245 | 	{ ROADSIDE_STREET_LIGHTS, ROADSIDE_PAVED },
 | |
| 1246 | 	{ ROADSIDE_STREET_LIGHTS, ROADSIDE_PAVED },
 | |
| 1247 | 	{ ROADSIDE_STREET_LIGHTS, ROADSIDE_PAVED }
 | |
| 0 | 1248 | }; | 
| 1249 | ||
| 1250 | ||
| 1977 
4392ae3d8e31
(svn r2483) Replace almost 500 "uint tile" (and variants) with "TileIndex tile"
 tron parents: 
1942diff
changeset | 1251 | static void TileLoop_Road(TileIndex tile) | 
| 0 | 1252 | {
 | 
| 3017 
915fae59d5e0
(svn r3597) Miscellaneous (I like that word) changes: Fix some indentation, add consts, reduce indentation level by short-circuit logic, convert if cascades to switch, whitespace, bracing, plus some minor stuff
 tron parents: 
2989diff
changeset | 1253 | 	switch (_opt.landscape) {
 | 
| 9517 | 1254 | case LT_ARCTIC: | 
| 9505 | 1255 | 			if (IsOnSnow(tile) != (GetTileZ(tile) > GetSnowLine())) {
 | 
| 3430 
b283bb956a36
(svn r4258) -Codechange: Add and make use of map accessors dealing with road ground types (including roadworks).
 celestar parents: 
3421diff
changeset | 1256 | ToggleSnow(tile); | 
| 3017 
915fae59d5e0
(svn r3597) Miscellaneous (I like that word) changes: Fix some indentation, add consts, reduce indentation level by short-circuit logic, convert if cascades to switch, whitespace, bracing, plus some minor stuff
 tron parents: 
2989diff
changeset | 1257 | MarkTileDirtyByTile(tile); | 
| 
915fae59d5e0
(svn r3597) Miscellaneous (I like that word) changes: Fix some indentation, add consts, reduce indentation level by short-circuit logic, convert if cascades to switch, whitespace, bracing, plus some minor stuff
 tron parents: 
2989diff
changeset | 1258 | } | 
| 
915fae59d5e0
(svn r3597) Miscellaneous (I like that word) changes: Fix some indentation, add consts, reduce indentation level by short-circuit logic, convert if cascades to switch, whitespace, bracing, plus some minor stuff
 tron parents: 
2989diff
changeset | 1259 | break; | 
| 
915fae59d5e0
(svn r3597) Miscellaneous (I like that word) changes: Fix some indentation, add consts, reduce indentation level by short-circuit logic, convert if cascades to switch, whitespace, bracing, plus some minor stuff
 tron parents: 
2989diff
changeset | 1260 | |
| 9517 | 1261 | case LT_TROPIC: | 
| 3430 
b283bb956a36
(svn r4258) -Codechange: Add and make use of map accessors dealing with road ground types (including roadworks).
 celestar parents: 
3421diff
changeset | 1262 | 			if (GetTropicZone(tile) == TROPICZONE_DESERT && !IsOnDesert(tile)) {
 | 
| 
b283bb956a36
(svn r4258) -Codechange: Add and make use of map accessors dealing with road ground types (including roadworks).
 celestar parents: 
3421diff
changeset | 1263 | ToggleDesert(tile); | 
| 3017 
915fae59d5e0
(svn r3597) Miscellaneous (I like that word) changes: Fix some indentation, add consts, reduce indentation level by short-circuit logic, convert if cascades to switch, whitespace, bracing, plus some minor stuff
 tron parents: 
2989diff
changeset | 1264 | MarkTileDirtyByTile(tile); | 
| 
915fae59d5e0
(svn r3597) Miscellaneous (I like that word) changes: Fix some indentation, add consts, reduce indentation level by short-circuit logic, convert if cascades to switch, whitespace, bracing, plus some minor stuff
 tron parents: 
2989diff
changeset | 1265 | } | 
| 
915fae59d5e0
(svn r3597) Miscellaneous (I like that word) changes: Fix some indentation, add consts, reduce indentation level by short-circuit logic, convert if cascades to switch, whitespace, bracing, plus some minor stuff
 tron parents: 
2989diff
changeset | 1266 | break; | 
| 0 | 1267 | } | 
| 1268 | ||
| 9732 | 1269 | if (IsRoadDepot(tile)) return; | 
| 0 | 1270 | |
| 9704 | 1271 | const Town* t = ClosestTownFromTile(tile, (uint)-1); | 
| 3430 
b283bb956a36
(svn r4258) -Codechange: Add and make use of map accessors dealing with road ground types (including roadworks).
 celestar parents: 
3421diff
changeset | 1272 | 	if (!HasRoadWorks(tile)) {
 | 
| 9724 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 1273 | HouseZonesBits grp = HZB_TOWN_EDGE; | 
| 1280 
b6925875de49
(svn r1784) -Fix: removed ClosestTownFromTile where possible, or replaced it
 truelight parents: 
1264diff
changeset | 1274 | |
| 0 | 1275 | 		if (t != NULL) {
 | 
| 1276 | grp = GetTownRadiusGroup(t, tile); | |
| 201 
c40d343115f8
(svn r202) -Codechange: I missed some files with trailing spaces.. this should be
 truelight parents: 
159diff
changeset | 1277 | |
| 9574 | 1278 | /* Show an animation to indicate road work */ | 
| 201 
c40d343115f8
(svn r202) -Codechange: I missed some files with trailing spaces.. this should be
 truelight parents: 
159diff
changeset | 1279 | if (t->road_build_months != 0 && | 
| 9724 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 1280 | (DistanceManhattan(t->xy, tile) < 8 || grp != HZB_TOWN_EDGE) && | 
| 9732 | 1281 | 					IsNormalRoad(tile) && CountBits(GetAllRoadBits(tile)) > 1 ) {
 | 
| 9723 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 1282 | 				if (GetTileSlope(tile, NULL) == SLOPE_FLAT && EnsureNoVehicleOnGround(tile) && Chance16(1, 40)) {
 | 
| 3430 
b283bb956a36
(svn r4258) -Codechange: Add and make use of map accessors dealing with road ground types (including roadworks).
 celestar parents: 
3421diff
changeset | 1283 | StartRoadWorks(tile); | 
| 201 
c40d343115f8
(svn r202) -Codechange: I missed some files with trailing spaces.. this should be
 truelight parents: 
159diff
changeset | 1284 | |
| 541 | 1285 | SndPlayTileFx(SND_21_JACKHAMMER, tile); | 
| 0 | 1286 | CreateEffectVehicleAbove( | 
| 3421 
8ab76c47c72c
(svn r4246) -Codechange. Replaced about 100 occurences of '16' by TILE_SIZE
 celestar parents: 
3418diff
changeset | 1287 | TileX(tile) * TILE_SIZE + 7, | 
| 
8ab76c47c72c
(svn r4246) -Codechange. Replaced about 100 occurences of '16' by TILE_SIZE
 celestar parents: 
3418diff
changeset | 1288 | TileY(tile) * TILE_SIZE + 7, | 
| 0 | 1289 | 0, | 
| 1359 
8ba976aed634
(svn r1863) Give the effect vehicle type enums more descriptive names and use the enum as parameter type for CreateEffectVehicle*()
 tron parents: 
1327diff
changeset | 1290 | EV_BULLDOZER); | 
| 0 | 1291 | MarkTileDirtyByTile(tile); | 
| 1292 | return; | |
| 1293 | } | |
| 1294 | } | |
| 1295 | } | |
| 1296 | ||
| 1297 | 		{
 | |
| 3430 
b283bb956a36
(svn r4258) -Codechange: Add and make use of map accessors dealing with road ground types (including roadworks).
 celestar parents: 
3421diff
changeset | 1298 | /* Adjust road ground type depending on 'grp' (grp is the distance to the center) */ | 
| 9517 | 1299 | const Roadside* new_rs = (_opt.landscape == LT_TOYLAND) ? _town_road_types_2[grp] : _town_road_types[grp]; | 
| 4048 | 1300 | Roadside cur_rs = GetRoadside(tile); | 
| 201 
c40d343115f8
(svn r202) -Codechange: I missed some files with trailing spaces.. this should be
 truelight parents: 
159diff
changeset | 1301 | |
| 3430 
b283bb956a36
(svn r4258) -Codechange: Add and make use of map accessors dealing with road ground types (including roadworks).
 celestar parents: 
3421diff
changeset | 1302 | /* We have our desired type, do nothing */ | 
| 4048 | 1303 | if (cur_rs == new_rs[0]) return; | 
| 3430 
b283bb956a36
(svn r4258) -Codechange: Add and make use of map accessors dealing with road ground types (including roadworks).
 celestar parents: 
3421diff
changeset | 1304 | |
| 
b283bb956a36
(svn r4258) -Codechange: Add and make use of map accessors dealing with road ground types (including roadworks).
 celestar parents: 
3421diff
changeset | 1305 | /* We have the pre-type of the desired type, switch to the desired type */ | 
| 4048 | 1306 | 			if (cur_rs == new_rs[1]) {
 | 
| 1307 | cur_rs = new_rs[0]; | |
| 3430 
b283bb956a36
(svn r4258) -Codechange: Add and make use of map accessors dealing with road ground types (including roadworks).
 celestar parents: 
3421diff
changeset | 1308 | /* We have barren land, install the pre-type */ | 
| 4048 | 1309 | 			} else if (cur_rs == ROADSIDE_BARREN) {
 | 
| 1310 | cur_rs = new_rs[1]; | |
| 3430 
b283bb956a36
(svn r4258) -Codechange: Add and make use of map accessors dealing with road ground types (including roadworks).
 celestar parents: 
3421diff
changeset | 1311 | /* We're totally off limits, remove any installation and make barren land */ | 
| 0 | 1312 | 			} else {
 | 
| 4048 | 1313 | cur_rs = ROADSIDE_BARREN; | 
| 0 | 1314 | } | 
| 4048 | 1315 | SetRoadside(tile, cur_rs); | 
| 0 | 1316 | MarkTileDirtyByTile(tile); | 
| 1317 | } | |
| 3430 
b283bb956a36
(svn r4258) -Codechange: Add and make use of map accessors dealing with road ground types (including roadworks).
 celestar parents: 
3421diff
changeset | 1318 | 	} else if (IncreaseRoadWorksCounter(tile)) {
 | 
| 
b283bb956a36
(svn r4258) -Codechange: Add and make use of map accessors dealing with road ground types (including roadworks).
 celestar parents: 
3421diff
changeset | 1319 | TerminateRoadWorks(tile); | 
| 9704 | 1320 | |
| 1321 | 		if (_patches.mod_road_rebuild) {
 | |
| 1322 | /* Generate a nicer town surface */ | |
| 1323 | const RoadBits old_rb = GetAnyRoadBits(tile, ROADTYPE_ROAD); | |
| 1324 | const RoadBits new_rb = CleanUpRoadBits(tile, old_rb); | |
| 1325 | ||
| 1326 | 			if (old_rb != new_rb) {
 | |
| 9724 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 1327 | RemoveRoad(tile, DC_EXEC | DC_AUTO | DC_NO_WATER, (old_rb ^ new_rb), ROADTYPE_ROAD, true); | 
| 9704 | 1328 | } | 
| 1329 | } | |
| 1330 | ||
| 0 | 1331 | MarkTileDirtyByTile(tile); | 
| 1332 | } | |
| 1333 | } | |
| 1334 | ||
| 1977 
4392ae3d8e31
(svn r2483) Replace almost 500 "uint tile" (and variants) with "TileIndex tile"
 tron parents: 
1942diff
changeset | 1335 | static void ClickTile_Road(TileIndex tile) | 
| 0 | 1336 | {
 | 
| 9732 | 1337 | if (IsRoadDepot(tile)) ShowDepotWindow(tile, VEH_ROAD); | 
| 0 | 1338 | } | 
| 1339 | ||
| 9732 | 1340 | /* Converts RoadBits to TrackBits */ | 
| 0 | 1341 | static const byte _road_trackbits[16] = {
 | 
| 1342 | 0x0, 0x0, 0x0, 0x10, 0x0, 0x2, 0x8, 0x1A, 0x0, 0x4, 0x1, 0x15, 0x20, 0x26, 0x29, 0x3F, | |
| 1343 | }; | |
| 1344 | ||
| 9732 | 1345 | static TrackStatus GetTileTrackStatus_Road(TileIndex tile, TransportType mode, uint sub_mode, DiagDirection side) | 
| 1977 
4392ae3d8e31
(svn r2483) Replace almost 500 "uint tile" (and variants) with "TileIndex tile"
 tron parents: 
1942diff
changeset | 1346 | {
 | 
| 9732 | 1347 | TrackdirBits trackdirbits = TRACKDIR_BIT_NONE; | 
| 1348 | TrackdirBits red_signals = TRACKDIR_BIT_NONE; // crossing barred | |
| 3066 
0d34dff23d98
(svn r3655) Simplify a boolean expression and turn 3 if-cascades into switches
 tron parents: 
3061diff
changeset | 1349 | 	switch (mode) {
 | 
| 
0d34dff23d98
(svn r3655) Simplify a boolean expression and turn 3 if-cascades into switches
 tron parents: 
3061diff
changeset | 1350 | case TRANSPORT_RAIL: | 
| 9732 | 1351 | if (IsLevelCrossing(tile)) trackdirbits = TrackBitsToTrackdirBits(GetCrossingRailBits(tile)); | 
| 1352 | break; | |
| 201 
c40d343115f8
(svn r202) -Codechange: I missed some files with trailing spaces.. this should be
 truelight parents: 
159diff
changeset | 1353 | |
| 3066 
0d34dff23d98
(svn r3655) Simplify a boolean expression and turn 3 if-cascades into switches
 tron parents: 
3061diff
changeset | 1354 | case TRANSPORT_ROAD: | 
| 9732 | 1355 | if ((GetRoadTypes(tile) & sub_mode) == 0) break; | 
| 3793 
33cdb5bf7b21
(svn r4789) - Codechange: rename RoadType to RoadTileType and ROAD_{NORMAL,CROSSING,DEPOT} to ROAD_TILE_* for consistency
 rubidium parents: 
3792diff
changeset | 1356 | 			switch (GetRoadTileType(tile)) {
 | 
| 9624 | 1357 | 				case ROAD_TILE_NORMAL: {
 | 
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1358 | 					const uint drd_to_multiplier[DRD_END] = { 0x101, 0x100, 0x1, 0x0 };
 | 
| 9732 | 1359 | RoadType rt = (RoadType)FindFirstBit(sub_mode); | 
| 1360 | RoadBits bits = GetRoadBits(tile, rt); | |
| 1361 | ||
| 1362 | /* no roadbit at this side of tile, return 0 */ | |
| 1363 | if (side != INVALID_DIAGDIR && (DiagDirToRoadBits(side) & bits) == 0) break; | |
| 1364 | ||
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1365 | uint multiplier = drd_to_multiplier[rt == ROADTYPE_TRAM ? DRD_NONE : GetDisallowedRoadDirections(tile)]; | 
| 9732 | 1366 | if (!HasRoadWorks(tile)) trackdirbits = (TrackdirBits)(_road_trackbits[bits] * multiplier); | 
| 1367 | break; | |
| 9624 | 1368 | } | 
| 3066 
0d34dff23d98
(svn r3655) Simplify a boolean expression and turn 3 if-cascades into switches
 tron parents: 
3061diff
changeset | 1369 | |
| 3793 
33cdb5bf7b21
(svn r4789) - Codechange: rename RoadType to RoadTileType and ROAD_{NORMAL,CROSSING,DEPOT} to ROAD_TILE_* for consistency
 rubidium parents: 
3792diff
changeset | 1370 | 				case ROAD_TILE_CROSSING: {
 | 
| 9732 | 1371 | Axis axis = GetCrossingRoadAxis(tile); | 
| 3272 
7e556f209503
(svn r3984) Add a function to get the road axis of a level crossing
 tron parents: 
3269diff
changeset | 1372 | |
| 9732 | 1373 | if (side != INVALID_DIAGDIR && axis != DiagDirToAxis(side)) break; | 
| 1374 | ||
| 1375 | trackdirbits = TrackBitsToTrackdirBits(AxisToTrackBits(axis)); | |
| 1376 | if (IsCrossingBarred(tile)) red_signals = trackdirbits; | |
| 1377 | break; | |
| 3066 
0d34dff23d98
(svn r3655) Simplify a boolean expression and turn 3 if-cascades into switches
 tron parents: 
3061diff
changeset | 1378 | } | 
| 
0d34dff23d98
(svn r3655) Simplify a boolean expression and turn 3 if-cascades into switches
 tron parents: 
3061diff
changeset | 1379 | |
| 3069 
0e6aca11c3da
(svn r3658) Add functions and symbolic names to retrieve road tile types and road pieces
 tron parents: 
3068diff
changeset | 1380 | default: | 
| 9732 | 1381 | 				case ROAD_TILE_DEPOT: {
 | 
| 1382 | DiagDirection dir = GetRoadDepotDirection(tile); | |
| 1383 | ||
| 1384 | if (side != INVALID_DIAGDIR && side != dir) break; | |
| 1385 | ||
| 1386 | trackdirbits = TrackBitsToTrackdirBits(AxisToTrackBits(DiagDirToAxis(dir))); | |
| 1387 | break; | |
| 1388 | } | |
| 201 
c40d343115f8
(svn r202) -Codechange: I missed some files with trailing spaces.. this should be
 truelight parents: 
159diff
changeset | 1389 | } | 
| 3066 
0d34dff23d98
(svn r3655) Simplify a boolean expression and turn 3 if-cascades into switches
 tron parents: 
3061diff
changeset | 1390 | break; | 
| 
0d34dff23d98
(svn r3655) Simplify a boolean expression and turn 3 if-cascades into switches
 tron parents: 
3061diff
changeset | 1391 | |
| 
0d34dff23d98
(svn r3655) Simplify a boolean expression and turn 3 if-cascades into switches
 tron parents: 
3061diff
changeset | 1392 | default: break; | 
| 0 | 1393 | } | 
| 9732 | 1394 | return CombineTrackStatus(trackdirbits, red_signals); | 
| 0 | 1395 | } | 
| 1396 | ||
| 1397 | static const StringID _road_tile_strings[] = {
 | |
| 1398 | STR_1814_ROAD, | |
| 1399 | STR_1814_ROAD, | |
| 1400 | STR_1814_ROAD, | |
| 1401 | STR_1815_ROAD_WITH_STREETLIGHTS, | |
| 1402 | STR_1814_ROAD, | |
| 1403 | STR_1816_TREE_LINED_ROAD, | |
| 1404 | STR_1814_ROAD, | |
| 1405 | STR_1814_ROAD, | |
| 1406 | }; | |
| 1407 | ||
| 1977 
4392ae3d8e31
(svn r2483) Replace almost 500 "uint tile" (and variants) with "TileIndex tile"
 tron parents: 
1942diff
changeset | 1408 | static void GetTileDesc_Road(TileIndex tile, TileDesc *td) | 
| 0 | 1409 | {
 | 
| 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 | 1410 | td->owner = GetTileOwner(tile); | 
| 3793 
33cdb5bf7b21
(svn r4789) - Codechange: rename RoadType to RoadTileType and ROAD_{NORMAL,CROSSING,DEPOT} to ROAD_TILE_* for consistency
 rubidium parents: 
3792diff
changeset | 1411 | 	switch (GetRoadTileType(tile)) {
 | 
| 
33cdb5bf7b21
(svn r4789) - Codechange: rename RoadType to RoadTileType and ROAD_{NORMAL,CROSSING,DEPOT} to ROAD_TILE_* for consistency
 rubidium parents: 
3792diff
changeset | 1412 | case ROAD_TILE_CROSSING: td->str = STR_1818_ROAD_RAIL_LEVEL_CROSSING; break; | 
| 
33cdb5bf7b21
(svn r4789) - Codechange: rename RoadType to RoadTileType and ROAD_{NORMAL,CROSSING,DEPOT} to ROAD_TILE_* for consistency
 rubidium parents: 
3792diff
changeset | 1413 | case ROAD_TILE_DEPOT: td->str = STR_1817_ROAD_VEHICLE_DEPOT; break; | 
| 4048 | 1414 | default: td->str = _road_tile_strings[GetRoadside(tile)]; break; | 
| 3069 
0e6aca11c3da
(svn r3658) Add functions and symbolic names to retrieve road tile types and road pieces
 tron parents: 
3068diff
changeset | 1415 | } | 
| 0 | 1416 | } | 
| 1417 | ||
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1418 | /** | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1419 | * Given the direction the road depot is pointing, this is the direction the | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1420 | * vehicle should be travelling in in order to enter the depot. | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1421 | */ | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1422 | static const byte _roadveh_enter_depot_dir[4] = {
 | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1423 | TRACKDIR_X_SW, TRACKDIR_Y_NW, TRACKDIR_X_NE, TRACKDIR_Y_SE | 
| 0 | 1424 | }; | 
| 1425 | ||
| 9723 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 1426 | static VehicleEnterTileStatus VehicleEnter_Road(Vehicle *v, TileIndex tile, int x, int y) | 
| 0 | 1427 | {
 | 
| 3793 
33cdb5bf7b21
(svn r4789) - Codechange: rename RoadType to RoadTileType and ROAD_{NORMAL,CROSSING,DEPOT} to ROAD_TILE_* for consistency
 rubidium parents: 
3792diff
changeset | 1428 | 	switch (GetRoadTileType(tile)) {
 | 
| 
33cdb5bf7b21
(svn r4789) - Codechange: rename RoadType to RoadTileType and ROAD_{NORMAL,CROSSING,DEPOT} to ROAD_TILE_* for consistency
 rubidium parents: 
3792diff
changeset | 1429 | case ROAD_TILE_CROSSING: | 
| 9724 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 1430 | 			if (v->type == VEH_TRAIN) {
 | 
| 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 1431 | /* it should be barred */ | 
| 
b39bc69bb2f2
(svn r12051) [NoAI] -Sync: with trunk (r11795:12050).
 rubidium parents: 
9723diff
changeset | 1432 | assert(IsCrossingBarred(tile)); | 
| 0 | 1433 | } | 
| 3060 | 1434 | break; | 
| 1435 | ||
| 3793 
33cdb5bf7b21
(svn r4789) - Codechange: rename RoadType to RoadTileType and ROAD_{NORMAL,CROSSING,DEPOT} to ROAD_TILE_* for consistency
 rubidium parents: 
3792diff
changeset | 1436 | case ROAD_TILE_DEPOT: | 
| 6585 
7da94b26498a
(svn r9068) -Codechange: capitalize the VEH_Train etc. enums to match the coding style (and rest of the code).
 rubidium parents: 
6582diff
changeset | 1437 | if (v->type == VEH_ROAD && | 
| 4077 
d3022f976946
(svn r5391) Miscellaneous, mostly bracing and whitespace, nothing spectacular
 tron parents: 
4048diff
changeset | 1438 | v->u.road.frame == 11 && | 
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1439 | 					_roadveh_enter_depot_dir[GetRoadDepotDirection(tile)] == v->u.road.state) {
 | 
| 9627 | 1440 | v->u.road.state = RVSB_IN_DEPOT; | 
| 1441 | v->vehstatus |= VS_HIDDEN; | |
| 1442 | v->direction = ReverseDir(v->direction); | |
| 9701 
d1ac22c62f64
(svn r11036) [NoAI] -Sync: with trunk r10774:11035.
 rubidium parents: 
9694diff
changeset | 1443 | if (v->Next() == NULL) VehicleEnterDepot(v); | 
| 9627 | 1444 | v->tile = tile; | 
| 1445 | ||
| 1446 | InvalidateWindowData(WC_VEHICLE_DEPOT, v->tile); | |
| 6317 
c73bda71ac16
(svn r8698) -Codechange: enumify the returns of VehicleEnterTile
 rubidium parents: 
6193diff
changeset | 1447 | return VETSB_ENTERED_WORMHOLE; | 
| 3060 | 1448 | } | 
| 1449 | break; | |
| 1450 | ||
| 1451 | default: break; | |
| 0 | 1452 | } | 
| 6317 
c73bda71ac16
(svn r8698) -Codechange: enumify the returns of VehicleEnterTile
 rubidium parents: 
6193diff
changeset | 1453 | return VETSB_CONTINUE; | 
| 0 | 1454 | } | 
| 1455 | ||
| 1456 | ||
| 2436 
177cb6a8339f
(svn r2962) - const correctness for all Get* functions and most Draw* functions that don't change their pointer parameters
 Darkvater parents: 
2425diff
changeset | 1457 | static void ChangeTileOwner_Road(TileIndex tile, PlayerID old_player, PlayerID new_player) | 
| 0 | 1458 | {
 | 
| 9732 | 1459 | 	if (IsRoadDepot(tile)) {
 | 
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1460 | 		if (GetTileOwner(tile) == old_player) {
 | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1461 | 			if (new_player == PLAYER_SPECTATOR) {
 | 
| 9732 | 1462 | DoCommand(tile, 0, 0, DC_EXEC | DC_BANKRUPT, CMD_LANDSCAPE_CLEAR); | 
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1463 | 			} else {
 | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1464 | SetTileOwner(tile, new_player); | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1465 | } | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1466 | } | 
| 9624 | 1467 | return; | 
| 0 | 1468 | } | 
| 1469 | ||
| 9624 | 1470 | 	for (RoadType rt = ROADTYPE_ROAD; rt < ROADTYPE_END; rt++) {
 | 
| 9732 | 1471 | /* ROADTYPE_ROAD denotes the tile owner, so update it too */ | 
| 1472 | if (rt != ROADTYPE_ROAD && !HasTileRoadType(tile, rt)) continue; | |
| 0 | 1473 | |
| 9624 | 1474 | 		if (GetRoadOwner(tile, rt) == old_player) {
 | 
| 1475 | SetRoadOwner(tile, rt, new_player == PLAYER_SPECTATOR ? OWNER_NONE : new_player); | |
| 1476 | } | |
| 1477 | } | |
| 3060 | 1478 | |
| 9624 | 1479 | 	if (IsLevelCrossing(tile)) {
 | 
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1480 | 		if (GetTileOwner(tile) == old_player) {
 | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1481 | 			if (new_player == PLAYER_SPECTATOR) {
 | 
| 9732 | 1482 | DoCommand(tile, 0, GetCrossingRailTrack(tile), DC_EXEC | DC_BANKRUPT, CMD_REMOVE_SINGLE_RAIL); | 
| 9625 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1483 | 			} else {
 | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1484 | SetTileOwner(tile, new_player); | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1485 | } | 
| 
3301b1b3889c
(svn r10016) [NoAI] -Sync with trunk r9914:r10015.
 rubidium parents: 
9624diff
changeset | 1486 | } | 
| 0 | 1487 | } | 
| 1488 | } | |
| 1489 | ||
| 9701 
d1ac22c62f64
(svn r11036) [NoAI] -Sync: with trunk r10774:11035.
 rubidium parents: 
9694diff
changeset | 1490 | static CommandCost TerraformTile_Road(TileIndex tile, uint32 flags, uint z_new, Slope tileh_new) | 
| 
d1ac22c62f64
(svn r11036) [NoAI] -Sync: with trunk r10774:11035.
 rubidium parents: 
9694diff
changeset | 1491 | {
 | 
| 9703 
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
 rubidium parents: 
9701diff
changeset | 1492 | 	if (_patches.build_on_slopes && AutoslopeEnabled()) {
 | 
| 
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
 rubidium parents: 
9701diff
changeset | 1493 | 		switch (GetRoadTileType(tile)) {
 | 
| 
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
 rubidium parents: 
9701diff
changeset | 1494 | case ROAD_TILE_CROSSING: | 
| 9723 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 1495 | if (!IsSteepSlope(tileh_new) && (GetTileMaxZ(tile) == z_new + GetSlopeMaxZ(tileh_new)) && HasBit(VALID_LEVEL_CROSSING_SLOPES, tileh_new)) return CommandCost(EXPENSES_CONSTRUCTION, _price.terraform); | 
| 9703 
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
 rubidium parents: 
9701diff
changeset | 1496 | break; | 
| 
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
 rubidium parents: 
9701diff
changeset | 1497 | |
| 
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
 rubidium parents: 
9701diff
changeset | 1498 | case ROAD_TILE_DEPOT: | 
| 9723 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 1499 | if (AutoslopeCheckForEntranceEdge(tile, z_new, tileh_new, GetRoadDepotDirection(tile))) return CommandCost(EXPENSES_CONSTRUCTION, _price.terraform); | 
| 9703 
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
 rubidium parents: 
9701diff
changeset | 1500 | break; | 
| 
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
 rubidium parents: 
9701diff
changeset | 1501 | |
| 
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
 rubidium parents: 
9701diff
changeset | 1502 | 			case ROAD_TILE_NORMAL: {
 | 
| 
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
 rubidium parents: 
9701diff
changeset | 1503 | RoadBits bits = GetAllRoadBits(tile); | 
| 
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
 rubidium parents: 
9701diff
changeset | 1504 | RoadBits bits_copy = bits; | 
| 
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
 rubidium parents: 
9701diff
changeset | 1505 | /* Check if the slope-road_bits combination is valid at all, i.e. it is save to call GetRoadFoundation(). */ | 
| 9826 
9707ad4c9b60
(svn r12462) [NoAI] -Sync: with trunk r12304:12461.
 rubidium parents: 
9800diff
changeset | 1506 | 				if (!CmdFailed(CheckRoadSlope(tileh_new, &bits_copy, ROAD_NONE, ROAD_NONE))) {
 | 
| 9703 
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
 rubidium parents: 
9701diff
changeset | 1507 | /* CheckRoadSlope() sometimes changes the road_bits, if it does not agree with them. */ | 
| 
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
 rubidium parents: 
9701diff
changeset | 1508 | 					if (bits == bits_copy) {
 | 
| 
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
 rubidium parents: 
9701diff
changeset | 1509 | uint z_old; | 
| 
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
 rubidium parents: 
9701diff
changeset | 1510 | Slope tileh_old = GetTileSlope(tile, &z_old); | 
| 
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
 rubidium parents: 
9701diff
changeset | 1511 | |
| 
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
 rubidium parents: 
9701diff
changeset | 1512 | /* Get the slope on top of the foundation */ | 
| 
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
 rubidium parents: 
9701diff
changeset | 1513 | z_old += ApplyFoundationToSlope(GetRoadFoundation(tileh_old, bits), &tileh_old); | 
| 
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
 rubidium parents: 
9701diff
changeset | 1514 | z_new += ApplyFoundationToSlope(GetRoadFoundation(tileh_new, bits), &tileh_new); | 
| 
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
 rubidium parents: 
9701diff
changeset | 1515 | |
| 
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
 rubidium parents: 
9701diff
changeset | 1516 | /* The surface slope must not be changed */ | 
| 9723 
eee46cb39750
(svn r11796) [NoAI] -Sync: with trunk r11502:11795.
 rubidium parents: 
9722diff
changeset | 1517 | if ((z_old == z_new) && (tileh_old == tileh_new)) return CommandCost(EXPENSES_CONSTRUCTION, _price.terraform); | 
| 9703 
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
 rubidium parents: 
9701diff
changeset | 1518 | } | 
| 
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
 rubidium parents: 
9701diff
changeset | 1519 | } | 
| 
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
 rubidium parents: 
9701diff
changeset | 1520 | break; | 
| 
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
 rubidium parents: 
9701diff
changeset | 1521 | } | 
| 
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
 rubidium parents: 
9701diff
changeset | 1522 | |
| 
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
 rubidium parents: 
9701diff
changeset | 1523 | default: NOT_REACHED(); | 
| 
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
 rubidium parents: 
9701diff
changeset | 1524 | } | 
| 
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
 rubidium parents: 
9701diff
changeset | 1525 | } | 
| 
d2a6acdbd665
(svn r11146) [NoAI] -Sync: with trunk r11035:11045.
 rubidium parents: 
9701diff
changeset | 1526 | |
| 9701 
d1ac22c62f64
(svn r11036) [NoAI] -Sync: with trunk r10774:11035.
 rubidium parents: 
9694diff
changeset | 1527 | return DoCommand(tile, 0, 0, flags, CMD_LANDSCAPE_CLEAR); | 
| 
d1ac22c62f64
(svn r11036) [NoAI] -Sync: with trunk r10774:11035.
 rubidium parents: 
9694diff
changeset | 1528 | } | 
| 
d1ac22c62f64
(svn r11036) [NoAI] -Sync: with trunk r10774:11035.
 rubidium parents: 
9694diff
changeset | 1529 | |
| 0 | 1530 | |
| 5838 
9c3129cb019b
(svn r8038) -Merge: the cpp branch. Effort of KUDr, Celestar, glx, Smoovius, stillunknown and pv2b.
 rubidium parents: 
5835diff
changeset | 1531 | extern const TileTypeProcs _tile_type_road_procs = {
 | 
| 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: 
4246diff
changeset | 1532 | DrawTile_Road, /* draw_tile_proc */ | 
| 
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: 
4246diff
changeset | 1533 | GetSlopeZ_Road, /* get_slope_z_proc */ | 
| 
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: 
4246diff
changeset | 1534 | ClearTile_Road, /* clear_tile_proc */ | 
| 
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: 
4246diff
changeset | 1535 | GetAcceptedCargo_Road, /* get_accepted_cargo_proc */ | 
| 
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: 
4246diff
changeset | 1536 | GetTileDesc_Road, /* get_tile_desc_proc */ | 
| 
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: 
4246diff
changeset | 1537 | GetTileTrackStatus_Road, /* get_tile_track_status_proc */ | 
| 
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: 
4246diff
changeset | 1538 | ClickTile_Road, /* click_tile_proc */ | 
| 
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: 
4246diff
changeset | 1539 | AnimateTile_Road, /* animate_tile_proc */ | 
| 
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: 
4246diff
changeset | 1540 | TileLoop_Road, /* tile_loop_clear */ | 
| 
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: 
4246diff
changeset | 1541 | ChangeTileOwner_Road, /* change_tile_owner_clear */ | 
| 
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: 
4246diff
changeset | 1542 | NULL, /* get_produced_cargo_proc */ | 
| 
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: 
4246diff
changeset | 1543 | VehicleEnter_Road, /* vehicle_enter_tile_proc */ | 
| 9694 
e72987579514
(svn r10775) [NoAI] -Sync: with trunk r10535:r10774.
 rubidium parents: 
9686diff
changeset | 1544 | GetFoundation_Road, /* get_foundation_proc */ | 
| 9701 
d1ac22c62f64
(svn r11036) [NoAI] -Sync: with trunk r10774:11035.
 rubidium parents: 
9694diff
changeset | 1545 | TerraformTile_Road, /* terraform_tile_proc */ | 
| 0 | 1546 | }; |