Added non-edit mode to DataGridWidget.

Some work on TIADebug.  Change tracking now works for the color
registers.  Getting/setting the color registers works (sort of,
since the change doesn't seem to be registering in TIA).

Some work on TiaWidget.  Color registers and scanline count are
shown.  VSync and VBlank are shown, but can't be changed.

Made CheckboxWidget only emit a signal when interactively
clicking on the checkbox (changing state programmatically no
longer emits the signal).  TODO: maybe two signals should be used??


git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@647 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
This commit is contained in:
stephena 2005-07-14 18:28:36 +00:00
parent 10298d8ba2
commit 0f4b93acf3
7 changed files with 158 additions and 74 deletions

View File

@ -13,7 +13,7 @@
// See the file "license" for information on usage and redistribution of
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
//
// $Id: TIADebug.cxx,v 1.10 2005-07-09 23:44:07 urchlay Exp $
// $Id: TIADebug.cxx,v 1.11 2005-07-14 18:28:35 stephena Exp $
//============================================================================
#include "System.hxx"
@ -44,6 +44,12 @@ DebuggerState& TIADebug::getState()
for(int i = 0; i < 0x010; ++i)
myState.ram.push_back(myTIA->peek(i));
myState.coluRegs.clear();
myState.coluRegs.push_back(coluP0());
myState.coluRegs.push_back(coluP1());
myState.coluRegs.push_back(coluPF());
myState.coluRegs.push_back(coluBK());
return myState;
}
@ -53,6 +59,56 @@ void TIADebug::saveOldState()
myOldState.ram.clear();
for(int i = 0; i < 0x010; ++i)
myOldState.ram.push_back(myTIA->peek(i));
myOldState.coluRegs.clear();
myOldState.coluRegs.push_back(coluP0());
myOldState.coluRegs.push_back(coluP1());
myOldState.coluRegs.push_back(coluPF());
myOldState.coluRegs.push_back(coluBK());
}
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
uInt8 TIADebug::coluP0(int newVal)
{
// TIA::myCOLUxx are stored 4 copies to each int,
// we need only 1 when fetching, but store all 4
if(newVal > -1)
myTIA->myCOLUP0 = (((((newVal << 8) | newVal) << 8) | newVal) << 8) | newVal;
return myTIA->myCOLUP0 & 0xff;
}
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
uInt8 TIADebug::coluP1(int newVal)
{
// TIA::myCOLUxx are stored 4 copies to each int,
// we need only 1 when fetching, but store all 4
if(newVal > -1)
myTIA->myCOLUP1 = (((((newVal << 8) | newVal) << 8) | newVal) << 8) | newVal;
return myTIA->myCOLUP1 & 0xff;
}
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
uInt8 TIADebug::coluPF(int newVal)
{
// TIA::myCOLUxx are stored 4 copies to each int,
// we need only 1 when fetching, but store all 4
if(newVal > -1)
myTIA->myCOLUPF = (((((newVal << 8) | newVal) << 8) | newVal) << 8) | newVal;
return myTIA->myCOLUPF & 0xff;
}
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
uInt8 TIADebug::coluBK(int newVal)
{
// TIA::myCOLUxx are stored 4 copies to each int,
// we need only 1 when fetching, but store all 4
if(newVal > -1)
myTIA->myCOLUBK = (((((newVal << 8) | newVal) << 8) | newVal) << 8) | newVal;
return myTIA->myCOLUBK & 0xff;
}
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
@ -141,11 +197,10 @@ string TIADebug::state()
// TODO: inverse video for changed regs. Core needs to track this.
// TODO: strobes? WSYNC RSYNC RESP0/1 RESM0/1 RESBL HMOVE HMCLR CXCLR
// TIA::myCOLUxx are stored 4 copies to each int, we need only 1
uInt8 COLUP0 = myTIA->myCOLUP0 & 0xff;
uInt8 COLUP1 = myTIA->myCOLUP1 & 0xff;
uInt8 COLUPF = myTIA->myCOLUPF & 0xff;
uInt8 COLUBK = myTIA->myCOLUBK & 0xff;
uInt8 COLUP0 = coluP0();
uInt8 COLUP1 = coluP1();
uInt8 COLUPF = coluPF();
uInt8 COLUBK = coluBK();
// TIA::myPF holds all 3 PFx regs, we shall extract
int PF = myTIA->myPF;

View File

@ -13,7 +13,7 @@
// See the file "license" for information on usage and redistribution of
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
//
// $Id: TIADebug.hxx,v 1.6 2005-07-08 17:22:40 stephena Exp $
// $Id: TIADebug.hxx,v 1.7 2005-07-14 18:28:35 stephena Exp $
//============================================================================
#ifndef TIA_DEBUG_HXX
@ -29,6 +29,7 @@ class TiaState : public DebuggerState
{
public:
IntArray ram;
IntArray coluRegs;
};
class TIADebug : public DebuggerSystem
@ -42,6 +43,10 @@ class TIADebug : public DebuggerSystem
void saveOldState();
// FIXME - add whole slew of setXXX() methods
uInt8 coluP0(int newVal = -1);
uInt8 coluP1(int newVal = -1);
uInt8 coluPF(int newVal = -1);
uInt8 coluBK(int newVal = -1);
int scanlines();
int frameCount();

View File

@ -13,7 +13,7 @@
// See the file "license" for information on usage and redistribution of
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
//
// $Id: Array.hxx,v 1.6 2005-07-02 18:34:54 stephena Exp $
// $Id: Array.hxx,v 1.7 2005-07-14 18:28:36 stephena Exp $
//
// Based on code from ScummVM - Scumm Interpreter
// Copyright (C) 2002-2004 The ScummVM project
@ -194,5 +194,6 @@ class Array
typedef GUI::Array<int> IntArray;
typedef GUI::Array<bool> BoolArray;
typedef GUI::Array<uInt8> ByteArray;
#endif

View File

@ -13,7 +13,7 @@
// See the file "license" for information on usage and redistribution of
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
//
// $Id: DataGridWidget.cxx,v 1.13 2005-07-07 15:19:04 stephena Exp $
// $Id: DataGridWidget.cxx,v 1.14 2005-07-14 18:28:36 stephena Exp $
//
// Based on code from ScummVM - Scumm Interpreter
// Copyright (C) 2002-2004 The ScummVM project
@ -297,42 +297,63 @@ bool DataGridWidget::handleKeyDown(int ascii, int keycode, int modifiers)
break;
case 'n': // negate
if(_editable)
{
negateCell();
dirty = true;
}
break;
case 'i': // invert
case '!':
if(_editable)
{
invertCell();
dirty = true;
}
break;
case '-': // decrement
if(_editable)
{
decrementCell();
dirty = true;
}
break;
case '+': // increment
case '=':
if(_editable)
{
incrementCell();
dirty = true;
}
break;
case '<': // shift left
case ',':
if(_editable)
{
lshiftCell();
dirty = true;
}
break;
case '>': // shift right
case '.':
if(_editable)
{
rshiftCell();
dirty = true;
}
break;
case 'z': // zero
if(_editable)
{
zeroCell();
dirty = true;
}
break;
default:

View File

@ -13,7 +13,7 @@
// See the file "license" for information on usage and redistribution of
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
//
// $Id: TiaWidget.cxx,v 1.9 2005-07-12 02:27:07 urchlay Exp $
// $Id: TiaWidget.cxx,v 1.10 2005-07-14 18:28:36 stephena Exp $
//
// Based on code from ScummVM - Scumm Interpreter
// Copyright (C) 2002-2004 The ScummVM project
@ -33,18 +33,18 @@
// ID's for the various widgets
// We need ID's, since there are more than one of several types of widgets
enum {
kRamID,
kColorRegsID,
kVSyncID,
kVBlankID
kRamID = 'TWra',
kColorRegsID = 'TWcr',
kVSyncID = 'TWvs',
kVBlankID = 'TWvb'
};
// Color registers
enum {
kCOLUP0Addr,
kCOLUP1Addr,
kCOLUBKAddr,
kCOLUPFAddr
kCOLUPFAddr,
kCOLUBKAddr
};
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
@ -60,6 +60,7 @@ TiaWidget::TiaWidget(GuiObject* boss, int x, int y, int w, int h)
// Create a 16x1 grid holding byte values with labels
myRamGrid = new DataGridWidget(boss, xpos+lwidth, ypos, 16, 1, 2, 8, kBASE_16);
myRamGrid->setEditable(false);
myRamGrid->setTarget(this);
myRamGrid->setID(kRamID);
myActiveWidget = myRamGrid;
@ -130,7 +131,7 @@ TiaWidget::TiaWidget(GuiObject* boss, int x, int y, int w, int h)
xpos = 10; ypos += 2* kLineHeight;
for(int row = 0; row < 4; ++row)
{
StaticTextWidget* t = new StaticTextWidget(boss, xpos, ypos + row*kLineHeight + 2,
new StaticTextWidget(boss, xpos, ypos + row*kLineHeight + 2,
40, kLineHeight,
regNames[row] + string(":"),
kTextAlignLeft);
@ -168,7 +169,7 @@ void TiaWidget::handleCommand(CommandSender* sender, int cmd, int data, int id)
// It will then send the 'kDGItemDataChangedCmd' signal to change the actual
// memory location
int addr, value;
const char* buf;
string buf;
Debugger& dbg = instance()->debugger();
@ -177,10 +178,6 @@ void TiaWidget::handleCommand(CommandSender* sender, int cmd, int data, int id)
case kDGItemDataChangedCmd:
switch(id)
{
case kRamID:
changeRam();
break;
case kColorRegsID:
changeColorRegs();
break;
@ -201,12 +198,10 @@ void TiaWidget::handleCommand(CommandSender* sender, int cmd, int data, int id)
addr = myRamGrid->getSelectedAddr();
value = myRamGrid->getSelectedValue();
buf = instance()->debugger().equates()->getLabel(addr).c_str();
if(*buf) myLabel->setEditString(buf);
else myLabel->setEditString("");
myLabel->setEditString(dbg.equates()->getLabel(addr));
myDecValue->setEditString(instance()->debugger().valueToString(value, kBASE_10));
myBinValue->setEditString(instance()->debugger().valueToString(value, kBASE_2));
myDecValue->setEditString(dbg.valueToString(value, kBASE_10));
myBinValue->setEditString(dbg.valueToString(value, kBASE_2));
break;
}
break;
@ -243,7 +238,8 @@ void TiaWidget::fillGrid()
IntArray vlist;
BoolArray changed;
TIADebug& tia = instance()->debugger().tiaDebug();
Debugger& dbg = instance()->debugger();
TIADebug& tia = dbg.tiaDebug();
TiaState state = (TiaState&) tia.getState();
TiaState oldstate = (TiaState&) tia.getOldState();
@ -258,40 +254,43 @@ void TiaWidget::fillGrid()
myRamGrid->setList(alist, vlist, changed);
// Scanline and VSync/VBlank
// FIXME
myScanlines->setEditString(dbg.valueToString(tia.scanlines(), kBASE_10));
myVSync->setState(tia.vsync());
myVBlank->setState(tia.vblank());
// Color registers
alist.clear(); vlist.clear(); changed.clear();
for(unsigned int i = 0; i < 4; i++)
{
alist.push_back(i);
vlist.push_back(i);
changed.push_back(false);
vlist.push_back(state.coluRegs[i]);
changed.push_back(state.coluRegs[i] != oldstate.coluRegs[i]);
}
myColorRegs->setList(alist, vlist, changed);
}
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
void TiaWidget::changeRam()
{
int addr = myRamGrid->getSelectedAddr();
int value = myRamGrid->getSelectedValue();
IntArray ram;
ram.push_back(addr);
ram.push_back(value);
// instance()->debugger().setRAM(ram);
myDecValue->setEditString(instance()->debugger().valueToString(value, kBASE_10));
myBinValue->setEditString(instance()->debugger().valueToString(value, kBASE_2));
}
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
void TiaWidget::changeColorRegs()
{
cerr << "TiaWidget::changeColorRegs()\n";
int addr = myColorRegs->getSelectedAddr();
int value = myColorRegs->getSelectedValue();
//FIXME instance()->debugger().writeRAM(addr - kRamStart, value);
switch(addr)
{
case kCOLUP0Addr:
instance()->debugger().tiaDebug().coluP0(value);
break;
case kCOLUP1Addr:
instance()->debugger().tiaDebug().coluP1(value);
break;
case kCOLUPFAddr:
instance()->debugger().tiaDebug().coluPF(value);
break;
case kCOLUBKAddr:
instance()->debugger().tiaDebug().coluBK(value);
break;
}
}

View File

@ -13,7 +13,7 @@
// See the file "license" for information on usage and redistribution of
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
//
// $Id: TiaWidget.hxx,v 1.4 2005-07-06 19:09:26 stephena Exp $
// $Id: TiaWidget.hxx,v 1.5 2005-07-14 18:28:36 stephena Exp $
//
// Based on code from ScummVM - Scumm Interpreter
// Copyright (C) 2002-2004 The ScummVM project
@ -46,7 +46,6 @@ class TiaWidget : public Widget, public CommandSender
private:
void fillGrid();
void changeRam();
void changeColorRegs();
private:

View File

@ -13,7 +13,7 @@
// See the file "license" for information on usage and redistribution of
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
//
// $Id: Widget.cxx,v 1.23 2005-07-06 15:09:16 stephena Exp $
// $Id: Widget.cxx,v 1.24 2005-07-14 18:28:36 stephena Exp $
//
// Based on code from ScummVM - Scumm Interpreter
// Copyright (C) 2002-2004 The ScummVM project
@ -246,17 +246,17 @@ void Widget::setNextInChain(Widget* start, Widget* hasFocus)
if(!start)
return;
// FIXME - get this working
cerr << "--------------------------------\nWidget list:\n";
//cerr << "--------------------------------\nWidget list:\n";
Widget* w1 = start;
while(w1)
{
if(w1->getFlags() & WIDGET_TAB_NAVIGATE)
{
cerr << w1 << endl;
// cerr << w1 << endl;
}
w1 = w1->_next;
}
cerr << "\n--------------------------------\n";
//cerr << "\n--------------------------------\n";
// We search the array in circular fashion until the 'end' is reached
@ -397,7 +397,12 @@ CheckboxWidget::CheckboxWidget(GuiObject *boss, int x, int y, int w, int h,
void CheckboxWidget::handleMouseUp(int x, int y, int button, int clickCount)
{
if(isEnabled() && x >= 0 && x < _w && y >= 0 && y < _h)
{
toggleState();
// We only send a command when the widget has been changed interactively
sendCommand(_cmd, _state, _id);
}
}
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
@ -409,7 +414,6 @@ void CheckboxWidget::setState(bool state)
_flags ^= WIDGET_INV_BORDER;
draw();
}
sendCommand(_cmd, _state, _id);
// Refresh the screen after the checkbox is drawn
// TODO - create dirty rectangle