From 31788216cc0490c66015bbea07b1d5f48d85a61c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?S=C5=82awomir=20Lach?= Date: Sun, 28 Mar 2021 12:44:55 +0200 Subject: [PATCH] - Added routines to obtain number of counters for given scope - Added default value for counter - Added routine declaration for obtaining number of city counters - Initialize city counters by default values - Added routines for manipulating city counter values - Added default value for counter - Added routine declaration for obtaining number of city counters - Coding repaired to match freeciv code styling guide - Correct assertions - Assign default value for builtin counters diff --git a/common/city.c b/common/city.c index c0d7ab334e..f56e249762 100644 --- a/common/city.c +++ b/common/city.c @@ -29,6 +29,7 @@ /* common */ #include "ai.h" #include "citizens.h" +#include "counters.h" #include "effects.h" #include "game.h" #include "government.h" @@ -3270,6 +3271,28 @@ void city_styles_free(void) game.control.styles_count = 0; } +/**********************************************************************//** + Set given counter of a City. +**************************************************************************/ +void city_set_counter_value(const struct city *pcity, + const struct counter *pcount, int value) +{ + fc_assert_exit_msg(pcount != NULL, "Counter pointer is NULL"); + fc_assert_exit_msg(pcity != NULL, "City pointer is NULL"); + pcity->counter_values[pcount->index] = value; +} + +/**********************************************************************//** + Retrieve value of given counter of given City. +**************************************************************************/ +int city_read_counter_value(const struct city *pcity, + const struct counter *pcount) +{ + fc_assert_exit_msg(pcount != NULL, "Counter pointer is NULL"); + fc_assert_exit_msg(pcity != NULL, "City pointer is NULL"); + return pcity->counter_values[pcount->index]; +} + /**********************************************************************//** Create virtual skeleton for a city. Values are mostly sane defaults. @@ -3340,6 +3363,12 @@ struct city *create_city_virtual(struct player *pplayer, * collecting_info_units_present set by fc_calloc(). */ } + pcity->counter_values = fc_malloc(sizeof(int) * counters_get_city_counters_count()); + + for (i = 0; i < counters_get_city_counters_count(); i++) { + pcity->counter_values[i] = counter_by_index(i, CTGT_CITY)->def; + } + return pcity; } @@ -3371,6 +3400,10 @@ void destroy_city_virtual(struct city *pcity) if (pcity->cm_parameter) { free(pcity->cm_parameter); } + + if (pcity->counter_values) { + free(pcity->counter_values); + } if (!is_server()) { unit_list_destroy(pcity->client.info_units_supported); diff --git a/common/city.h b/common/city.h index e7c7716af3..d9b4cf2b90 100644 --- a/common/city.h +++ b/common/city.h @@ -23,6 +23,7 @@ extern "C" { /* common */ #include "fc_types.h" +#include "counters.h" #include "name_translation.h" #include "improvement.h" #include "tile.h" @@ -387,6 +388,8 @@ struct city { struct unit_list *units_supported; + int *counter_values; + int history; /* Cumulative culture */ struct worker_task_list *task_reqs; @@ -802,6 +805,11 @@ bool is_free_worked(const struct city *pcity, const struct tile *ptile); void *city_ai_data(const struct city *pcity, const struct ai_type *ai); void city_set_ai_data(struct city *pcity, const struct ai_type *ai, void *data); +void city_set_counter_value(const struct city *pcity, + const struct counter *pcount, int value); +int city_read_counter_value(const struct city *pcity, + const struct counter *pcount); + #ifdef __cplusplus } diff --git a/common/counters.c b/common/counters.c index 290454cc94..59fc67cedb 100644 --- a/common/counters.c +++ b/common/counters.c @@ -22,11 +22,14 @@ static struct counter counters[MAX_COUNTERS] = { - { "Owned", COUNTER_OWNED, CTGT_CITY, 0, 0 } + { "Owned", COUNTER_OWNED, CTGT_CITY, 0, 0, 0 } }; static struct counter *counters_city[MAX_COUNTERS]; +static int number_city_counters; + + /************************************************************************//** Initialize counters system ****************************************************************************/ @@ -43,6 +46,7 @@ void counters_init(void) counters_city[city_i] = &counters[i]; counters[i].index = city_i++; counters[i].target = CTGT_CITY; + number_city_counters++; } } } @@ -52,6 +56,15 @@ void counters_init(void) ****************************************************************************/ void counters_free(void) { + number_city_counters = 0; +} + +/************************************************************************//** + Return number of city counters. +****************************************************************************/ +int counters_get_city_counters_count(void) +{ + return number_city_counters; } /************************************************************************//** @@ -78,8 +91,8 @@ int counter_id(struct counter *pcount) struct counter *counter_by_rule_name(const char *name) { int i; - fc_assert_ret_val(NULL == name, NULL); - fc_assert_ret_val('\0' == name[0], NULL); + fc_assert_ret_val(NULL != name, NULL); + fc_assert_ret_val('\0' != name[0], NULL); for (i = 0; i < MAX_COUNTERS; i++) { if (0 == fc_strcasecmp(name, counters[i].rule_name)) { diff --git a/common/counters.h b/common/counters.h index 6b2f94b8dc..60dc00844b 100644 --- a/common/counters.h +++ b/common/counters.h @@ -29,6 +29,8 @@ struct counter const char *rule_name; enum counter_type type; enum counter_target target; + int def; /* default value for each entity of given type + * for this counter */ int id; /* id in global counters array */ int index; /* index in specific (city/player/world) array */ }; @@ -44,6 +46,7 @@ const char *counter_rule_name(struct counter *pcount); int counter_index(struct counter *pcount); struct counter *counter_by_index(int index, enum counter_target target); +int counters_get_city_counters_count(void); #ifdef __cplusplus } -- 2.31.1