1
0
mirror of https://github.com/vcmi/vcmi.git synced 2025-01-12 02:28:11 +02:00

Fixes crash on accessing recruitment window via click on creature icon

This commit is contained in:
Ivan Savenko 2024-06-03 13:37:35 +00:00
parent df83fa33a1
commit 62dd5681f5
2 changed files with 18 additions and 11 deletions

View File

@ -1085,9 +1085,9 @@ CCreaInfo::CCreaInfo(Point position, const CGTownInstance * Town, int Level, boo
}
addUsedEvents(LCLICK | SHOW_POPUP | HOVER);
CreatureID creatureID = town->creatures[level].second.back();
creature = town->creatures[level].second.back();
picture = std::make_shared<CAnimImage>(AnimationPath::builtin("CPRSMALL"), creatureID.toEntity(VLC)->getIconIndex(), 0, 8, 0);
picture = std::make_shared<CAnimImage>(AnimationPath::builtin("CPRSMALL"), creature.toEntity(VLC)->getIconIndex(), 0, 8, 0);
std::string value;
if(showAvailable)
@ -1127,16 +1127,17 @@ void CCreaInfo::update()
void CCreaInfo::hover(bool on)
{
std::string message = CGI->generaltexth->allTexts[588];
boost::algorithm::replace_first(message, "%s", creature->getNamePluralTranslated());
MetaString message;
message.appendTextID("core.genrltxt.588");
message.replaceNameSingular(creature);
if(on)
{
GH.statusbar()->write(message);
GH.statusbar()->write(message.toString());
}
else
{
GH.statusbar()->clearIfMatching(message);
GH.statusbar()->clearIfMatching(message.toString());
}
}
@ -1153,12 +1154,18 @@ void CCreaInfo::clickPressed(const Point & cursorPosition)
std::string CCreaInfo::genGrowthText()
{
GrowthInfo gi = town->getGrowthInfo(level);
std::string descr = boost::str(boost::format(CGI->generaltexth->allTexts[589]) % creature->getNameSingularTranslated() % gi.totalGrowth());
MetaString descr;
descr.appendTextID("core.genrltxt.589");
descr.replaceNameSingular(creature);
descr.replaceNumber(gi.totalGrowth());
for(const GrowthInfo::Entry & entry : gi.entries)
descr +="\n" + entry.description;
{
descr.appendEOL();
descr.appendRawString(entry.description);
}
return descr;
return descr.toString();
}
void CCreaInfo::showPopupWindow(const Point & cursorPosition)
@ -1166,7 +1173,7 @@ void CCreaInfo::showPopupWindow(const Point & cursorPosition)
if (showAvailable)
GH.windows().createAndPushWindow<CDwellingInfoBox>(GH.screenDimensions().x / 2, GH.screenDimensions().y / 2, town, level);
else
CRClickPopup::createAndPush(genGrowthText(), std::make_shared<CComponent>(ComponentType::CREATURE, creature->getId()));
CRClickPopup::createAndPush(genGrowthText(), std::make_shared<CComponent>(ComponentType::CREATURE, creature));
}
bool CCreaInfo::getShowAvailable()

View File

@ -181,7 +181,7 @@ public:
class CCreaInfo : public CIntObject
{
const CGTownInstance * town;
const CCreature * creature;
CreatureID creature;
int level;
bool showAvailable;