Cleaned up int comparison sign mismatches in Qt TasEditor markers.

This commit is contained in:
harry 2023-01-28 13:49:09 -05:00
parent d530bab2e7
commit 4434974350
1 changed files with 15 additions and 15 deletions

View File

@ -27,8 +27,7 @@ MARKERS::MARKERS()
void MARKERS::save(EMUFILE *os) void MARKERS::save(EMUFILE *os)
{ {
// write size // write size
int size = markersArray.size(); uint32_t size = markersArray.size();
int len;
write32le(size, os); write32le(size, os);
// write array // write array
if (!alreadyCompressed) if (!alreadyCompressed)
@ -38,9 +37,9 @@ void MARKERS::save(EMUFILE *os)
// write notes // write notes
size = notes.size(); size = notes.size();
write32le(size, os); write32le(size, os);
for (int i = 0; i < size; ++i) for (unsigned int i = 0; i < size; ++i)
{ {
len = notes[i].length() + 1; uint32_t len = notes[i].length() + 1;
if (len > MAX_NOTE_LEN) len = MAX_NOTE_LEN; if (len > MAX_NOTE_LEN) len = MAX_NOTE_LEN;
write32le(len, os); write32le(len, os);
os->fwrite(notes[i].c_str(), len); os->fwrite(notes[i].c_str(), len);
@ -49,13 +48,13 @@ void MARKERS::save(EMUFILE *os)
// returns true if couldn't load // returns true if couldn't load
bool MARKERS::load(EMUFILE *is) bool MARKERS::load(EMUFILE *is)
{ {
int size; uint32_t size=0;
if (read32le(&size, is)) if (read32le(&size, is))
{ {
markersArray.resize(size); markersArray.resize(size);
// read and uncompress array // read and uncompress array
alreadyCompressed = true; alreadyCompressed = true;
int comprlen, len; uint32_t comprlen, len;
uLongf destlen = size * sizeof(int); uLongf destlen = size * sizeof(int);
if (!read32le(&comprlen, is)) return true; if (!read32le(&comprlen, is)) return true;
if (comprlen <= 0) return true; if (comprlen <= 0) return true;
@ -64,14 +63,15 @@ bool MARKERS::load(EMUFILE *is)
int e = uncompress((uint8*)&markersArray[0], &destlen, &compressedMarkersArray[0], comprlen); int e = uncompress((uint8*)&markersArray[0], &destlen, &compressedMarkersArray[0], comprlen);
if (e != Z_OK && e != Z_BUF_ERROR) return true; if (e != Z_OK && e != Z_BUF_ERROR) return true;
// read notes // read notes
if (read32le(&size, is) && size >= 0) if (read32le(&size, is))
{ {
notes.resize(size); notes.resize(size);
char temp_str[MAX_NOTE_LEN]; char temp_str[MAX_NOTE_LEN];
for (int i = 0; i < size; ++i) for (unsigned int i = 0; i < size; ++i)
{ {
if (!read32le(&len, is) || len < 0) return true; if (!read32le(&len, is) || (len > MAX_NOTE_LEN) ) return true;
if ((int)is->fread(temp_str, len) < len) return true; if (is->fread(temp_str, len) < len) return true;
temp_str[sizeof(temp_str)-1] = 0;
notes[i] = temp_str; notes[i] = temp_str;
} }
// all ok // all ok
@ -85,15 +85,15 @@ bool MARKERS::skipLoad(EMUFILE *is)
if (!(is->fseek(sizeof(int), SEEK_CUR))) if (!(is->fseek(sizeof(int), SEEK_CUR)))
{ {
// read array // read array
int comprlen, len; uint32_t comprlen, len;
if (!read32le(&comprlen, is)) return true; if (!read32le(&comprlen, is)) return true;
if (is->fseek(comprlen, SEEK_CUR) != 0) return true; if (is->fseek(comprlen, SEEK_CUR) != 0) return true;
// read notes // read notes
if (read32le(&comprlen, is) && comprlen >= 0) if (read32le(&comprlen, is))
{ {
for (int i = 0; i < comprlen; ++i) for (unsigned int i = 0; i < comprlen; ++i)
{ {
if (!read32le(&len, is) || len < 0) return true; if (!read32le(&len, is) || (len > MAX_NOTE_LEN) ) return true;
if (is->fseek(len, SEEK_CUR) != 0) return true; if (is->fseek(len, SEEK_CUR) != 0) return true;
} }
// all ok // all ok
@ -105,7 +105,7 @@ bool MARKERS::skipLoad(EMUFILE *is)
void MARKERS::compressData() void MARKERS::compressData()
{ {
int len = markersArray.size() * sizeof(int); uint32_t len = markersArray.size() * sizeof(int);
uLongf comprlen = (len>>9)+12 + len; uLongf comprlen = (len>>9)+12 + len;
compressedMarkersArray.resize(comprlen); compressedMarkersArray.resize(comprlen);
compress(&compressedMarkersArray[0], &comprlen, (uint8*)&markersArray[0], len); compress(&compressedMarkersArray[0], &comprlen, (uint8*)&markersArray[0], len);