diff --git a/src/common/HighScoresManager.cxx b/src/common/HighScoresManager.cxx index e53433dbf..de1c0d3d8 100644 --- a/src/common/HighScoresManager.cxx +++ b/src/common/HighScoresManager.cxx @@ -120,8 +120,9 @@ bool HighScoresManager::enabled() const uInt32 HighScoresManager::numVariations(const Properties& props) const { string numVariations = getPropIdx(props, PropType::Cart_Variations); + uInt32 maxVariations = MAX_VARIATIONS; - return min(uInt32(stringToInt(numVariations, DEFAULT_VARIATION)), MAX_VARIATIONS); + return min(uInt32(stringToInt(numVariations, DEFAULT_VARIATION)), maxVariations); } // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - @@ -161,8 +162,9 @@ void HighScoresManager::set(Properties& props, uInt32 numVariations, { ostringstream buf; string output; + uInt32 maxVariations = MAX_VARIATIONS; - props.set(PropType::Cart_Variations, to_string(min(numVariations, MAX_VARIATIONS))); + props.set(PropType::Cart_Variations, to_string(min(numVariations, maxVariations))); // fill from the back to skip default values if (output.length() || !info.notes.empty()) @@ -211,16 +213,18 @@ void HighScoresManager::set(Properties& props, uInt32 numVariations, uInt32 HighScoresManager::numDigits(const Properties& props) const { string digits = getPropIdx(props, PropType::Cart_Formats, IDX_SCORE_DIGITS); + uInt32 maxScoreDigits = MAX_SCORE_DIGITS; - return min(uInt32(stringToInt(digits, DEFAULT_DIGITS)), MAX_SCORE_DIGITS); + return min(uInt32(stringToInt(digits, DEFAULT_DIGITS)), maxScoreDigits); } // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - uInt32 HighScoresManager::trailingZeroes(const Properties& props) const { string trailing = getPropIdx(props, PropType::Cart_Formats, IDX_TRAILING_ZEROES); + const uInt32 maxTrailing = MAX_TRAILING; - return min(uInt32(stringToInt(trailing, DEFAULT_TRAILING)), MAX_TRAILING); + return min(uInt32(stringToInt(trailing, DEFAULT_TRAILING)), maxTrailing); } // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - @@ -357,11 +361,12 @@ Int32 HighScoresManager::variation() const Properties props; uInt16 addr = varAddress(properties(props)); - if(addr == DEFAULT_ADDRESS) + if(addr == DEFAULT_ADDRESS) { if(numVariations() == 1) return DEFAULT_VARIATION; else return NO_VALUE; + } return variation(addr, varBCD(props), varZeroBased(props), numVariations(props)); } @@ -378,7 +383,7 @@ Int32 HighScoresManager::score(uInt32 numAddrBytes, uInt32 trailingZeroes, for (uInt32 b = 0; b < numAddrBytes; ++b) { uInt16 addr = scoreAddr[b]; - uInt32 score; + Int32 score; totalScore *= isBCD ? 100 : 256; score = peek(addr); @@ -486,7 +491,7 @@ string HighScoresManager::notes() const } // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -Int32 HighScoresManager::convert(uInt32 val, uInt32 maxVal, bool isBCD, bool zeroBased) const +Int32 HighScoresManager::convert(Int32 val, uInt32 maxVal, bool isBCD, bool zeroBased) const { maxVal += zeroBased ? 0 : 1; Int32 bits = isBCD diff --git a/src/common/HighScoresManager.hxx b/src/common/HighScoresManager.hxx index 198c20392..7cef40a2c 100644 --- a/src/common/HighScoresManager.hxx +++ b/src/common/HighScoresManager.hxx @@ -29,16 +29,16 @@ class OSystem; */ namespace HSM { - static const uInt32 MAX_SCORE_DIGITS = 8; - static const uInt32 MAX_ADDR_CHARS = MAX_SCORE_DIGITS / 2; - static const uInt32 MAX_SCORE_ADDR = 4; - static const uInt32 MAX_SPECIAL_NAME = 5; - static const uInt32 MAX_SPECIAL_DIGITS = 3; + static constexpr uInt32 MAX_SCORE_DIGITS = 8; + static constexpr uInt32 MAX_ADDR_CHARS = MAX_SCORE_DIGITS / 2; + static constexpr uInt32 MAX_SCORE_ADDR = 4; + static constexpr uInt32 MAX_SPECIAL_NAME = 5; + static constexpr uInt32 MAX_SPECIAL_DIGITS = 3; - static const uInt32 DEFAULT_VARIATION = 1; - static const uInt32 DEFAULT_ADDRESS = 0; + static constexpr uInt32 DEFAULT_VARIATION = 1; + static constexpr uInt32 DEFAULT_ADDRESS = 0; - static const Int32 NO_VALUE = -1; + static constexpr Int32 NO_VALUE = -1; using ScoreAddresses = array; @@ -62,9 +62,6 @@ namespace HSM { }; } // namespace HSM -using namespace HSM; - - /** This class provides an interface to define, load and save scores. It is meant for games which do not support saving highscores. @@ -88,12 +85,12 @@ class HighScoresManager @return True if highscore data exists, else false */ bool get(const Properties& props, uInt32& numVariations, - ScoresInfo& info) const; + HSM::ScoresInfo& info) const; /** Set the highscore data of game's properties */ void set(Properties& props, uInt32 numVariations, - const ScoresInfo& info) const; + const HSM::ScoresInfo& info) const; /** Calculate the number of bytes for one player's score from given parameters @@ -110,7 +107,7 @@ class HighScoresManager @return The current score or -1 if no valid data exists */ Int32 score(uInt32 numAddrBytes, uInt32 trailingZeroes, bool isBCD, - const ScoreAddresses& scoreAddr) const; + const HSM::ScoreAddresses& scoreAddr) const; Int32 special(uInt16 addr, bool varBCD, bool zeroBased) const; @@ -126,7 +123,7 @@ class HighScoresManager // converts the given value, using only the maximum bits required by maxVal // and adjusted for BCD and zero based data - Int32 convert(uInt32 val, uInt32 maxVal, bool isBCD, bool zeroBased) const; + Int32 convert(Int32 val, uInt32 maxVal, bool isBCD, bool zeroBased) const; // Peek into memory Int16 peek(uInt16 addr) const; @@ -150,18 +147,18 @@ class HighScoresManager IDX_SPECIAL_ADDRESS }; - static const uInt32 MAX_VARIATIONS = 256; + static constexpr uInt32 MAX_VARIATIONS = 256; - static const uInt32 MAX_TRAILING = 3; - static const bool DEFAULT_ARM_RAM = false; - static const uInt32 DEFAULT_DIGITS = 4; - static const uInt32 DEFAULT_TRAILING = 0; - static const bool DEFAULT_SCORE_BCD = true; - static const bool DEFAULT_SCORE_REVERSED = false; - static const bool DEFAULT_VARS_BCD = true; - static const bool DEFAULT_VARS_ZERO_BASED = false; - static const bool DEFAULT_SPECIAL_BCD = true; - static const bool DEFAULT_SPECIAL_ZERO_BASED = false; + static constexpr uInt32 MAX_TRAILING = 3; + static constexpr bool DEFAULT_ARM_RAM = false; + static constexpr uInt32 DEFAULT_DIGITS = 4; + static constexpr uInt32 DEFAULT_TRAILING = 0; + static constexpr bool DEFAULT_SCORE_BCD = true; + static constexpr bool DEFAULT_SCORE_REVERSED = false; + static constexpr bool DEFAULT_VARS_BCD = true; + static constexpr bool DEFAULT_VARS_ZERO_BASED = false; + static constexpr bool DEFAULT_SPECIAL_BCD = true; + static constexpr bool DEFAULT_SPECIAL_ZERO_BASED = false; private: // Get individual highscore info from properties diff --git a/src/gui/CommandMenu.cxx b/src/gui/CommandMenu.cxx index a45d99062..15e40e528 100644 --- a/src/gui/CommandMenu.cxx +++ b/src/gui/CommandMenu.cxx @@ -35,11 +35,12 @@ CommandMenu::~CommandMenu() // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - Dialog* CommandMenu::baseDialog() { - if (myBaseDialog == nullptr) + if (myBaseDialog == nullptr) { if (myOSystem.settings().getBool("minimal_ui")) myBaseDialog = new MinUICommandDialog(myOSystem, *this); else myBaseDialog = new CommandDialog(myOSystem, *this); + } return myBaseDialog; } diff --git a/src/gui/GameInfoDialog.cxx b/src/gui/GameInfoDialog.cxx index 98ad978d7..b4404ae04 100644 --- a/src/gui/GameInfoDialog.cxx +++ b/src/gui/GameInfoDialog.cxx @@ -193,8 +193,7 @@ void GameInfoDialog::addConsoleTab() const int VBORDER = 8; const int HBORDER = 10; const int VGAP = 4; - const int lineHeight = _font.getLineHeight(), - fontHeight = _font.getFontHeight(); + const int lineHeight = _font.getLineHeight(); int xpos, ypos, lwidth, tabID; WidgetArray wid; @@ -251,8 +250,7 @@ void GameInfoDialog::addControllersTab() const int VGAP = 4; const GUI::Font& ifont = instance().frameBuffer().infoFont(); const int lineHeight = _font.getLineHeight(), - fontWidth = _font.getMaxCharWidth(), - fontHeight = _font.getFontHeight(); + fontWidth = _font.getMaxCharWidth(); int xpos, ypos, pwidth, tabID; WidgetArray wid; @@ -502,7 +500,7 @@ void GameInfoDialog::addHighScoresTab() vwidth = _font.getStringWidth("AB") + 3; items.clear(); - for (int i = 1; i <= HSM::MAX_SCORE_DIGITS; ++i) + for (uInt32 i = 1; i <= HSM::MAX_SCORE_DIGITS; ++i) VarList::push_back(items, std::to_string(i), std::to_string(i)); myScoreDigitsLabel = new StaticTextWidget(myTab, _font, xpos, ypos + 1, "Digits "); @@ -511,7 +509,7 @@ void GameInfoDialog::addHighScoresTab() wid.push_back(myScoreDigits); items.clear(); - for (int i = 0; i <= HSM::MAX_SCORE_DIGITS - 3; ++i) + for (uInt32 i = 0; i <= HSM::MAX_SCORE_DIGITS - 3; ++i) VarList::push_back(items, std::to_string(i), std::to_string(i)); pwidth = _font.getStringWidth("0"); @@ -797,12 +795,12 @@ void GameInfoDialog::loadHighScoresProperties(const Properties& props) myHighScoreNotes->setText(info.notes); ss.str(""); - ss << hex << right //<< setw(HSM::MAX_ADDR_CHARS) << setfill(' ') + ss << hex << right // << setw(HSM::MAX_ADDR_CHARS) << setfill(' ') << uppercase << info.varsAddr; myVarAddress->setText(ss.str()); ss.str(""); - ss << hex << right //<< setw(HSM::MAX_ADDR_CHARS) << setfill(' ') + ss << hex << right // << setw(HSM::MAX_ADDR_CHARS) << setfill(' ') << uppercase << info.specialAddr; mySpecialAddress->setText(ss.str()); @@ -812,7 +810,7 @@ void GameInfoDialog::loadHighScoresProperties(const Properties& props) ss.str(""); if(a < instance().highScores().numAddrBytes(info.numDigits, info.trailingZeroes)) { - ss << hex << right //<< setw(HSM::MAX_ADDR_CHARS) << setfill(' ') + ss << hex << right // << setw(HSM::MAX_ADDR_CHARS) << setfill(' ') << uppercase << info.scoreAddr[a]; } myScoreAddress[a]->setText(ss.str()); @@ -1197,9 +1195,9 @@ void GameInfoDialog::setAddressVal(EditTextWidget* addressWidget, EditTextWidget val = instance().highScores().convert(val, maxVal, isBCD, zeroBased); // format output and display in value widget - //if (isBCD) + // if (isBCD) // ss << hex; - ss << right //<< setw(2) << setfill(' ') + ss << right // << setw(2) << setfill(' ') << uppercase << uInt16(val); valWidget->setText(ss.str()); } diff --git a/src/gui/HighScoresDialog.cxx b/src/gui/HighScoresDialog.cxx index 8afa0719a..29d3f1dfb 100644 --- a/src/gui/HighScoresDialog.cxx +++ b/src/gui/HighScoresDialog.cxx @@ -62,17 +62,16 @@ HighScoresDialog::HighScoresDialog(OSystem& osystem, DialogContainer& parent, int max_w, int max_h, Menu::AppMode mode) : Dialog(osystem, parent, osystem.frameBuffer().font(), "High Scores"), - myMode(mode), + myDirty(false), + myHighScoreSaved(false), _max_w(max_w), _max_h(max_h), myVariation(HSM::DEFAULT_VARIATION), myInitials(""), - myDirty(false), - myHighScoreSaved(false) + myMode(mode) { const GUI::Font& ifont = instance().frameBuffer().infoFont(); const int lineHeight = _font.getLineHeight(), - fontWidth = _font.getMaxCharWidth(), infoLineHeight = ifont.getLineHeight(); const int VBORDER = 10; const int HBORDER = 10; @@ -326,7 +325,7 @@ void HighScoresDialog::updateWidgets(bool init) myPrevVarButton->setEnabled(myVariation > 1); myNextVarButton->setEnabled(myVariation < instance().highScores().numVariations()); - for (Int32 r = 0; r < NUM_RANKS; ++r) + for (uInt32 r = 0; r < NUM_RANKS; ++r) { ostringstream buf; @@ -352,7 +351,7 @@ void HighScoresDialog::updateWidgets(bool init) myNameWidgets[r]->setLabel(myNames[r]); myDateWidgets[r]->setLabel(myDates[r]); - if (r == myEditRank) + if (static_cast(r) == myEditRank) { myNameWidgets[r]->setFlags(EditTextWidget::FLAG_INVISIBLE); myEditNameWidgets[r]->clearFlags(EditTextWidget::FLAG_INVISIBLE); @@ -382,7 +381,7 @@ void HighScoresDialog::handlePlayedVariation() Int32 newSpecial = instance().highScores().special(); bool scoreInvert = instance().highScores().scoreInvert(); - for (myHighScoreRank = 0; myHighScoreRank < NUM_RANKS; ++myHighScoreRank) + for (myHighScoreRank = 0; myHighScoreRank < static_cast(NUM_RANKS); ++myHighScoreRank) { if ((!scoreInvert && newScore > myHighScores[myHighScoreRank]) || ((scoreInvert && newScore < myHighScores[myHighScoreRank]) || myHighScores[myHighScoreRank] == 0)) @@ -391,10 +390,10 @@ void HighScoresDialog::handlePlayedVariation() break; } - if (myHighScoreRank < NUM_RANKS) + if (myHighScoreRank < static_cast(NUM_RANKS)) { myEditRank = myHighScoreRank; - for (Int32 r = NUM_RANKS - 1; r > myHighScoreRank; --r) + for (uInt32 r = NUM_RANKS - 1; static_cast(r) > myHighScoreRank; --r) { myHighScores[r] = myHighScores[r - 1]; mySpecials[r] = mySpecials[r - 1]; @@ -414,7 +413,7 @@ void HighScoresDialog::handlePlayedVariation() // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - void HighScoresDialog::deleteRank(int rank) { - for (Int32 r = rank; r < NUM_RANKS - 1; ++r) + for (uInt32 r = rank; r < NUM_RANKS - 1; ++r) { myHighScores[r] = myHighScores[r + 1]; mySpecials[r] = mySpecials[r + 1]; @@ -508,7 +507,7 @@ void HighScoresDialog::saveHighScores(Int32 variation) const // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - void HighScoresDialog::loadHighScores(Int32 variation) { - for (Int32 r = 0; r < NUM_RANKS; ++r) + for (uInt32 r = 0; r < NUM_RANKS; ++r) { myHighScores[r] = 0; mySpecials[r] = 0; @@ -560,7 +559,7 @@ bool HighScoresDialog::save(Serializer& out, Int32 variation) const out.putString(myMD5); out.putInt(variation); - for (Int32 r = 0; r < NUM_RANKS; ++r) + for (uInt32 r = 0; r < NUM_RANKS; ++r) { out.putInt(myHighScores[r]); out.putInt(mySpecials[r]); @@ -586,7 +585,7 @@ bool HighScoresDialog::load(Serializer& in, Int32 variation) if (Int32(in.getInt()) != variation) return false; - for (Int32 r = 0; r < NUM_RANKS; ++r) + for (uInt32 r = 0; r < NUM_RANKS; ++r) { myHighScores[r] = in.getInt(); mySpecials[r] = in.getInt();