Freeciv-3.1
|
#include <string.h>
#include "log.h"
#include "mem.h"
#include "game.h"
#include "map.h"
#include "movement.h"
#include "packets.h"
#include "pf_tools.h"
#include "road.h"
#include "unit.h"
#include "unitlist.h"
#include "client_main.h"
#include "control.h"
#include "mapview_g.h"
#include "goto.h"
#include "mapctrl_common.h"
#include "speclist.h"
Go to the source code of this file.
Data Structures | |
struct | part |
struct | goto_map |
Macros | |
#define | LOG_GOTO_PATH LOG_DEBUG |
#define | log_goto_path log_debug |
#define | log_goto_packet log_debug |
#define | SPECLIST_TAG goto_map |
#define | SPECLIST_TYPE struct goto_map |
#define | goto_map_list_iterate(gotolist, pgoto) TYPED_LIST_ITERATE(struct goto_map, gotolist, pgoto) |
#define | goto_map_list_iterate_end LIST_ITERATE_END |
#define | goto_map_unit_iterate(gotolist, pgoto, punit) |
#define | goto_map_unit_iterate_end } goto_map_list_iterate_end; |
Functions | |
static void | reset_last_part (struct goto_map *goto_map) |
static void | remove_last_part (struct goto_map *goto_map) |
static void | fill_parameter_part (struct pf_parameter *param, const struct goto_map *goto_map, const struct part *p) |
static struct goto_map * | goto_map_new (struct unit *punit) |
static void | goto_map_free (struct goto_map *goto_map) |
static struct unit * | goto_map_unit (const struct goto_map *goto_map) |
void | init_client_goto (void) |
void | free_client_goto (void) |
bool | is_valid_goto_destination (const struct tile *ptile) |
static void | goto_path_redraw (const struct pf_path *new_path, const struct pf_path *old_path) |
static void | goto_path_undraw (const struct pf_path *path) |
static bool | update_last_part (struct goto_map *goto_map, struct tile *ptile) |
static void | add_part (struct goto_map *goto_map) |
bool | goto_add_waypoint (void) |
bool | goto_pop_waypoint (void) |
static unsigned | get_EC (const struct tile *ptile, enum known_type known, const struct pf_parameter *param) |
static enum tile_behavior | get_TB_aggr (const struct tile *ptile, enum known_type known, const struct pf_parameter *param) |
static enum tile_behavior | get_TB_caravan (const struct tile *ptile, enum known_type known, const struct pf_parameter *param) |
static int | get_activity_time (const struct tile *ptile, const struct player *pplayer) |
static bool | is_non_allied_city_adjacent (const struct player *pplayer, const struct tile *ptile) |
static int | get_connect_road (const struct tile *src_tile, enum direction8 dir, const struct tile *dest_tile, int src_cost, int src_extra, unsigned *dest_cost, unsigned *dest_extra, const struct pf_parameter *param) |
static int | get_connect_irrig (const struct tile *src_tile, enum direction8 dir, const struct tile *dest_tile, int src_cost, int src_extra, unsigned *dest_cost, unsigned *dest_extra, const struct pf_parameter *param) |
static enum tile_behavior | no_fights_or_unknown_goto (const struct tile *ptile, enum known_type known, const struct pf_parameter *p) |
static void | goto_fill_parameter_base (struct pf_parameter *parameter, const struct unit *punit) |
static void | goto_fill_parameter_full (struct goto_map *goto_map, const struct unit *punit) |
void | enter_goto_state (struct unit_list *punits) |
void | exit_goto_state (void) |
void | goto_unit_killed (struct unit *punit) |
bool | goto_is_active (void) |
bool | goto_get_turns (int *min, int *max) |
bool | goto_tile_state (const struct tile *ptile, enum goto_tile_state *state, int *turns, bool *waypoint) |
bool | is_valid_goto_draw_line (struct tile *dest_tile) |
void | request_orders_cleared (struct unit *punit) |
static void | make_path_orders (struct unit *punit, struct pf_path *path, enum unit_orders orders, struct unit_order *final_order, struct unit_order *order_list, int *length, int *dest_tile) |
static void | send_path_orders (struct unit *punit, struct pf_path *path, bool repeat, bool vigilant, enum unit_orders orders, struct unit_order *final_order) |
static void | send_rally_path_orders (struct city *pcity, struct unit *punit, struct pf_path *path, bool vigilant, bool persistent, enum unit_orders orders, struct unit_order *final_order) |
void | send_goto_path (struct unit *punit, struct pf_path *path, struct unit_order *final_order) |
static void | send_rally_path (struct city *pcity, struct unit *punit, bool persistent, struct pf_path *path, struct unit_order *final_order) |
bool | send_goto_tile (struct unit *punit, struct tile *ptile) |
bool | send_rally_tile (struct city *pcity, struct tile *ptile, bool persistent) |
bool | send_attack_tile (struct unit *punit, struct tile *ptile) |
void | send_patrol_route (void) |
static bool | order_recursive_roads (struct tile *ptile, struct extra_type *pextra, struct packet_unit_orders *p, int rec) |
void | send_connect_route (enum unit_activity activity, struct extra_type *tgt) |
static bool | order_wants_direction (enum unit_orders order, action_id act_id, struct tile *tgt_tile) |
static bool | order_demands_direction (enum unit_orders order, action_id act_id) |
void | send_goto_route (void) |
struct pf_path * | path_to_nearest_allied_city (struct unit *punit) |
struct tile * | tile_before_end_path (struct unit *punit, struct tile *ptile) |
Variables | |
static struct goto_map_list * | goto_maps = NULL |
static bool | goto_warned = FALSE |
static struct tile * | goto_destination = NULL |
#define goto_map_list_iterate | ( | gotolist, | |
pgoto | |||
) | TYPED_LIST_ITERATE(struct goto_map, gotolist, pgoto) |
#define goto_map_list_iterate_end LIST_ITERATE_END |
#define goto_map_unit_iterate | ( | gotolist, | |
pgoto, | |||
punit | |||
) |
#define goto_map_unit_iterate_end } goto_map_list_iterate_end; |
|
static |
Add a part. Depending on the num of already existing parts the start of the new part is either the unit position (for the first part) or the destination of the last part (not the first part).
Definition at line 438 of file goto.c.
Referenced by enter_goto_state(), and goto_add_waypoint().
void enter_goto_state | ( | struct unit_list * | punits | ) |
Enter the goto state: activate, prepare PF-template and add the initial part.
Definition at line 998 of file goto.c.
Referenced by patrol_here_callback(), request_unit_connect(), request_unit_goto(), request_unit_patrol(), and mr_menu::slot_delayed_goto().
void exit_goto_state | ( | void | ) |
Tidy up and deactivate goto state.
Definition at line 1019 of file goto.c.
Referenced by paradrop_here_callback(), patrol_here_callback(), set_hover_state(), and map_view::shortcut_pressed().
|
static |
Fill pathfinding parameter for adding a new part.
Definition at line 407 of file goto.c.
Referenced by add_part(), and update_last_part().
void free_client_goto | ( | void | ) |
Called above, and by control_done() in client/control.c.
Definition at line 162 of file goto.c.
Referenced by control_free(), and init_client_goto().
Return the number of MP needed to do the connect activity at this position. A negative number means it's impossible.
Definition at line 611 of file goto.c.
Referenced by get_connect_irrig(), get_connect_road(), goto_fill_parameter_full(), goto_get_turns(), and goto_tile_state().
|
static |
PF jumbo callback for the cost of a connect by irrigation. Here we are only interested in how long it will take to irrigate the path.
param->data should contain the result of get_activity_rate(punit) / 10.
Definition at line 798 of file goto.c.
Referenced by goto_fill_parameter_full().
|
static |
PF jumbo callback for the cost of a connect by road. In road-connect mode we are concerned with (1) the number of steps of the resulting path (2) (the tie-breaker) time to build the path (travel plus activity time). In rail-connect the priorities are reversed.
param->data should contain the result of get_activity_rate(punit).
Definition at line 688 of file goto.c.
Referenced by goto_fill_parameter_full().
|
static |
PF callback to get the path with the minimal number of steps (out of all shortest paths).
Definition at line 555 of file goto.c.
Referenced by goto_fill_parameter_base().
|
static |
PF callback to prohibit going into the unknown. Also makes sure we don't plan our route through enemy city/tile.
Definition at line 565 of file goto.c.
Referenced by goto_fill_parameter_base().
|
static |
PF callback for caravans. Caravans doesn't go into the unknown and don't attack enemy units but enter enemy cities.
Definition at line 585 of file goto.c.
Referenced by goto_fill_parameter_base().
bool goto_add_waypoint | ( | void | ) |
Inserts a waypoint at the end of the current goto line.
Definition at line 487 of file goto.c.
Referenced by request_unit_connect(), request_unit_goto(), and request_unit_patrol().
|
static |
Fill the PF parameter with the correct client-goto values. See also goto_fill_parameter_full().
Definition at line 888 of file goto.c.
Referenced by goto_fill_parameter_full(), path_to_nearest_allied_city(), send_attack_tile(), send_goto_tile(), send_rally_tile(), and tile_before_end_path().
|
static |
Fill the PF parameter with the correct client-goto values. The storage behind "connect_speed" must remain valid for the lifetime of the pf_map.
Note that you must call this function only if the 'hover_state' is set, and we are in goto mode (usually, this function is only called from enter_goto_state()).
See also goto_fill_parameter_base().
Definition at line 921 of file goto.c.
Referenced by enter_goto_state().
bool goto_get_turns | ( | int * | min, |
int * | max | ||
) |
Return the path length (in turns). WARNING: not useful for determining paths of scattered groups.
Definition at line 1065 of file goto.c.
Referenced by get_unit_info_label_text2().
bool goto_is_active | ( | void | ) |
Is goto state active?
Definition at line 1056 of file goto.c.
Referenced by do_unit_goto(), enter_goto_state(), exit_goto_state(), fill_sprite_array(), goto_add_waypoint(), goto_fill_parameter_full(), goto_get_turns(), goto_pop_waypoint(), goto_tile_state(), goto_unit_killed(), is_valid_goto_draw_line(), request_unit_connect(), request_unit_goto(), request_unit_patrol(), send_connect_route(), send_goto_route(), send_patrol_route(), map_view::shortcut_pressed(), map_view::shortcut_released(), and unit_actions::update_actions().
|
static |
Free an existing goto map.
Definition at line 122 of file goto.c.
Referenced by exit_goto_state(), free_client_goto(), and goto_unit_killed().
Returns the unit associated with the goto map.
Definition at line 139 of file goto.c.
Referenced by add_part(), and fill_parameter_part().
|
static |
bool goto_pop_waypoint | ( | void | ) |
Returns whether there were any waypoint popped (we don't remove the initial position)
Definition at line 524 of file goto.c.
Referenced by key_cancel_action().
bool goto_tile_state | ( | const struct tile * | ptile, |
enum goto_tile_state * | state, | ||
int * | turns, | ||
bool * | waypoint | ||
) |
void goto_unit_killed | ( | struct unit * | punit | ) |
Called from control_unit_killed() in client/control.c
Definition at line 1037 of file goto.c.
Referenced by control_unit_killed().
void init_client_goto | ( | void | ) |
Called only by handle_map_info() in client/packhand.c.
Definition at line 152 of file goto.c.
Referenced by handle_map_info().
|
static |
When building a road or a railroad, we don't want to go next to nonallied cities
Definition at line 667 of file goto.c.
Referenced by get_connect_irrig(), and get_connect_road().
Determines if a goto to the destination tile is allowed.
Definition at line 179 of file goto.c.
Referenced by control_mouse_cursor().
Puts a line to dest_tile on the map according to the current goto_map. If there is no route to the dest then don't draw anything.
Definition at line 1335 of file goto.c.
Referenced by do_unit_connect(), do_unit_goto(), do_unit_patrol_to(), overview_update_line(), and update_line().
|
static |
Creates orders for a path as a goto or patrol route.
Definition at line 1383 of file goto.c.
Referenced by send_path_orders(), and send_rally_path_orders().
|
static |
PF callback to prohibit going into the unknown (conditionally). Also makes sure we don't plan to attack anyone.
Definition at line 872 of file goto.c.
Referenced by goto_fill_parameter_base().
|
static |
Returns TRUE if it is certain that the order must be performed from an adjacent tile.
Definition at line 1845 of file goto.c.
Referenced by send_goto_route().
|
static |
Fill orders to build recursive roads.
Definition at line 1674 of file goto.c.
Referenced by order_recursive_roads(), and send_connect_route().
|
static |
Returns TRUE if the order preferably should be performed from an adjacent tile.
This function doesn't care if a direction is required or just possible. Use order_demands_direction() for that.
Definition at line 1800 of file goto.c.
Referenced by send_goto_route().
Find the path to the nearest (fastest to reach) allied city for the unit, or NULL if none is reachable.
Definition at line 1983 of file goto.c.
Referenced by request_unit_return().
|
static |
Remove the last part, erasing the corresponding path segment.
Definition at line 469 of file goto.c.
Referenced by goto_map_free(), and goto_pop_waypoint().
void request_orders_cleared | ( | struct unit * | punit | ) |
Send a packet to the server to request that the current orders be cleared.
Definition at line 1360 of file goto.c.
Referenced by clear_unit_orders().
|
static |
Change the drawn path to a size of 0 steps by setting it to the start position.
Definition at line 394 of file goto.c.
Referenced by remove_last_part(), and update_last_part().
Send orders for the unit to move it to the arbitrary tile and attack everything it approaches. Returns FALSE if no path is found.
Definition at line 1621 of file goto.c.
Referenced by mr_menu::slot_execute_orders().
void send_connect_route | ( | enum unit_activity | activity, |
struct extra_type * | tgt | ||
) |
Send the current connect route (i.e., the one generated via HOVER_STATE) to the server.
Definition at line 1713 of file goto.c.
Referenced by do_unit_connect().
void send_goto_path | ( | struct unit * | punit, |
struct pf_path * | path, | ||
struct unit_order * | final_order | ||
) |
Send an arbitrary goto path for the unit to the server.
Definition at line 1530 of file goto.c.
Referenced by request_unit_return(), send_goto_route(), and send_goto_tile().
void send_goto_route | ( | void | ) |
Send the current goto route (i.e., the one generated via HOVER_STATE) to the server. The route might involve more than one part, if waypoints were used. FIXME: danger paths are not supported.
Definition at line 1870 of file goto.c.
Referenced by do_unit_goto(), and key_unit_action_select_tgt().
Send orders for the unit to move it to the arbitrary tile. Returns FALSE if no path is found.
Definition at line 1551 of file goto.c.
Referenced by goto_dialog::go_to_city(), goto_city_callback(), goto_cmd_callback(), goto_here_callback(), and mr_menu::slot_autocaravan().
|
static |
Send a path as a goto or patrol route to the server.
Definition at line 1472 of file goto.c.
Referenced by send_attack_tile(), send_goto_path(), and send_patrol_route().
void send_patrol_route | ( | void | ) |
Send the current patrol route (i.e., the one generated via HOVER_STATE) to the server.
Definition at line 1647 of file goto.c.
Referenced by do_unit_patrol_to().
|
static |
Send an arbitrary rally path for the city to the server.
Definition at line 1539 of file goto.c.
Referenced by send_rally_tile().
|
static |
Send a path as a goto or patrol rally orders to the server.
Definition at line 1504 of file goto.c.
Referenced by send_rally_path().
Send rally orders for the city to move new units to the arbitrary tile. Returns FALSE if no path is found for the currently produced unit type.
Definition at line 1575 of file goto.c.
Referenced by rally_set_tile(), and map_view::shortcut_pressed().
Finds penultimate tile on path for given unit going to ptile
Definition at line 2012 of file goto.c.
Referenced by mr_menu::find_last_unit_pos().
Change the destination of the last part to the given location. If a path cannot be found, the destination is set to the start. Return TRUE when the new path is valid.
Definition at line 258 of file goto.c.
Referenced by goto_pop_waypoint(), is_valid_goto_draw_line(), and reset_last_part().
|
static |
Definition at line 103 of file goto.c.
Referenced by exit_goto_state(), free_client_goto(), goto_add_waypoint(), goto_get_turns(), goto_tile_state(), is_valid_goto_destination(), and is_valid_goto_draw_line().
|
static |
Definition at line 91 of file goto.c.
Referenced by enter_goto_state(), exit_goto_state(), free_client_goto(), goto_add_waypoint(), goto_get_turns(), goto_is_active(), goto_pop_waypoint(), goto_tile_state(), goto_unit_killed(), init_client_goto(), is_valid_goto_draw_line(), send_connect_route(), send_goto_route(), and send_patrol_route().
Definition at line 92 of file goto.c.
Referenced by enter_goto_state(), exit_goto_state(), free_client_goto(), and update_last_part().