From 34baa0af0286c2b2070a79edd6a344499071242a Mon Sep 17 00:00:00 2001 From: "Leilani A." <168607226+kaleohanopahala@users.noreply.github.com> Date: Fri, 11 Oct 2024 11:02:33 -0300 Subject: [PATCH] fix: player wheel string conversion (#2967) Now checks to ensure that strings are numeric before converting them to numbers with std::stoull. If the strings are not numeric, it falls back to a lexicographical comparison, preventing crashes caused by invalid conversions. Resolves #2966 --- src/creatures/players/wheel/player_wheel.cpp | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/src/creatures/players/wheel/player_wheel.cpp b/src/creatures/players/wheel/player_wheel.cpp index 3d0a3619bd0..7a317106074 100644 --- a/src/creatures/players/wheel/player_wheel.cpp +++ b/src/creatures/players/wheel/player_wheel.cpp @@ -771,12 +771,18 @@ std::vector PlayerWheel::getRevealedGems() const { if (unlockedGemUUIDs.empty()) { return unlockedGems; } + std::vector sortedUnlockedGemGUIDs; for (const auto &uuid : unlockedGemUUIDs) { sortedUnlockedGemGUIDs.push_back(uuid); } + std::sort(sortedUnlockedGemGUIDs.begin(), sortedUnlockedGemGUIDs.end(), [](const std::string &a, const std::string &b) { - return std::stoull(a) < std::stoull(b); + if (std::ranges::all_of(a, ::isdigit) && std::ranges::all_of(b, ::isdigit)) { + return std::stoull(a) < std::stoull(b); + } else { + return a < b; + } }); for (const auto &uuid : sortedUnlockedGemGUIDs) {