From 4d99772a10f4ee09bd4eafc83ef424bfb62cb85b Mon Sep 17 00:00:00 2001 From: Stephen Anthony <sa666666@gmail.com> Date: Sat, 13 Apr 2019 22:26:53 -0230 Subject: [PATCH] More 'enum class' conversions. --- src/debugger/CartDebug.cxx | 20 +-- src/debugger/CartDebug.hxx | 9 +- src/debugger/DebuggerParser.cxx | 253 ++++++++++++++++---------------- src/debugger/DebuggerParser.hxx | 43 +++--- src/debugger/DiStella.cxx | 8 +- src/emucore/EventHandler.cxx | 54 +++---- src/emucore/EventHandler.hxx | 18 +-- src/emucore/M6502.hxx | 17 +-- src/emucore/M6532.hxx | 11 +- 9 files changed, 209 insertions(+), 224 deletions(-) diff --git a/src/debugger/CartDebug.cxx b/src/debugger/CartDebug.cxx index 42f6a0006..41c5ec5ec 100644 --- a/src/debugger/CartDebug.cxx +++ b/src/debugger/CartDebug.cxx @@ -523,8 +523,8 @@ bool CartDebug::addLabel(const string& label, uInt16 address) // Only user-defined labels can be added or redefined switch(addressType(address)) { - case ADDR_TIA: - case ADDR_IO: + case AddrType::TIA: + case AddrType::IO: return false; default: removeLabel(label); @@ -562,7 +562,7 @@ bool CartDebug::getLabel(ostream& buf, uInt16 addr, bool isRead, int places) con { switch(addressType(addr)) { - case ADDR_TIA: + case AddrType::TIA: { if(isRead) { @@ -591,7 +591,7 @@ bool CartDebug::getLabel(ostream& buf, uInt16 addr, bool isRead, int places) con return true; } - case ADDR_IO: + case AddrType::IO: { uInt16 a = addr & 0xFF, offset = addr & 0xFD00; if(a <= 0x97) @@ -611,7 +611,7 @@ bool CartDebug::getLabel(ostream& buf, uInt16 addr, bool isRead, int places) con return true; } - case ADDR_ZPRAM: + case AddrType::ZPRAM: { // RAM can use user-defined labels; otherwise we default to // standard mnemonics @@ -634,7 +634,7 @@ bool CartDebug::getLabel(ostream& buf, uInt16 addr, bool isRead, int places) con return true; } - case ADDR_ROM: + case AddrType::ROM: { // These addresses can never be in the system labels list const auto& iter = myUserLabels.find(addr); @@ -1317,21 +1317,21 @@ CartDebug::AddrType CartDebug::addressType(uInt16 addr) const if(addr % 0x2000 < 0x1000) { if((addr & 0x00ff) < 0x80) - return ADDR_TIA; + return AddrType::TIA; else { switch(addr & 0x0f00) { case 0x000: case 0x100: case 0x400: case 0x500: case 0x800: case 0x900: case 0xc00: case 0xd00: - return ADDR_ZPRAM; + return AddrType::ZPRAM; case 0x200: case 0x300: case 0x600: case 0x700: case 0xa00: case 0xb00: case 0xe00: case 0xf00: - return ADDR_IO; + return AddrType::IO; } } } - return ADDR_ROM; + return AddrType::ROM; } // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - diff --git a/src/debugger/CartDebug.hxx b/src/debugger/CartDebug.hxx index da886682d..205c89dff 100644 --- a/src/debugger/CartDebug.hxx +++ b/src/debugger/CartDebug.hxx @@ -47,7 +47,7 @@ class CartDebug : public DebuggerSystem friend class DiStella; public: - enum DisasmType { + enum DisasmType { // TODO - make this 'enum class' NONE = 0, REFERENCED = 1 << 0, /* 0x01, code somewhere in the program references it, i.e. LDA $F372 referenced $F372 */ @@ -86,12 +86,7 @@ class CartDebug : public DebuggerSystem }; // Determine 'type' of address (ie, what part of the system accessed) - enum AddrType { - ADDR_TIA, - ADDR_IO, - ADDR_ZPRAM, - ADDR_ROM - }; + enum class AddrType { TIA, IO, ZPRAM, ROM }; AddrType addressType(uInt16 addr) const; public: diff --git a/src/debugger/DebuggerParser.cxx b/src/debugger/DebuggerParser.cxx index d3c36d70e..238994277 100644 --- a/src/debugger/DebuggerParser.cxx +++ b/src/debugger/DebuggerParser.cxx @@ -110,7 +110,7 @@ string DebuggerParser::run(const string& command) getArgs(command, verb); commandResult.str(""); - for(int i = 0; i < kNumCommands; ++i) + for(uInt32 i = 0; i < NumCommands; ++i) { if(BSPF::equalsIgnoreCase(verb, commands[i].cmdString)) { @@ -177,7 +177,7 @@ void DebuggerParser::outputCommandError(const string& errorMsg, int command) void DebuggerParser::getCompletions(const char* in, StringList& completions) const { // cerr << "Attempting to complete \"" << in << "\"" << endl; - for(int i = 0; i < kNumCommands; ++i) + for(uInt32 i = 0; i < NumCommands; ++i) { if(BSPF::matches(commands[i].cmdString, in)) completions.push_back(commands[i].cmdString); @@ -332,7 +332,8 @@ string DebuggerParser::showWatches() // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - bool DebuggerParser::getArgs(const string& command, string& verb) { - int state = kIN_COMMAND, i = 0, length = int(command.length()); + ParseState state = ParseState::IN_COMMAND; + uInt32 i = 0, length = uInt32(command.length()); string curArg = ""; verb = ""; @@ -348,23 +349,23 @@ bool DebuggerParser::getArgs(const string& command, string& verb) char c = command[i++]; switch(state) { - case kIN_COMMAND: + case ParseState::IN_COMMAND: if(c == ' ') - state = kIN_SPACE; + state = ParseState::IN_SPACE; else verb += c; break; - case kIN_SPACE: + case ParseState::IN_SPACE: if(c == '{') - state = kIN_BRACE; + state = ParseState::IN_BRACE; else if(c != ' ') { - state = kIN_ARG; + state = ParseState::IN_ARG; curArg += c; } break; - case kIN_BRACE: + case ParseState::IN_BRACE: if(c == '}') { - state = kIN_SPACE; + state = ParseState::IN_SPACE; argStrings.push_back(curArg); // cerr << "{" << curArg << "}" << endl; curArg = ""; @@ -372,9 +373,9 @@ bool DebuggerParser::getArgs(const string& command, string& verb) curArg += c; } break; - case kIN_ARG: + case ParseState::IN_ARG: if(c == ' ') { - state = kIN_SPACE; + state = ParseState::IN_SPACE; argStrings.push_back(curArg); curArg = ""; } else { @@ -410,7 +411,7 @@ bool DebuggerParser::validateArgs(int cmd) { // cerr << "entering validateArgs(" << cmd << ")" << endl; bool required = commands[cmd].parmsRequired; - parameters* p = commands[cmd].parms; + Parameters* p = commands[cmd].parms; if(argCount == 0) { @@ -426,7 +427,7 @@ bool DebuggerParser::validateArgs(int cmd) // Figure out how many arguments are required by the command uInt32 count = 0, argRequiredCount = 0; - while(*p != kARG_END_ARGS && *p != kARG_MULTI_BYTE) + while(*p != Parameters::ARG_END_ARGS && *p != Parameters::ARG_MULTI_BYTE) { ++count; ++p; @@ -434,7 +435,7 @@ bool DebuggerParser::validateArgs(int cmd) // Evil hack: some commands intentionally take multiple arguments // In this case, the required number of arguments is unbounded - argRequiredCount = (*p == kARG_END_ARGS) ? count : argCount; + argRequiredCount = (*p == Parameters::ARG_END_ARGS) ? count : argCount; p = commands[cmd].parms; uInt32 curCount = 0; @@ -448,7 +449,7 @@ bool DebuggerParser::validateArgs(int cmd) switch(*p) { - case kARG_DWORD: + case Parameters::ARG_DWORD: #if 0 // TODO - do we need error checking at all here? if(curArgInt > 0xffffffff) { @@ -458,7 +459,7 @@ bool DebuggerParser::validateArgs(int cmd) #endif break; - case kARG_WORD: + case Parameters::ARG_WORD: if(curArgInt > 0xffff) { commandResult.str(red("invalid word argument (must be 0-$ffff)")); @@ -466,7 +467,7 @@ bool DebuggerParser::validateArgs(int cmd) } break; - case kARG_BYTE: + case Parameters::ARG_BYTE: if(curArgInt > 0xff) { commandResult.str(red("invalid byte argument (must be 0-$ff)")); @@ -474,7 +475,7 @@ bool DebuggerParser::validateArgs(int cmd) } break; - case kARG_BOOL: + case Parameters::ARG_BOOL: if(curArgInt != 0 && curArgInt != 1) { commandResult.str(red("invalid boolean argument (must be 0 or 1)")); @@ -482,7 +483,7 @@ bool DebuggerParser::validateArgs(int cmd) } break; - case kARG_BASE_SPCL: + case Parameters::ARG_BASE_SPCL: if(curArgInt != 2 && curArgInt != 10 && curArgInt != 16 && curArgStr != "hex" && curArgStr != "dec" && curArgStr != "bin") { @@ -491,21 +492,21 @@ bool DebuggerParser::validateArgs(int cmd) } break; - case kARG_LABEL: - case kARG_FILE: + case Parameters::ARG_LABEL: + case Parameters::ARG_FILE: break; // TODO: validate these (for now any string's allowed) - case kARG_MULTI_BYTE: - case kARG_MULTI_WORD: + case Parameters::ARG_MULTI_BYTE: + case Parameters::ARG_MULTI_WORD: break; // FIXME: validate these (for now, any number's allowed) - case kARG_END_ARGS: + case Parameters::ARG_END_ARGS: break; } ++curCount; ++p; - } while(*p != kARG_END_ARGS && curCount < argRequiredCount); + } while(*p != Parameters::ARG_END_ARGS && curCount < argRequiredCount); /* cerr << "curCount = " << curCount << endl @@ -1240,14 +1241,14 @@ void DebuggerParser::executeHelp() { // Find length of longest command uInt32 clen = 0; - for(int i = 0; i < kNumCommands; ++i) + for(uInt32 i = 0; i < NumCommands; ++i) { uInt32 len = uInt32(commands[i].cmdString.length()); if(len > clen) clen = len; } commandResult << setfill(' '); - for(int i = 0; i < kNumCommands; ++i) + for(uInt32 i = 0; i < NumCommands; ++i) commandResult << setw(clen) << right << commands[i].cmdString << " - " << commands[i].description << endl; @@ -1255,7 +1256,7 @@ void DebuggerParser::executeHelp() } else // get help for specific command { - for(int i = 0; i < kNumCommands; ++i) + for(uInt32 i = 0; i < NumCommands; ++i) { if(argStrings[0] == commands[i].cmdString) { @@ -2040,7 +2041,7 @@ void DebuggerParser::executeTrapRW(uInt32 addr, bool read, bool write, bool add) { switch(debugger.cartDebug().addressType(addr)) { - case CartDebug::ADDR_TIA: + case CartDebug::AddrType::TIA: { for(uInt32 i = 0; i <= 0xFFFF; ++i) { @@ -2055,7 +2056,7 @@ void DebuggerParser::executeTrapRW(uInt32 addr, bool read, bool write, bool add) } break; } - case CartDebug::ADDR_IO: + case CartDebug::AddrType::IO: { for(uInt32 i = 0; i <= 0xFFFF; ++i) { @@ -2069,7 +2070,7 @@ void DebuggerParser::executeTrapRW(uInt32 addr, bool read, bool write, bool add) } break; } - case CartDebug::ADDR_ZPRAM: + case CartDebug::AddrType::ZPRAM: { for(uInt32 i = 0; i <= 0xFFFF; ++i) { @@ -2083,7 +2084,7 @@ void DebuggerParser::executeTrapRW(uInt32 addr, bool read, bool write, bool add) } break; } - case CartDebug::ADDR_ROM: + case CartDebug::AddrType::ROM: { if(addr >= 0x1000 && addr <= 0xFFFF) { @@ -2220,14 +2221,14 @@ void DebuggerParser::executeZ() // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - // List of all commands available to the parser -DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { +DebuggerParser::Command DebuggerParser::commands[NumCommands] = { { "a", "Set Accumulator to <value>", "Valid value is 0 - ff\nExample: a ff, a #10", true, true, - { kARG_BYTE, kARG_END_ARGS }, + { Parameters::ARG_BYTE, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeA) }, @@ -2237,7 +2238,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Base is #2, #10, #16, bin, dec or hex\nExample: base hex", true, true, - { kARG_BASE_SPCL, kARG_END_ARGS }, + { Parameters::ARG_BASE_SPCL, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeBase) }, @@ -2248,7 +2249,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: break, break f000", false, true, - { kARG_WORD, kARG_END_ARGS }, + { Parameters::ARG_WORD, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeBreak) }, @@ -2258,7 +2259,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Condition can include multiple items, see documentation\nExample: breakif _scan>100", true, false, - { kARG_WORD, kARG_END_ARGS }, + { Parameters::ARG_WORD, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeBreakif) }, @@ -2268,7 +2269,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: c, c 0, c 1", false, true, - { kARG_BOOL, kARG_END_ARGS }, + { Parameters::ARG_BOOL, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeC) }, @@ -2278,7 +2279,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: cheat 0040, cheat abff00", false, false, - { kARG_LABEL, kARG_END_ARGS }, + { Parameters::ARG_LABEL, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeCheat) }, @@ -2288,7 +2289,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: clearbreaks (no parameters)", false, true, - { kARG_END_ARGS }, + { Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeClearbreaks) }, @@ -2298,7 +2299,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: clearconfig 0, clearconfig 1", false, false, - { kARG_WORD, kARG_MULTI_BYTE }, + { Parameters::ARG_WORD, Parameters::ARG_MULTI_BYTE }, std::mem_fn(&DebuggerParser::executeClearconfig) }, @@ -2308,7 +2309,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: clearsavestateifss (no parameters)", false, true, - { kARG_END_ARGS }, + { Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeClearsavestateifs) }, @@ -2318,7 +2319,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "All traps cleared, including any mirrored ones\nExample: cleartraps (no parameters)", false, false, - { kARG_END_ARGS }, + { Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeCleartraps) }, @@ -2328,7 +2329,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: clearwatches (no parameters)", false, false, - { kARG_END_ARGS }, + { Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeClearwatches) }, @@ -2338,7 +2339,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Completely clears screen, but keeps history of commands", false, false, - { kARG_END_ARGS }, + { Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeCls) }, @@ -2348,7 +2349,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Start and end of range required\nExample: code f000 f010", true, false, - { kARG_WORD, kARG_MULTI_BYTE }, + { Parameters::ARG_WORD, Parameters::ARG_MULTI_BYTE }, std::mem_fn(&DebuggerParser::executeCode) }, @@ -2358,7 +2359,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Shows a color swatch for the given value\nExample: colortest 1f", true, false, - { kARG_BYTE, kARG_END_ARGS }, + { Parameters::ARG_BYTE, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeColortest) }, @@ -2368,7 +2369,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: d, d 0, d 1", false, true, - { kARG_BOOL, kARG_END_ARGS }, + { Parameters::ARG_BOOL, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeD) }, @@ -2378,7 +2379,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Start and end of range required\nExample: data f000 f010", true, false, - { kARG_WORD, kARG_MULTI_BYTE }, + { Parameters::ARG_WORD, Parameters::ARG_MULTI_BYTE }, std::mem_fn(&DebuggerParser::executeData) }, @@ -2388,7 +2389,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: debugcolors (no parameters)", false, false, - { kARG_END_ARGS }, + { Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeDebugColors) }, @@ -2398,7 +2399,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: define LABEL1 f100", true, true, - { kARG_LABEL, kARG_WORD, kARG_END_ARGS }, + { Parameters::ARG_LABEL, Parameters::ARG_WORD, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeDefine) }, @@ -2408,7 +2409,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: delbreakif 0", true, false, - { kARG_WORD, kARG_END_ARGS }, + { Parameters::ARG_WORD, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeDelbreakif) }, @@ -2418,7 +2419,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: delfunction FUNC1", true, false, - { kARG_LABEL, kARG_END_ARGS }, + { Parameters::ARG_LABEL, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeDelfunction) }, @@ -2428,7 +2429,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: delsavestateif 0", true, false, - { kARG_WORD, kARG_END_ARGS }, + { Parameters::ARG_WORD, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeDelsavestateif) }, @@ -2438,7 +2439,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: deltrap 0", true, false, - { kARG_WORD, kARG_END_ARGS }, + { Parameters::ARG_WORD, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeDeltrap) }, @@ -2448,7 +2449,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: delwatch 0", true, false, - { kARG_WORD, kARG_END_ARGS }, + { Parameters::ARG_WORD, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeDelwatch) }, @@ -2459,7 +2460,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: disasm, disasm f000 100", false, false, - { kARG_WORD, kARG_MULTI_BYTE }, + { Parameters::ARG_WORD, Parameters::ARG_MULTI_BYTE }, std::mem_fn(&DebuggerParser::executeDisasm) }, @@ -2472,7 +2473,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { " dump f000 f0ff 7 - dumps all bytes from f000 to f0ff, CPU state and input registers into a file", true, false, - { kARG_WORD, kARG_MULTI_BYTE }, + { Parameters::ARG_WORD, Parameters::ARG_MULTI_BYTE }, std::mem_fn(&DebuggerParser::executeDump) }, @@ -2482,7 +2483,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: exec script.dat, exec auto.txt", true, true, - { kARG_FILE, kARG_LABEL, kARG_MULTI_BYTE }, + { Parameters::ARG_FILE, Parameters::ARG_LABEL, Parameters::ARG_MULTI_BYTE }, std::mem_fn(&DebuggerParser::executeExec) }, @@ -2492,7 +2493,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Self-explanatory", false, false, - { kARG_END_ARGS }, + { Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeExitRom) }, @@ -2502,7 +2503,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: frame, frame 100", false, true, - { kARG_WORD, kARG_END_ARGS }, + { Parameters::ARG_WORD, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeFrame) }, @@ -2512,7 +2513,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: function FUNC1 { ... }", true, false, - { kARG_LABEL, kARG_WORD, kARG_END_ARGS }, + { Parameters::ARG_LABEL, Parameters::ARG_WORD, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeFunction) }, @@ -2522,7 +2523,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Start and end of range required\nExample: gfx f000 f010", true, false, - { kARG_WORD, kARG_MULTI_BYTE }, + { Parameters::ARG_WORD, Parameters::ARG_MULTI_BYTE }, std::mem_fn(&DebuggerParser::executeGfx) }, @@ -2533,7 +2534,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: help, help code", false, false, - { kARG_LABEL, kARG_END_ARGS }, + { Parameters::ARG_LABEL, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeHelp) }, @@ -2543,7 +2544,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: joy0up 0", false, true, - { kARG_BOOL, kARG_END_ARGS }, + { Parameters::ARG_BOOL, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeJoy0Up) }, @@ -2553,7 +2554,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: joy0down 0", false, true, - { kARG_BOOL, kARG_END_ARGS }, + { Parameters::ARG_BOOL, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeJoy0Down) }, @@ -2563,7 +2564,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: joy0left 0", false, true, - { kARG_BOOL, kARG_END_ARGS }, + { Parameters::ARG_BOOL, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeJoy0Left) }, @@ -2573,7 +2574,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: joy0left 0", false, true, - { kARG_BOOL, kARG_END_ARGS }, + { Parameters::ARG_BOOL, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeJoy0Right) }, @@ -2583,7 +2584,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: joy0fire 0", false, true, - { kARG_BOOL, kARG_END_ARGS }, + { Parameters::ARG_BOOL, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeJoy0Fire) }, @@ -2593,7 +2594,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: joy1up 0", false, true, - { kARG_BOOL, kARG_END_ARGS }, + { Parameters::ARG_BOOL, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeJoy1Up) }, @@ -2603,7 +2604,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: joy1down 0", false, true, - { kARG_BOOL, kARG_END_ARGS }, + { Parameters::ARG_BOOL, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeJoy1Down) }, @@ -2613,7 +2614,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: joy1left 0", false, true, - { kARG_BOOL, kARG_END_ARGS }, + { Parameters::ARG_BOOL, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeJoy1Left) }, @@ -2623,7 +2624,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: joy1left 0", false, true, - { kARG_BOOL, kARG_END_ARGS }, + { Parameters::ARG_BOOL, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeJoy1Right) }, @@ -2633,7 +2634,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: joy1fire 0", false, true, - { kARG_BOOL, kARG_END_ARGS }, + { Parameters::ARG_BOOL, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeJoy1Fire) }, @@ -2643,7 +2644,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Moves disassembly listing to address <xx>\nExample: jump f400", true, false, - { kARG_WORD, kARG_END_ARGS }, + { Parameters::ARG_WORD, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeJump) }, @@ -2653,7 +2654,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: listbreaks (no parameters)", false, false, - { kARG_END_ARGS }, + { Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeListbreaks) }, @@ -2663,7 +2664,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: listconfig 0, listconfig 1", false, false, - { kARG_WORD, kARG_MULTI_BYTE }, + { Parameters::ARG_WORD, Parameters::ARG_MULTI_BYTE }, std::mem_fn(&DebuggerParser::executeListconfig) }, @@ -2673,7 +2674,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: listfunctions (no parameters)", false, false, - { kARG_END_ARGS }, + { Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeListfunctions) }, @@ -2683,7 +2684,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: listsavestateifs (no parameters)", false, false, - { kARG_END_ARGS }, + { Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeListsavestateifs) }, @@ -2693,7 +2694,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Lists all traps (read and/or write)\nExample: listtraps (no parameters)", false, false, - { kARG_END_ARGS }, + { Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeListtraps) }, @@ -2703,7 +2704,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: loadconfig file.cfg", false, true, - { kARG_END_ARGS }, + { Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeLoadconfig) }, @@ -2713,7 +2714,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: loadstate 0, loadstate 9", true, true, - { kARG_BYTE, kARG_END_ARGS }, + { Parameters::ARG_BYTE, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeLoadstate) }, @@ -2723,7 +2724,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: n, n 0, n 1", false, true, - { kARG_BOOL, kARG_END_ARGS }, + { Parameters::ARG_BOOL, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeN) }, @@ -2733,7 +2734,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: palette (no parameters)", false, false, - { kARG_END_ARGS }, + { Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executePalette) }, @@ -2743,7 +2744,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: pc f000", true, true, - { kARG_WORD, kARG_END_ARGS }, + { Parameters::ARG_WORD, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executePc) }, @@ -2753,7 +2754,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Start and end of range required\nExample: pgfx f000 f010", true, false, - { kARG_WORD, kARG_MULTI_BYTE }, + { Parameters::ARG_WORD, Parameters::ARG_MULTI_BYTE }, std::mem_fn(&DebuggerParser::executePGfx) }, @@ -2764,7 +2765,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: print pc, print f000", true, false, - { kARG_DWORD, kARG_END_ARGS }, + { Parameters::ARG_DWORD, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executePrint) }, @@ -2774,7 +2775,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: ram, ram 80 00 ...", false, true, - { kARG_WORD, kARG_MULTI_BYTE }, + { Parameters::ARG_WORD, Parameters::ARG_MULTI_BYTE }, std::mem_fn(&DebuggerParser::executeRam) }, @@ -2784,7 +2785,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "System is completely reset, just as if it was just powered on", false, true, - { kARG_END_ARGS }, + { Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeReset) }, @@ -2794,7 +2795,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: rewind, rewind 5", false, true, - { kARG_WORD, kARG_END_ARGS }, + { Parameters::ARG_WORD, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeRewind) }, @@ -2804,7 +2805,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Display text-based output of the contents of the RIOT tab", false, false, - { kARG_END_ARGS }, + { Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeRiot) }, @@ -2815,7 +2816,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: rom f000 00 01 ff ...", true, true, - { kARG_WORD, kARG_MULTI_BYTE }, + { Parameters::ARG_WORD, Parameters::ARG_MULTI_BYTE }, std::mem_fn(&DebuggerParser::executeRom) }, @@ -2825,7 +2826,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Start and end of range required\nExample: row f000 f010", true, false, - { kARG_WORD, kARG_MULTI_BYTE }, + { Parameters::ARG_WORD, Parameters::ARG_MULTI_BYTE }, std::mem_fn(&DebuggerParser::executeRow) }, @@ -2835,7 +2836,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Self-explanatory", false, false, - { kARG_END_ARGS }, + { Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeRun) }, @@ -2846,7 +2847,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: runto lda", true, true, - { kARG_LABEL, kARG_END_ARGS }, + { Parameters::ARG_LABEL, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeRunTo) }, @@ -2856,7 +2857,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: runtopc f200", true, true, - { kARG_WORD, kARG_END_ARGS }, + { Parameters::ARG_WORD, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeRunToPc) }, @@ -2866,7 +2867,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Accepts 8-bit value, Example: s f0", true, true, - { kARG_BYTE, kARG_END_ARGS }, + { Parameters::ARG_BYTE, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeS) }, @@ -2876,7 +2877,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: save commands.script", true, false, - { kARG_FILE, kARG_END_ARGS }, + { Parameters::ARG_FILE, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeSave) }, @@ -2886,7 +2887,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: saveconfig", false, false, - { kARG_END_ARGS }, + { Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeSaveconfig) }, @@ -2897,7 +2898,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "NOTE: saves to default save location", false, false, - { kARG_END_ARGS }, + { Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeSavedisassembly) }, @@ -2908,7 +2909,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "NOTE: saves to default save location", false, false, - { kARG_END_ARGS }, + { Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeSaverom) }, @@ -2919,7 +2920,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "NOTE: saves to default save location", false, false, - { kARG_END_ARGS }, + { Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeSaveses) }, @@ -2930,7 +2931,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: savesnap (no parameters)", false, false, - { kARG_END_ARGS }, + { Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeSavesnap) }, @@ -2940,7 +2941,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: savestate 0, savestate 9", true, false, - { kARG_BYTE, kARG_END_ARGS }, + { Parameters::ARG_BYTE, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeSavestate) }, @@ -2950,7 +2951,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Condition can include multiple items, see documentation\nExample: savestateif pc==f000", true, false, - { kARG_WORD, kARG_END_ARGS }, + { Parameters::ARG_WORD, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeSavestateif) }, @@ -2960,7 +2961,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: scanline, scanline 100", false, true, - { kARG_WORD, kARG_END_ARGS }, + { Parameters::ARG_WORD, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeScanline) }, @@ -2970,7 +2971,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: step, step 100", false, true, - { kARG_WORD, kARG_END_ARGS }, + { Parameters::ARG_WORD, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeStep) }, @@ -2980,7 +2981,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: stepwhile pc!=$f2a9", true, true, - { kARG_WORD, kARG_END_ARGS }, + { Parameters::ARG_WORD, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeStepwhile) }, @@ -2990,7 +2991,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Display text-based output of the contents of the TIA tab", false, false, - { kARG_END_ARGS }, + { Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeTia) }, @@ -3000,7 +3001,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: trace, trace 100", false, true, - { kARG_WORD, kARG_END_ARGS }, + { Parameters::ARG_WORD, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeTrace) }, @@ -3011,7 +3012,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: trap f000, trap f000 f100", true, false, - { kARG_WORD, kARG_MULTI_BYTE }, + { Parameters::ARG_WORD, Parameters::ARG_MULTI_BYTE }, std::mem_fn(&DebuggerParser::executeTrap) }, @@ -3022,7 +3023,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: trapif _scan>#100 GRP0, trapif _bank==1 f000 f100", true, false, - { kARG_WORD, kARG_MULTI_BYTE }, + { Parameters::ARG_WORD, Parameters::ARG_MULTI_BYTE }, std::mem_fn(&DebuggerParser::executeTrapif) }, @@ -3033,7 +3034,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: trapread f000, trapread f000 f100", true, false, - { kARG_WORD, kARG_MULTI_BYTE }, + { Parameters::ARG_WORD, Parameters::ARG_MULTI_BYTE }, std::mem_fn(&DebuggerParser::executeTrapread) }, @@ -3044,7 +3045,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: trapreadif _scan>#100 GRP0, trapreadif _bank==1 f000 f100", true, false, - { kARG_WORD, kARG_MULTI_BYTE }, + { Parameters::ARG_WORD, Parameters::ARG_MULTI_BYTE }, std::mem_fn(&DebuggerParser::executeTrapreadif) }, @@ -3055,7 +3056,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: trapwrite f000, trapwrite f000 f100", true, false, - { kARG_WORD, kARG_MULTI_BYTE }, + { Parameters::ARG_WORD, Parameters::ARG_MULTI_BYTE }, std::mem_fn(&DebuggerParser::executeTrapwrite) }, @@ -3066,7 +3067,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: trapwriteif _scan>#100 GRP0, trapwriteif _bank==1 f000 f100", true, false, - { kARG_WORD, kARG_MULTI_BYTE }, + { Parameters::ARG_WORD, Parameters::ARG_MULTI_BYTE }, std::mem_fn(&DebuggerParser::executeTrapwriteif) }, @@ -3076,7 +3077,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: type f000, type f000 f010", true, false, - { kARG_WORD, kARG_MULTI_BYTE }, + { Parameters::ARG_WORD, Parameters::ARG_MULTI_BYTE }, std::mem_fn(&DebuggerParser::executeType) }, @@ -3087,7 +3088,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: uhex (no parameters)", false, true, - { kARG_END_ARGS }, + { Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeUHex) }, @@ -3097,7 +3098,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: undef LABEL1", true, true, - { kARG_LABEL, kARG_END_ARGS }, + { Parameters::ARG_LABEL, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeUndef) }, @@ -3107,7 +3108,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: unwind, unwind 5", false, true, - { kARG_WORD, kARG_END_ARGS }, + { Parameters::ARG_WORD, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeUnwind) }, @@ -3117,7 +3118,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: v, v 0, v 1", false, true, - { kARG_BOOL, kARG_END_ARGS }, + { Parameters::ARG_BOOL, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeV) }, @@ -3127,7 +3128,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: watch ram_80", true, false, - { kARG_WORD, kARG_END_ARGS }, + { Parameters::ARG_WORD, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeWatch) }, @@ -3137,7 +3138,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Valid value is 0 - ff\nExample: x ff, x #10", true, true, - { kARG_BYTE, kARG_END_ARGS }, + { Parameters::ARG_BYTE, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeX) }, @@ -3147,7 +3148,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Valid value is 0 - ff\nExample: y ff, y #10", true, true, - { kARG_BYTE, kARG_END_ARGS }, + { Parameters::ARG_BYTE, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeY) }, @@ -3157,7 +3158,7 @@ DebuggerParser::Command DebuggerParser::commands[kNumCommands] = { "Example: z, z 0, z 1", false, true, - { kARG_BOOL, kARG_END_ARGS }, + { Parameters::ARG_BOOL, Parameters::ARG_END_ARGS }, std::mem_fn(&DebuggerParser::executeZ) } }; diff --git a/src/debugger/DebuggerParser.hxx b/src/debugger/DebuggerParser.hxx index 17bf0bfad..063173540 100644 --- a/src/debugger/DebuggerParser.hxx +++ b/src/debugger/DebuggerParser.hxx @@ -66,38 +66,40 @@ class DebuggerParser string saveScriptFile(string file); private: - enum { kNumCommands = 92 }; - // Constants for argument processing - enum { - kIN_COMMAND, - kIN_SPACE, - kIN_BRACE, - kIN_ARG + enum class ParseState { + IN_COMMAND, + IN_SPACE, + IN_BRACE, + IN_ARG }; - enum parameters { - kARG_WORD, // single 16-bit value - kARG_DWORD, // single 32-bit value - kARG_MULTI_WORD, // multiple 16-bit values (must occur last) - kARG_BYTE, // single 8-bit value - kARG_MULTI_BYTE, // multiple 8-bit values (must occur last) - kARG_BOOL, // 0 or 1 only - kARG_LABEL, // label (need not be defined, treated as string) - kARG_FILE, // filename - kARG_BASE_SPCL, // base specifier: 2, 10, or 16 (or "bin" "dec" "hex") - kARG_END_ARGS // sentinel, occurs at end of list + enum class Parameters { + ARG_WORD, // single 16-bit value + ARG_DWORD, // single 32-bit value + ARG_MULTI_WORD, // multiple 16-bit values (must occur last) + ARG_BYTE, // single 8-bit value + ARG_MULTI_BYTE, // multiple 8-bit values (must occur last) + ARG_BOOL, // 0 or 1 only + ARG_LABEL, // label (need not be defined, treated as string) + ARG_FILE, // filename + ARG_BASE_SPCL, // base specifier: 2, 10, or 16 (or "bin" "dec" "hex") + ARG_END_ARGS // sentinel, occurs at end of list }; + // List of commands available + static constexpr uInt32 NumCommands = 92; struct Command { string cmdString; string description; string extendedDesc; bool parmsRequired; bool refreshRequired; - parameters parms[10]; + Parameters parms[10]; std::function<void (DebuggerParser*)> executor; }; + static Command commands[NumCommands]; + struct Trap { bool read; @@ -233,9 +235,6 @@ class DebuggerParser void executeY(); void executeZ(); - // List of commands available - static Command commands[kNumCommands]; - private: // Following constructors and assignment operators not supported DebuggerParser() = delete; diff --git a/src/debugger/DiStella.cxx b/src/debugger/DiStella.cxx index 8a331a5df..8944382c5 100644 --- a/src/debugger/DiStella.cxx +++ b/src/debugger/DiStella.cxx @@ -81,7 +81,7 @@ DiStella::DiStella(const CartDebug& dbg, CartDebug::DisassemblyList& list, // multi-byte instruction, then we make note of that address for reference // // However, we only do this for labels pointing to ROM (above $1000) - if (myDbg.addressType(k + myOffset) == CartDebug::ADDR_ROM) { + if (myDbg.addressType(k + myOffset) == CartDebug::AddrType::ROM) { reservedLabel.str(""); reservedLabel << "L" << Base::HEX4 << (k + myOffset); myReserved.Label.emplace(k + myOffset, reservedLabel.str()); @@ -877,11 +877,11 @@ int DiStella::mark(uInt32 address, uInt8 mask, bool directive) // Check for equates before ROM/ZP-RAM accesses, because the original logic // of Distella assumed either equates or ROM; it didn't take ZP-RAM into account CartDebug::AddrType type = myDbg.addressType(address); - if (type == CartDebug::ADDR_TIA) { + if (type == CartDebug::AddrType::TIA) { return 2; - } else if (type == CartDebug::ADDR_IO) { + } else if (type == CartDebug::AddrType::IO) { return 3; - } else if (type == CartDebug::ADDR_ZPRAM && myOffset != 0) { + } else if (type == CartDebug::AddrType::ZPRAM && myOffset != 0) { return 5; } else if (address >= uInt32(myOffset) && address <= uInt32(myAppData.end + myOffset)) { myLabels[address - myOffset] = myLabels[address - myOffset] | mask; diff --git a/src/emucore/EventHandler.cxx b/src/emucore/EventHandler.cxx index 3a18b2e24..4efe12bca 100644 --- a/src/emucore/EventHandler.cxx +++ b/src/emucore/EventHandler.cxx @@ -75,8 +75,8 @@ EventHandler::EventHandler(OSystem& osystem) myPJoyHandler = make_unique<PhysicalJoystickHandler>(osystem, *this, myEvent); // Erase the 'combo' array - for(int i = 0; i < kComboSize; ++i) - for(int j = 0; j < kEventsPerCombo; ++j) + for(int i = 0; i < COMBO_SIZE; ++i) + for(int j = 0; j < EVENTS_PER_COMBO; ++j) myComboTable[i][j] = Event::NoType; } @@ -442,7 +442,7 @@ void EventHandler::handleEvent(Event::Type event, bool pressed) case Event::Combo14: case Event::Combo15: case Event::Combo16: - for(int i = 0, combo = event - Event::Combo1; i < kEventsPerCombo; ++i) + for(int i = 0, combo = event - Event::Combo1; i < EVENTS_PER_COMBO; ++i) if(myComboTable[combo][i] != Event::NoType) handleEvent(myComboTable[combo][i], pressed); return; @@ -690,11 +690,11 @@ void EventHandler::setActionMappings(EventMode mode) switch(mode) { case kEmulationMode: - listsize = kEmulActionListSize; + listsize = EMUL_ACTIONLIST_SIZE; list = ourEmulActionList; break; case kMenuMode: - listsize = kMenuActionListSize; + listsize = MENU_ACTIONLIST_SIZE; list = ourMenuActionList; break; default: @@ -768,8 +768,8 @@ void EventHandler::setComboMap() // Erase the 'combo' array auto ERASE_ALL = [&]() { - for(int i = 0; i < kComboSize; ++i) - for(int j = 0; j < kEventsPerCombo; ++j) + for(int i = 0; i < COMBO_SIZE; ++i) + for(int j = 0; j < EVENTS_PER_COMBO; ++j) myComboTable[i][j] = Event::NoType; }; @@ -781,18 +781,18 @@ void EventHandler::setComboMap() { string key; buf >> key; - if(atoi(key.c_str()) == kComboSize) + if(atoi(key.c_str()) == COMBO_SIZE) { // Fill the combomap table with events for as long as they exist int combocount = 0; - while(buf >> key && combocount < kComboSize) + while(buf >> key && combocount < COMBO_SIZE) { // Each event in a comboevent is separated by a comma replace(key.begin(), key.end(), ',', ' '); istringstream buf2(key); int eventcount = 0; - while(buf2 >> key && eventcount < kEventsPerCombo) + while(buf2 >> key && eventcount < EVENTS_PER_COMBO) { myComboTable[combocount][eventcount] = Event::Type(atoi(key.c_str())); ++eventcount; @@ -931,11 +931,11 @@ void EventHandler::saveComboMapping() // For each combo event, create a comma-separated list of its events // Prepend the event count, so we can check it on next load ostringstream buf; - buf << kComboSize; - for(int i = 0; i < kComboSize; ++i) + buf << COMBO_SIZE; + for(int i = 0; i < COMBO_SIZE; ++i) { buf << ":" << myComboTable[i][0]; - for(int j = 1; j < kEventsPerCombo; ++j) + for(int j = 1; j < EVENTS_PER_COMBO; ++j) buf << "," << myComboTable[i][j]; } myOSystem.settings().setValue("combomap", buf.str()); @@ -948,11 +948,11 @@ StringList EventHandler::getActionList(EventMode mode) const switch(mode) { case kEmulationMode: - for(uInt32 i = 0; i < kEmulActionListSize; ++i) + for(uInt32 i = 0; i < EMUL_ACTIONLIST_SIZE; ++i) l.push_back(EventHandler::ourEmulActionList[i].action); break; case kMenuMode: - for(uInt32 i = 0; i < kMenuActionListSize; ++i) + for(uInt32 i = 0; i < MENU_ACTIONLIST_SIZE; ++i) l.push_back(EventHandler::ourMenuActionList[i].action); break; default: @@ -969,7 +969,7 @@ VariantList EventHandler::getComboList(EventMode /**/) const ostringstream buf; VarList::push_back(l, "None", "-1"); - for(uInt32 i = 0; i < kEmulActionListSize; ++i) + for(uInt32 i = 0; i < EMUL_ACTIONLIST_SIZE; ++i) { if(EventHandler::ourEmulActionList[i].allow_combo) { @@ -989,10 +989,10 @@ StringList EventHandler::getComboListForEvent(Event::Type event) const if(event >= Event::Combo1 && event <= Event::Combo16) { int combo = event - Event::Combo1; - for(uInt32 i = 0; i < kEventsPerCombo; ++i) + for(uInt32 i = 0; i < EVENTS_PER_COMBO; ++i) { Event::Type e = myComboTable[combo][i]; - for(uInt32 j = 0; j < kEmulActionListSize; ++j) + for(uInt32 j = 0; j < EMUL_ACTIONLIST_SIZE; ++j) { if(EventHandler::ourEmulActionList[j].event == e && EventHandler::ourEmulActionList[j].allow_combo) @@ -1020,7 +1020,7 @@ void EventHandler::setComboListForEvent(Event::Type event, const StringList& eve for(int i = 0; i < 8; ++i) { int idx = atoi(events[i].c_str()); - if(idx >=0 && idx < kEmulActionListSize) + if(idx >= 0 && idx < EMUL_ACTIONLIST_SIZE) myComboTable[combo][i] = EventHandler::ourEmulActionList[idx].event; else myComboTable[combo][i] = Event::NoType; @@ -1035,12 +1035,12 @@ Event::Type EventHandler::eventAtIndex(int idx, EventMode mode) const switch(mode) { case kEmulationMode: - if(idx < 0 || idx >= kEmulActionListSize) + if(idx < 0 || idx >= EMUL_ACTIONLIST_SIZE) return Event::NoType; else return ourEmulActionList[idx].event; case kMenuMode: - if(idx < 0 || idx >= kMenuActionListSize) + if(idx < 0 || idx >= MENU_ACTIONLIST_SIZE) return Event::NoType; else return ourMenuActionList[idx].event; @@ -1055,12 +1055,12 @@ string EventHandler::actionAtIndex(int idx, EventMode mode) const switch(mode) { case kEmulationMode: - if(idx < 0 || idx >= kEmulActionListSize) + if(idx < 0 || idx >= EMUL_ACTIONLIST_SIZE) return EmptyString; else return ourEmulActionList[idx].action; case kMenuMode: - if(idx < 0 || idx >= kMenuActionListSize) + if(idx < 0 || idx >= MENU_ACTIONLIST_SIZE) return EmptyString; else return ourMenuActionList[idx].action; @@ -1075,12 +1075,12 @@ string EventHandler::keyAtIndex(int idx, EventMode mode) const switch(mode) { case kEmulationMode: - if(idx < 0 || idx >= kEmulActionListSize) + if(idx < 0 || idx >= EMUL_ACTIONLIST_SIZE) return EmptyString; else return ourEmulActionList[idx].key; case kMenuMode: - if(idx < 0 || idx >= kMenuActionListSize) + if(idx < 0 || idx >= MENU_ACTIONLIST_SIZE) return EmptyString; else return ourMenuActionList[idx].key; @@ -1268,7 +1268,7 @@ void EventHandler::setState(EventHandlerState state) } // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -EventHandler::ActionList EventHandler::ourEmulActionList[kEmulActionListSize] = { +EventHandler::ActionList EventHandler::ourEmulActionList[EMUL_ACTIONLIST_SIZE] = { { Event::ConsoleSelect, "Select", "", true }, { Event::ConsoleReset, "Reset", "", true }, { Event::ConsoleColor, "Color TV", "", true }, @@ -1380,7 +1380,7 @@ EventHandler::ActionList EventHandler::ourEmulActionList[kEmulActionListSize] = }; // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -EventHandler::ActionList EventHandler::ourMenuActionList[kMenuActionListSize] = { +EventHandler::ActionList EventHandler::ourMenuActionList[MENU_ACTIONLIST_SIZE] = { { Event::UIUp, "Move Up", "", false }, { Event::UIDown, "Move Down", "", false }, { Event::UILeft, "Move Left", "", false }, diff --git a/src/emucore/EventHandler.hxx b/src/emucore/EventHandler.hxx index cbec19b40..5ee949c7f 100644 --- a/src/emucore/EventHandler.hxx +++ b/src/emucore/EventHandler.hxx @@ -360,12 +360,12 @@ class EventHandler void removePhysicalJoystick(int index); private: - enum { - kComboSize = 16, - kEventsPerCombo = 8, - kEmulActionListSize = 83 + kComboSize, - kMenuActionListSize = 14 - }; + static constexpr Int32 + COMBO_SIZE = 16, + EVENTS_PER_COMBO = 8, + EMUL_ACTIONLIST_SIZE = 83 + COMBO_SIZE, + MENU_ACTIONLIST_SIZE = 14 + ; /** The following methods take care of assigning action mappings. @@ -403,7 +403,7 @@ class EventHandler unique_ptr<MouseControl> myMouseControl; // The event(s) assigned to each combination event - Event::Type myComboTable[kComboSize][kEventsPerCombo]; + Event::Type myComboTable[COMBO_SIZE][EVENTS_PER_COMBO]; // Indicates the current state of the system (ie, which mode is current) EventHandlerState myState; @@ -423,8 +423,8 @@ class EventHandler bool myIs7800; // Holds static strings for the remap menu (emulation and menu events) - static ActionList ourEmulActionList[kEmulActionListSize]; - static ActionList ourMenuActionList[kMenuActionListSize]; + static ActionList ourEmulActionList[EMUL_ACTIONLIST_SIZE]; + static ActionList ourMenuActionList[MENU_ACTIONLIST_SIZE]; // Following constructors and assignment operators not supported EventHandler() = delete; diff --git a/src/emucore/M6502.hxx b/src/emucore/M6502.hxx index c3065ba69..ba10f138e 100644 --- a/src/emucore/M6502.hxx +++ b/src/emucore/M6502.hxx @@ -326,13 +326,12 @@ class M6502 : public Serializable handled such as stopping execution, fatal errors, maskable interrupts and non-maskable interrupts (in myExecutionStatus) */ - enum - { - StopExecutionBit = 0x01, - FatalErrorBit = 0x02, - MaskableInterruptBit = 0x04, + static constexpr uInt8 + StopExecutionBit = 0x01, + FatalErrorBit = 0x02, + MaskableInterruptBit = 0x04, NonmaskableInterruptBit = 0x08 - }; + ; uInt8 myExecutionStatus; /// Pointer to the system the processor is installed in or the null pointer @@ -397,12 +396,6 @@ class M6502 : public Serializable bool myHaltRequested; #ifdef DEBUGGER_SUPPORT - enum CondAction - { - breakAction, - saveStateAction - }; - Int32 evalCondBreaks() { for(uInt32 i = 0; i < myCondBreaks.size(); i++) if(myCondBreaks[i]->evaluate()) diff --git a/src/emucore/M6532.hxx b/src/emucore/M6532.hxx index 8e5d0c54c..b57f3be2d 100644 --- a/src/emucore/M6532.hxx +++ b/src/emucore/M6532.hxx @@ -155,13 +155,6 @@ class M6532 : public Device #endif // DEBUGGER_SUPPORT private: - // Accessible bits in the interrupt flag register - // All other bits are always zeroed - enum { - TimerBit = 0x80, - PA7Bit = 0x40 - }; - // Reference to the console const ConsoleIO& myConsole; @@ -212,6 +205,10 @@ class M6532 : public Device // Last value written to the timer registers uInt8 myOutTimer[4]; + // Accessible bits in the interrupt flag register + // All other bits are always zeroed + static constexpr uInt8 TimerBit = 0x80, PA7Bit = 0x40; + #ifdef DEBUGGER_SUPPORT // The arrays containing information about every byte of RIOT // indicating whether and how (RW) it is used.