Веб-сайт самохостера Lotigara

summaryrefslogtreecommitdiff
path: root/source/core
diff options
context:
space:
mode:
authorKae <80987908+Novaenia@users.noreply.github.com>2024-09-12 23:52:01 +1000
committerKae <80987908+Novaenia@users.noreply.github.com>2024-09-12 23:52:01 +1000
commit834acaf6bd6f1c62b0f5c01f8891c814749f80ec (patch)
treef074292d3eb3af6a55dcb8287bb6ce870964270c /source/core
parent261ba6d643542cc10ba07711a278fac7d3e09997 (diff)
parent7a043e472701ed6c473072cc2578c44bcdab48db (diff)
Merge branch 'main' into wip/net-n-btree
Diffstat (limited to 'source/core')
-rw-r--r--source/core/StarFile_windows.cpp20
1 files changed, 7 insertions, 13 deletions
diff --git a/source/core/StarFile_windows.cpp b/source/core/StarFile_windows.cpp
index 54d6c82..6352bb7 100644
--- a/source/core/StarFile_windows.cpp
+++ b/source/core/StarFile_windows.cpp
@@ -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) {
@@ -377,10 +375,8 @@ size_t File::pread(void* f, char* data, size_t len, StreamOffset position) {
HANDLE file = (HANDLE)f;
DWORD numRead = 0;
OVERLAPPED overlapped = makeOverlapped(position);
- StreamOffset pos = ftell(f);
- fseek(f, 0, IOSeek::Absolute);
int ret = ReadFile(file, data, len, &numRead, &overlapped);
- fseek(f, pos, IOSeek::Absolute);
+ fseek(f, -(StreamOffset)numRead, IOSeek::Relative);
if (ret == 0) {
auto err = GetLastError();
if (err != ERROR_IO_PENDING)
@@ -394,10 +390,8 @@ size_t File::pwrite(void* f, char const* data, size_t len, StreamOffset position
HANDLE file = (HANDLE)f;
DWORD numWritten = 0;
OVERLAPPED overlapped = makeOverlapped(position);
- StreamOffset pos = ftell(f);
- fseek(f, 0, IOSeek::Absolute);
int ret = WriteFile(file, data, len, &numWritten, &overlapped);
- fseek(f, pos, IOSeek::Absolute);
+ fseek(f, -(StreamOffset)numWritten, IOSeek::Relative);
if (ret == 0) {
auto err = GetLastError();
if (err != ERROR_IO_PENDING)