|
|
|
@ -92,7 +92,7 @@ static void _DoCommandReturnBuildBridge1(class AIInstance *instance)
|
|
|
|
|
TileIndex end = AIObject::GetCallbackVariable(0);
|
|
|
|
|
TileIndex start = AIObject::GetCallbackVariable(1);
|
|
|
|
|
|
|
|
|
|
DiagDirection dir_1 = (DiagDirection)((::TileX(start) == ::TileX(end)) ? (::TileY(start) < ::TileY(end) ? DIAGDIR_NW : DIAGDIR_SE) : (::TileX(start) < ::TileX(end) ? DIAGDIR_NE : DIAGDIR_SW));
|
|
|
|
|
DiagDirection dir_1 = ::DiagdirBetweenTiles(end, start);
|
|
|
|
|
DiagDirection dir_2 = ::ReverseDiagDir(dir_1);
|
|
|
|
|
|
|
|
|
|
if (!AIObject::DoCommand(start + ::TileOffsByDiagDir(dir_1), ::DiagDirToRoadBits(dir_2) | (AIObject::GetRoadType() << 4), 0, CMD_BUILD_ROAD, NULL, &_DoCommandReturnBuildBridge2)) return false;
|
|
|
|
@ -107,7 +107,7 @@ static void _DoCommandReturnBuildBridge1(class AIInstance *instance)
|
|
|
|
|
TileIndex end = AIObject::GetCallbackVariable(0);
|
|
|
|
|
TileIndex start = AIObject::GetCallbackVariable(1);
|
|
|
|
|
|
|
|
|
|
DiagDirection dir_1 = (DiagDirection)((::TileX(start) == ::TileX(end)) ? (::TileY(start) < ::TileY(end) ? DIAGDIR_NW : DIAGDIR_SE) : (::TileX(start) < ::TileX(end) ? DIAGDIR_NE : DIAGDIR_SW));
|
|
|
|
|
DiagDirection dir_1 = ::DiagdirBetweenTiles(end, start);
|
|
|
|
|
DiagDirection dir_2 = ::ReverseDiagDir(dir_1);
|
|
|
|
|
|
|
|
|
|
return AIObject::DoCommand(end + ::TileOffsByDiagDir(dir_2), ::DiagDirToRoadBits(dir_1) | (AIObject::GetRoadType() << 4), 0, CMD_BUILD_ROAD);
|
|
|
|
|