From 916cf17b80a7e6556e3f0c17e154f99680f9182e Mon Sep 17 00:00:00 2001 From: thrust26 Date: Mon, 6 Aug 2018 10:51:45 +0200 Subject: [PATCH 1/9] more background dialog widget color adjustments --- docs/graphics/cheat.png | Bin 3655 -> 3717 bytes src/gui/CheckListWidget.cxx | 7 ++++--- src/gui/EditTextWidget.cxx | 7 +++++-- src/gui/RomInfoWidget.cxx | 4 ++-- src/gui/StringListWidget.cxx | 3 ++- src/gui/TabWidget.cxx | 2 +- src/gui/Widget.cxx | 11 +++++++---- 7 files changed, 21 insertions(+), 13 deletions(-) diff --git a/docs/graphics/cheat.png b/docs/graphics/cheat.png index 63c4bc1be671ba4a65eb9f06ec9e3802527287fe..c9979db34fe2152f7ad6d0457bb9096d3bc047d6 100644 GIT binary patch literal 3717 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 literal 3655 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 L?JP<$9?|~*dAvlp diff --git a/src/gui/CheckListWidget.cxx b/src/gui/CheckListWidget.cxx index 53c747794..859fc5439 100644 --- a/src/gui/CheckListWidget.cxx +++ b/src/gui/CheckListWidget.cxx @@ -96,6 +96,7 @@ void CheckListWidget::drawWidget(bool hilite) { //cerr << "CheckListWidget::drawWidget\n"; FBSurface& s = _boss->dialog().surface(); + bool onTop = _boss->dialog().isOnTop(); int i, pos, len = int(_list.size()); // Draw a thin frame around the list and to separate columns @@ -126,17 +127,17 @@ void CheckListWidget::drawWidget(bool hilite) } else s.frameRect(_x + r.left - 3, _y + 1 + _fontHeight * i, - _w - r.left, _fontHeight, kTextColorHi); + _w - r.left, _fontHeight, onTop ? kTextColorHi : kColor); } if (_selectedItem == pos && _editMode) { adjustOffset(); - s.drawString(_font, editString(), _x + r.left, y, r.width(), kTextColor, + s.drawString(_font, editString(), _x + r.left, y, r.width(), onTop ? kTextColor : kColor, TextAlign::Left, -_editScrollOffset, false); } else - s.drawString(_font, _list[pos], _x + r.left, y, r.width(), textColor); + s.drawString(_font, _list[pos], _x + r.left, y, r.width(), onTop ? textColor : kColor); } // Only draw the caret while editing, and if it's in the current viewport diff --git a/src/gui/EditTextWidget.cxx b/src/gui/EditTextWidget.cxx index d0dcf8fa8..35b1670f1 100644 --- a/src/gui/EditTextWidget.cxx +++ b/src/gui/EditTextWidget.cxx @@ -28,7 +28,7 @@ EditTextWidget::EditTextWidget(GuiObject* boss, const GUI::Font& font, _changed(false) { _flags = WIDGET_ENABLED | WIDGET_CLEARBG | WIDGET_RETAIN_FOCUS; - + startEditMode(); // We're always in edit mode } @@ -80,6 +80,7 @@ void EditTextWidget::handleMouseDown(int x, int y, MouseButton b, int clickCount void EditTextWidget::drawWidget(bool hilite) { FBSurface& s = _boss->dialog().surface(); + bool onTop = _boss->dialog().isOnTop(); // Highlight changes if(_changed) @@ -96,7 +97,9 @@ void EditTextWidget::drawWidget(bool hilite) // Draw the text adjustOffset(); s.drawString(_font, editString(), _x + 2, _y + 2, getEditRect().width(), - !_changed ? _textcolor : uInt32(kDbgChangedTextColor), + !_changed + ? onTop ? _textcolor : kColor + : uInt32(kDbgChangedTextColor), TextAlign::Left, -_editScrollOffset, false); // Draw the caret diff --git a/src/gui/RomInfoWidget.cxx b/src/gui/RomInfoWidget.cxx index 744f0e215..74f03003d 100644 --- a/src/gui/RomInfoWidget.cxx +++ b/src/gui/RomInfoWidget.cxx @@ -166,13 +166,13 @@ void RomInfoWidget::drawWidget(bool hilite) const GUI::Font& font = instance().frameBuffer().font(); uInt32 x = _x + ((_w - font.getStringWidth(mySurfaceErrorMsg)) >> 1); uInt32 y = _y + ((yoff - font.getLineHeight()) >> 1); - s.drawString(font, mySurfaceErrorMsg, x, y, _w - 10, _textcolor); + s.drawString(font, mySurfaceErrorMsg, x, y, _w - 10, onTop ? _textcolor : _shadowcolor); } int xpos = _x + 8, ypos = _y + yoff + 10; for(const auto& info: myRomInfo) { - s.drawString(_font, info, xpos, ypos, _w - 16, _textcolor); + s.drawString(_font, info, xpos, ypos, _w - 16, onTop ? _textcolor : _shadowcolor); ypos += _font.getLineHeight(); } } diff --git a/src/gui/StringListWidget.cxx b/src/gui/StringListWidget.cxx index 6ddd46dbe..3e6f0da15 100644 --- a/src/gui/StringListWidget.cxx +++ b/src/gui/StringListWidget.cxx @@ -58,6 +58,7 @@ void StringListWidget::handleMouseLeft() void StringListWidget::drawWidget(bool hilite) { FBSurface& s = _boss->dialog().surface(); + bool onTop = _boss->dialog().isOnTop(); int i, pos, len = int(_list.size()); // Draw a thin frame around the list. @@ -67,7 +68,7 @@ void StringListWidget::drawWidget(bool hilite) for (i = 0, pos = _currentPos; i < _rows && pos < len; i++, pos++) { const int y = _y + 2 + _fontHeight * i; - uInt32 textColor = kTextColor; + uInt32 textColor = onTop ? kTextColor : kShadowColor; // Draw the selected item inverted, on a highlighted background. if (_selectedItem == pos && _hilite) diff --git a/src/gui/TabWidget.cxx b/src/gui/TabWidget.cxx index 64fe23df7..0ac9cc217 100644 --- a/src/gui/TabWidget.cxx +++ b/src/gui/TabWidget.cxx @@ -268,7 +268,7 @@ void TabWidget::drawWidget(bool hilite) int i, x = _x + kTabLeftOffset; for (i = 0; i < int(_tabs.size()); ++i) { - uInt32 fontcolor = _tabs[i].enabled ? kTextColor : kColor; + uInt32 fontcolor = _tabs[i].enabled && onTop? kTextColor : kColor; int yOffset = (i == _activeTab) ? 0 : 1; s.fillRect(x, _y + 1, _tabWidth, _tabHeight - 1, (i == _activeTab) diff --git a/src/gui/Widget.cxx b/src/gui/Widget.cxx index 4c20e8745..f77d0e057 100644 --- a/src/gui/Widget.cxx +++ b/src/gui/Widget.cxx @@ -354,8 +354,9 @@ void StaticTextWidget::setLabel(const string& label) void StaticTextWidget::drawWidget(bool hilite) { FBSurface& s = _boss->dialog().surface(); + bool onTop = _boss->dialog().isOnTop(); s.drawString(_font, _label, _x, _y, _w, - isEnabled() ? _textcolor : uInt32(kColor), _align, 0, true, _shadowcolor); + isEnabled() && onTop ? _textcolor : uInt32(kColor), _align, 0, true, _shadowcolor); setDirty(); } @@ -542,6 +543,7 @@ CheckboxWidget::CheckboxWidget(GuiObject* boss, const GUI::Font& font, { _flags = WIDGET_ENABLED; _bgcolor = _bgcolorhi = kWidColor; + _bgcolorlo = kDlgColor; _editable = true; @@ -638,19 +640,20 @@ void CheckboxWidget::setState(bool state, bool changed) void CheckboxWidget::drawWidget(bool hilite) { FBSurface& s = _boss->dialog().surface(); + bool onTop = _boss->dialog().isOnTop(); if(_drawBox) - s.frameRect(_x, _y + _boxY, 14, 14, hilite && isEnabled() && isEditable() ? kWidColorHi : kColor); + s.frameRect(_x, _y + _boxY, 14, 14, onTop && hilite && isEnabled() && isEditable() ? kWidColorHi : kColor); // Do we draw a square or cross? s.fillRect(_x + 1, _y + _boxY + 1, 12, 12, _changed ? uInt32(kDbgChangedColor) : isEnabled() ? _bgcolor : uInt32(kColor)); if(_state) - s.drawBitmap(_img, _x + 2, _y + _boxY + 2, isEnabled() ? hilite && isEditable() ? kWidColorHi : kCheckColor + s.drawBitmap(_img, _x + 2, _y + _boxY + 2, onTop && isEnabled() ? hilite && isEditable() ? kWidColorHi : kCheckColor : kColor, 10); // Finally draw the label s.drawString(_font, _label, _x + 20, _y + _textY, _w, - isEnabled() ? kTextColor : kColor); + onTop && isEnabled() ? kTextColor : kColor); setDirty(); } From 5614fb0e761d133adfd2d3744b38fb504be47256 Mon Sep 17 00:00:00 2001 From: thrust26 Date: Mon, 6 Aug 2018 14:48:11 +0200 Subject: [PATCH 2/9] fixed warning in EditTextWidget --- src/gui/EditTextWidget.cxx | 3 --- 1 file changed, 3 deletions(-) diff --git a/src/gui/EditTextWidget.cxx b/src/gui/EditTextWidget.cxx index 35b1670f1..8b6ad7679 100644 --- a/src/gui/EditTextWidget.cxx +++ b/src/gui/EditTextWidget.cxx @@ -86,10 +86,7 @@ void EditTextWidget::drawWidget(bool hilite) if(_changed) s.fillRect(_x, _y, _w, _h, kDbgChangedColor); else if(!isEditable()) - { - bool onTop = _boss->dialog().isOnTop(); s.fillRect(_x, _y, _w, _h, onTop ? kDlgColor : kBGColorLo); - } // Draw a thin frame around us. s.frameRect(_x, _y, _w, _h, hilite && isEditable() && isEnabled() ? kWidColorHi : kColor); From 1bf33fc4d2303ae7a6bcf4022a997b7df1d18851 Mon Sep 17 00:00:00 2001 From: Stephen Anthony Date: Mon, 6 Aug 2018 11:13:13 -0230 Subject: [PATCH 3/9] Remove superfluous declaration. --- src/gui/StringListWidget.cxx | 3 --- 1 file changed, 3 deletions(-) diff --git a/src/gui/StringListWidget.cxx b/src/gui/StringListWidget.cxx index 3e6f0da15..dc53b427d 100644 --- a/src/gui/StringListWidget.cxx +++ b/src/gui/StringListWidget.cxx @@ -79,10 +79,7 @@ void StringListWidget::drawWidget(bool hilite) textColor = kTextColorInv; } else - { - bool onTop = _boss->dialog().isOnTop(); s.frameRect(_x + 1, _y + 1 + _fontHeight * i, _w - 1, _fontHeight, onTop ? kWidColorHi : kBGColorLo); - } } GUI::Rect r(getEditRect()); From 68eec27c5cd5ae39fab0890f991cb36b41f7ea91 Mon Sep 17 00:00:00 2001 From: Stephen Anthony Date: Mon, 6 Aug 2018 11:14:57 -0230 Subject: [PATCH 4/9] Make FilesystemNode class non-virtual. - this class is never inherited, so it's pointless for it to have virtual methods --- src/emucore/FSNode.hxx | 28 +++++++++++++--------------- 1 file changed, 13 insertions(+), 15 deletions(-) diff --git a/src/emucore/FSNode.hxx b/src/emucore/FSNode.hxx index 160274a5b..9e417e144 100644 --- a/src/emucore/FSNode.hxx +++ b/src/emucore/FSNode.hxx @@ -92,8 +92,6 @@ class FilesystemNode */ explicit FilesystemNode(const string& path); - virtual ~FilesystemNode() = default; - /** * Assignment operators. */ @@ -136,7 +134,7 @@ class FilesystemNode * * @return bool true if the path exists, false otherwise. */ - virtual bool exists() const; + bool exists() const; /** * Return a list of child nodes of this directory node. If called on a node @@ -145,8 +143,8 @@ class FilesystemNode * @return true if successful, false otherwise (e.g. when the directory * does not exist). */ - virtual bool getChildren(FSList& fslist, ListMode mode = kListDirectoriesOnly, - bool hidden = false) const; + bool getChildren(FSList& fslist, ListMode mode = kListDirectoriesOnly, + bool hidden = false) const; /** * Return a string representation of the name of the file. This is can be @@ -156,7 +154,7 @@ class FilesystemNode * * @return the file name */ - virtual const string& getName() const; + const string& getName() const; /** * Return a string representation of the file which can be passed to fopen(). @@ -165,7 +163,7 @@ class FilesystemNode * * @return the 'path' represented by this filesystem node */ - virtual const string& getPath() const; + const string& getPath() const; /** * Return a string representation of the file which contains the '~' @@ -174,7 +172,7 @@ class FilesystemNode * * @return the 'path' represented by this filesystem node */ - virtual string getShortPath() const; + string getShortPath() const; /** * Determine whether this node has a parent. @@ -190,14 +188,14 @@ class FilesystemNode /** * Indicates whether the path refers to a directory or not. */ - virtual bool isDirectory() const; + bool isDirectory() const; /** * Indicates whether the path refers to a real file or not. * * Currently, a symlink or pipe is not considered a file. */ - virtual bool isFile() const; + bool isFile() const; /** * Indicates whether the object referred by this path can be read from or not. @@ -210,7 +208,7 @@ class FilesystemNode * * @return bool true if the object can be read, false otherwise. */ - virtual bool isReadable() const; + bool isReadable() const; /** * Indicates whether the object referred by this path can be written to or not. @@ -224,21 +222,21 @@ class FilesystemNode * * @return bool true if the object can be written to, false otherwise. */ - virtual bool isWritable() const; + bool isWritable() const; /** * Create a directory from the current node path. * * @return bool true if the directory was created, false otherwise. */ - virtual bool makeDir(); + bool makeDir(); /** * Rename the current node path with the new given name. * * @return bool true if the node was renamed, false otherwise. */ - virtual bool rename(const string& newfile); + bool rename(const string& newfile); /** * Read data (binary format) into the given buffer. @@ -249,7 +247,7 @@ class FilesystemNode * This method can throw exceptions, and should be used inside * a try-catch block. */ - virtual uInt32 read(BytePtr& buffer) const; + uInt32 read(BytePtr& buffer) const; /** * The following methods are almost exactly the same as the various From 64fd3f50f9026f73dfd3b4b515c5cf39c3d29184 Mon Sep 17 00:00:00 2001 From: Stephen Anthony Date: Mon, 6 Aug 2018 11:22:55 -0230 Subject: [PATCH 5/9] For FSNodeUNIX, use actual symlink name instead of underlying name (fixes #325), --- Changes.txt | 7 +++++-- src/unix/FSNodePOSIX.cxx | 11 +++++++---- 2 files changed, 12 insertions(+), 6 deletions(-) diff --git a/Changes.txt b/Changes.txt index 0a0fe01cc..d2619c8aa 100644 --- a/Changes.txt +++ b/Changes.txt @@ -52,8 +52,11 @@ * Fixed emulator crash when starting SaveKey ROMs from commandline with SaveKey messages enabled. - * Fixed missing TV format update in frame stats dialog when switching display - type. + * Fixed missing TV format update in frame stats dialog when switching + display type. + + * For UNIX systems: in the ROM launcher, when using symlinks use the + symlink pathname instead of the underlying filesystem pathname. * Updated PAL palette. diff --git a/src/unix/FSNodePOSIX.cxx b/src/unix/FSNodePOSIX.cxx index 8cdff324f..7a68dcad5 100644 --- a/src/unix/FSNodePOSIX.cxx +++ b/src/unix/FSNodePOSIX.cxx @@ -63,10 +63,13 @@ FilesystemNodePOSIX::FilesystemNodePOSIX(const string& p, bool verify) _path.replace(0, 1, home); } - // Get absolute path - char buf[MAXPATHLEN]; - if(realpath(_path.c_str(), buf)) - _path = buf; + // Get absolute path (only used for relative directories) + if(_path[0] == '.') + { + char buf[MAXPATHLEN]; + if(realpath(_path.c_str(), buf)) + _path = buf; + } _displayName = lastPathComponent(_path); From 24bb06e8b19c74d980e674960cd590ec4e1081cd Mon Sep 17 00:00:00 2001 From: Stephen Anthony Date: Mon, 6 Aug 2018 11:43:58 -0230 Subject: [PATCH 6/9] Updated changelog. --- Changes.txt | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/Changes.txt b/Changes.txt index d2619c8aa..9009860af 100644 --- a/Changes.txt +++ b/Changes.txt @@ -14,6 +14,9 @@ 5.1.3 to 6.0: (MMM d, 2018) + * Note: because of major TIA sound changes, the state file format has + changed, and old state files will not work with this release. + * New cycle exact audio core based on work by Chris Brenner (crispy); greatly improved audio emulation accuracy (i.e. E.T., Ms. Pacman). @@ -34,7 +37,10 @@ * Fixes for collision corner cases (during HBlank). - * UI modernization (new widget look, dialog titles added, dialogs refactored). + * UI modernization (new widget look, dialog titles added, dialogs + refactored). + + * Fixed excessive CPU usage while in UI modes (ROM launcher, debugger, etc). * Changes in 'Game Properties' dialog - 'Default' button now affects only current tab like in all other dialogs. From 0b04b130f90c4832f2f761f1ad503722c7f373df Mon Sep 17 00:00:00 2001 From: Stephen Anthony Date: Mon, 6 Aug 2018 12:30:00 -0230 Subject: [PATCH 7/9] Minor optimization: use two-way IF instead of separate ones. --- src/unix/FSNodePOSIX.cxx | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/src/unix/FSNodePOSIX.cxx b/src/unix/FSNodePOSIX.cxx index 7a68dcad5..1931139de 100644 --- a/src/unix/FSNodePOSIX.cxx +++ b/src/unix/FSNodePOSIX.cxx @@ -59,12 +59,11 @@ FilesystemNodePOSIX::FilesystemNodePOSIX(const string& p, bool verify) if(_path[0] == '~') { const char* home = getenv("HOME"); - if (home != nullptr) + if(home != nullptr) _path.replace(0, 1, home); } - // Get absolute path (only used for relative directories) - if(_path[0] == '.') + else if(_path[0] == '.') { char buf[MAXPATHLEN]; if(realpath(_path.c_str(), buf)) From 573d9a1e25f3980dd860df1837229107795c43ba Mon Sep 17 00:00:00 2001 From: thrust26 Date: Mon, 6 Aug 2018 17:14:22 +0200 Subject: [PATCH 8/9] even more background dialog widget color adjustments --- src/debugger/gui/DataGridWidget.cxx | 9 +++++---- src/debugger/gui/PromptWidget.cxx | 4 +++- src/debugger/gui/RomListWidget.cxx | 18 ++++++++++-------- src/debugger/gui/ToggleBitWidget.cxx | 7 ++++--- src/gui/ColorWidget.cxx | 3 ++- src/gui/EditTextWidget.cxx | 8 ++++---- src/gui/PopUpWidget.cxx | 11 ++++++----- src/gui/ScrollBarWidget.cxx | 3 ++- src/gui/Widget.cxx | 4 ++-- 9 files changed, 38 insertions(+), 29 deletions(-) diff --git a/src/debugger/gui/DataGridWidget.cxx b/src/debugger/gui/DataGridWidget.cxx index ab12fd5c2..43d2a6ffd 100644 --- a/src/debugger/gui/DataGridWidget.cxx +++ b/src/debugger/gui/DataGridWidget.cxx @@ -593,9 +593,10 @@ void DataGridWidget::handleCommand(CommandSender* sender, int cmd, void DataGridWidget::drawWidget(bool hilite) { FBSurface& s = _boss->dialog().surface(); + bool onTop = _boss->dialog().isOnTop(); int row, col; - s.fillRect(_x, _y, _w, _h, hilite && isEnabled() && isEditable() ? _bgcolorhi : _bgcolor); + s.fillRect(_x, _y, _w, _h, hilite && isEnabled() && isEditable() ? _bgcolorhi : onTop ? _bgcolor : _bgcolorlo); // Draw the internal grid and labels int linewidth = _cols * _colWidth; s.frameRect(_x, _y, _w, _h, hilite && isEnabled() && isEditable() ? kWidColorHi : kColor); @@ -614,7 +615,7 @@ void DataGridWidget::drawWidget(bool hilite) int x = _x + 4 + (col * _colWidth); int y = _y + 2 + (row * _rowHeight); int pos = row*_cols + col; - uInt32 textColor = kTextColor; + uInt32 textColor = onTop ? kTextColor : kColor; // Draw the selected item inverted, on a highlighted background. if (_currentRow == row && _currentCol == col && @@ -634,12 +635,12 @@ void DataGridWidget::drawWidget(bool hilite) { if(_changedList[pos]) { - s.fillRect(x - 3, y - 1, _colWidth-1, _rowHeight-1, kDbgChangedColor); + s.fillRect(x - 3, y - 1, _colWidth-1, _rowHeight-1, onTop ? kDbgChangedColor : _bgcolorlo); if(_hiliteList[pos]) textColor = kDbgColorHi; else - textColor = kDbgChangedTextColor; + textColor = onTop ? kDbgChangedTextColor : textColor; } else if(_hiliteList[pos]) textColor = kDbgColorHi; diff --git a/src/debugger/gui/PromptWidget.cxx b/src/debugger/gui/PromptWidget.cxx index ede0d20ad..9093c1537 100644 --- a/src/debugger/gui/PromptWidget.cxx +++ b/src/debugger/gui/PromptWidget.cxx @@ -45,6 +45,7 @@ PromptWidget::PromptWidget(GuiObject* boss, const GUI::Font& font, WIDGET_WANTS_TAB | WIDGET_WANTS_RAWDATA; _textcolor = kTextColor; _bgcolor = kWidColor; + _bgcolorlo = kDlgColor; _kConsoleCharWidth = font.getMaxCharWidth(); _kConsoleCharHeight = font.getFontHeight(); @@ -74,6 +75,7 @@ void PromptWidget::drawWidget(bool hilite) uInt32 fgcolor, bgcolor; FBSurface& s = _boss->dialog().surface(); + bool onTop = _boss->dialog().isOnTop(); // Draw text int start = _scrollLine - _linesPerPage + 1; @@ -94,7 +96,7 @@ void PromptWidget::drawWidget(bool hilite) else fgcolor = c >> 8; - s.drawChar(_font, c & 0x7f, x, y, fgcolor); + s.drawChar(_font, c & 0x7f, x, y, onTop ? fgcolor : kColor); x += _kConsoleCharWidth; } y += _kConsoleLineHeight; diff --git a/src/debugger/gui/RomListWidget.cxx b/src/debugger/gui/RomListWidget.cxx index bc077e94b..cc8cc1e46 100644 --- a/src/debugger/gui/RomListWidget.cxx +++ b/src/debugger/gui/RomListWidget.cxx @@ -465,8 +465,10 @@ void RomListWidget::lostFocusWidget() void RomListWidget::drawWidget(bool hilite) { FBSurface& s = _boss->dialog().surface(); + bool onTop = _boss->dialog().isOnTop(); const CartDebug::DisassemblyList& dlist = myDisasm->list; int i, pos, xpos, ypos, len = int(dlist.size()); + uInt32 textColor = onTop ? kTextColor : kColor; const GUI::Rect& r = getEditRect(); const GUI::Rect& l = getLineRect(); @@ -487,7 +489,7 @@ void RomListWidget::drawWidget(bool hilite) xpos = _x + CheckboxWidget::boxSize() + 10; ypos = _y + 2; for (i = 0, pos = _currentPos; i < _rows && pos < len; i++, pos++, ypos += _fontHeight) { - uInt32 bytesColor = kTextColor; + uInt32 bytesColor = textColor; // Draw checkboxes for correct lines (takes scrolling into account) myCheckList[i]->setState(myBPState->isSet(dlist[pos].address)); @@ -496,7 +498,7 @@ void RomListWidget::drawWidget(bool hilite) // Draw highlighted item in a frame if (_highlightedItem == pos) - s.frameRect(_x + l.x() - 3, ypos - 1, _w - l.x(), _fontHeight, kWidColorHi); + s.frameRect(_x + l.x() - 3, ypos - 1, _w - l.x(), _fontHeight, onTop ? kWidColorHi : kBGColorLo); // Draw the selected item inverted, on a highlighted background. if(_selectedItem == pos && _hasFocus) @@ -512,7 +514,7 @@ void RomListWidget::drawWidget(bool hilite) // Draw labels s.drawString(_font, dlist[pos].label, xpos, ypos, _labelWidth, - dlist[pos].hllabel ? kTextColor : kColor); + dlist[pos].hllabel ? textColor : kColor); // Bytes are only editable if they represent code, graphics, or accessible data // Otherwise, the disassembly should get all remaining space @@ -522,14 +524,14 @@ void RomListWidget::drawWidget(bool hilite) { // Draw mnemonic s.drawString(_font, dlist[pos].disasm.substr(0, 7), xpos + _labelWidth, ypos, - 7 * _fontWidth, kTextColor); + 7 * _fontWidth, textColor); // Draw operand if (dlist[pos].disasm.length() > 8) s.drawString(_font, dlist[pos].disasm.substr(8), xpos + _labelWidth + 7 * _fontWidth, ypos, - codeDisasmW - 7 * _fontWidth, kTextColor); + codeDisasmW - 7 * _fontWidth, textColor); // Draw cycle count s.drawString(_font, dlist[pos].ccount, xpos + _labelWidth + codeDisasmW, ypos, - cycleCountW, kTextColor); + cycleCountW, textColor); } else { @@ -546,7 +548,7 @@ void RomListWidget::drawWidget(bool hilite) if (_selectedItem == pos && _editMode) { adjustOffset(); - s.drawString(_font, editString(), _x + r.x(), ypos, r.width(), kTextColor, + s.drawString(_font, editString(), _x + r.x(), ypos, r.width(), textColor, TextAlign::Left, -_editScrollOffset, false); drawCaret(); @@ -561,7 +563,7 @@ void RomListWidget::drawWidget(bool hilite) { // Draw disassembly, giving it all remaining horizontal space s.drawString(_font, dlist[pos].disasm, xpos + _labelWidth, ypos, - noTypeDisasmW, kTextColor); + noTypeDisasmW, textColor); } } } diff --git a/src/debugger/gui/ToggleBitWidget.cxx b/src/debugger/gui/ToggleBitWidget.cxx index ebd6c1898..11fd8bc3e 100644 --- a/src/debugger/gui/ToggleBitWidget.cxx +++ b/src/debugger/gui/ToggleBitWidget.cxx @@ -73,6 +73,7 @@ void ToggleBitWidget::drawWidget(bool hilite) { //cerr << "ToggleBitWidget::drawWidget\n"; FBSurface& s = dialog().surface(); + bool onTop = _boss->dialog().isOnTop(); int row, col; string buffer; @@ -114,11 +115,11 @@ void ToggleBitWidget::drawWidget(bool hilite) // Highlight changes if(_changedList[pos]) { - s.fillRect(x - 3, y - 1, _colWidth-1, _rowHeight-1, kDbgChangedColor); - s.drawString(_font, buffer, x, y, _colWidth, kDbgChangedTextColor); + s.fillRect(x - 3, y - 1, _colWidth-1, _rowHeight-1, onTop ? kDbgChangedColor : _bgcolorlo); + s.drawString(_font, buffer, x, y, _colWidth, onTop ? kDbgChangedTextColor : kColor); } else - s.drawString(_font, buffer, x, y, _colWidth, textColor); + s.drawString(_font, buffer, x, y, _colWidth, onTop ? textColor : kColor); } else { diff --git a/src/gui/ColorWidget.cxx b/src/gui/ColorWidget.cxx index 9abcf2d91..e5a49a939 100644 --- a/src/gui/ColorWidget.cxx +++ b/src/gui/ColorWidget.cxx @@ -46,12 +46,13 @@ void ColorWidget::setColor(int color) void ColorWidget::drawWidget(bool hilite) { FBSurface& s = dialog().surface(); + bool onTop = _boss->dialog().isOnTop(); // Draw a thin frame around us. s.frameRect(_x, _y, _w, _h + 1, kColor); // Show the currently selected color - s.fillRect(_x+1, _y+1, _w-2, _h-1, isEnabled() ? _color : kWidColor); + s.fillRect(_x+1, _y+1, _w-2, _h-1, onTop ? isEnabled() ? _color : kWidColor : kDlgColor); // Cross out the grid? if(_crossGrid) diff --git a/src/gui/EditTextWidget.cxx b/src/gui/EditTextWidget.cxx index 8b6ad7679..acf972349 100644 --- a/src/gui/EditTextWidget.cxx +++ b/src/gui/EditTextWidget.cxx @@ -83,7 +83,7 @@ void EditTextWidget::drawWidget(bool hilite) bool onTop = _boss->dialog().isOnTop(); // Highlight changes - if(_changed) + if(_changed && onTop) s.fillRect(_x, _y, _w, _h, kDbgChangedColor); else if(!isEditable()) s.fillRect(_x, _y, _w, _h, onTop ? kDlgColor : kBGColorLo); @@ -94,9 +94,9 @@ void EditTextWidget::drawWidget(bool hilite) // Draw the text adjustOffset(); s.drawString(_font, editString(), _x + 2, _y + 2, getEditRect().width(), - !_changed - ? onTop ? _textcolor : kColor - : uInt32(kDbgChangedTextColor), + _changed && onTop + ? uInt32(kDbgChangedTextColor) + : onTop ? _textcolor : kColor, TextAlign::Left, -_editScrollOffset, false); // Draw the caret diff --git a/src/gui/PopUpWidget.cxx b/src/gui/PopUpWidget.cxx index aaf9d810c..8b2b4b6df 100644 --- a/src/gui/PopUpWidget.cxx +++ b/src/gui/PopUpWidget.cxx @@ -198,6 +198,7 @@ void PopUpWidget::drawWidget(bool hilite) { //cerr << "PopUpWidget::drawWidget\n"; FBSurface& s = dialog().surface(); + bool onTop = _boss->dialog().isOnTop(); int x = _x + _labelWidth; int w = _w - _labelWidth; @@ -205,23 +206,23 @@ void PopUpWidget::drawWidget(bool hilite) // Draw the label, if any if(_labelWidth > 0) s.drawString(_font, _label, _x, _y + myTextY, _labelWidth, - isEnabled() ? _textcolor : uInt32(kColor), TextAlign::Left); + isEnabled() && onTop ? _textcolor : uInt32(kColor), TextAlign::Left); // Draw a thin frame around us. s.frameRect(x, _y, w, _h, isEnabled() && hilite ? kWidColorHi : kColor); s.frameRect(x + w - 16, _y + 1, 15, _h - 2, isEnabled() && hilite ? kWidColorHi : kBGColorLo); // Fill the background - s.fillRect(x + 1, _y + 1, w - 17, _h - 2, _changed ? kDbgChangedColor : kWidColor); - s.fillRect(x + w - 15, _y + 2, 13, _h - 4, isEnabled() && hilite ? kWidColor : kBGColorHi); + s.fillRect(x + 1, _y + 1, w - 17, _h - 2, onTop ? _changed ? kDbgChangedColor : kWidColor : kDlgColor); + s.fillRect(x + w - 15, _y + 2, 13, _h - 4, onTop ? isEnabled() && hilite ? kWidColor : kBGColorHi : kBGColorLo); // Draw an arrow pointing down at the right end to signal this is a dropdown/popup s.drawBitmap(down_arrow, x + w - 13, _y + myArrowsY + 1, - !isEnabled() ? kColor : kTextColor, 9u, 8u); + !(isEnabled() && onTop) ? kColor : kTextColor, 9u, 8u); // Draw the selected entry, if any const string& name = myMenu->getSelectedName(); TextAlign align = (_font.getStringWidth(name) > w-6) ? TextAlign::Right : TextAlign::Left; s.drawString(_font, name, x+2, _y+myTextY, w-6, - !isEnabled() ? kColor : kTextColor, align); + !(isEnabled() && onTop) ? kColor : kTextColor, align); } diff --git a/src/gui/ScrollBarWidget.cxx b/src/gui/ScrollBarWidget.cxx index 8e3960965..3370eac79 100644 --- a/src/gui/ScrollBarWidget.cxx +++ b/src/gui/ScrollBarWidget.cxx @@ -249,6 +249,7 @@ void ScrollBarWidget::drawWidget(bool hilite) { //cerr << "ScrollBarWidget::drawWidget\n"; FBSurface& s = _boss->dialog().surface(); + bool onTop = _boss->dialog().isOnTop(); int bottomY = _y + _h; bool isSinglePage = (_numEntries <= _entriesPerPage); @@ -273,7 +274,7 @@ void ScrollBarWidget::drawWidget(bool hilite) if(!isSinglePage) { s.fillRect(_x + 1, _y + _sliderPos - 1, _w - 2, _sliderHeight + 2, - (hilite && _part == kSliderPart) ? kScrollColorHi : kScrollColor); + onTop ? (hilite && _part == kSliderPart) ? kScrollColorHi : kScrollColor : kColor); } } diff --git a/src/gui/Widget.cxx b/src/gui/Widget.cxx index f77d0e057..79a53b12b 100644 --- a/src/gui/Widget.cxx +++ b/src/gui/Widget.cxx @@ -645,8 +645,8 @@ void CheckboxWidget::drawWidget(bool hilite) if(_drawBox) s.frameRect(_x, _y + _boxY, 14, 14, onTop && hilite && isEnabled() && isEditable() ? kWidColorHi : kColor); // Do we draw a square or cross? - s.fillRect(_x + 1, _y + _boxY + 1, 12, 12, _changed ? uInt32(kDbgChangedColor) - : isEnabled() ? _bgcolor : uInt32(kColor)); + s.fillRect(_x + 1, _y + _boxY + 1, 12, 12, _changed ? onTop ? uInt32(kDbgChangedColor) : kDlgColor + : isEnabled() ? onTop ? _bgcolor : kDlgColor : uInt32(kColor)); if(_state) s.drawBitmap(_img, _x + 2, _y + _boxY + 2, onTop && isEnabled() ? hilite && isEditable() ? kWidColorHi : kCheckColor : kColor, 10); From 86a242a8cf0c1eb95bc65038c4dca37db1505e04 Mon Sep 17 00:00:00 2001 From: Christian Speckner Date: Mon, 6 Aug 2018 17:51:47 +0200 Subject: [PATCH 9/9] Fix spurious failures of debugger breakpoints. --- src/emucore/M6502.cxx | 10 +++++++++- src/emucore/M6502.hxx | 3 +++ 2 files changed, 12 insertions(+), 1 deletion(-) diff --git a/src/emucore/M6502.cxx b/src/emucore/M6502.cxx index d9497cb7d..39bd4a1b4 100644 --- a/src/emucore/M6502.cxx +++ b/src/emucore/M6502.cxx @@ -118,6 +118,8 @@ void M6502::reset() myHaltRequested = false; myGhostReadsTrap = mySettings.getBool("dbg.ghostreadstrap"); + + myLastBreakCycle = -1; } // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - @@ -259,17 +261,19 @@ inline void M6502::_execute(uInt64 cycles, DispatchResult& result) { #ifdef DEBUGGER_SUPPORT // Don't break if we haven't actually executed anything yet - if (currentCycles > 0) { + if (myLastBreakCycle != mySystem->cycles()) { if(myJustHitReadTrapFlag || myJustHitWriteTrapFlag) { bool read = myJustHitReadTrapFlag; myJustHitReadTrapFlag = myJustHitWriteTrapFlag = false; + myLastBreakCycle = mySystem->cycles(); result.setDebugger(currentCycles, myHitTrapInfo.message, myHitTrapInfo.address, read); return; } if(myBreakPoints.isInitialized() && myBreakPoints.isSet(PC)) { + myLastBreakCycle = mySystem->cycles(); result.setDebugger(currentCycles, "BP: ", PC); return; } @@ -280,6 +284,7 @@ inline void M6502::_execute(uInt64 cycles, DispatchResult& result) stringstream msg; msg << "CBP[" << Common::Base::HEX2 << cond << "]: " << myCondBreakNames[cond]; + myLastBreakCycle = mySystem->cycles(); result.setDebugger(currentCycles, msg.str()); return; } @@ -432,6 +437,7 @@ bool M6502::save(Serializer& out) const out.putBool(myHaltRequested); out.putBool(myStepStateByInstruction); out.putBool(myGhostReadsTrap); + out.putLong(myLastBreakCycle); } catch(...) { @@ -484,6 +490,8 @@ bool M6502::load(Serializer& in) myHaltRequested = in.getBool(); myStepStateByInstruction = in.getBool(); myGhostReadsTrap = in.getBool(); + + myLastBreakCycle = in.getLong(); } catch(...) { diff --git a/src/emucore/M6502.hxx b/src/emucore/M6502.hxx index 5504a5366..98fb45b5e 100644 --- a/src/emucore/M6502.hxx +++ b/src/emucore/M6502.hxx @@ -377,6 +377,9 @@ class M6502 : public Serializable /// Indicates the last address which was accessed uInt16 myLastAddress; + /// Last cycle that triggered a breakpoint + uInt64 myLastBreakCycle; + /// Indicates the last address which was accessed specifically /// by a peek or poke command uInt16 myLastPeekAddress, myLastPokeAddress;