mirror of https://github.com/stella-emu/stella.git
Made CPU registers and program counter always show in hexidecimal.
Added 'Dec' and 'Bin' textboxes to CPU area to show the decimal and binary equivalents for the currently selected CPU register. This isn't done for the PC or status registers, since I don't feel it's important for those. Made the label textbox much longer for the PC, since there's now extra space there. git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@1703 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
This commit is contained in:
parent
cd4eb84425
commit
9d22c883d4
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: Debugger.cxx,v 1.135 2009-03-26 19:46:05 stephena Exp $
|
// $Id: Debugger.cxx,v 1.136 2009-04-13 15:17:06 stephena Exp $
|
||||||
//============================================================================
|
//============================================================================
|
||||||
|
|
||||||
#include "bspf.hxx"
|
#include "bspf.hxx"
|
||||||
|
@ -57,34 +57,34 @@ Debugger* Debugger::myStaticDebugger;
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
static const string builtin_functions[][3] = {
|
static const string builtin_functions[][3] = {
|
||||||
// { "name", "definition", "help text" }
|
// { "name", "definition", "help text" }
|
||||||
|
|
||||||
// left joystick:
|
// left joystick:
|
||||||
{ "_joy0left", "!(*SWCHA & $40)", "Left joystick moved left" },
|
{ "_joy0left", "!(*SWCHA & $40)", "Left joystick moved left" },
|
||||||
{ "_joy0right", "!(*SWCHA & $80)", "Left joystick moved right" },
|
{ "_joy0right", "!(*SWCHA & $80)", "Left joystick moved right" },
|
||||||
{ "_joy0up", "!(*SWCHA & $10)", "Left joystick moved up" },
|
{ "_joy0up", "!(*SWCHA & $10)", "Left joystick moved up" },
|
||||||
{ "_joy0down", "!(*SWCHA & $20)", "Left joystick moved down" },
|
{ "_joy0down", "!(*SWCHA & $20)", "Left joystick moved down" },
|
||||||
{ "_joy0button", "!(*INPT4 & $80)", "Left joystick button pressed" },
|
{ "_joy0button", "!(*INPT4 & $80)", "Left joystick button pressed" },
|
||||||
|
|
||||||
// right joystick:
|
// right joystick:
|
||||||
{ "_joy1left", "!(*SWCHA & $04)", "Right joystick moved left" },
|
{ "_joy1left", "!(*SWCHA & $04)", "Right joystick moved left" },
|
||||||
{ "_joy1right", "!(*SWCHA & $08)", "Right joystick moved right" },
|
{ "_joy1right", "!(*SWCHA & $08)", "Right joystick moved right" },
|
||||||
{ "_joy1up", "!(*SWCHA & $01)", "Right joystick moved up" },
|
{ "_joy1up", "!(*SWCHA & $01)", "Right joystick moved up" },
|
||||||
{ "_joy1down", "!(*SWCHA & $02)", "Right joystick moved down" },
|
{ "_joy1down", "!(*SWCHA & $02)", "Right joystick moved down" },
|
||||||
{ "_joy1button", "!(*INPT5 & $80)", "Right joystick button pressed" },
|
{ "_joy1button", "!(*INPT5 & $80)", "Right joystick button pressed" },
|
||||||
|
|
||||||
// console switches:
|
// console switches:
|
||||||
{ "_select", "!(*SWCHB & $02)", "Game Select pressed" },
|
{ "_select", "!(*SWCHB & $02)", "Game Select pressed" },
|
||||||
{ "_reset", "!(*SWCHB & $01)", "Game Reset pressed" },
|
{ "_reset", "!(*SWCHB & $01)", "Game Reset pressed" },
|
||||||
{ "_color", "*SWCHB & $08", "Color/BW set to Color" },
|
{ "_color", "*SWCHB & $08", "Color/BW set to Color" },
|
||||||
{ "_bw", "!(*SWCHB & $08)", "Color/BW set to BW" },
|
{ "_bw", "!(*SWCHB & $08)", "Color/BW set to BW" },
|
||||||
{ "_diff0b", "!(*SWCHB & $40)", "Left difficulty set to B (easy)" },
|
{ "_diff0b", "!(*SWCHB & $40)", "Left difficulty set to B (easy)" },
|
||||||
{ "_diff0a", "*SWCHB & $40", "Left difficulty set to A (hard)" },
|
{ "_diff0a", "*SWCHB & $40", "Left difficulty set to A (hard)" },
|
||||||
{ "_diff1b", "!(*SWCHB & $80)", "Right difficulty set to B (easy)" },
|
{ "_diff1b", "!(*SWCHB & $80)", "Right difficulty set to B (easy)" },
|
||||||
{ "_diff1a", "*SWCHB & $80", "Right difficulty set to A (hard)" },
|
{ "_diff1a", "*SWCHB & $80", "Right difficulty set to A (hard)" },
|
||||||
|
|
||||||
// empty string marks end of list, do not remove
|
// empty string marks end of list, do not remove
|
||||||
{ "", "", "" }
|
{ "", "", "" }
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -325,35 +325,34 @@ string Debugger::getSourceLines(int addr) const
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void Debugger::autoExec() {
|
void Debugger::autoExec()
|
||||||
// autoexec.stella is always run
|
{
|
||||||
myPrompt->print("autoExec():\n" +
|
// autoexec.stella is always run
|
||||||
myParser->exec(
|
const string& autoexec = myOSystem->baseDir(false) + BSPF_PATH_SEPARATOR +
|
||||||
myOSystem->baseDir() +
|
"autoexec.stella";
|
||||||
BSPF_PATH_SEPARATOR +
|
myPrompt->print("autoExec():\n" + myParser->exec(autoexec) + "\n");
|
||||||
"autoexec.stella") +
|
|
||||||
"\n");
|
|
||||||
|
|
||||||
// also, "romname.stella" if present
|
// Also, "romname.stella" if present
|
||||||
string file = myOSystem->romFile();
|
string file = myOSystem->romFile();
|
||||||
|
|
||||||
string::size_type pos;
|
string::size_type pos;
|
||||||
if( (pos = file.find_last_of('.')) != string::npos ) {
|
if( (pos = file.find_last_of('.')) != string::npos )
|
||||||
file.replace(pos, file.size(), ".stella");
|
file.replace(pos, file.size(), ".stella");
|
||||||
} else {
|
else
|
||||||
file += ".stella";
|
file += ".stella";
|
||||||
}
|
|
||||||
myPrompt->print("autoExec():\n" + myParser->exec(file) + "\n");
|
|
||||||
myPrompt->printPrompt();
|
|
||||||
|
|
||||||
// init builtins
|
myPrompt->print("autoExec():\n" + myParser->exec(file) + "\n");
|
||||||
for(int i=0; builtin_functions[i][0] != ""; i++) {
|
myPrompt->printPrompt();
|
||||||
string f = builtin_functions[i][1];
|
|
||||||
int res = YaccParser::parse(f.c_str());
|
// Init builtins
|
||||||
if(res != 0) cerr << "ERROR in builtin function!" << endl;
|
for(int i = 0; builtin_functions[i][0] != ""; i++)
|
||||||
Expression *exp = YaccParser::getResult();
|
{
|
||||||
addFunction(builtin_functions[i][0], builtin_functions[i][1], exp, true);
|
// TODO - check this for memory leaks
|
||||||
}
|
int res = YaccParser::parse(builtin_functions[i][1].c_str());
|
||||||
|
if(res != 0) cerr << "ERROR in builtin function!" << endl;
|
||||||
|
Expression* exp = YaccParser::getResult();
|
||||||
|
addFunction(builtin_functions[i][0], builtin_functions[i][1], exp, true);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: DebuggerParser.cxx,v 1.110 2009-01-14 20:31:07 stephena Exp $
|
// $Id: DebuggerParser.cxx,v 1.111 2009-04-13 15:17:06 stephena Exp $
|
||||||
//============================================================================
|
//============================================================================
|
||||||
|
|
||||||
#include <fstream>
|
#include <fstream>
|
||||||
|
@ -30,6 +30,7 @@
|
||||||
#include "YaccParser.hxx"
|
#include "YaccParser.hxx"
|
||||||
#include "M6502.hxx"
|
#include "M6502.hxx"
|
||||||
#include "Expression.hxx"
|
#include "Expression.hxx"
|
||||||
|
#include "FSNode.hxx"
|
||||||
#include "RomWidget.hxx"
|
#include "RomWidget.hxx"
|
||||||
|
|
||||||
#ifdef CHEATCODE_SUPPORT
|
#ifdef CHEATCODE_SUPPORT
|
||||||
|
@ -125,16 +126,14 @@ string DebuggerParser::run(const string& command)
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
string DebuggerParser::exec(const string& file, bool verbose)
|
string DebuggerParser::exec(const string& file, bool verbose)
|
||||||
{
|
{
|
||||||
string ret, path = file;
|
string ret;
|
||||||
int count = 0;
|
int count = 0;
|
||||||
char buffer[256]; // FIXME: static buffers suck
|
char buffer[256]; // FIXME: static buffers suck
|
||||||
|
|
||||||
if( file.find_last_of('.') == string::npos )
|
FilesystemNode node(file);
|
||||||
path += ".stella";
|
ifstream in(node.getPath().c_str());
|
||||||
|
|
||||||
ifstream in(path.c_str());
|
|
||||||
if(!in.is_open())
|
if(!in.is_open())
|
||||||
return red("file \"" + path + "\" not found.");
|
return red("file \'" + file + "\' not found.");
|
||||||
|
|
||||||
while( !in.eof() ) {
|
while( !in.eof() ) {
|
||||||
if(!in.getline(buffer, 255))
|
if(!in.getline(buffer, 255))
|
||||||
|
@ -152,7 +151,7 @@ string DebuggerParser::exec(const string& file, bool verbose)
|
||||||
ret += "Executed ";
|
ret += "Executed ";
|
||||||
ret += debugger->valueToString(count);
|
ret += debugger->valueToString(count);
|
||||||
ret += " commands from \"";
|
ret += " commands from \"";
|
||||||
ret += path;
|
ret += file;
|
||||||
ret += "\"\n";
|
ret += "\"\n";
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: CpuWidget.cxx,v 1.15 2009-01-01 18:13:35 stephena Exp $
|
// $Id: CpuWidget.cxx,v 1.16 2009-04-13 15:17:07 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -32,31 +32,6 @@
|
||||||
|
|
||||||
#include "CpuWidget.hxx"
|
#include "CpuWidget.hxx"
|
||||||
|
|
||||||
// ID's for the various widgets
|
|
||||||
// We need ID's, since there are more than one of several types of widgets
|
|
||||||
enum {
|
|
||||||
kPCRegID,
|
|
||||||
kCpuRegID
|
|
||||||
};
|
|
||||||
|
|
||||||
enum {
|
|
||||||
kPCRegAddr,
|
|
||||||
kSPRegAddr,
|
|
||||||
kARegAddr,
|
|
||||||
kXRegAddr,
|
|
||||||
kYRegAddr
|
|
||||||
};
|
|
||||||
|
|
||||||
enum {
|
|
||||||
kPSRegN = 0,
|
|
||||||
kPSRegV = 1,
|
|
||||||
kPSRegB = 3,
|
|
||||||
kPSRegD = 4,
|
|
||||||
kPSRegI = 5,
|
|
||||||
kPSRegZ = 6,
|
|
||||||
kPSRegC = 7
|
|
||||||
};
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
CpuWidget::CpuWidget(GuiObject* boss, const GUI::Font& font, int x, int y)
|
CpuWidget::CpuWidget(GuiObject* boss, const GUI::Font& font, int x, int y)
|
||||||
: Widget(boss, font, x, y, 16, 16),
|
: Widget(boss, font, x, y, 16, 16),
|
||||||
|
@ -73,20 +48,37 @@ CpuWidget::CpuWidget(GuiObject* boss, const GUI::Font& font, int x, int y)
|
||||||
xpos = x; ypos = y; lwidth = 4 * fontWidth;
|
xpos = x; ypos = y; lwidth = 4 * fontWidth;
|
||||||
new StaticTextWidget(boss, font, xpos, ypos+2, lwidth-2, fontHeight,
|
new StaticTextWidget(boss, font, xpos, ypos+2, lwidth-2, fontHeight,
|
||||||
"PC:", kTextAlignLeft);
|
"PC:", kTextAlignLeft);
|
||||||
myPCGrid = new DataGridWidget(boss, font, xpos + lwidth, ypos, 1, 1, 16, 16);
|
myPCGrid =
|
||||||
|
new DataGridWidget(boss, font, xpos + lwidth, ypos, 1, 1, 4, 16, kBASE_16);
|
||||||
myPCGrid->setTarget(this);
|
myPCGrid->setTarget(this);
|
||||||
myPCGrid->setID(kPCRegID);
|
myPCGrid->setID(kPCRegID);
|
||||||
addFocusWidget(myPCGrid);
|
addFocusWidget(myPCGrid);
|
||||||
|
|
||||||
// Create a read-only textbox containing the current PC label
|
// Create a read-only textbox containing the current PC label
|
||||||
xpos += lwidth + myPCGrid->getWidth() + 10;
|
xpos += lwidth + myPCGrid->getWidth() + 10;
|
||||||
myPCLabel = new EditTextWidget(boss, font, xpos, ypos, fontWidth*15,
|
myPCLabel = new EditTextWidget(boss, font, xpos, ypos, fontWidth*25,
|
||||||
lineHeight, "");
|
lineHeight, "");
|
||||||
myPCLabel->setEditable(false);
|
myPCLabel->setEditable(false);
|
||||||
|
|
||||||
|
// Create read-only textboxes for decimal and binary of currently selected item
|
||||||
|
ypos += myPCLabel->getHeight() + 5 + 5;
|
||||||
|
new StaticTextWidget(boss, font, xpos, ypos, 4*fontWidth, fontHeight,
|
||||||
|
"Dec:", kTextAlignLeft);
|
||||||
|
myDecValue = new EditTextWidget(boss, font, xpos+4*fontWidth + 5, ypos-2,
|
||||||
|
4*fontWidth, lineHeight, "");
|
||||||
|
myDecValue->setEditable(false);
|
||||||
|
|
||||||
|
ypos += myPCLabel->getHeight() + 5;
|
||||||
|
new StaticTextWidget(boss, font, xpos, ypos, 4*fontWidth, fontHeight,
|
||||||
|
"Bin:", kTextAlignLeft);
|
||||||
|
myBinValue = new EditTextWidget(boss, font, xpos+4*fontWidth + 5, ypos-2,
|
||||||
|
9*fontWidth, lineHeight, "");
|
||||||
|
myBinValue->setEditable(false);
|
||||||
|
|
||||||
// Create a 1x4 grid with labels for the other CPU registers
|
// Create a 1x4 grid with labels for the other CPU registers
|
||||||
xpos = x; ypos += myPCGrid->getHeight() + 1;
|
xpos = x; ypos += myPCGrid->getHeight() + 1 - 2*(myPCLabel->getHeight() + 5) - 5;
|
||||||
myCpuGrid = new DataGridWidget(boss, font, xpos + lwidth, ypos, 1, 4, 8, 8);
|
myCpuGrid =
|
||||||
|
new DataGridWidget(boss, font, xpos + lwidth, ypos, 1, 4, 2, 8, kBASE_16);
|
||||||
myCpuGrid->setTarget(this);
|
myCpuGrid->setTarget(this);
|
||||||
myCpuGrid->setID(kCpuRegID);
|
myCpuGrid->setID(kCpuRegID);
|
||||||
addFocusWidget(myCpuGrid);
|
addFocusWidget(myCpuGrid);
|
||||||
|
@ -148,6 +140,8 @@ void CpuWidget::handleCommand(CommandSender* sender, int cmd, int data, int id)
|
||||||
case kCpuRegID:
|
case kCpuRegID:
|
||||||
addr = myCpuGrid->getSelectedAddr();
|
addr = myCpuGrid->getSelectedAddr();
|
||||||
value = myCpuGrid->getSelectedValue();
|
value = myCpuGrid->getSelectedValue();
|
||||||
|
myDecValue->setEditString(instance().debugger().valueToString(value, kBASE_10));
|
||||||
|
myBinValue->setEditString(instance().debugger().valueToString(value, kBASE_2));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -181,6 +175,15 @@ void CpuWidget::handleCommand(CommandSender* sender, int cmd, int data, int id)
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case kDGSelectionChangedCmd:
|
||||||
|
if(id == kCpuRegID)
|
||||||
|
{
|
||||||
|
value = myCpuGrid->getSelectedValue();
|
||||||
|
myDecValue->setEditString(instance().debugger().valueToString(value, kBASE_10));
|
||||||
|
myBinValue->setEditString(instance().debugger().valueToString(value, kBASE_2));
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
case kTWItemDataChangedCmd:
|
case kTWItemDataChangedCmd:
|
||||||
{
|
{
|
||||||
bool state = myPSRegister->getSelectedState();
|
bool state = myPSRegister->getSelectedState();
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: CpuWidget.hxx,v 1.5 2009-01-01 18:13:35 stephena Exp $
|
// $Id: CpuWidget.hxx,v 1.6 2009-04-13 15:17:07 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -48,10 +48,37 @@ class CpuWidget : public Widget, public CommandSender
|
||||||
void fillGrid();
|
void fillGrid();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
// ID's for the various widgets
|
||||||
|
// We need ID's, since there are more than one of several types of widgets
|
||||||
|
enum {
|
||||||
|
kPCRegID,
|
||||||
|
kCpuRegID
|
||||||
|
};
|
||||||
|
|
||||||
|
enum {
|
||||||
|
kPCRegAddr,
|
||||||
|
kSPRegAddr,
|
||||||
|
kARegAddr,
|
||||||
|
kXRegAddr,
|
||||||
|
kYRegAddr
|
||||||
|
};
|
||||||
|
|
||||||
|
enum {
|
||||||
|
kPSRegN = 0,
|
||||||
|
kPSRegV = 1,
|
||||||
|
kPSRegB = 3,
|
||||||
|
kPSRegD = 4,
|
||||||
|
kPSRegI = 5,
|
||||||
|
kPSRegZ = 6,
|
||||||
|
kPSRegC = 7
|
||||||
|
};
|
||||||
|
|
||||||
DataGridWidget* myPCGrid;
|
DataGridWidget* myPCGrid;
|
||||||
DataGridWidget* myCpuGrid;
|
DataGridWidget* myCpuGrid;
|
||||||
ToggleBitWidget* myPSRegister;
|
ToggleBitWidget* myPSRegister;
|
||||||
EditTextWidget* myPCLabel;
|
EditTextWidget* myPCLabel;
|
||||||
|
EditTextWidget* myBinValue;
|
||||||
|
EditTextWidget* myDecValue;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
Loading…
Reference in New Issue