fix windows pread and pwrite bug
reading without a byte offset specified can affect absolute reads afterward, this is a workaround (thanks windows...)
This commit is contained in:
parent
7852ad9cf2
commit
9df51b51b8
@ -18,13 +18,11 @@
|
||||
|
||||
namespace Star {
|
||||
|
||||
namespace {
|
||||
OVERLAPPED makeOverlapped(StreamOffset offset) {
|
||||
OVERLAPPED overlapped = {};
|
||||
overlapped.Offset = offset;
|
||||
overlapped.OffsetHigh = offset >> 32;
|
||||
return overlapped;
|
||||
}
|
||||
OVERLAPPED makeOverlapped(StreamOffset offset) {
|
||||
OVERLAPPED overlapped = {};
|
||||
overlapped.Offset = offset;
|
||||
overlapped.OffsetHigh = offset >> 32;
|
||||
return overlapped;
|
||||
}
|
||||
|
||||
String File::convertDirSeparators(String const& path) {
|
||||
@ -378,6 +376,7 @@ size_t File::pread(void* f, char* data, size_t len, StreamOffset position) {
|
||||
DWORD numRead = 0;
|
||||
OVERLAPPED overlapped = makeOverlapped(position);
|
||||
int ret = ReadFile(file, data, len, &numRead, &overlapped);
|
||||
fseek(f, -(StreamOffset)numRead, IOSeek::Relative);
|
||||
if (ret == 0) {
|
||||
auto err = GetLastError();
|
||||
if (err != ERROR_IO_PENDING)
|
||||
@ -392,6 +391,7 @@ size_t File::pwrite(void* f, char const* data, size_t len, StreamOffset position
|
||||
DWORD numWritten = 0;
|
||||
OVERLAPPED overlapped = makeOverlapped(position);
|
||||
int ret = WriteFile(file, data, len, &numWritten, &overlapped);
|
||||
fseek(f, -(StreamOffset)numWritten, IOSeek::Relative);
|
||||
if (ret == 0) {
|
||||
auto err = GetLastError();
|
||||
if (err != ERROR_IO_PENDING)
|
||||
|
@ -18,13 +18,12 @@ void readPngData(png_structp pngPtr, png_bytep data, png_size_t length) {
|
||||
};
|
||||
|
||||
bool Image::isPng(IODevicePtr device) {
|
||||
png_byte header[8];
|
||||
device->readAbsolute(0, (char*)header, sizeof(header));
|
||||
return !png_sig_cmp(header, 0, sizeof(header));
|
||||
png_byte header[8]{};
|
||||
return !png_sig_cmp(header, 0, device->readAbsolute(0, (char*)header, sizeof(header)));
|
||||
}
|
||||
|
||||
Image Image::readPng(IODevicePtr device) {
|
||||
png_byte header[8];
|
||||
png_byte header[8]{};
|
||||
device->readFull((char*)header, sizeof(header));
|
||||
|
||||
if (png_sig_cmp(header, 0, sizeof(header)))
|
||||
|
Loading…
x
Reference in New Issue
Block a user