Skip to content

Commit

Permalink
Expand the city dialog text for military happiness
Browse files Browse the repository at this point in the history
Improve the description of martial law by listing the number of units applying
it and the total number of citizens made happier as a result.
Greatly expand the description of military unhappiness by explaining the three
effects that come into play and providing numbers similiar to the above.

Should help with #269.
  • Loading branch information
lmoureaux committed Aug 7, 2022
1 parent 3b9a79c commit 9ec8341
Show file tree
Hide file tree
Showing 2 changed files with 120 additions and 29 deletions.
147 changes: 119 additions & 28 deletions client/text.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1731,41 +1731,132 @@ QString text_happiness_cities(const struct city *pcity)
}

/**
Describing units that affect happiness.
* Describe units that affect happiness.
*/
const QString text_happiness_units(const struct city *pcity)
QString text_happiness_units(const struct city *pcity)
{
int mlmax = get_city_bonus(pcity, EFT_MARTIAL_LAW_MAX);
int uhcfac = get_city_bonus(pcity, EFT_UNHAPPY_FACTOR);
QString str;
auto str = QString();

if (mlmax > 0) {
int mleach = get_city_bonus(pcity, EFT_MARTIAL_LAW_EACH);
if (mlmax == 100) {
str = QStringLiteral("%1").arg(_("Unlimited martial law in effect."))
+ qendl();
/*
* First part: martial law
*/
int martial_law_max = get_city_bonus(pcity, EFT_MARTIAL_LAW_MAX);
int martial_law_each = get_city_bonus(pcity, EFT_MARTIAL_LAW_EACH);
if (martial_law_each > 0 && martial_law_max >= 0) {
str += QStringLiteral("<p>");
// The rules
if (martial_law_max == 0) {
str += _("Every military unit in the city may impose martial law.");
} else {
str += QString(PL_("%1 military unit may impose martial law.",
"Up to %1 military units may impose martial "
"law.",
mlmax))
.arg(QString::number(mlmax))
+ qendl();
str +=
QString(PL_("%1 military unit in the city may impose martial law.",
"Up to %1 military units in the city may impose "
"martial law.",
martial_law_max))
.arg(martial_law_max);
}
str += QString(PL_("Each military unit makes %1 "
"unhappy citizen content.",
"Each military unit makes %1 "
"unhappy citizens content.",
mleach))
.arg(QString::number(mleach))
+ qendl();
} else if (uhcfac > 0) {
str += QString(_("Military units in the field may cause unhappiness. "))
+ qendl();

str += QStringLiteral(" ");
str += QString(PL_("Each of them makes %1 unhappy citizen content.",
"Each of them makes %1 unhappy citizens content.",
martial_law_each))
.arg(martial_law_each);

str += QStringLiteral("</p><p>");

int count = 0;
unit_list_iterate(pcity->tile->units, punit)
{
if ((count < martial_law_max || martial_law_max == 0)
&& is_military_unit(punit)
&& unit_owner(punit) == city_owner(pcity)) {
count++;
}
}
unit_list_iterate_end;

str +=
QString(PL_("%1 military unit in this city imposes the martial law.",
"%1 military units in this city impose the martial law.",
count))
.arg(count);
str += QStringLiteral(" ");
str += QString(PL_("<b>%1 citizen</b> is made happier as a result.",
"<b>%1 citizens</b> are made happier as a result.",
count * martial_law_each))
.arg(count * martial_law_each);

str += QStringLiteral("</p>");
}

/*
* Second part: military unhappiness
*
* Had to say anything here because this is unit dependent (and I don't
* want to build a list of unit types or so, this is shown elsewhere).
*/
str += QStringLiteral("<p>");

auto pplayer = city_owner(pcity);
int unhappy_factor = get_player_bonus(pplayer, EFT_UNHAPPY_FACTOR);
if (unhappy_factor == 0) {
str += _("Military units have no happiness effect.");
return str + QStringLiteral("</p>");
}

str += _("Military units in the field may cause unhappiness.");

// Special rule: ignore the first N military unhappy
int made_content = get_city_bonus(pcity, EFT_MAKE_CONTENT_MIL);
if (made_content > 0) {
str += QStringLiteral(" ");
str += QString(_("The unhappiness caused by military units is reduced "
"by %1 with respect to its normal value."))
.arg(made_content);
}

// Special rule: ignore N military unhappy per unit
// Let's hope ruleset authors don't combine them too often, the sentences
// are very similar.
int made_content_each = get_city_bonus(pcity, EFT_MAKE_CONTENT_MIL_PER);
if (made_content_each > 0) {
str += QStringLiteral(" ");
str += QString(_("The unhappiness caused by each military unit is "
"reduced by %1 with respect to its normal value."))
.arg(made_content_each);
}

// And finally how many unhappy we get in this city
int count = 0;
unit_list_iterate(pcity->units_supported, punit)
{
int dummy = 0;
if (city_unit_unhappiness(punit, &dummy) > 0) {
count++;
}
}
unit_list_iterate_end;

str += QStringLiteral("</p><p>");
if (count > 0) {
// TRANS: "This city supports %1 agressive military units, resulting in X
// unhappy citizens." (first part)
str += QString(PL_("This city supports %1 agressive military unit, ",
"This city supports %1 agressive military units, ",
count))
.arg(count);
// TRANS: "This city supports %1 agressive military units, resulting in X
// unhappy citizens." (second part)
str += QString(PL_("resulting in <b>%1 additional unhappy citizen.</b>",
"resulting in <b>%1 additional unhappy citizens.</b>",
pcity->unit_happy_upkeep))
.arg(pcity->unit_happy_upkeep);
} else {
str += QString(_("Military units have no happiness effect. ")) + qendl();
str += _("Currently, military units do not cause additional unhappiness "
"in this city.");
}
return str.trimmed();

return str + QStringLiteral("</p>");
}

/**
Expand Down
2 changes: 1 addition & 1 deletion client/text.h
Original file line number Diff line number Diff line change
Expand Up @@ -48,6 +48,6 @@ QString text_happiness_buildings(const struct city *pcity);
QString text_happiness_nationality(const struct city *pcity);
QString text_happiness_cities(const struct city *pcity);
QString text_happiness_luxuries(const struct city *pcity);
const QString text_happiness_units(const struct city *pcity);
QString text_happiness_units(const struct city *pcity);
QString text_happiness_wonders(const struct city *pcity);
int get_bulbs_per_turn(int *pours, bool *pteam, int *ptheirs);

0 comments on commit 9ec8341

Please sign in to comment.