diff --git a/src/common/HighScoresManager.cxx b/src/common/HighScoresManager.cxx index 33e98e1ef..e53433dbf 100644 --- a/src/common/HighScoresManager.cxx +++ b/src/common/HighScoresManager.cxx @@ -541,10 +541,14 @@ string HighScoresManager::fromPropString(const string& text) const } // some ugly formatting - char first = result[0]; - result = BSPF::toLowerCase(result); - result[0] = first; + if(result.length()) + { + char first = result[0]; + result = BSPF::toLowerCase(result); + result[0] = first; + } - return result; + // remove leading spaces (especially for empty values) + size_t start = result.find_first_not_of(" "); + return (start == std::string::npos) ? "" : result.substr(start); } - diff --git a/src/gui/GameInfoDialog.cxx b/src/gui/GameInfoDialog.cxx index d5507063c..98ad978d7 100644 --- a/src/gui/GameInfoDialog.cxx +++ b/src/gui/GameInfoDialog.cxx @@ -807,11 +807,14 @@ void GameInfoDialog::loadHighScoresProperties(const Properties& props) mySpecialAddress->setText(ss.str()); - for (uInt32 a = 0; a < instance().highScores().numAddrBytes(info.numDigits, info.trailingZeroes); ++a) + for (uInt32 a = 0; a < HSM::MAX_SCORE_ADDR; ++a) { ss.str(""); - ss << hex << right //<< setw(HSM::MAX_ADDR_CHARS) << setfill(' ') - << uppercase << info.scoreAddr[a]; + if(a < instance().highScores().numAddrBytes(info.numDigits, info.trailingZeroes)) + { + ss << hex << right //<< setw(HSM::MAX_ADDR_CHARS) << setfill(' ') + << uppercase << info.scoreAddr[a]; + } myScoreAddress[a]->setText(ss.str()); } updateHighScoresWidgets(); diff --git a/src/gui/HighScoresDialog.cxx b/src/gui/HighScoresDialog.cxx index 246f3fdcb..8afa0719a 100644 --- a/src/gui/HighScoresDialog.cxx +++ b/src/gui/HighScoresDialog.cxx @@ -212,7 +212,10 @@ void HighScoresDialog::loadConfig() label = label.substr(label.length() - 5); mySpecialLabelWidget->setLabel(label); - myNotesWidget->setLabel("Note: " + instance().highScores().notes()); + if(!instance().highScores().notes().empty()) + myNotesWidget->setLabel("Note: " + instance().highScores().notes()); + else + myNotesWidget->setLabel(""); if (instance().hasConsole()) myMD5 = instance().console().properties().get(PropType::Cart_MD5);