summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/rail_gui.cpp9
-rw-r--r--src/road_gui.cpp10
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);
+ }
}