Qt: Load/save bytes from memory viewer in the order visible (fixes #1900)

This commit is contained in:
Vicki Pfau 2020-10-06 01:11:34 -07:00
parent 22950a6796
commit 7b3900ff93
1 changed files with 4 additions and 4 deletions

View File

@ -246,7 +246,7 @@ QByteArray MemoryModel::serialize() {
for (uint32_t i = m_selection.first; i < m_selection.second; i += m_align) { for (uint32_t i = m_selection.first; i < m_selection.second; i += m_align) {
quint16 datum = m_core->rawRead16(m_core, i, m_currentBank); quint16 datum = m_core->rawRead16(m_core, i, m_currentBank);
char leDatum[2]; char leDatum[2];
STORE_16LE(datum, 0, (uint16_t*) leDatum); STORE_16BE(datum, 0, (uint16_t*) leDatum);
bytes.append(leDatum, 2); bytes.append(leDatum, 2);
} }
break; break;
@ -254,7 +254,7 @@ QByteArray MemoryModel::serialize() {
for (uint32_t i = m_selection.first; i < m_selection.second; i += m_align) { for (uint32_t i = m_selection.first; i < m_selection.second; i += m_align) {
quint32 datum = m_core->rawRead32(m_core, i, m_currentBank); quint32 datum = m_core->rawRead32(m_core, i, m_currentBank);
char leDatum[4]; char leDatum[4];
STORE_32LE(datum, 0, (uint16_t*) leDatum); STORE_32BE(datum, 0, (uint32_t*) leDatum);
bytes.append(leDatum, 4); bytes.append(leDatum, 4);
} }
break; break;
@ -275,7 +275,7 @@ void MemoryModel::deserialize(const QByteArray& bytes) {
for (int i = 0; i < bytes.size(); i += m_align, addr += m_align) { for (int i = 0; i < bytes.size(); i += m_align, addr += m_align) {
char leDatum[2]{ bytes[i], bytes[i + 1] }; char leDatum[2]{ bytes[i], bytes[i + 1] };
uint16_t datum; uint16_t datum;
LOAD_16LE(datum, 0, leDatum); LOAD_16BE(datum, 0, leDatum);
m_core->rawWrite16(m_core, addr, m_currentBank, datum); m_core->rawWrite16(m_core, addr, m_currentBank, datum);
} }
break; break;
@ -283,7 +283,7 @@ void MemoryModel::deserialize(const QByteArray& bytes) {
for (int i = 0; i < bytes.size(); i += m_align, addr += m_align) { for (int i = 0; i < bytes.size(); i += m_align, addr += m_align) {
char leDatum[4]{ bytes[i], bytes[i + 1], bytes[i + 2], bytes[i + 3] }; char leDatum[4]{ bytes[i], bytes[i + 1], bytes[i + 2], bytes[i + 3] };
uint32_t datum; uint32_t datum;
LOAD_32LE(datum, 0, leDatum); LOAD_32BE(datum, 0, leDatum);
m_core->rawWrite32(m_core, addr, m_currentBank, datum); m_core->rawWrite32(m_core, addr, m_currentBank, datum);
} }
break; break;