Fixed an obvious bug, simplified a bit the code
git-svn-id: file:///srv/svn/repos/haiku/trunk/current@2470 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
089f7debba
commit
51ee67dc8f
@ -123,17 +123,16 @@ BBufferIO::ReadAt(off_t pos, void *buffer, size_t size)
|
|||||||
|| pos > m_buffer_start + m_buffer_used)
|
|| pos > m_buffer_start + m_buffer_used)
|
||||||
{
|
{
|
||||||
// ...cache as much as we can from the stream
|
// ...cache as much as we can from the stream
|
||||||
ssize_t readSize = m_stream->ReadAt(pos, m_buffer, m_buffer_phys);
|
m_buffer_used = m_stream->ReadAt(pos, m_buffer, m_buffer_phys);
|
||||||
m_buffer_used += readSize;
|
|
||||||
|
if (m_buffer_used > 0)
|
||||||
if (readSize > 0)
|
|
||||||
m_buffer_start = pos; // The data is buffered starting from this offset
|
m_buffer_start = pos; // The data is buffered starting from this offset
|
||||||
}
|
}
|
||||||
|
|
||||||
size = min_c(size, m_buffer_used);
|
size = min_c(size, m_buffer_used);
|
||||||
|
|
||||||
// copy data from the cache to the given buffer
|
// copy data from the cache to the given buffer
|
||||||
memcpy(buffer, m_buffer + pos, size);
|
memcpy(buffer, m_buffer + pos - m_buffer_start, size);
|
||||||
|
|
||||||
return size;
|
return size;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user