mirror of
https://github.com/tumic0/GPXSee.git
synced 2025-01-18 03:42:09 +01:00
Fixed possible crash when the cache wouldn't accept the new item
This commit is contained in:
parent
5cd0a3a8b0
commit
8f799e1bcf
@ -230,20 +230,18 @@ template<class T> bool IMG::readValue(T &val)
|
||||
return true;
|
||||
}
|
||||
|
||||
QByteArray IMG::readBlock(int blockNum)
|
||||
bool IMG::readBlock(int blockNum, QByteArray &data)
|
||||
{
|
||||
QByteArray *block = _blockCache[blockNum];
|
||||
if (!block) {
|
||||
if (!_file.seek((qint64)blockNum * (qint64)_blockSize))
|
||||
return QByteArray();
|
||||
QByteArray *ba = new QByteArray();
|
||||
ba->resize(_blockSize);
|
||||
if (read(ba->data(), _blockSize) < _blockSize) {
|
||||
delete ba;
|
||||
return QByteArray();
|
||||
}
|
||||
_blockCache.insert(blockNum, ba);
|
||||
return *ba;
|
||||
return false;
|
||||
data.resize(_blockSize);
|
||||
if (read(data.data(), _blockSize) < _blockSize)
|
||||
return false;
|
||||
_blockCache.insert(blockNum, new QByteArray(data));
|
||||
} else
|
||||
return *block;
|
||||
data = *block;
|
||||
|
||||
return true;
|
||||
}
|
||||
|
@ -65,7 +65,7 @@ private:
|
||||
typedef RTree<VectorTile*, double, 2> TileTree;
|
||||
|
||||
int blockSize() const {return _blockSize;}
|
||||
QByteArray readBlock(int blockNum);
|
||||
bool readBlock(int blockNum, QByteArray &data);
|
||||
qint64 read(char *data, qint64 maxSize);
|
||||
template<class T> bool readValue(T &val);
|
||||
|
||||
|
@ -33,8 +33,7 @@ bool SubFile::seek(Handle &handle, quint32 pos) const
|
||||
if (handle.blockNum != blockNum) {
|
||||
if (blockNum >= _blocks.size())
|
||||
return false;
|
||||
handle.data = _img->readBlock(_blocks.at(blockNum));
|
||||
if (handle.data.isNull())
|
||||
if (!_img->readBlock(_blocks.at(blockNum), handle.data))
|
||||
return false;
|
||||
handle.blockNum = blockNum;
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user