diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/rail_gui.cpp | 9 | ||||
-rw-r--r-- | src/road_gui.cpp | 10 |
2 files changed, 17 insertions, 2 deletions
diff --git a/src/rail_gui.cpp b/src/rail_gui.cpp index c30e63017..1d9302872 100644 --- a/src/rail_gui.cpp +++ b/src/rail_gui.cpp @@ -254,7 +254,14 @@ static void GenericPlaceSignals(TileIndex tile) static void PlaceRail_Bridge(TileIndex tile) { - VpStartPlaceSizing(tile, VPM_X_OR_Y, DDSP_BUILD_BRIDGE); + if (IsBridgeTile(tile)) { + TileIndex other_tile = GetOtherTunnelBridgeEnd(tile); + Window *w = GetCallbackWnd(); + Point pt = {0, 0}; + if (w != NULL) w->OnPlaceMouseUp(VPM_X_OR_Y, DDSP_BUILD_BRIDGE, pt, tile, other_tile); + } else { + VpStartPlaceSizing(tile, VPM_X_OR_Y, DDSP_BUILD_BRIDGE); + } } /** Command callback for building a tunnel */ diff --git a/src/road_gui.cpp b/src/road_gui.cpp index 0fdb7c183..bacf1df85 100644 --- a/src/road_gui.cpp +++ b/src/road_gui.cpp @@ -25,6 +25,7 @@ #include "sound_func.h" #include "company_func.h" #include "tunnelbridge.h" +#include "tunnelbridge_map.h" #include "tilehighlight_func.h" #include "company_base.h" @@ -112,7 +113,14 @@ static void PlaceRoad_AutoRoad(TileIndex tile) static void PlaceRoad_Bridge(TileIndex tile) { - VpStartPlaceSizing(tile, VPM_X_OR_Y, DDSP_BUILD_BRIDGE); + if (IsBridgeTile(tile)) { + TileIndex other_tile = GetOtherTunnelBridgeEnd(tile); + Window *w = GetCallbackWnd(); + Point pt = {0, 0}; + if (w != NULL) w->OnPlaceMouseUp(VPM_X_OR_Y, DDSP_BUILD_BRIDGE, pt, tile, other_tile); + } else { + VpStartPlaceSizing(tile, VPM_X_OR_Y, DDSP_BUILD_BRIDGE); + } } |