Freeciv-3.1
Loading...
Searching...
No Matches
Data Structures | Macros | Functions | Variables
government.c File Reference
#include "fcintl.h"
#include "log.h"
#include "mem.h"
#include "shared.h"
#include "string_vector.h"
#include "support.h"
#include "game.h"
#include "player.h"
#include "tech.h"
#include "government.h"

Go to the source code of this file.

Data Structures

struct  ruler_title
 
struct  government_iter
 

Macros

#define GOVERNMENT_ITER(p)   ((struct government_iter *) (p))
 

Functions

struct governmentgovernment_by_translated_name (const char *name)
 
struct governmentgovernment_by_rule_name (const char *name)
 
Government_type_id government_count (void)
 
Government_type_id government_index (const struct government *pgovern)
 
Government_type_id government_number (const struct government *pgovern)
 
struct governmentgovernment_by_number (const Government_type_id gov)
 
struct governmentgovernment_of_player (const struct player *pplayer)
 
struct governmentgovernment_of_city (const struct city *pcity)
 
const char * government_rule_name (const struct government *pgovern)
 
const char * government_name_translation (const struct government *pgovern)
 
const char * government_name_for_player (const struct player *pplayer)
 
bool can_change_to_government (struct player *pplayer, const struct government *gov)
 
static genhash_val_t nation_hash_val (const struct nation_type *pnation)
 
static bool nation_hash_comp (const struct nation_type *pnation1, const struct nation_type *pnation2)
 
static struct ruler_titleruler_title_new (const struct nation_type *pnation, const char *domain, const char *ruler_male_title, const char *ruler_female_title)
 
static void ruler_title_destroy (struct ruler_title *pruler_title)
 
static bool ruler_title_check (const struct ruler_title *pruler_title)
 
const struct ruler_title_hash * government_ruler_titles (const struct government *pgovern)
 
struct ruler_titlegovernment_ruler_title_new (struct government *pgovern, const struct nation_type *pnation, const char *ruler_male_title, const char *ruler_female_title)
 
const struct nation_typeruler_title_nation (const struct ruler_title *pruler_title)
 
const char * ruler_title_male_untranslated_name (const struct ruler_title *pruler_title)
 
const char * ruler_title_female_untranslated_name (const struct ruler_title *pruler_title)
 
const char * ruler_title_for_player (const struct player *pplayer, char *buf, size_t buf_len)
 
const char * default_title_for_player (const struct player *pplayer, char *buf, size_t buf_len)
 
size_t government_iter_sizeof (void)
 
static void government_iter_next (struct iterator *iter)
 
static void * government_iter_get (const struct iterator *iter)
 
static bool government_iter_valid (const struct iterator *iter)
 
struct iteratorgovernment_iter_init (struct government_iter *it)
 
static void government_init (struct government *pgovern)
 
static void government_free (struct government *pgovern)
 
void governments_alloc (int num)
 
void governments_free (void)
 
bool untargeted_revolution_allowed (void)
 

Variables

struct governmentgovernments = NULL
 

Macro Definition Documentation

◆ GOVERNMENT_ITER

#define GOVERNMENT_ITER (   p)    ((struct government_iter *) (p))

Definition at line 444 of file government.c.

Function Documentation

◆ can_change_to_government()

bool can_change_to_government ( struct player pplayer,
const struct government gov 
)

Can change to government if appropriate tech exists, and one of:

  • no required tech (required is A_NONE)
  • player has required tech
  • we have an appropriate wonder Returns FALSE if pplayer is NULL (used for observers).

Definition at line 165 of file government.c.

Referenced by adv_best_government(), dai_effect_value(), found_new_tech(), handle_player_change_government(), pick_random_government(), popup_government_dialog(), real_menus_update(), research_tech_lost(), and gov_menu::update().

◆ default_title_for_player()

const char * default_title_for_player ( const struct player pplayer,
char *  buf,
size_t  buf_len 
)

Return default ruler title of the player (translated).

Definition at line 425 of file government.c.

Referenced by ruler_title_for_player(), and title_for_player().

◆ government_by_number()

struct government * government_by_number ( const Government_type_id  gov)

◆ government_by_rule_name()

struct government * government_by_rule_name ( const char *  name)

Returns the government that has the given (untranslated) rule name. Returns NULL if none match.

Definition at line 54 of file government.c.

Referenced by api_find_government_by_name(), tab_gov::initialize_new_gov(), load_ruleset_nations(), lookup_government(), tab_gov::select_gov(), sg_load_player_main(), sg_load_player_main(), sg_load_ruledata(), sg_load_ruledata(), and universal_value_from_str().

◆ government_by_translated_name()

struct government * government_by_translated_name ( const char *  name)

Returns the government that has the given (translated) name. Returns NULL if none match.

Definition at line 39 of file government.c.

Referenced by help_update_government(), help_dialog::make_tree(), and help_widget::set_topic_government().

◆ government_count()

Government_type_id government_count ( void  )

◆ government_free()

static void government_free ( struct government pgovern)
inlinestatic

De-allocate resources associated with the given government.

Definition at line 512 of file government.c.

Referenced by governments_free().

◆ government_index()

Government_type_id government_index ( const struct government pgovern)

◆ government_init()

static void government_init ( struct government pgovern)
inlinestatic

Allocate resources associated with the given government.

Definition at line 495 of file government.c.

Referenced by governments_alloc().

◆ government_iter_get()

static void * government_iter_get ( const struct iterator iter)
static

Implementation of iterator 'get' function.

Definition at line 465 of file government.c.

Referenced by government_iter_init().

◆ government_iter_init()

struct iterator * government_iter_init ( struct government_iter it)

Implementation of iterator 'init' function.

Definition at line 482 of file government.c.

◆ government_iter_next()

static void government_iter_next ( struct iterator iter)
static

Implementation of iterator 'next' function.

Definition at line 457 of file government.c.

Referenced by government_iter_init().

◆ government_iter_sizeof()

size_t government_iter_sizeof ( void  )

Implementation of iterator 'sizeof' function.

Definition at line 449 of file government.c.

◆ government_iter_valid()

static bool government_iter_valid ( const struct iterator iter)
static

Implementation of iterator 'valid' function.

Definition at line 473 of file government.c.

Referenced by government_iter_init().

◆ government_name_for_player()

const char * government_name_for_player ( const struct player pplayer)

◆ government_name_translation()

const char * government_name_translation ( const struct government pgovern)

◆ government_number()

Government_type_id government_number ( const struct government pgovern)

◆ government_of_city()

struct government * government_of_city ( const struct city pcity)

Return the government of the player who owns the city.

Definition at line 122 of file government.c.

Referenced by update_city_activity().

◆ government_of_player()

struct government * government_of_player ( const struct player pplayer)

◆ government_rule_name()

const char * government_rule_name ( const struct government pgovern)

◆ government_ruler_title_new()

struct ruler_title * government_ruler_title_new ( struct government pgovern,
const struct nation_type pnation,
const char *  ruler_male_title,
const char *  ruler_female_title 
)

Add a new ruler title for the nation. Pass NULL for pnation for defining the default title.

Definition at line 324 of file government.c.

Referenced by handle_ruleset_government_ruler_title(), load_ruleset_governments(), and load_ruleset_nations().

◆ government_ruler_titles()

const struct ruler_title_hash * government_ruler_titles ( const struct government pgovern)

Returns all ruler titles for a government type.

Definition at line 313 of file government.c.

Referenced by send_ruleset_governments().

◆ governments_alloc()

void governments_alloc ( int  num)

Allocate the governments.

Definition at line 528 of file government.c.

Referenced by handle_ruleset_control(), and load_government_names().

◆ governments_free()

void governments_free ( void  )

De-allocate the currently allocated governments.

Definition at line 544 of file government.c.

Referenced by game_ruleset_free().

◆ nation_hash_comp()

static bool nation_hash_comp ( const struct nation_type pnation1,
const struct nation_type pnation2 
)
static

Hash function.

Definition at line 204 of file government.c.

Referenced by government_init().

◆ nation_hash_val()

static genhash_val_t nation_hash_val ( const struct nation_type pnation)
static

Hash function.

Definition at line 196 of file government.c.

Referenced by government_init().

◆ ruler_title_check()

static bool ruler_title_check ( const struct ruler_title pruler_title)
static

Return TRUE if the ruler title is valid.

Definition at line 238 of file government.c.

Referenced by government_ruler_title_new().

◆ ruler_title_destroy()

static void ruler_title_destroy ( struct ruler_title pruler_title)
static

Free a ruler title.

Definition at line 230 of file government.c.

Referenced by government_init(), and government_ruler_title_new().

◆ ruler_title_female_untranslated_name()

const char * ruler_title_female_untranslated_name ( const struct ruler_title pruler_title)

Return the female ruler title name.

Definition at line 382 of file government.c.

Referenced by save_governments_ruleset(), save_nation(), and send_ruleset_governments().

◆ ruler_title_for_player()

const char * ruler_title_for_player ( const struct player pplayer,
char *  buf,
size_t  buf_len 
)

Return the ruler title of the player (translated).

Definition at line 390 of file government.c.

Referenced by create_diplomacy_dialog(), diplo_wdg::diplo_wdg(), get_report_title(), title_for_player(), update_city_activities(), and update_intel_dialog().

◆ ruler_title_male_untranslated_name()

const char * ruler_title_male_untranslated_name ( const struct ruler_title pruler_title)

Return the male ruler title name.

Definition at line 373 of file government.c.

Referenced by save_governments_ruleset(), save_nation(), and send_ruleset_governments().

◆ ruler_title_nation()

const struct nation_type * ruler_title_nation ( const struct ruler_title pruler_title)

Return the nation of the ruler title. Returns NULL if this is default.

Definition at line 364 of file government.c.

Referenced by send_ruleset_governments().

◆ ruler_title_new()

static struct ruler_title * ruler_title_new ( const struct nation_type pnation,
const char *  domain,
const char *  ruler_male_title,
const char *  ruler_female_title 
)
static

Create a new ruler title.

Definition at line 213 of file government.c.

Referenced by government_ruler_title_new().

◆ untargeted_revolution_allowed()

bool untargeted_revolution_allowed ( void  )

Is it possible to start a revolution without specifying the target government in the current game?

Definition at line 565 of file government.c.

Referenced by real_menus_update(), revolution_length(), and gov_menu::update().

Variable Documentation

◆ governments

struct government* governments = NULL