| author | bjarni | 
| Mon, 06 Sep 2004 21:29:02 +0000 | |
| changeset 170 | 8b184d95b4fe | 
| parent 145 | 6e5468217504 | 
| child 193 | 0a7025304867 | 
| permissions | -rw-r--r-- | 
| 110 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 1 | #include "stdafx.h" | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 2 | #include "ttd.h" | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 3 | #include "command.h" | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 4 | #include "ai.h" | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 5 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 6 | #define TEST_STATION_NO_DIR 0xFF | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 7 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 8 | // Tests if a station can be build on the given spot | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 9 | // TODO: make it train compatible | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 10 | bool TestCanBuildStationHere(uint tile, byte dir) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 11 | Player *p = DEREF_PLAYER(_current_player); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 12 |     if (dir == TEST_STATION_NO_DIR) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 13 | // TODO: currently we only allow spots that can be access from al 4 directions... | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 14 | // should be fixed!!! | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 15 |         for (dir=0;dir<4;dir++) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 16 | int res = AiNew_Build_Station(p, p->ainew.tbt, tile, 1, 1, dir, DC_QUERY_COST); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 17 | if (res != CMD_ERROR) | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 18 | return true; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 19 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 20 | return false; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 21 |     } else {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 22 | int res = AiNew_Build_Station(p, p->ainew.tbt, tile, 1, 1, dir, DC_QUERY_COST); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 23 | if (res == CMD_ERROR) | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 24 | return false; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 25 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 26 | return true; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 27 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 28 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 29 | // Checks if a tile 'a' is between the tiles 'b' and 'c' | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 30 | #define TILES_BETWEEN(a,b,c) (GET_TILE_X(a) >= GET_TILE_X(b) && GET_TILE_X(a) <= GET_TILE_X(c) && GET_TILE_Y(a) >= GET_TILE_Y(b) && GET_TILE_Y(a) <= GET_TILE_Y(c)) | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 31 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 32 | // Check if the current tile is in our end-area | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 33 | int32 AyStar_AiPathFinder_EndNodeCheck(AyStar *aystar, OpenListNode *current) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 34 | Ai_PathFinderInfo *PathFinderInfo = (Ai_PathFinderInfo*)aystar->user_target; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 35 | // It is not allowed to have a station on the end of a bridge or tunnel ;) | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 36 | if (current->path.node.user_data[0] != 0) return AYSTAR_DONE; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 37 | if (TILES_BETWEEN(current->path.node.tile, PathFinderInfo->end_tile_tl, PathFinderInfo->end_tile_br)) | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 38 | if (IS_TILETYPE(current->path.node.tile, MP_CLEAR) || IS_TILETYPE(current->path.node.tile, MP_TREES)) | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 39 | if (current->path.parent == NULL || TestCanBuildStationHere(current->path.node.tile,AiNew_GetDirection(current->path.parent->node.tile, current->path.node.tile))) | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 40 | return AYSTAR_FOUND_END_NODE; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 41 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 42 | return AYSTAR_DONE; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 43 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 44 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 45 | // Calculates the hash | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 46 | // Currently it is a 10 bit hash, so the hash array has a max depth of 6 bits (so 64) | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 47 | uint AiPathFinder_Hash(uint key1, uint key2) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 48 | return (GET_TILE_X(key1) & 0x1F) + ((GET_TILE_Y(key1) & 0x1F) << 5); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 49 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 50 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 51 | // Clear the memory of all the things | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 52 | void AyStar_AiPathFinder_Free(AyStar *aystar) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 53 | AyStarMain_Free(aystar); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 54 | free(aystar); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 55 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 56 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 57 | static int32 AyStar_AiPathFinder_CalculateG(AyStar *aystar, AyStarNode *current, OpenListNode *parent); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 58 | static int32 AyStar_AiPathFinder_CalculateH(AyStar *aystar, AyStarNode *current, OpenListNode *parent); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 59 | static void AyStar_AiPathFinder_FoundEndNode(AyStar *aystar, OpenListNode *current); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 60 | static void AyStar_AiPathFinder_GetNeighbours(AyStar *aystar, OpenListNode *current); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 61 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 62 | // This creates the AiPathFinder | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 63 | AyStar *new_AyStar_AiPathFinder(int max_tiles_around, Ai_PathFinderInfo *PathFinderInfo) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 64 | PathNode start_node; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 65 | uint x,y; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 66 | // Create AyStar | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 67 | AyStar *result = malloc(sizeof(AyStar)); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 68 | init_AyStar(result, AiPathFinder_Hash, 1 << 10); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 69 | // Set the function pointers | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 70 | result->CalculateG = AyStar_AiPathFinder_CalculateG; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 71 | result->CalculateH = AyStar_AiPathFinder_CalculateH; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 72 | result->EndNodeCheck = AyStar_AiPathFinder_EndNodeCheck; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 73 | result->FoundEndNode = AyStar_AiPathFinder_FoundEndNode; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 74 | result->GetNeighbours = AyStar_AiPathFinder_GetNeighbours; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 75 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 76 | result->free = AyStar_AiPathFinder_Free; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 77 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 78 | // Set some information | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 79 | result->loops_per_tick = AI_PATHFINDER_LOOPS_PER_TICK; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 80 | result->max_path_cost = 0; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 81 | result->max_search_nodes = AI_PATHFINDER_MAX_SEARCH_NODES; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 82 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 83 | // Set the user_data to the PathFinderInfo | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 84 | result->user_target = PathFinderInfo; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 85 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 86 | // Set the start node | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 87 | start_node.parent = NULL; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 88 | start_node.node.direction = 0; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 89 | start_node.node.user_data[0] = 0; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 90 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 91 | // Now we add all the starting tiles | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 92 | 	for (x=GET_TILE_X(PathFinderInfo->start_tile_tl);x<=GET_TILE_X(PathFinderInfo->start_tile_br);x++) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 93 | 		for (y=GET_TILE_Y(PathFinderInfo->start_tile_tl);y<=GET_TILE_Y(PathFinderInfo->start_tile_br);y++) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 94 | start_node.node.tile = TILE_XY(x,y); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 95 | result->addstart(result, &start_node.node); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 96 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 97 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 98 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 99 | return result; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 100 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 101 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 102 | // To reuse AyStar we sometimes have to clean all the memory | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 103 | void clean_AyStar_AiPathFinder(AyStar *aystar, Ai_PathFinderInfo *PathFinderInfo) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 104 | PathNode start_node; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 105 | uint x,y; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 106 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 107 | aystar->clear(aystar); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 108 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 109 | // Set the user_data to the PathFinderInfo | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 110 | aystar->user_target = PathFinderInfo; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 111 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 112 | // Set the start node | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 113 | start_node.parent = NULL; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 114 | start_node.node.direction = 0; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 115 | start_node.node.user_data[0] = 0; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 116 | start_node.node.tile = PathFinderInfo->start_tile_tl; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 117 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 118 | // Now we add all the starting tiles | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 119 | 	for (x=GET_TILE_X(PathFinderInfo->start_tile_tl);x<=GET_TILE_X(PathFinderInfo->start_tile_br);x++) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 120 | 		for (y=GET_TILE_Y(PathFinderInfo->start_tile_tl);y<=GET_TILE_Y(PathFinderInfo->start_tile_br);y++) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 121 | if (!(IS_TILETYPE(TILE_XY(x,y), MP_CLEAR) || IS_TILETYPE(TILE_XY(x,y), MP_TREES))) continue; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 122 | if (!TestCanBuildStationHere(TILE_XY(x,y),TEST_STATION_NO_DIR)) continue; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 123 | start_node.node.tile = TILE_XY(x,y); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 124 | aystar->addstart(aystar, &start_node.node); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 125 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 126 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 127 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 128 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 129 | // The h-value, simple calculation | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 130 | static int32 AyStar_AiPathFinder_CalculateH(AyStar *aystar, AyStarNode *current, OpenListNode *parent) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 131 | Ai_PathFinderInfo *PathFinderInfo = (Ai_PathFinderInfo*)aystar->user_target; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 132 | int r, r2; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 133 | 	if (PathFinderInfo->end_direction != AI_PATHFINDER_NO_DIRECTION) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 134 | // The station is pointing to a direction, add a tile towards that direction, so the H-value is more accurate | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 135 | r = GetTileDist(current->tile, PathFinderInfo->end_tile_tl + _tiles_around[PathFinderInfo->end_direction]); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 136 | r2 = GetTileDist(current->tile, PathFinderInfo->end_tile_br + _tiles_around[PathFinderInfo->end_direction]); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 137 | 	} else {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 138 | // No direction, so just get the fastest route to the station | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 139 | r = GetTileDist(current->tile, PathFinderInfo->end_tile_tl); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 140 | r2 = GetTileDist(current->tile, PathFinderInfo->end_tile_br); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 141 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 142 | // See if the bottomright is faster then the topleft.. | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 143 | if (r2 < r) r = r2; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 144 | return r * AI_PATHFINDER_H_MULTIPLER; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 145 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 146 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 147 | // We found the end.. let's get the route back and put it in an array | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 148 | static void AyStar_AiPathFinder_FoundEndNode(AyStar *aystar, OpenListNode *current) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 149 | Ai_PathFinderInfo *PathFinderInfo = (Ai_PathFinderInfo*)aystar->user_target; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 150 | int i = 0; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 151 | PathNode *parent = ¤t->path; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 152 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 153 | 	do {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 154 | PathFinderInfo->route_extra[i] = parent->node.user_data[0]; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 155 | PathFinderInfo->route[i++] = parent->node.tile; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 156 | 		if (i > lengthof(PathFinderInfo->route)) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 157 | // We ran out of space for the PathFinder | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 158 | 			DEBUG(ai,0)("[AiPathFinder] Ran out of spacein the route[] array!!!");
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 159 | PathFinderInfo->route_length = -1; // -1 indicates out of space | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 160 | return; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 161 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 162 | parent = parent->parent; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 163 | } while (parent != NULL); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 164 | PathFinderInfo->route_length = i; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 165 | 	DEBUG(ai,1)("[Ai-PathFinding] Found route of %d nodes long in %d nodes of searching",i,Hash_Size(&aystar->ClosedListHash));
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 166 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 167 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 168 | // What tiles are around us. | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 169 | static void AyStar_AiPathFinder_GetNeighbours(AyStar *aystar, OpenListNode *current) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 170 | int i, r, dir; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 171 | Ai_PathFinderInfo *PathFinderInfo = (Ai_PathFinderInfo*)aystar->user_target; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 172 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 173 | aystar->num_neighbours = 0; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 174 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 175 | // Go through all surrounding tiles and check if they are within the limits | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 176 |    	for (i=0;i<4;i++) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 177 | if (GET_TILE_X(_tiles_around[i] + current->path.node.tile) > 1 && GET_TILE_X(_tiles_around[i] + current->path.node.tile) < TILE_X_MAX - 1 && | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 178 |        		GET_TILE_Y(_tiles_around[i] + current->path.node.tile) > 1 && GET_TILE_Y(_tiles_around[i] + current->path.node.tile) < TILE_Y_MAX - 1) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 179 | // We also directly test if the current tile can connect to this tile.. | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 180 | // We do this simply by just building the tile! | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 181 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 182 | // If the next step is a bridge, we have to enter it the right way | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 183 |        		if (!PathFinderInfo->rail_or_road && AI_PATHFINDER_IS_ROAD(current->path.node.tile + _tiles_around[i])) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 184 |        			if (IS_TILETYPE(current->path.node.tile + _tiles_around[i], MP_TUNNELBRIDGE)) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 185 | // An existing bridge... let's test the direction ;) | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 186 | if ((_map5[current->path.node.tile + _tiles_around[i]] & 1) != (i & 1)) continue; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 187 | // This problem only is valid for tunnels: | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 188 | // When the last tile was not yet a tunnel, check if we enter from the right side.. | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 189 |        				if (!IS_TILETYPE(current->path.node.tile, MP_TUNNELBRIDGE) && (_map5[current->path.node.tile + _tiles_around[i]] & 0x80) == 0) {
 | 
| 145 | 190 | if (i != (_map5[current->path.node.tile + _tiles_around[i]] & 3)) continue; | 
| 110 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 191 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 192 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 193 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 194 | // But also if we are on a bridge, we can only move a certain direction | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 195 |        		if (!PathFinderInfo->rail_or_road && AI_PATHFINDER_IS_ROAD(current->path.node.tile)) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 196 |        			if (IS_TILETYPE(current->path.node.tile, MP_TUNNELBRIDGE)) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 197 | // An existing bridge/tunnel... let's test the direction ;) | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 198 | if ((_map5[current->path.node.tile] & 1) != (i & 1)) continue; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 199 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 200 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 201 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 202 | if ((AI_PATHFINDER_FLAG_BRIDGE & current->path.node.user_data[0]) != 0 || | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 203 |        			(AI_PATHFINDER_FLAG_TUNNEL & current->path.node.user_data[0]) != 0) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 204 | // We are a bridge/tunnel, how cool!! | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 205 | // This means we can only point forward.. get the direction from the user_data | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 206 | if (i != (current->path.node.user_data[0] >> 8)) continue; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 207 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 208 | dir = 0; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 209 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 210 | // First, check if we have a parent | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 211 |        		if (current->path.parent == NULL && current->path.node.user_data[0] == 0) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 212 | // If not, this means we are at the starting station | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 213 |        			if (PathFinderInfo->start_direction != AI_PATHFINDER_NO_DIRECTION) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 214 | // We do need a direction? | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 215 | if (AiNew_GetDirection(current->path.node.tile, current->path.node.tile + _tiles_around[i]) != PathFinderInfo->start_direction) | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 216 | // We are not pointing the right way, invalid tile | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 217 | continue; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 218 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 219 |        		} else if (current->path.node.user_data[0] == 0) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 220 |        			if (PathFinderInfo->rail_or_road) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 221 | // Rail check | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 222 | dir = AiNew_GetRailDirection(current->path.parent->node.tile, current->path.node.tile, current->path.node.tile + _tiles_around[i]); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 223 | r = DoCommandByTile(current->path.node.tile, 0, dir, DC_AUTO | DC_NO_WATER, CMD_BUILD_SINGLE_RAIL); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 224 | if (r == CMD_ERROR) continue; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 225 | #ifdef AI_PATHFINDER_NO_90DEGREES_TURN | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 226 |        				if (current->path.parent->parent != NULL) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 227 | // Check if we don't make a 90degree curve | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 228 | int dir1 = AiNew_GetRailDirection(current->path.parent->parent->node.tile, current->path.parent->node.tile, current->path.node.tile); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 229 |        					if (_illegal_curves[dir1] == dir || _illegal_curves[dir] == dir1) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 230 | continue; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 231 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 232 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 233 | #endif | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 234 |        			} else {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 235 | // Road check | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 236 | dir = AiNew_GetRoadDirection(current->path.parent->node.tile, current->path.node.tile, current->path.node.tile + _tiles_around[i]); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 237 |        				if (AI_PATHFINDER_IS_ROAD(current->path.node.tile)) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 238 |        					if (IS_TILETYPE(current->path.node.tile, MP_TUNNELBRIDGE)) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 239 | // We have a bridge, how nicely! We should mark it... | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 240 | dir = 0; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 241 |        					} else {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 242 | // It already has road.. check if we miss any bits! | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 243 | 	       					if ((_map5[current->path.node.tile] & dir) != dir) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 244 | // We do miss some pieces :( | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 245 | dir &= ~_map5[current->path.node.tile]; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 246 | 	       					} else {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 247 | dir = 0; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 248 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 249 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 250 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 251 | // Only destruct things if it is MP_CLEAR of MP_TREES | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 252 |        				if (dir != 0) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 253 | r = DoCommandByTile(current->path.node.tile, dir, 0, DC_AUTO | DC_NO_WATER, CMD_BUILD_ROAD); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 254 | if (r == CMD_ERROR) continue; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 255 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 256 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 257 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 258 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 259 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 260 | // The tile can be connected | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 261 | aystar->neighbours[aystar->num_neighbours].tile = _tiles_around[i] + current->path.node.tile; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 262 | aystar->neighbours[aystar->num_neighbours].user_data[0] = 0; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 263 | aystar->neighbours[aystar->num_neighbours++].direction = 0; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 264 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 265 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 266 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 267 | // Next step, check for bridges and tunnels | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 268 |     if (current->path.parent != NULL && current->path.node.user_data[0] == 0) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 269 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 270 | TileInfo ti; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 271 | // First we get the dir from this tile and his parent | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 272 | int dir = AiNew_GetDirection(current->path.parent->node.tile, current->path.node.tile); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 273 | // It means we can only walk with the track, so the bridge has to be in the same direction | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 274 | TileIndex tile = current->path.node.tile; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 275 | TileIndex new_tile = tile; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 276 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 277 | FindLandscapeHeightByTile(&ti, tile); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 278 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 279 | // Bridges can only be build on land that is not flat | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 280 | // And if there is a road or rail blocking | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 281 | if (ti.tileh != 0 || | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 282 | (PathFinderInfo->rail_or_road && IS_TILETYPE(tile + _tiles_around[dir], MP_STREET)) || | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 283 |        		(!PathFinderInfo->rail_or_road && IS_TILETYPE(tile + _tiles_around[dir], MP_RAILWAY))) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 284 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 285 |     		for (;;) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 286 | new_tile += _tiles_around[dir]; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 287 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 288 | // Precheck, is the length allowed? | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 289 | if (!CheckBridge_Stuff(0,GetBridgeLength(tile, new_tile))) break; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 290 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 291 | // Check if we hit the station-tile.. we don't like that! | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 292 | if (TILES_BETWEEN(new_tile,PathFinderInfo->end_tile_tl,PathFinderInfo->end_tile_br)) break; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 293 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 294 | // Try building the bridge.. | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 295 | r = DoCommandByTile(tile, new_tile, (0<<8) + (MAX_BRIDGES / 2), DC_AUTO, CMD_BUILD_BRIDGE); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 296 | if (r == CMD_ERROR) continue; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 297 | // We can build a bridge here.. add him to the neighbours | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 298 | aystar->neighbours[aystar->num_neighbours].tile = new_tile; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 299 | aystar->neighbours[aystar->num_neighbours].user_data[0] = AI_PATHFINDER_FLAG_BRIDGE + (dir << 8); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 300 | aystar->neighbours[aystar->num_neighbours++].direction = 0; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 301 | // We can only have 12 neighbours, and we need 1 left for tunnels | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 302 | if (aystar->num_neighbours == 11) break; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 303 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 304 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 305 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 306 | // Next, check for tunnels! | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 307 | // Tunnels can only be build with tileh of 3, 6, 9 or 12, depending on the direction | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 308 | // For now, we check both sides for this tile.. terraforming gives fuzzy result | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 309 | if ((dir == 0 && ti.tileh == 12) || | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 310 | (dir == 1 && ti.tileh == 6) || | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 311 | (dir == 2 && ti.tileh == 3) || | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 312 |     		(dir == 3 && ti.tileh == 9)) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 313 | // Now simply check if a tunnel can be build | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 314 | r = DoCommandByTile(tile, (PathFinderInfo->rail_or_road?0:0x200), 0, DC_AUTO, CMD_BUILD_TUNNEL); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 315 | FindLandscapeHeightByTile(&ti, _build_tunnel_endtile); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 316 |     		if (r != CMD_ERROR && (ti.tileh == 3 || ti.tileh == 6 || ti.tileh == 9 || ti.tileh == 12)) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 317 | aystar->neighbours[aystar->num_neighbours].tile = _build_tunnel_endtile; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 318 | aystar->neighbours[aystar->num_neighbours].user_data[0] = AI_PATHFINDER_FLAG_TUNNEL + (dir << 8); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 319 | aystar->neighbours[aystar->num_neighbours++].direction = 0; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 320 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 321 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 322 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 323 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 324 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 325 | extern uint GetRailFoundation(uint tileh, uint bits); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 326 | extern uint GetRoadFoundation(uint tileh, uint bits); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 327 | extern uint GetBridgeFoundation(uint tileh, byte direction); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 328 | enum {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 329 | BRIDGE_NO_FOUNDATION = 1 << 0 | 1 << 3 | 1 << 6 | 1 << 9 | 1 << 12, | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 330 | }; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 331 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 332 | // The most important function: it calculates the g-value | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 333 | static int32 AyStar_AiPathFinder_CalculateG(AyStar *aystar, AyStarNode *current, OpenListNode *parent) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 334 | Ai_PathFinderInfo *PathFinderInfo = (Ai_PathFinderInfo*)aystar->user_target; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 335 | int r, res = 0; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 336 | TileInfo ti, parent_ti; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 337 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 338 | // Gather some information about the tile.. | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 339 | FindLandscapeHeightByTile(&ti, current->tile); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 340 | FindLandscapeHeightByTile(&parent_ti, parent->path.node.tile); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 341 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 342 | // Check if we hit the end-tile | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 343 | 	if (TILES_BETWEEN(current->tile,PathFinderInfo->end_tile_tl,PathFinderInfo->end_tile_br)) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 344 | // We are at the end-tile, check if we had a direction or something... | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 345 | if (PathFinderInfo->end_direction != AI_PATHFINDER_NO_DIRECTION && AiNew_GetDirection(current->tile, parent->path.node.tile) != PathFinderInfo->end_direction) | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 346 | // We are not pointing the right way, invalid tile | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 347 | return AYSTAR_INVALID_NODE; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 348 | // If it was valid, drop out.. we don't build on the endtile | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 349 | return 0; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 350 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 351 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 352 | // Give everything a small penalty | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 353 | res += AI_PATHFINDER_PENALTY; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 354 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 355 | 	if (!PathFinderInfo->rail_or_road) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 356 | // Road has the lovely advantage it can use other road... check if | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 357 | // the current tile is road, and if so, give a good bonus | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 358 | 		if (AI_PATHFINDER_IS_ROAD(current->tile)) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 359 | res -= AI_PATHFINDER_ROAD_ALREADY_EXISTS_BONUS; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 360 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 361 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 362 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 363 | // We should give a penalty when the tile is going up or down.. this is one way to do so! | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 364 | // Too bad we have to count it from the parent.. but that is not so bad | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 365 | 	if (parent_ti.tileh != 0 && parent->path.parent != NULL) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 366 | // Skip if the tile was from a bridge or tunnel | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 367 | 		if (parent->path.node.user_data[0] == 0 && current->user_data[0] == 0) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 368 | 			if (PathFinderInfo->rail_or_road) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 369 | r = GetRailFoundation(parent_ti.tileh, 1 << AiNew_GetRailDirection(parent->path.parent->node.tile, parent->path.node.tile, current->tile)); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 370 | // Maybe is BRIDGE_NO_FOUNDATION a bit strange here, but it contains just the right information.. | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 371 | 				if (r >= 15 || (r == 0 && (BRIDGE_NO_FOUNDATION & (1 << ti.tileh)))) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 372 | res += AI_PATHFINDER_TILE_GOES_UP_PENALTY; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 373 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 374 | 			} else {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 375 | 				if (!(AI_PATHFINDER_IS_ROAD(parent->path.node.tile) && IS_TILETYPE(parent->path.node.tile, MP_TUNNELBRIDGE))) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 376 | r = GetRoadFoundation(parent_ti.tileh, AiNew_GetRoadDirection(parent->path.parent->node.tile, parent->path.node.tile, current->tile)); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 377 | if (r >= 15 || r == 0) | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 378 | res += AI_PATHFINDER_TILE_GOES_UP_PENALTY; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 379 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 380 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 381 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 382 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 383 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 384 | // Are we part of a tunnel? | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 385 | 	if ((AI_PATHFINDER_FLAG_TUNNEL & current->user_data[0]) != 0) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 386 | // Tunnels are very expensive when build on long routes.. | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 387 | // Ironicly, we are using BridgeCode here ;) | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 388 | r = AI_PATHFINDER_TUNNEL_PENALTY * GetBridgeLength(current->tile, parent->path.node.tile); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 389 | res += r + (r >> 8); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 390 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 391 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 392 | // Are we part of a bridge? | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 393 | 	if ((AI_PATHFINDER_FLAG_BRIDGE & current->user_data[0]) != 0) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 394 | // That means for every length a penalty | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 395 | res += AI_PATHFINDER_BRIDGE_PENALTY * GetBridgeLength(current->tile, parent->path.node.tile); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 396 | // Check if we are going up or down, first for the starting point | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 397 | // In user_data[0] is at the 8th bit the direction | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 398 | 		if (!(BRIDGE_NO_FOUNDATION & (1 << parent_ti.tileh))) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 399 | if (GetBridgeFoundation(parent_ti.tileh, (current->user_data[0] >> 8) & 1) < 15) | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 400 | res += AI_PATHFINDER_BRIDGE_GOES_UP_PENALTY; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 401 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 402 | // Second for the end point | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 403 | 		if (!(BRIDGE_NO_FOUNDATION & (1 << ti.tileh))) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 404 | if (GetBridgeFoundation(ti.tileh, (current->user_data[0] >> 8) & 1) < 15) | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 405 | res += AI_PATHFINDER_BRIDGE_GOES_UP_PENALTY; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 406 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 407 | if (parent_ti.tileh == 0) | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 408 | res += AI_PATHFINDER_BRIDGE_GOES_UP_PENALTY; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 409 | if (ti.tileh == 0) | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 410 | res += AI_PATHFINDER_BRIDGE_GOES_UP_PENALTY; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 411 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 412 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 413 | // To prevent the AI from taking the fastest way in tiles, but not the fastest way | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 414 | // in speed, we have to give a good penalty to direction changing | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 415 | // This way, we get almost the fastest way in tiles, and a very good speed on the track | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 416 | 	if (!PathFinderInfo->rail_or_road) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 417 | if (parent->path.parent != NULL && | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 418 | 			AiNew_GetDirection(current->tile, parent->path.node.tile) != AiNew_GetDirection(parent->path.node.tile, parent->path.parent->node.tile)) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 419 | // When road exists, we don't like turning, but its free, so don't be to piggy about it | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 420 | if (AI_PATHFINDER_IS_ROAD(parent->path.node.tile)) | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 421 | res += AI_PATHFINDER_DIRECTION_CHANGE_ON_EXISTING_ROAD_PENALTY; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 422 | else | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 423 | res += AI_PATHFINDER_DIRECTION_CHANGE_PENALTY; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 424 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 425 | 	} else {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 426 | // For rail we have 1 exeption: diagonal rail.. | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 427 | // So we fetch 2 raildirection. That of the current one, and of the one before that | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 428 | 		if (parent->path.parent != NULL && parent->path.parent->parent != NULL) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 429 | int dir1 = AiNew_GetRailDirection(parent->path.parent->node.tile, parent->path.node.tile, current->tile); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 430 | int dir2 = AiNew_GetRailDirection(parent->path.parent->parent->node.tile, parent->path.parent->node.tile, parent->path.node.tile); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 431 | // First, see if we are on diagonal path, that is better then straight path | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 432 | 			if (dir1 > 1) { res -= AI_PATHFINDER_DIAGONAL_BONUS; }
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 433 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 434 | // First see if they are different | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 435 | 			if (dir1 != dir2) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 436 | // dir 2 and 3 are 1 diagonal track, and 4 and 5. | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 437 | 				if (!(((dir1 == 2 || dir1 == 3) && (dir2 == 2 || dir2 == 3)) || ((dir1 == 4 || dir1 == 5) && (dir2 == 4 || dir2 == 5)))) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 438 | // It is not, so we changed of direction | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 439 | res += AI_PATHFINDER_DIRECTION_CHANGE_PENALTY; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 440 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 441 | 				if (parent->path.parent->parent->parent != NULL) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 442 | int dir3 = AiNew_GetRailDirection(parent->path.parent->parent->parent->node.tile, parent->path.parent->parent->node.tile, parent->path.parent->node.tile); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 443 | // Check if we changed 3 tiles of direction in 3 tiles.. bad!!! | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 444 | 					if ((dir1 == 0 || dir1 == 1) && dir2 > 1 && (dir3 == 0 || dir3 == 1)) {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 445 | res += AI_PATHFINDER_CURVE_PENALTY; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 446 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 447 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 448 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 449 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 450 | } | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 451 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 452 | // Res should never be below zero.. if so, make it zero! | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 453 | 	if (res < 0) { res = 0; }
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 454 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 455 | // Return our value | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 456 | return res; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
84diff
changeset | 457 | } |