From c21d7d09282fb27cb62d1e83954029d2f0cc2b0d Mon Sep 17 00:00:00 2001 From: RobbieNeko <30732426+RobbieNeko@users.noreply.github.com> Date: Sun, 22 Dec 2024 18:10:42 -0500 Subject: [PATCH] feat(balance): Make Stylish trait the default behavior, add Unstylish trait (#5826) * Make Stylish default behavior * Fix docs and npc generation * style(autofix.ci): automated formatting --------- Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> --- data/json/flags.json | 4 ++-- data/json/mutations/mutations.json | 8 ++++---- data/json/npcs/starting_traits.json | 2 +- data/json/obsoletion/mutations.json | 8 ++++++++ .../Aftershock/npcs/Backgrounds/trait_groups.json | 2 +- .../Aftershock/npcs/mutant_npcs/trait_groups.json | 2 +- .../content/docs/en/mod/json/reference/json_flags.md | 6 ++++-- src/morale.cpp | 12 ++++++------ tests/morale_test.cpp | 11 ++++++----- 9 files changed, 33 insertions(+), 22 deletions(-) diff --git a/data/json/flags.json b/data/json/flags.json index ddeafa0b9726..c96eff446991 100644 --- a/data/json/flags.json +++ b/data/json/flags.json @@ -265,7 +265,7 @@ "id": "FANCY", "type": "json_flag", "context": [ "ARMOR", "TOOL_ARMOR" ], - "//": "Wearing this clothing gives a morale bonus if the player has the Stylish trait.", + "//": "Wearing this clothing gives a morale bonus if the player doesn't have the Fashion Deficient trait.", "info": "This clothing is fancy.", "conflicts": [ "SUPER_FANCY" ] }, @@ -798,7 +798,7 @@ "id": "SUPER_FANCY", "type": "json_flag", "context": [ "ARMOR", "TOOL_ARMOR" ], - "//": "Gives an additional moral bonus over FANCY if the player has the Stylish trait.", + "//": "Gives an additional moral bonus over FANCY if the player doesn't have the Fashion Deficient trait.", "info": "This clothing is very fancy.", "conflicts": [ "FANCY" ] }, diff --git a/data/json/mutations/mutations.json b/data/json/mutations/mutations.json index ae854cde1d6e..7937a95b70a2 100644 --- a/data/json/mutations/mutations.json +++ b/data/json/mutations/mutations.json @@ -502,10 +502,10 @@ }, { "type": "mutation", - "id": "STYLISH", - "name": { "str": "Stylish" }, - "points": 2, - "description": "Practicality is far less important than style. Your morale is improved by wearing fashionable and attractive clothing.", + "id": "UNSTYLISH", + "name": { "str": "Fashion Deficient" }, + "points": -1, + "description": "You have no sense of style, and don't care about wearing anything 'fancy'; you'd be perfectly happy to wear non-matching socks, or wear socks and sandals. You get no morale bonus from fancy equipment.", "starting_trait": true, "valid": false }, diff --git a/data/json/npcs/starting_traits.json b/data/json/npcs/starting_traits.json index 71f501e9428b..a8cf7fbd8862 100644 --- a/data/json/npcs/starting_traits.json +++ b/data/json/npcs/starting_traits.json @@ -44,7 +44,7 @@ { "trait": "ROBUST", "prob": 10 }, { "trait": "SELFAWARE", "prob": 10 }, { "trait": "SPIRITUAL", "prob": 10 }, - { "trait": "STYLISH", "prob": 10 }, + { "trait": "UNSTYLISH", "prob": 10 }, { "trait": "TERRIFYING", "prob": 10 }, { "trait": "ALBINO", "prob": 1 }, { "trait": "ASTHMA", "prob": 10 }, diff --git a/data/json/obsoletion/mutations.json b/data/json/obsoletion/mutations.json index 5f6c3eed64e8..d6ffb26a9bb8 100644 --- a/data/json/obsoletion/mutations.json +++ b/data/json/obsoletion/mutations.json @@ -238,5 +238,13 @@ "points": 1, "description": "This mutation has been obsoleted due to the hidden movement speed penalty being removed. If you see this on a profession or mutate this trait, this is a bug.", "valid": false + }, + { + "type": "mutation", + "id": "STYLISH", + "name": { "str": "Stylish" }, + "points": 2, + "description": "Obsoleted due to becoming default behavior.", + "valid": false } ] diff --git a/data/mods/Aftershock/npcs/Backgrounds/trait_groups.json b/data/mods/Aftershock/npcs/Backgrounds/trait_groups.json index 21dd6d738fcb..570210c5269d 100644 --- a/data/mods/Aftershock/npcs/Backgrounds/trait_groups.json +++ b/data/mods/Aftershock/npcs/Backgrounds/trait_groups.json @@ -893,7 +893,7 @@ { "trait": "ROBUST", "prob": 10 }, { "trait": "SELFAWARE", "prob": 10 }, { "trait": "SPIRITUAL", "prob": 10 }, - { "trait": "STYLISH", "prob": 10 }, + { "trait": "UNSTYLISH", "prob": 10 }, { "trait": "ALBINO", "prob": 5 }, { "trait": "ASTHMA", "prob": 5 }, { "trait": "CHEMIMBALANCE", "prob": 10 }, diff --git a/data/mods/Aftershock/npcs/mutant_npcs/trait_groups.json b/data/mods/Aftershock/npcs/mutant_npcs/trait_groups.json index 4612bf796f45..c871bf95f916 100644 --- a/data/mods/Aftershock/npcs/mutant_npcs/trait_groups.json +++ b/data/mods/Aftershock/npcs/mutant_npcs/trait_groups.json @@ -899,7 +899,7 @@ { "trait": "ROBUST", "prob": 10 }, { "trait": "SELFAWARE", "prob": 10 }, { "trait": "SPIRITUAL", "prob": 10 }, - { "trait": "STYLISH", "prob": 10 }, + { "trait": "UNSTYLISH", "prob": 10 }, { "trait": "ALBINO", "prob": 5 }, { "trait": "ASTHMA", "prob": 5 }, { "trait": "CHEMIMBALANCE", "prob": 10 }, diff --git a/doc/src/content/docs/en/mod/json/reference/json_flags.md b/doc/src/content/docs/en/mod/json/reference/json_flags.md index 4780672c0e3d..c423df3c07da 100644 --- a/doc/src/content/docs/en/mod/json/reference/json_flags.md +++ b/doc/src/content/docs/en/mod/json/reference/json_flags.md @@ -200,7 +200,8 @@ to find which flags work elsewhere. - `COLLAR` This piece of clothing has a wide collar that can keep your mouth warm. - `DEAF` Makes the player deaf. - `ELECTRIC_IMMUNE` This gear completely protects you from electric discharges. -- `FANCY` Wearing this clothing gives a morale bonus if the player has the `Stylish` trait. +- `FANCY` Wearing this clothing gives a morale bonus if the player doesn't have the + `Fashion Deficient` trait. - `FIX_FARSIGHT` This gear corrects farsightedness. - `FIX_NEARSIGHT` This gear corrects nearsightedness. - `FLOTATION` Prevents the player from drowning in deep water. Also prevents diving underwater. @@ -249,7 +250,8 @@ to find which flags work elsewhere. 0.70. - `STURDY` This clothing is a lot more resistant to damage than normal. - `SUN_GLASSES` Prevents glaring when in sunlight. -- `SUPER_FANCY` Gives an additional moral bonus over `FANCY` if the player has the `Stylish` trait. +- `SUPER_FANCY` Gives an additional moral bonus over `FANCY` if the player doesn't have the + `Fashion Deficient` trait. - `SWIM_GOGGLES` Allows you to see much further under water. - `THERMOMETER` This gear is equipped with an accurate thermometer (which is used to measure temperature). diff --git a/src/morale.cpp b/src/morale.cpp index 8a366374bd14..910c73f301b7 100644 --- a/src/morale.cpp +++ b/src/morale.cpp @@ -48,7 +48,7 @@ static const trait_id trait_OPTIMISTIC( "OPTIMISTIC" ); static const trait_id trait_ROOTS1( "ROOTS1" ); static const trait_id trait_ROOTS2( "ROOTS2" ); static const trait_id trait_ROOTS3( "ROOTS3" ); -static const trait_id trait_STYLISH( "STYLISH" ); +static const trait_id trait_UNSTYLISH( "UNSTYLISH" ); namespace io { @@ -269,7 +269,7 @@ player_morale::player_morale() : level_is_valid( false ), took_prozac( false ), took_prozac_bad( false ), - stylish( false ), + stylish( true ), perceived_pain( 0 ) { using namespace std::placeholders; @@ -288,9 +288,9 @@ player_morale::player_morale() : mutations[trait_BADTEMPER] = mutation_data( std::bind( set_badtemper, _1, -9 ), std::bind( set_badtemper, _1, 0 ) ); - mutations[trait_STYLISH] = mutation_data( - std::bind( set_stylish, _1, true ), - std::bind( set_stylish, _1, false ) ); + mutations[trait_UNSTYLISH] = mutation_data( + std::bind( set_stylish, _1, false ), + std::bind( set_stylish, _1, true ) ); mutations[trait_FLOWERS] = mutation_data( update_constrained ); mutations[trait_ROOTS1] = mutation_data( update_constrained ); mutations[trait_ROOTS2] = mutation_data( update_constrained ); @@ -892,7 +892,7 @@ void player_morale::clear() } took_prozac = false; took_prozac_bad = false; - stylish = false; + stylish = true; super_fancy_items.clear(); invalidate(); diff --git a/tests/morale_test.cpp b/tests/morale_test.cpp index bc30f1af23fd..f7daebc995b0 100644 --- a/tests/morale_test.cpp +++ b/tests/morale_test.cpp @@ -179,13 +179,18 @@ TEST_CASE( "player_morale", "[morale]" ) m.on_item_wear( heels ); WHEN( "not a stylish person" ) { + m.on_mutation_gain( trait_id( "UNSTYLISH" ) ); THEN( "just don't care (even if man)" ) { CHECK( m.get_level() == 0 ); } + + AND_WHEN( "not anymore" ) { + m.on_mutation_loss( trait_id( "UNSTYLISH" ) ); + CHECK( m.get_level() == 19 ); + } } WHEN( "a stylish person" ) { - m.on_mutation_gain( trait_id( "STYLISH" ) ); CHECK( m.get_level() == 19 ); @@ -216,10 +221,6 @@ TEST_CASE( "player_morale", "[morale]" ) CHECK( m.get_level() == 20 ); } } - AND_WHEN( "not anymore" ) { - m.on_mutation_loss( trait_id( "STYLISH" ) ); - CHECK( m.get_level() == 0 ); - } } }