Freeciv-3.1
|
#include <stdarg.h>
#include "bitvector.h"
#include "fcintl.h"
#include "log.h"
#include "mem.h"
#include "rand.h"
#include "shared.h"
#include "support.h"
#include "citizens.h"
#include "culture.h"
#include "diptreaty.h"
#include "government.h"
#include "map.h"
#include "movement.h"
#include "multipliers.h"
#include "nation.h"
#include "packets.h"
#include "player.h"
#include "research.h"
#include "rgbcolor.h"
#include "tech.h"
#include "unitlist.h"
#include "luascript_types.h"
#include "aiiface.h"
#include "barbarian.h"
#include "citytools.h"
#include "cityturn.h"
#include "connecthand.h"
#include "diplhand.h"
#include "gamehand.h"
#include "maphand.h"
#include "mood.h"
#include "notify.h"
#include "plrhand.h"
#include "sernet.h"
#include "srv_main.h"
#include "stdinhand.h"
#include "spaceship.h"
#include "spacerace.h"
#include "techtools.h"
#include "unittools.h"
#include "voting.h"
#include "advdata.h"
#include "autosettlers.h"
#include "script_server.h"
#include "aitraits.h"
#include "difficulty.h"
#include "handicaps.h"
Go to the source code of this file.
Functions | |
static void | package_player_common (struct player *plr, struct packet_player_info *packet, struct packet_web_player_info_addition *web_packet) |
static void | package_player_diplstate (struct player *plr1, struct player *plr2, struct packet_player_diplstate *packet_ds, struct player *receiver, enum plr_info_level min_info_level) |
static void | package_player_info (struct player *plr, struct packet_player_info *packet, struct packet_web_player_info_addition *web_packet, struct player *receiver, enum plr_info_level min_info_level) |
static enum plr_info_level | player_info_level (struct player *plr, struct player *receiver) |
static void | send_player_remove_info_c (const struct player_slot *pslot, struct conn_list *dest) |
static void | send_player_info_c_real (struct player *src, struct conn_list *dest) |
static void | send_player_diplstate_c_real (struct player *src, struct conn_list *dest) |
static void | send_nation_availability_real (struct conn_list *dest, bool nationset_change) |
void | kill_player (struct player *pplayer) |
static int | get_player_maxrate (struct player *pplayer) |
void | handle_player_rates (struct player *pplayer, int tax, int luxury, int science) |
void | government_change (struct player *pplayer, struct government *gov, bool revolution_finished) |
static int | revolentype_length (enum revolen_type rltype, struct government *gov) |
int | revolution_length (struct government *gov, struct player *plr) |
void | handle_player_change_government (struct player *pplayer, Government_type_id government) |
void | update_revolution (struct player *pplayer) |
void | update_capital (struct player *pplayer) |
void | check_player_max_rates (struct player *pplayer) |
void | update_players_after_alliance_breakup (struct player *pplayer, struct player *pplayer2, const struct unit_list *pplayer_seen_units, const struct unit_list *pplayer2_seen_units) |
static void | maybe_claim_base (struct tile *ptile, struct player *new_owner, struct player *old_owner) |
void | enter_war (struct player *pplayer, struct player *pplayer2) |
void | player_update_last_war_action (struct player *pplayer) |
void | handle_diplomacy_cancel_pact (struct player *pplayer, int other_player_id, enum clause_type clause) |
void | player_info_freeze (void) |
void | player_info_thaw (void) |
void | send_player_all_c (struct player *src, struct conn_list *dest) |
void | send_player_info_c (struct player *src, struct conn_list *dest) |
void | send_player_diplstate_c (struct player *src, struct conn_list *dest) |
struct conn_list * | player_reply_dest (struct player *pplayer) |
static void | call_first_contact (struct player *pplayer, struct player *aplayer) |
void | server_player_init (struct player *pplayer, bool initmap, bool needs_team) |
const struct rgbcolor * | player_preferred_color (struct player *pplayer) |
bool | player_color_changeable (const struct player *pplayer, const char **reason) |
void | assign_player_colors (void) |
void | server_player_set_color (struct player *pplayer, const struct rgbcolor *prgbcolor) |
const char * | player_color_ftstr (struct player *pplayer) |
void | give_midgame_initial_units (struct player *pplayer, struct tile *ptile) |
struct player * | server_create_player (int player_id, const char *ai_tname, struct rgbcolor *prgbcolor, bool allow_ai_type_fallbacking) |
void | server_remove_player (struct player *pplayer) |
void | player_limit_to_max_rates (struct player *pplayer) |
static bool | server_player_name_is_allowed (const struct connection *caller, const struct player *pplayer, const struct nation_type *pnation, const char *name, char *error_buf, size_t error_buf_len) |
bool | server_player_set_name_full (const struct connection *caller, struct player *pplayer, const struct nation_type *pnation, const char *name, char *error_buf, size_t error_buf_len) |
void | server_player_set_name (struct player *pplayer, const char *name) |
static enum diplstate_type | get_default_diplstate (const struct player *pplayer1, const struct player *pplayer2) |
void | make_contact (struct player *pplayer1, struct player *pplayer2, struct tile *ptile) |
void | maybe_make_contact (struct tile *ptile, struct player *pplayer) |
void | shuffle_players (void) |
void | set_shuffled_players (int *shuffled_players) |
struct player * | shuffled_player (int i) |
struct nation_type * | pick_a_nation (const struct nation_list *choices, bool ignore_conflicts, bool needs_startpos, enum barbarian_type barb_type) |
static struct nation_set * | current_nationset (void) |
bool | nation_is_in_current_set (const struct nation_type *pnation) |
void | count_playable_nations (void) |
bool | client_can_pick_nation (const struct nation_type *pnation) |
void | send_nation_availability (struct conn_list *dest, bool nationset_change) |
void | fit_nationset_to_players (void) |
void | reset_all_start_commands (bool plrchange) |
static struct player * | split_player (struct player *pplayer) |
bool | civil_war_possible (struct player *pplayer, bool conquering_city, bool honour_server_option) |
bool | civil_war_triggered (struct player *pplayer) |
struct player * | civil_war (struct player *pplayer) |
void | handle_player_attribute_chunk (struct player *pplayer, const struct packet_player_attribute_chunk *chunk) |
void | handle_player_attribute_block (struct player *pplayer) |
void | handle_player_phase_done (struct player *pplayer, int turn) |
int | barbarian_count (void) |
int | normal_player_count (void) |
void | player_status_add (struct player *plr, enum player_status pstatus) |
bool | player_status_check (struct player *plr, enum player_status pstatus) |
void | player_status_reset (struct player *plr) |
const char * | player_delegation_get (const struct player *pplayer) |
void | player_delegation_set (struct player *pplayer, const char *username) |
bool | player_delegation_active (const struct player *pplayer) |
void | send_delegation_info (const struct connection *pconn) |
struct player * | player_by_user_delegated (const char *name) |
void | playercolor_init (void) |
void | playercolor_free (void) |
void | playercolor_add (struct rgbcolor *prgbcolor) |
struct rgbcolor * | playercolor_get (int id) |
int | playercolor_count (void) |
void | handle_player_multiplier (struct player *pplayer, int count, const int *multipliers) |
void | player_set_to_ai_mode (struct player *pplayer, enum ai_level skill_level) |
void | player_set_under_human_control (struct player *pplayer) |
Variables | |
static int | shuffled_order [MAX_NUM_PLAYER_SLOTS] |
static int | player_info_frozen_level = 0 |
void assign_player_colors | ( | void | ) |
Permanently assign colors to any players that don't already have them. First assign preferred colors, then assign the rest randomly, trying to avoid clashes.
Definition at line 1563 of file plrhand.c.
Referenced by create_animals(), create_barbarian_player(), create_command_newcomer(), handle_edit_player_create(), sg_load_players(), sg_load_players(), split_player(), and srv_ready().
int barbarian_count | ( | void | ) |
Call first_contact function if such is defined for player
Definition at line 1435 of file plrhand.c.
Referenced by make_contact().
void check_player_max_rates | ( | struct player * | pplayer | ) |
The following checks that government rates are acceptable for the present form of government. Has to be called when switching governments or when toggling from AI to human.
Definition at line 657 of file plrhand.c.
Referenced by adv_best_government(), dai_gov_value(), government_change(), handle_player_change_government(), and player_set_under_human_control().
Capturing a nation's primary capital is a devastating blow. This function creates a new AI player, and randomly splits the original players city list into two. Of course this results in a real mix up of territory - but since when have civil wars ever been tidy, or civil.
Embassies: All embassies with other players are lost. Other players retain their embassies with pplayer. Units: Units inside cities are assigned to the new owner of the city. Units outside are transferred along with the ownership of their supporting city. If the units are in a unit stack with non rebel units, then whichever units are nearest an allied city are teleported to that city. If the stack is a transport at sea, then all rebel units on the transport are teleported to their nearest allied city.
Cities: Are split randomly into 2. This results in a real mix up of teritory - but since when have civil wars ever been tidy, or for any matter civil?
One caveat, since the spliting of cities is random, you can conceive that this could result in either the original player or the rebel getting 0 cities. To prevent this, the hack below ensures that each side gets roughly half, which ones is still determined randomly.
Definition at line 2835 of file plrhand.c.
Referenced by api_edit_civil_war(), kill_player(), unit_conquer_city(), and unit_do_destroy_city().
bool civil_war_possible | ( | struct player * | pplayer, |
bool | conquering_city, | ||
bool | honour_server_option | ||
) |
Check if civil war is possible for a player. If conquering_city is TRUE, one of the cities currently in the empire will shortly not be and shouldn't be considered. honour_server_option controls whether we honour the 'civilwarsize' server option. (If we don't, we still enforce a minimum empire size, to avoid the risk of creating a new player with no cities.)
Definition at line 2738 of file plrhand.c.
Referenced by api_edit_civil_war(), unit_conquer_city(), and unit_do_destroy_city().
civil_war_triggered: The capture of a primary capital is not a sure fire way to throw and empire into civil war. Some governments are more susceptible than others, here are the base probabilities: Anarchy 90% Despotism 80% Monarchy 70% Fundamentalism 60% (Only in civ2 ruleset) Communism 50% Republic 40% Democracy 30% In addition each city in disorder adds and each celebrating city subtracts from the probability of a civil war. If you have at least 1 turns notice of the impending loss of your capital, you can hike luxuries up to the highest value, and by this reduce the chance of a civil war. In fact by hiking the luxuries to 100% under Democracy, it is easy to get massively negative numbers - guaranteeing imunity from civil war. Likewise, 3 cities in disorder under despotism guarantees a civil war. This routine calculates these probabilities and returns true if a civil war is triggered.
Definition at line 2785 of file plrhand.c.
Referenced by api_edit_civil_war(), unit_conquer_city(), and unit_do_destroy_city().
bool client_can_pick_nation | ( | const struct nation_type * | pnation | ) |
Return whether a nation is "pickable" – whether players can select it at game start. (is_nation_pickable() is the equivalent function on the client.)
Definition at line 2443 of file plrhand.c.
Referenced by generate_players(), handle_nation_select_req(), playernation_command(), and send_nation_availability_real().
void count_playable_nations | ( | void | ) |
Update the server's cached number of playable nations. Call when the nationset changes.
Definition at line 2428 of file plrhand.c.
Referenced by fit_nationset_to_players(), load_ruleset_nations(), and nationset_action().
|
static |
Return the nationset currently in effect.
Definition at line 2410 of file plrhand.c.
Referenced by fit_nationset_to_players(), and nation_is_in_current_set().
Two players enter war.
Definition at line 729 of file plrhand.c.
Referenced by handle_diplomacy_cancel_pact(), and update_diplomatics().
void fit_nationset_to_players | ( | void | ) |
Try to select a nation set that fits the current players' nations, or failing that, unset the nations of some of the players.
Does not update clients, as is assumed to be called during game setup, and to be followed by sending full game info to clients.
Definition at line 2488 of file plrhand.c.
Referenced by sg_load_players(), and sg_load_players().
|
static |
Returns the default diplomatic state between 2 players.
Mainly, this returns DS_WAR, but it can also return DS_PEACE if both players are allied with the same third player.
Definition at line 2114 of file plrhand.c.
Referenced by make_contact().
|
static |
Return player maxrate in legal range.
Definition at line 269 of file plrhand.c.
Referenced by government_change(), handle_player_rates(), and player_limit_to_max_rates().
Gives units that every player should have. Usually called for players created midgame.
Definition at line 1699 of file plrhand.c.
Referenced by civil_war().
void government_change | ( | struct player * | pplayer, |
struct government * | gov, | ||
bool | revolution_finished | ||
) |
Finish the revolution and set the player's government. Call this as soon as the player has set a target_government and the revolution_finishes turn has arrived.
Definition at line 336 of file plrhand.c.
Referenced by handle_edit_player(), handle_player_change_government(), and update_revolution().
void handle_diplomacy_cancel_pact | ( | struct player * | pplayer, |
int | other_player_id, | ||
enum clause_type | clause | ||
) |
Handles a player cancelling a "pact" with another player.
pplayer | player cancelling the pact |
other_player_id | id of player we want to cancel a pact with |
clause | value indicating what kind of treaty we want to break. If this is CLAUSE_VISION, we break shared vision. Otherwise we break one pact level. |
Definition at line 761 of file plrhand.c.
Referenced by dai_diplomacy_actions(), dai_go_to_war(), handle_diplomacy_cancel_pact(), server_handle_packet(), and update_diplomatics().
void handle_player_attribute_block | ( | struct player * | pplayer | ) |
The client request an attribute block.
Definition at line 2999 of file plrhand.c.
Referenced by server_handle_packet().
void handle_player_attribute_chunk | ( | struct player * | pplayer, |
const struct packet_player_attribute_chunk * | chunk | ||
) |
The client has send as a chunk of the attribute block.
Definition at line 2989 of file plrhand.c.
Referenced by client_handle_packet(), and server_handle_packet().
void handle_player_change_government | ( | struct player * | pplayer, |
Government_type_id | government | ||
) |
Called by the client or AI to change government.
Definition at line 454 of file plrhand.c.
Referenced by dai_go_to_war(), dai_government_change(), research_tech_lost(), server_handle_packet(), and update_city_activity().
void handle_player_multiplier | ( | struct player * | pplayer, |
int | count, | ||
const int * | multipliers | ||
) |
Sets player's multipliers.
Definition at line 3220 of file plrhand.c.
Referenced by server_handle_packet().
void handle_player_phase_done | ( | struct player * | pplayer, |
int | turn | ||
) |
(Hmm, how should "turn done" work for multi-connected non-observer players?)
Definition at line 3007 of file plrhand.c.
Referenced by server_handle_packet().
void handle_player_rates | ( | struct player * | pplayer, |
int | tax, | ||
int | luxury, | ||
int | science | ||
) |
Handle a client or AI request to change the tax/luxury/science rates. This function does full sanity checking.
Definition at line 285 of file plrhand.c.
Referenced by server_handle_packet().
void kill_player | ( | struct player * | pplayer | ) |
Murder a player in cold blood.
Called from srv_main kill_dying_players() and edit packet handler handle_edit_player_remove().
Definition at line 125 of file plrhand.c.
Referenced by handle_edit_player_remove(), and kill_dying_players().
Update contact info.
Definition at line 2132 of file plrhand.c.
Referenced by do_have_contacts_effect(), and maybe_make_contact().
|
static |
If there's any units of new_owner on tile, they claim bases.
Definition at line 704 of file plrhand.c.
Referenced by enter_war().
Check if we make contact with anyone.
Definition at line 2191 of file plrhand.c.
Referenced by create_city(), do_paradrop(), illegal_action_pay_price(), place_unit(), transfer_city(), transfer_unit(), and unit_move().
bool nation_is_in_current_set | ( | const struct nation_type * | pnation | ) |
Is the nation in the currently selected nationset? If not, it's not allowed to appear in the game.
Definition at line 2419 of file plrhand.c.
Referenced by client_can_pick_nation(), create_command_newcomer(), dai_can_requirement_be_met_in_city(), fit_nationset_to_players(), handle_edit_player(), handle_nation_select_req(), nationset_action(), and pick_a_nation().
int normal_player_count | ( | void | ) |
Return the number of non-barbarian players.
Definition at line 3034 of file plrhand.c.
Referenced by adjust_improvement_wants_by_effects(), civil_war(), connection_attach_real(), create_command_newcomer(), create_command_pregame(), dai_gov_value(), dai_tech_effect_values(), is_allowed_to_take(), nationset_action(), send_lanserver_response(), sg_load_sanitycheck(), sg_load_sanitycheck(), srv_ready(), start_command(), take_command(), unit_conquer_city(), and unit_do_destroy_city().
|
static |
Package player information that is always sent.
Definition at line 1108 of file plrhand.c.
Referenced by send_player_info_c_real().
|
static |
Package player diplstate depending on info_level. We send everything to plr's connections, we send almost everything to players with embassy to plr, we send a little to players we are in contact with and almost nothing to everyone else.
Receiver may be NULL in which cases dummy values are sent for some fields.
Definition at line 1360 of file plrhand.c.
Referenced by send_player_diplstate_c_real().
|
static |
Package player info depending on info_level. We send everything to plr's connections, we send almost everything to players with embassy to plr, we send a little to players we are in contact with and almost nothing to everyone else.
Receiver may be NULL in which cases dummy values are sent for some fields.
Definition at line 1169 of file plrhand.c.
Referenced by send_player_info_c_real().
struct nation_type * pick_a_nation | ( | const struct nation_list * | choices, |
bool | ignore_conflicts, | ||
bool | needs_startpos, | ||
enum barbarian_type | barb_type | ||
) |
This function returns a random-ish nation that is suitable for 'barb_type' and is usable (not already in use by an existing player, and if needs_startpos is set, would not be prohibited from starting on the map by the current scenario – NB this doesn't check that any start position is actually free).
Unless 'ignore_conflicts' is set, this function tries hard to avoid a nation marked as "conflicting with" one already in the game. A conflicting nation will be returned only if the alternative is to return NO_NATION_SELECTED. Such a return indicates that there are no remaining nations which match the above criteria.
If 'choices' is non-NULL, nations from the supplied list are preferred; but if there are no (non-conflicting) nations on the list that match the criteria, one will be chosen from outside the list (as if the list had not been supplied).
All other things being equal, prefers to pick a nation which returns a high score from nations_match() relative to any nations already in the game.
Definition at line 2282 of file plrhand.c.
Referenced by create_animals(), create_barbarian_player(), create_command_newcomer(), generate_players(), handle_edit_player_create(), sg_load_players(), sg_load_players(), and split_player().
struct player * player_by_user_delegated | ( | const char * | name | ) |
For a given user, if there is some player that the user originally controlled but is currently delegated to another user, return that player. See also player_by_user().
Definition at line 3147 of file plrhand.c.
Referenced by establish_new_connection().
Return whether a player's color can currently be set with the '/playercolor' command. If not, give a reason why not, if 'reason' is not NULL (need not be freed).
Definition at line 1546 of file plrhand.c.
Referenced by package_player_info(), and playercolor_command().
const char * player_color_ftstr | ( | struct player * | pplayer | ) |
Return the player color as featured text string. (In pregame, this uses the color the player will take, if known, even if not assigned yet.)
Definition at line 1672 of file plrhand.c.
Referenced by playercolor_command(), show_colors(), and show_players().
Returns TRUE if a delegation is active. This means that either the player is controlled by a delegate, or the player has been temporarily 'put aside' by a delegate.
Definition at line 3096 of file plrhand.c.
Referenced by delegate_command(), show_delegations(), and take_command().
const char * player_delegation_get | ( | const struct player * | pplayer | ) |
Returns the username that control of the player is delegated to, if any.
Definition at line 3067 of file plrhand.c.
Referenced by delegate_command(), establish_new_connection(), player_by_user_delegated(), send_delegation_info(), sg_save_player_main(), and show_delegations().
void player_delegation_set | ( | struct player * | pplayer, |
const char * | username | ||
) |
Define a delegation. NULL for no delegate.
Definition at line 3080 of file plrhand.c.
Referenced by delegate_command(), sg_load_player_main(), and sg_load_player_main().
void player_info_freeze | ( | void | ) |
Do not compute and send PACKET_PLAYER_INFO or PACKET_NATION_AVAILABILITY until a call to player_info_thaw(). This is used during savegame load or ruleset (re)load cycles, to avoid sending infos to the client that depend on ruleset data it does not yet have.
Definition at line 955 of file plrhand.c.
Referenced by load_command(), and set_rulesetdir().
|
static |
Return level of information player should receive about another.
Definition at line 1403 of file plrhand.c.
Referenced by package_player_diplstate(), and package_player_info().
void player_info_thaw | ( | void | ) |
If the frozen level is back to 0, send all players' infos, and nation availability, to all connections.
Definition at line 964 of file plrhand.c.
Referenced by load_command(), and set_rulesetdir().
void player_limit_to_max_rates | ( | struct player * | pplayer | ) |
The following limits a player's rates to those that are presently acceptable. If a rate exceeds current maxrate, it adjusts rates automatically adding the extra to the 2nd highest rate, preferring science to taxes and taxes to luxuries. (It assumes that for maxrate * 3 >= 100 in any situation)
Returns actual max rate used. This function should be called after team information are defined.
Definition at line 1886 of file plrhand.c.
Referenced by check_player_max_rates(), handle_edit_player_create(), server_player_init(), sg_load_sanitycheck(), sg_load_sanitycheck(), split_player(), and srv_ready().
If a player's color will be predictable when colors are assigned (or assignment has already happened), return that color. Otherwise (if the player's color is yet to be assigned randomly), return NULL.
Definition at line 1503 of file plrhand.c.
Referenced by assign_player_colors(), package_player_info(), and player_color_ftstr().
struct conn_list * player_reply_dest | ( | struct player * | pplayer | ) |
Convenience function to return "reply" destination connection list for player: pplayer->current_conn if set, else pplayer->connections.
Definition at line 1425 of file plrhand.c.
Referenced by handle_unit_sscs_set(), unit_move(), and unit_move_handling().
void player_set_to_ai_mode | ( | struct player * | pplayer, |
enum ai_level | skill_level | ||
) |
Toggle player to AI mode.
Definition at line 3259 of file plrhand.c.
Referenced by away_command(), and toggle_ai_player_direct().
void player_set_under_human_control | ( | struct player * | pplayer | ) |
Toggle player under human control.
Definition at line 3281 of file plrhand.c.
Referenced by away_command(), and toggle_ai_player_direct().
void player_status_add | ( | struct player * | plr, |
enum player_status | pstatus | ||
) |
Add a status flag to a player.
Definition at line 3042 of file plrhand.c.
Referenced by api_edit_player_victory(), kill_dying_players(), player_status_reset(), rank_users(), server_remove_unit_full(), and surrender_command().
Check player status flag.
Definition at line 3050 of file plrhand.c.
Referenced by check_for_game_over(), kill_dying_players(), rank_users(), and surrender_command().
void player_status_reset | ( | struct player * | plr | ) |
Reset player status to 'normal'.
Definition at line 3058 of file plrhand.c.
Referenced by create_barbarian_player(), kill_player(), and server_player_init().
void player_update_last_war_action | ( | struct player * | pplayer | ) |
Update last war action timestamp (affects player mood).
Definition at line 746 of file plrhand.c.
Referenced by action_give_casus_belli(), handle_diplomacy_cancel_pact(), unit_bombs_unit(), and unit_versus_unit().
void playercolor_add | ( | struct rgbcolor * | prgbcolor | ) |
Add a color to the list of all available player colors.
Definition at line 3190 of file plrhand.c.
Referenced by load_ruleset_game().
int playercolor_count | ( | void | ) |
Number of player colors defined.
Definition at line 3210 of file plrhand.c.
Referenced by load_ruleset_game(), mapimg_server_plrcolor_count(), and player_preferred_color().
void playercolor_free | ( | void | ) |
Free the memory allocated for the player color.
Definition at line 3171 of file plrhand.c.
Referenced by load_rulesetdir(), and server_game_free().
struct rgbcolor * playercolor_get | ( | int | id | ) |
Get the player color with the index 'id'.
Definition at line 3200 of file plrhand.c.
Referenced by mapimg_server_plrcolor_get(), and player_preferred_color().
void playercolor_init | ( | void | ) |
Initialise the player colors.
Definition at line 3162 of file plrhand.c.
Referenced by load_rulesetdir(), and server_game_init().
void reset_all_start_commands | ( | bool | plrchange | ) |
Called when something is changed; this resets everyone's readiness.
Definition at line 2553 of file plrhand.c.
Referenced by connection_detach(), create_command_pregame(), establish_new_connection(), and set_command().
|
static |
Get length of a revolution.
rltype | The way to decide revolution length |
gov | Government that the revolution ends to |
Definition at line 410 of file plrhand.c.
Referenced by revolution_length().
int revolution_length | ( | struct government * | gov, |
struct player * | plr | ||
) |
Get length of a revolution.
Definition at line 438 of file plrhand.c.
Referenced by handle_edit_player(), and handle_player_change_government().
void send_delegation_info | ( | const struct connection * | pconn | ) |
Send information about delegations to reconnecting users.
Definition at line 3104 of file plrhand.c.
Referenced by connection_attach_real(), and establish_new_connection().
void send_nation_availability | ( | struct conn_list * | dest, |
bool | nationset_change | ||
) |
Tell clients which nations can be picked given current server settings.
Definition at line 2471 of file plrhand.c.
Referenced by nationset_action(), and send_ruleset_nations().
|
static |
Helper doing the actual work for send_nation_availability() (q.v.).
Definition at line 2455 of file plrhand.c.
Referenced by player_info_thaw(), and send_nation_availability().
void send_player_all_c | ( | struct player * | src, |
struct conn_list * | dest | ||
) |
Send all information about a player (player_info and all player_diplstates) to the given connections.
Send all players if src is NULL; send to all connections if dest is NULL.
This function also sends the diplstate of the player. So take care, that all players are defined in the client and in the server. To create a player without sending the diplstate, use send_player_info_c().
Definition at line 983 of file plrhand.c.
Referenced by action_consequence_common(), begin_phase(), civil_war(), create_animals(), create_barbarian_player(), diplomat_bribe(), diplomat_get_tech(), diplomat_may_lose_gold(), end_turn(), establish_embassy(), found_new_tech(), handle_diplomacy_accept_treaty_req(), handle_diplomacy_cancel_pact(), handle_edit_player(), handle_edit_player_create(), handle_player_phase_done(), make_contact(), send_all_info(), split_player(), and update_players_after_alliance_breakup().
void send_player_diplstate_c | ( | struct player * | src, |
struct conn_list * | dest | ||
) |
Identical to send_player_info_c(), but sends the diplstate of the player.
This function solves one problem of using an extra packet for the diplstate. It can only be send if the player exists at the destination. Thus, this function should be called after the player(s) exists on both sides of the connection.
Definition at line 1059 of file plrhand.c.
Referenced by create_command_newcomer(), load_command(), and send_player_all_c().
|
static |
Really send information. If 'dest' is NULL, then it is set to game.est_connections.
Definition at line 1075 of file plrhand.c.
Referenced by send_player_diplstate_c().
void send_player_info_c | ( | struct player * | src, |
struct conn_list * | dest | ||
) |
Send information about player slot 'src', or all valid (i.e. used and initialized) players if 'src' is NULL, to specified clients 'dest'. If 'dest' is NULL, it is treated as game.est_connections.
Note: package_player_info contains incomplete info if it has NULL as a dest arg and and info is < INFO_EMBASSY. NB: If 'src' is NULL (meaning send information about all players) this function will only send info for used players, i.e. player slots with a player defined.
Definition at line 1000 of file plrhand.c.
Referenced by aifill(), announce_player(), api_edit_change_gold(), api_edit_create_building(), api_edit_remove_building(), autotoggle_action(), away_command(), city_build_free_buildings(), connection_attach_real(), connection_delegate_restore(), connection_detach(), create_city_for_player(), create_command_newcomer(), create_command_pregame(), dai_manage_taxes(), detach_command(), diplomat_incite(), do_unit_establish_trade(), do_unit_upgrade(), establish_new_connection(), give_shared_vision(), government_change(), handle_edit_city(), handle_edit_unit_create(), handle_nation_select_req(), handle_player_change_government(), handle_player_multiplier(), handle_player_place_infra(), handle_player_rates(), handle_player_ready(), handle_unit_type_upgrade(), kill_player(), kill_unit(), nationset_action(), player_info_thaw(), player_update_last_war_action(), playernation_command(), plrcol_action(), really_handle_city_buy(), really_handle_city_sell(), remove_city(), remove_obsolete_buildings_city(), remove_shared_vision(), research_tech_lost(), reset_all_start_commands(), send_player_all_c(), server_player_set_color(), set_ai_level(), set_ai_level_direct(), split_player(), spy_steal_gold(), team_command(), toggle_ai_command(), transfer_city(), unit_conquer_city(), unit_do_help_build(), unit_enter_hut(), and update_revolution().
|
static |
Really send information. If 'dest' is NULL, then it is set to game.est_connections.
Definition at line 1020 of file plrhand.c.
Referenced by send_player_info_c().
|
static |
Send information about removed (unused) players.
Definition at line 935 of file plrhand.c.
Referenced by server_remove_player().
struct player * server_create_player | ( | int | player_id, |
const char * | ai_tname, | ||
struct rgbcolor * | prgbcolor, | ||
bool | allow_ai_type_fallbacking | ||
) |
Creates a new, uninitialized, used player slot. You should probably call server_player_init() to initialize it, and send_player_info_c() later to tell clients about it.
May return NULL if creation was not possible.
Definition at line 1723 of file plrhand.c.
Referenced by aifill(), connection_attach_real(), create_animals(), create_barbarian_player(), create_command_newcomer(), create_command_pregame(), handle_edit_player_create(), sg_load_players_basic(), sg_load_players_basic(), and split_player().
Initialize ANY newly-created player on the server.
The initmap option is used because we don't want to initialize the map before the x and y sizes have been determined. This should generally be FALSE in pregame.
The needs_team options should be set for players who should be assigned a team. They will be put on their own newly-created team.
Definition at line 1450 of file plrhand.c.
Referenced by aifill(), connection_attach_real(), create_animals(), create_barbarian_player(), create_command_newcomer(), create_command_pregame(), handle_edit_player_create(), server_create_player(), sg_load_players_basic(), sg_load_players_basic(), and split_player().
|
static |
Check if this name is allowed for the player. Fill out the error message (a translated string to be sent to the client) if not.
Definition at line 1935 of file plrhand.c.
Referenced by server_player_set_name_full().
Set the player's color. If 'prgbcolor' is not NULL the caller should free the pointer, as player_set_color() copies the data.
Definition at line 1652 of file plrhand.c.
Referenced by playercolor_command(), and plrcol_action().
void server_player_set_name | ( | struct player * | pplayer, |
const char * | name | ||
) |
Try to set the player name to 'name'. Else, find a default name.
Definition at line 2097 of file plrhand.c.
Referenced by aifill(), connection_attach_real(), create_barbarian_player(), create_command_newcomer(), create_command_pregame(), player_nation_defaults(), playernation_command(), sg_load_player_main(), and sg_load_player_main().
bool server_player_set_name_full | ( | const struct connection * | caller, |
struct player * | pplayer, | ||
const struct nation_type * | pnation, | ||
const char * | name, | ||
char * | error_buf, | ||
size_t | error_buf_len | ||
) |
Try to set the player name to 'name'. Else, find a default name. Returns TRUE on success.
Definition at line 1997 of file plrhand.c.
Referenced by handle_edit_player(), handle_nation_select_req(), playernation_command(), and server_player_set_name().
void server_remove_player | ( | struct player * | pplayer | ) |
This function does not close any connections attached to this player. The function cut_connection() is used for that. Be sure to send_player_slot_info_c() afterwards to tell clients that the player slot has become unused.
Definition at line 1772 of file plrhand.c.
Referenced by aifill(), connection_detach(), create_command_newcomer(), handle_edit_player_remove(), remove_player_command(), server_game_free(), sg_load_players_basic(), sg_load_players_basic(), and start_command().
void set_shuffled_players | ( | int * | shuffled_players | ) |
Initialize the shuffled players list (as from a loaded savegame).
Definition at line 2232 of file plrhand.c.
Referenced by sg_load_players_basic(), and sg_load_players_basic().
void shuffle_players | ( | void | ) |
Shuffle or reshuffle the player order, storing in static variables above.
Definition at line 2207 of file plrhand.c.
Referenced by begin_turn(), sg_load_players_basic(), sg_load_players_basic(), and srv_ready().
struct player * shuffled_player | ( | int | i | ) |
This function creates a new player and copies all of it's science research etc. Players are both thrown into anarchy and gold is split between both players.
Definition at line 2588 of file plrhand.c.
Referenced by civil_war().
void update_capital | ( | struct player * | pplayer | ) |
Recalculate what city is the named capital
Definition at line 612 of file plrhand.c.
Referenced by begin_phase(), and transfer_city().
void update_players_after_alliance_breakup | ( | struct player * | pplayer, |
struct player * | pplayer2, | ||
const struct unit_list * | pplayer_seen_units, | ||
const struct unit_list * | pplayer2_seen_units | ||
) |
After the alliance is breaken, we need to do two things:
Definition at line 685 of file plrhand.c.
Referenced by handle_diplomacy_accept_treaty_req(), and handle_diplomacy_cancel_pact().
void update_revolution | ( | struct player * | pplayer | ) |
See if the player has finished their revolution. This function should be called at the beginning of a player's phase.
Definition at line 553 of file plrhand.c.
Referenced by begin_phase().
|
static |
Definition at line 117 of file plrhand.c.
Referenced by player_info_freeze(), player_info_thaw(), send_nation_availability(), and send_player_info_c().
|
static |
Definition at line 114 of file plrhand.c.
Referenced by set_shuffled_players(), shuffle_players(), and shuffled_player().