Changed debugger "Enter memory address" to accept hex only (#1317)

* Changed debugger "Enter memory address" to accept hex only

The "Enter memory address" prompt by default expects a decimal address unless it's preceded by 0x. Or it expects an number starting with 0 is an octal.
The disassembly address should be hexadecimal regardless as that is how it it displays the address.
Also changed it so that it changes any address entered to be divisible by 4 as there was an observed issue that would cause the disassembly addresses to get locked to a address that was not divisible by 4

* Translation updates for Debugger memory address change

Updated the three translation files that mentioned the original "Invalid address. It should be in hex" string.

* Changed debugger "Enter memory address" to accept hex only

UPDATE TO PR #1316
The "Enter memory address" prompt by default expects a decimal address unless it's preceded by 0x. Or it expects an number starting with 0 is an octal.
The disassembly address should be hexadecimal regardless as that is how it it displays the address.
Also changed it so that it changes any breakpoint or disassembly address entered to be divisible by 4 as there was an observed issue that would cause the disassembly addresses to get locked to a address that was not divisible by 4 and a breakpoint address that is not divisible by 4 would never be hit.
This commit is contained in:
PugsyMAME 2020-12-26 14:43:43 +00:00 committed by GitHub
parent 56fc694076
commit 31423ef697
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
7 changed files with 17 additions and 17 deletions

View file

@ -644,7 +644,7 @@ void CheatManagerDialog::addToWatchClicked()
void CheatManagerDialog::addManualWatchAddressClicked()
{
std::optional<unsigned> address = QtUtils::PromptForAddress(this, windowTitle(), tr("Enter memory address:"));
std::optional<unsigned> address = QtUtils::PromptForAddress(this, windowTitle(), tr("Enter manual address:"), false);
if (!address.has_value())
return;

View file

@ -104,7 +104,7 @@ void DebuggerWindow::onGoToPCTriggered()
void DebuggerWindow::onGoToAddressTriggered()
{
std::optional<VirtualMemoryAddress> address =
QtUtils::PromptForAddress(this, windowTitle(), tr("Enter code address:"));
QtUtils::PromptForAddress(this, windowTitle(), tr("Enter code address:"), true);
if (!address.has_value())
return;
@ -114,7 +114,7 @@ void DebuggerWindow::onGoToAddressTriggered()
void DebuggerWindow::onDumpAddressTriggered()
{
std::optional<VirtualMemoryAddress> address =
QtUtils::PromptForAddress(this, windowTitle(), tr("Enter memory address:"));
QtUtils::PromptForAddress(this, windowTitle(), tr("Enter memory address:"), false);
if (!address.has_value())
return;
@ -129,7 +129,7 @@ void DebuggerWindow::onFollowAddressTriggered()
void DebuggerWindow::onAddBreakpointTriggered()
{
std::optional<VirtualMemoryAddress> address =
QtUtils::PromptForAddress(this, windowTitle(), tr("Enter code address:"));
QtUtils::PromptForAddress(this, windowTitle(), tr("Enter code address:") , true);
if (!address.has_value())
return;

View file

@ -737,7 +737,7 @@ void FillComboBoxWithEmulationSpeeds(QComboBox* cb)
}
}
std::optional<unsigned> PromptForAddress(QWidget* parent, const QString& title, const QString& label)
std::optional<unsigned> PromptForAddress(QWidget* parent, const QString& title, const QString& label, bool code)
{
const QString address_str(
QInputDialog::getText(parent, title, qApp->translate("DebuggerWindow", "Enter memory address:")));
@ -748,16 +748,16 @@ std::optional<unsigned> PromptForAddress(QWidget* parent, const QString& title,
uint address;
if (address_str.startsWith("0x"))
address = address_str.midRef(2).toUInt(&ok, 16);
else if (address_str[0] == '0' && address_str.length() > 1)
address = address_str.midRef(1).toUInt(&ok, 8);
else
address = address_str.toUInt(&ok, 10);
address = address_str.toUInt(&ok, 16);
if ( code == true )
address = address & 0xFFFFFFFC; //disassembly address should be divisible by 4 so make sure
if (!ok)
{
QMessageBox::critical(
parent, title,
qApp->translate("DebuggerWindow", "Invalid address. It should be in hex (0x12345678) or decimal (12345678)"));
qApp->translate("DebuggerWindow", "Invalid address. It should be in hex (0x12345678 or 12345678)"));
return std::nullopt;
}

View file

@ -71,7 +71,7 @@ void FillComboBoxWithMSAAModes(QComboBox* cb);
/// Fills a combo box with emulation speed options.
void FillComboBoxWithEmulationSpeeds(QComboBox* cb);
/// Prompts for an address in decimal, octal, or hex.
std::optional<unsigned> PromptForAddress(QWidget* parent, const QString& title, const QString& label);
/// Prompts for an address in hex.
std::optional<unsigned> PromptForAddress(QWidget* parent, const QString& title, const QString& label, bool code);
} // namespace QtUtils

View file

@ -2156,7 +2156,7 @@ Cet avertissement ne sera affiché qu&apos;une seule fois.</translation>
</message>
<message>
<location filename="../qtutils.cpp" line="760"/>
<source>Invalid address. It should be in hex (0x12345678) or decimal (12345678)</source>
<source>Invalid address. It should be in hex (0x12345678 or 12345678)</source>
<translation type="unfinished"></translation>
</message>
</context>

View file

@ -2252,8 +2252,8 @@ This warning will only be shown once.</source>
</message>
<message>
<location filename="../qtutils.cpp" line="760"/>
<source>Invalid address. It should be in hex (0x12345678) or decimal (12345678)</source>
<translation>Endereço inválido! Valores devem ser: hexa (0x12345678) ou decimal (12345678)</translation>
<source>Invalid address. It should be in hex (0x12345678 or 12345678)</source>
<translation>Endereço inválido! Valores devem ser: hexa (0x12345678 ou 12345678)</translation>
</message>
</context>
<context>

View file

@ -2213,8 +2213,8 @@ This warning will only be shown once.</source>
</message>
<message>
<location filename="../qtutils.cpp" line="760"/>
<source>Invalid address. It should be in hex (0x12345678) or decimal (12345678)</source>
<translation>(0x12345678)(12345678)</translation>
<source>Invalid address. It should be in hex (0x12345678 or 12345678)</source>
<translation>(0x1234567812345678)</translation>
</message>
</context>
<context>