From 6a74ebd01dfaf1518afbeebae99109d1dc5227cd Mon Sep 17 00:00:00 2001 From: Daniel Brooks Date: Fri, 16 Aug 2024 02:17:43 -0700 Subject: [PATCH] wrap the text in the martial arts selection window Some of those descriptions are long enough to make the window huge. Fixes #75674 --- src/character.cpp | 15 ++++++++++----- src/newcharacter.cpp | 12 ++++++++---- 2 files changed, 18 insertions(+), 9 deletions(-) diff --git a/src/character.cpp b/src/character.cpp index 2592339c1a71e..6bfd25ce3fd6b 100644 --- a/src/character.cpp +++ b/src/character.cpp @@ -13349,6 +13349,11 @@ bool Character::can_lift( const T &obj ) const template bool Character::can_lift( const item &obj ) const; template bool Character::can_lift( const vehicle &obj ) const; +static std::string wrap60( const std::string &text ) +{ + return string_join( foldstring( text, 60 ), "\n" ); +} + bool character_martial_arts::pick_style( const Character &you ) // Style selection menu { enum style_selection { @@ -13379,9 +13384,8 @@ bool character_martial_arts::pick_style( const Character &you ) // Style selecti ctxt.register_action( "SHOW_DESCRIPTION" ); uilist kmenu; - kmenu.text = string_format( _( "Select a style.\n" - "\n" - "STR: %d, DEX: %d, " + kmenu.title = _( "Select a style.\n" ); + kmenu.text = string_format( _( "STR: %d, DEX: %d, " "PER: %d, INT: %d\n" "Press [%s] for technique details and compatible weapons.\n" ), you.get_str(), you.get_dex(), you.get_per(), you.get_int(), @@ -13393,7 +13397,7 @@ bool character_martial_arts::pick_style( const Character &you ) // Style selecti kmenu.desc_enabled = true; kmenu.addentry_desc( KEEP_HANDS_FREE, true, 'h', keep_hands_free ? _( "Keep hands free (on)" ) : _( "Keep hands free (off)" ), - _( "When this is enabled, player won't wield things unless explicitly told to." ) ); + wrap60( _( "When this is enabled, player won't wield things unless explicitly told to." ) ) ); kmenu.selected = STYLE_OFFSET; @@ -13412,7 +13416,8 @@ bool character_martial_arts::pick_style( const Character &you ) // Style selecti kmenu.selected = i + STYLE_OFFSET; entry_text = colorize( entry_text, c_pink ); } - kmenu.addentry_desc( i + STYLE_OFFSET, true, -1, entry_text, style.description.translated() ); + kmenu.addentry_desc( i + STYLE_OFFSET, true, -1, entry_text, + wrap60( style.description.translated() ) ); } kmenu.query(); diff --git a/src/newcharacter.cpp b/src/newcharacter.cpp index 2ab15895c5dd5..3776377c66fbe 100644 --- a/src/newcharacter.cpp +++ b/src/newcharacter.cpp @@ -378,6 +378,11 @@ void Character::pick_name( bool bUseDefault ) } } +static std::string wrap60( const std::string &text ) +{ + return string_join( foldstring( text, 60 ), "\n" ); +} + static matype_id choose_ma_style( const character_type type, const std::vector &styles, const avatar &u ) { @@ -393,9 +398,8 @@ static matype_id choose_ma_style( const character_type type, const std::vector%d, DEX: %d, " + menu.title = _( "Select a style.\n" ); + menu.text = string_format( _( "STR: %d, DEX: %d, " "PER: %d, INT: %d\n" "Press [%s] for technique details and compatible weapons.\n" ), u.get_str(), u.get_dex(), u.get_per(), u.get_int(), @@ -408,7 +412,7 @@ static matype_id choose_ma_style( const character_type type, const std::vector