Added font selection options to Qt debugger. For #352.
This commit is contained in:
parent
37abb7305b
commit
151bee01dc
|
@ -35,6 +35,7 @@
|
||||||
#include <QGridLayout>
|
#include <QGridLayout>
|
||||||
#include <QRadioButton>
|
#include <QRadioButton>
|
||||||
#include <QInputDialog>
|
#include <QInputDialog>
|
||||||
|
#include <QFontDialog>
|
||||||
#include <QMessageBox>
|
#include <QMessageBox>
|
||||||
#include <QMenuBar>
|
#include <QMenuBar>
|
||||||
#include <QMenu>
|
#include <QMenu>
|
||||||
|
@ -104,13 +105,28 @@ ConsoleDebugger::ConsoleDebugger(QWidget *parent)
|
||||||
int opt, useNativeMenuBar;
|
int opt, useNativeMenuBar;
|
||||||
//fceuDecIntValidtor *validator;
|
//fceuDecIntValidtor *validator;
|
||||||
QSettings settings;
|
QSettings settings;
|
||||||
|
QFont cpuFont;
|
||||||
|
std::string fontString;
|
||||||
|
|
||||||
|
g_config->getOption("SDL.DebuggerCpuStatusFont", &fontString);
|
||||||
|
|
||||||
|
if ( fontString.size() > 0 )
|
||||||
|
{
|
||||||
|
cpuFont.fromString( QString::fromStdString( fontString ) );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
cpuFont.setFamily("Courier New");
|
||||||
|
cpuFont.setStyle( QFont::StyleNormal );
|
||||||
|
cpuFont.setStyleHint( QFont::Monospace );
|
||||||
|
}
|
||||||
|
|
||||||
font.setFamily("Courier New");
|
font.setFamily("Courier New");
|
||||||
font.setStyle( QFont::StyleNormal );
|
font.setStyle( QFont::StyleNormal );
|
||||||
font.setStyleHint( QFont::Monospace );
|
font.setStyleHint( QFont::Monospace );
|
||||||
QFontMetrics fm(font);
|
QFontMetrics fm(font);
|
||||||
|
|
||||||
fontCharWidth = 1.00 * fm.averageCharWidth();
|
fontCharWidth = fm.averageCharWidth();
|
||||||
|
|
||||||
setWindowTitle("6502 Debugger");
|
setWindowTitle("6502 Debugger");
|
||||||
|
|
||||||
|
@ -153,7 +169,7 @@ ConsoleDebugger::ConsoleDebugger(QWidget *parent)
|
||||||
|
|
||||||
// View -> Go to PC
|
// View -> Go to PC
|
||||||
act = new QAction(tr("Go to &PC"), this);
|
act = new QAction(tr("Go to &PC"), this);
|
||||||
act->setShortcut( QKeySequence(tr("Ctrl+P") ));
|
act->setShortcut( QKeySequence(tr("Ctrl+G") ));
|
||||||
act->setStatusTip(tr("Go to &PC"));
|
act->setStatusTip(tr("Go to &PC"));
|
||||||
//act->setIcon( QIcon(":icons/JumpTarget.png") );
|
//act->setIcon( QIcon(":icons/JumpTarget.png") );
|
||||||
connect(act, SIGNAL(triggered()), this, SLOT(seekPCCB(void)) );
|
connect(act, SIGNAL(triggered()), this, SLOT(seekPCCB(void)) );
|
||||||
|
@ -162,7 +178,7 @@ ConsoleDebugger::ConsoleDebugger(QWidget *parent)
|
||||||
|
|
||||||
// View -> Change PC
|
// View -> Change PC
|
||||||
act = new QAction(tr("&Change PC"), this);
|
act = new QAction(tr("&Change PC"), this);
|
||||||
act->setShortcut( QKeySequence(tr("Ctrl+Shift+P") ));
|
act->setShortcut( QKeySequence(tr("Ctrl+Shift+G") ));
|
||||||
act->setStatusTip(tr("&Change PC"));
|
act->setStatusTip(tr("&Change PC"));
|
||||||
//act->setIcon( QIcon(":icons/JumpTarget.png") );
|
//act->setIcon( QIcon(":icons/JumpTarget.png") );
|
||||||
connect(act, SIGNAL(triggered()), this, SLOT(openChangePcDialog(void)) );
|
connect(act, SIGNAL(triggered()), this, SLOT(openChangePcDialog(void)) );
|
||||||
|
@ -369,6 +385,37 @@ ConsoleDebugger::ConsoleDebugger(QWidget *parent)
|
||||||
actGroup->addAction(act);
|
actGroup->addAction(act);
|
||||||
subMenu->addAction(act);
|
subMenu->addAction(act);
|
||||||
|
|
||||||
|
optMenu->addSeparator();
|
||||||
|
|
||||||
|
// Options -> Font Selection
|
||||||
|
subMenu = optMenu->addMenu(tr("&Font Selection"));
|
||||||
|
|
||||||
|
// Options -> Font Selection -> Assembly View
|
||||||
|
act = new QAction(tr("&Assembly View"), this);
|
||||||
|
//act->setShortcut(QKeySequence( tr("F7") ) );
|
||||||
|
act->setStatusTip(tr("Set Assembly View Font"));
|
||||||
|
connect( act, SIGNAL(triggered(void)), this, SLOT(changeAsmFontCB(void)) );
|
||||||
|
|
||||||
|
subMenu->addAction(act);
|
||||||
|
|
||||||
|
// Options -> Font Selection -> Stack View
|
||||||
|
act = new QAction(tr("&Stack View"), this);
|
||||||
|
//act->setShortcut(QKeySequence( tr("F7") ) );
|
||||||
|
act->setStatusTip(tr("Set Stack View Font"));
|
||||||
|
connect( act, SIGNAL(triggered(void)), this, SLOT(changeStackFontCB(void)) );
|
||||||
|
|
||||||
|
subMenu->addAction(act);
|
||||||
|
|
||||||
|
// Options -> Font Selection -> CPU Data View
|
||||||
|
act = new QAction(tr("&CPU Data View"), this);
|
||||||
|
//act->setShortcut(QKeySequence( tr("F7") ) );
|
||||||
|
act->setStatusTip(tr("Set CPU View Font"));
|
||||||
|
connect( act, SIGNAL(triggered(void)), this, SLOT(changeCpuFontCB(void)) );
|
||||||
|
|
||||||
|
subMenu->addAction(act);
|
||||||
|
|
||||||
|
optMenu->addSeparator();
|
||||||
|
|
||||||
// Symbols
|
// Symbols
|
||||||
symMenu = menuBar->addMenu(tr("&Symbols"));
|
symMenu = menuBar->addMenu(tr("&Symbols"));
|
||||||
|
|
||||||
|
@ -560,43 +607,6 @@ ConsoleDebugger::ConsoleDebugger(QWidget *parent)
|
||||||
vbox2->addLayout( grid );
|
vbox2->addLayout( grid );
|
||||||
cpuFrame->setLayout( hbox1 );
|
cpuFrame->setLayout( hbox1 );
|
||||||
|
|
||||||
//button = new QPushButton( tr("Run") );
|
|
||||||
//grid->addWidget( button, 0, 0, Qt::AlignLeft );
|
|
||||||
//connect( button, SIGNAL(clicked(void)), this, SLOT(debugRunCB(void)) );
|
|
||||||
|
|
||||||
//button = new QPushButton( tr("Step Into") );
|
|
||||||
//grid->addWidget( button, 0, 1, Qt::AlignLeft );
|
|
||||||
//connect( button, SIGNAL(clicked(void)), this, SLOT(debugStepIntoCB(void)) );
|
|
||||||
|
|
||||||
//button = new QPushButton( tr("Step Out") );
|
|
||||||
//grid->addWidget( button, 1, 0, Qt::AlignLeft );
|
|
||||||
//connect( button, SIGNAL(clicked(void)), this, SLOT(debugStepOutCB(void)) );
|
|
||||||
|
|
||||||
//button = new QPushButton( tr("Step Over") );
|
|
||||||
//grid->addWidget( button, 1, 1, Qt::AlignLeft );
|
|
||||||
//connect( button, SIGNAL(clicked(void)), this, SLOT(debugStepOverCB(void)) );
|
|
||||||
|
|
||||||
//button = new QPushButton( tr("Run Line") );
|
|
||||||
//grid->addWidget( button, 2, 0, Qt::AlignLeft );
|
|
||||||
//connect( button, SIGNAL(clicked(void)), this, SLOT(debugRunLineCB(void)) );
|
|
||||||
|
|
||||||
//button = new QPushButton( tr("128 Lines") );
|
|
||||||
//grid->addWidget( button, 2, 1, Qt::AlignLeft );
|
|
||||||
//connect( button, SIGNAL(clicked(void)), this, SLOT(debugRunLine128CB(void)) );
|
|
||||||
|
|
||||||
//button = new QPushButton( tr("Seek To:") );
|
|
||||||
//grid->addWidget( button, 3, 0, Qt::AlignLeft );
|
|
||||||
//connect( button, SIGNAL(clicked(void)), this, SLOT(seekToCB(void)) );
|
|
||||||
|
|
||||||
//seekEntry = new QLineEdit();
|
|
||||||
//seekEntry->setFont( font );
|
|
||||||
//seekEntry->setText("0000");
|
|
||||||
//seekEntry->setMaxLength( 4 );
|
|
||||||
//seekEntry->setInputMask( ">HHHH;0" );
|
|
||||||
//seekEntry->setAlignment(Qt::AlignCenter);
|
|
||||||
//seekEntry->setMaximumWidth( 6 * fontCharWidth );
|
|
||||||
//grid->addWidget( seekEntry, 3, 1, Qt::AlignLeft );
|
|
||||||
|
|
||||||
hbox = new QHBoxLayout();
|
hbox = new QHBoxLayout();
|
||||||
lbl = new QLabel( tr("PC:") );
|
lbl = new QLabel( tr("PC:") );
|
||||||
lbl->setToolTip( tr("Program Counter Register") );
|
lbl->setToolTip( tr("Program Counter Register") );
|
||||||
|
@ -715,7 +725,7 @@ ConsoleDebugger::ConsoleDebugger(QWidget *parent)
|
||||||
//vbox2->addWidget( stackFrame );
|
//vbox2->addWidget( stackFrame );
|
||||||
hbox1->addWidget( stackFrame, 10 );
|
hbox1->addWidget( stackFrame, 10 );
|
||||||
stackFrame->setLayout( hbox );
|
stackFrame->setLayout( hbox );
|
||||||
stackText->setFont(font);
|
//stackText->setFont(font); // Stack font is now set in constructor
|
||||||
stackText->setReadOnly(true);
|
stackText->setReadOnly(true);
|
||||||
stackText->setWordWrapMode( QTextOption::NoWrap );
|
stackText->setWordWrapMode( QTextOption::NoWrap );
|
||||||
//stackText->setHorizontalScrollBarPolicy( Qt::ScrollBarAlwaysOff );
|
//stackText->setHorizontalScrollBarPolicy( Qt::ScrollBarAlwaysOff );
|
||||||
|
@ -963,6 +973,8 @@ ConsoleDebugger::ConsoleDebugger(QWidget *parent)
|
||||||
}
|
}
|
||||||
|
|
||||||
restoreGeometry(settings.value("debugger/geometry").toByteArray());
|
restoreGeometry(settings.value("debugger/geometry").toByteArray());
|
||||||
|
|
||||||
|
setCpuStatusFont( cpuFont );
|
||||||
}
|
}
|
||||||
//----------------------------------------------------------------------------
|
//----------------------------------------------------------------------------
|
||||||
ConsoleDebugger::~ConsoleDebugger(void)
|
ConsoleDebugger::~ConsoleDebugger(void)
|
||||||
|
@ -1009,6 +1021,39 @@ void ConsoleDebugger::closeWindow(void)
|
||||||
deleteLater();
|
deleteLater();
|
||||||
}
|
}
|
||||||
//----------------------------------------------------------------------------
|
//----------------------------------------------------------------------------
|
||||||
|
void ConsoleDebugger::setCpuStatusFont( const QFont &font )
|
||||||
|
{
|
||||||
|
QFontMetrics fm(font);
|
||||||
|
int fontCharWidth;
|
||||||
|
|
||||||
|
fontCharWidth = fm.averageCharWidth();
|
||||||
|
|
||||||
|
pcEntry->setFont( font );
|
||||||
|
pcEntry->setMinimumWidth( 6 * fontCharWidth );
|
||||||
|
pcEntry->setMaximumWidth( 6 * fontCharWidth );
|
||||||
|
|
||||||
|
regAEntry->setFont( font );
|
||||||
|
regAEntry->setMinimumWidth( 4 * fontCharWidth );
|
||||||
|
regAEntry->setMaximumWidth( 4 * fontCharWidth );
|
||||||
|
|
||||||
|
regXEntry->setFont( font );
|
||||||
|
regXEntry->setMinimumWidth( 4 * fontCharWidth );
|
||||||
|
regXEntry->setMaximumWidth( 4 * fontCharWidth );
|
||||||
|
|
||||||
|
regYEntry->setFont( font );
|
||||||
|
regYEntry->setMinimumWidth( 4 * fontCharWidth );
|
||||||
|
regYEntry->setMaximumWidth( 4 * fontCharWidth );
|
||||||
|
|
||||||
|
regPEntry->setFont( font );
|
||||||
|
regPEntry->setMinimumWidth( 4 * fontCharWidth );
|
||||||
|
regPEntry->setMaximumWidth( 4 * fontCharWidth );
|
||||||
|
|
||||||
|
cpuCyclesVal->setFont(font);
|
||||||
|
cpuCyclesVal->setMinimumWidth( 24 * fontCharWidth );
|
||||||
|
cpuInstrsVal->setFont(font);
|
||||||
|
cpuInstrsVal->setMinimumWidth( 24 * fontCharWidth );
|
||||||
|
}
|
||||||
|
//----------------------------------------------------------------------------
|
||||||
void ConsoleDebugger::bpItemClicked( QTreeWidgetItem *item, int column)
|
void ConsoleDebugger::bpItemClicked( QTreeWidgetItem *item, int column)
|
||||||
{
|
{
|
||||||
int row = bpTree->indexOfTopLevelItem(item);
|
int row = bpTree->indexOfTopLevelItem(item);
|
||||||
|
@ -1830,6 +1875,55 @@ void ConsoleDebugger::debFileAutoLoadCB( bool value )
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
//----------------------------------------------------------------------------
|
//----------------------------------------------------------------------------
|
||||||
|
void ConsoleDebugger::changeAsmFontCB(void)
|
||||||
|
{
|
||||||
|
bool ok = false;
|
||||||
|
|
||||||
|
QFont selFont = QFontDialog::getFont( &ok, asmView->QWidget::font(), this, tr("Select Font"), QFontDialog::MonospacedFonts );
|
||||||
|
|
||||||
|
if ( ok )
|
||||||
|
{
|
||||||
|
asmView->setFont( selFont );
|
||||||
|
asmView->updateAssemblyView();
|
||||||
|
|
||||||
|
//printf("Font Changed to: '%s'\n", font.toString().toStdString().c_str() );
|
||||||
|
|
||||||
|
g_config->setOption("SDL.DebuggerAsmFont", selFont.toString().toStdString().c_str() );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//----------------------------------------------------------------------------
|
||||||
|
void ConsoleDebugger::changeStackFontCB(void)
|
||||||
|
{
|
||||||
|
bool ok = false;
|
||||||
|
|
||||||
|
QFont selFont = QFontDialog::getFont( &ok, stackText->QWidget::font(), this, tr("Select Font"), QFontDialog::MonospacedFonts );
|
||||||
|
|
||||||
|
if ( ok )
|
||||||
|
{
|
||||||
|
stackText->setFont( selFont );
|
||||||
|
|
||||||
|
//printf("Font Changed to: '%s'\n", font.toString().toStdString().c_str() );
|
||||||
|
|
||||||
|
g_config->setOption("SDL.DebuggerStackFont", selFont.toString().toStdString().c_str() );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//----------------------------------------------------------------------------
|
||||||
|
void ConsoleDebugger::changeCpuFontCB(void)
|
||||||
|
{
|
||||||
|
bool ok = false;
|
||||||
|
|
||||||
|
QFont selFont = QFontDialog::getFont( &ok, pcEntry->QWidget::font(), this, tr("Select Font"), QFontDialog::MonospacedFonts );
|
||||||
|
|
||||||
|
if ( ok )
|
||||||
|
{
|
||||||
|
setCpuStatusFont( selFont );
|
||||||
|
|
||||||
|
//printf("Font Changed to: '%s'\n", font.toString().toStdString().c_str() );
|
||||||
|
|
||||||
|
g_config->setOption("SDL.DebuggerCpuStatusFont", selFont.toString().toStdString().c_str() );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//----------------------------------------------------------------------------
|
||||||
void ConsoleDebugger::reloadSymbolsCB(void)
|
void ConsoleDebugger::reloadSymbolsCB(void)
|
||||||
{
|
{
|
||||||
fceuWrapperLock();
|
fceuWrapperLock();
|
||||||
|
@ -3565,12 +3659,22 @@ QAsmView::QAsmView(QWidget *parent)
|
||||||
QPalette pal;
|
QPalette pal;
|
||||||
QColor fg("black"), bg("white");
|
QColor fg("black"), bg("white");
|
||||||
QColor c;
|
QColor c;
|
||||||
|
std::string fontString;
|
||||||
|
|
||||||
useDarkTheme = false;
|
useDarkTheme = false;
|
||||||
|
|
||||||
|
g_config->getOption("SDL.DebuggerAsmFont", &fontString);
|
||||||
|
|
||||||
|
if ( fontString.size() > 0 )
|
||||||
|
{
|
||||||
|
font.fromString( QString::fromStdString( fontString ) );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
font.setFamily("Courier New");
|
font.setFamily("Courier New");
|
||||||
font.setStyle( QFont::StyleNormal );
|
font.setStyle( QFont::StyleNormal );
|
||||||
font.setStyleHint( QFont::Monospace );
|
font.setStyleHint( QFont::Monospace );
|
||||||
|
}
|
||||||
|
|
||||||
pal = this->palette();
|
pal = this->palette();
|
||||||
|
|
||||||
|
@ -3780,9 +3884,18 @@ void QAsmView::setRegisterNameEnable( bool value )
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
//----------------------------------------------------------------------------
|
//----------------------------------------------------------------------------
|
||||||
|
void QAsmView::setFont( const QFont &newFont )
|
||||||
|
{
|
||||||
|
font = newFont;
|
||||||
|
|
||||||
|
QWidget::setFont(newFont);
|
||||||
|
|
||||||
|
calcFontData();
|
||||||
|
}
|
||||||
|
//----------------------------------------------------------------------------
|
||||||
void QAsmView::calcFontData(void)
|
void QAsmView::calcFontData(void)
|
||||||
{
|
{
|
||||||
this->setFont(font);
|
QWidget::setFont(font);
|
||||||
QFontMetrics metrics(font);
|
QFontMetrics metrics(font);
|
||||||
#if QT_VERSION > QT_VERSION_CHECK(5, 11, 0)
|
#if QT_VERSION > QT_VERSION_CHECK(5, 11, 0)
|
||||||
pxCharWidth = metrics.horizontalAdvance(QLatin1Char('2'));
|
pxCharWidth = metrics.horizontalAdvance(QLatin1Char('2'));
|
||||||
|
@ -4831,7 +4944,24 @@ debuggerBookmark_t *debuggerBookmarkManager_t::getAddr( int addr )
|
||||||
DebuggerStackDisplay::DebuggerStackDisplay(QWidget *parent)
|
DebuggerStackDisplay::DebuggerStackDisplay(QWidget *parent)
|
||||||
: QPlainTextEdit(parent)
|
: QPlainTextEdit(parent)
|
||||||
{
|
{
|
||||||
QFontMetrics fm(font());
|
QFont font;
|
||||||
|
std::string fontString;
|
||||||
|
|
||||||
|
g_config->getOption("SDL.DebuggerStackFont", &fontString);
|
||||||
|
|
||||||
|
if ( fontString.size() > 0 )
|
||||||
|
{
|
||||||
|
font.fromString( QString::fromStdString( fontString ) );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
font.setFamily("Courier New");
|
||||||
|
font.setStyle( QFont::StyleNormal );
|
||||||
|
font.setStyleHint( QFont::Monospace );
|
||||||
|
}
|
||||||
|
setFont( font );
|
||||||
|
|
||||||
|
QFontMetrics fm(font);
|
||||||
|
|
||||||
stackBytesPerLine = 4;
|
stackBytesPerLine = 4;
|
||||||
showAddrs = true;
|
showAddrs = true;
|
||||||
|
|
|
@ -121,6 +121,7 @@ class QAsmView : public QWidget
|
||||||
int isBreakpointAtLine( int line );
|
int isBreakpointAtLine( int line );
|
||||||
int isBreakpointAtAddr( int addr );
|
int isBreakpointAtAddr( int addr );
|
||||||
void determineLineBreakpoints(void);
|
void determineLineBreakpoints(void);
|
||||||
|
void setFont( const QFont &font );
|
||||||
protected:
|
protected:
|
||||||
bool event(QEvent *event) override;
|
bool event(QEvent *event) override;
|
||||||
void paintEvent(QPaintEvent *event);
|
void paintEvent(QPaintEvent *event);
|
||||||
|
@ -244,6 +245,8 @@ class ConsoleDebugger : public QDialog
|
||||||
void queueUpdate(void);
|
void queueUpdate(void);
|
||||||
|
|
||||||
QLabel *asmLineSelLbl;
|
QLabel *asmLineSelLbl;
|
||||||
|
|
||||||
|
void setCpuStatusFont( const QFont &font );
|
||||||
protected:
|
protected:
|
||||||
void closeEvent(QCloseEvent *event);
|
void closeEvent(QCloseEvent *event);
|
||||||
//void keyPressEvent(QKeyEvent *event);
|
//void keyPressEvent(QKeyEvent *event);
|
||||||
|
@ -355,6 +358,9 @@ class ConsoleDebugger : public QDialog
|
||||||
void pcSetPlaceLowerMid(void);
|
void pcSetPlaceLowerMid(void);
|
||||||
void pcSetPlaceBottom(void);
|
void pcSetPlaceBottom(void);
|
||||||
void pcSetPlaceCustom(void);
|
void pcSetPlaceCustom(void);
|
||||||
|
void changeAsmFontCB(void);
|
||||||
|
void changeStackFontCB(void);
|
||||||
|
void changeCpuFontCB(void);
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -574,6 +574,9 @@ InitConfig()
|
||||||
config->addOption("autoOpenDebugger" , "SDL.AutoOpenDebugger" , 0);
|
config->addOption("autoOpenDebugger" , "SDL.AutoOpenDebugger" , 0);
|
||||||
config->addOption("debuggerPCPlacementMode", "SDL.DebuggerPCPlacement" , 0);
|
config->addOption("debuggerPCPlacementMode", "SDL.DebuggerPCPlacement" , 0);
|
||||||
config->addOption("debuggerPCDLineOffset" , "SDL.DebuggerPCLineOffset" , 0);
|
config->addOption("debuggerPCDLineOffset" , "SDL.DebuggerPCLineOffset" , 0);
|
||||||
|
config->addOption("SDL.DebuggerAsmFont" , "");
|
||||||
|
config->addOption("SDL.DebuggerStackFont" , "");
|
||||||
|
config->addOption("SDL.DebuggerCpuStatusFont" , "");
|
||||||
|
|
||||||
// Code Data Logger Options
|
// Code Data Logger Options
|
||||||
config->addOption("autoSaveCDL" , "SDL.AutoSaveCDL", 1);
|
config->addOption("autoSaveCDL" , "SDL.AutoSaveCDL", 1);
|
||||||
|
|
Loading…
Reference in New Issue