[*] NT ReadFile: replace GENERIC_READ, FILE_SHARE_READ with GENERIC_READ, FILE_SHARE_READ | FILE_SHARE_WRITE

[*] ByteBuffer::IsValid() will now return true if there is no underlying buffer so long as the object is marked with the dynamic scaling flag (no contents isnt an invalid state; alloc failure on construct and ad-hoc failure is. latterly, specify the write flag on failure in the ByteBuffer::Write method.) the alloc error can be safely unwound by state raii helpers bc realloc and frens will not free or dirty the state. write-fail-aware may roll back the write head, like how readers can roll back the read head if the stream is incomplete.
This commit is contained in:
Reece Wilson 2022-09-23 00:59:08 +01:00
parent 6ac4fd61ab
commit 1de0bdb4e7
3 changed files with 5 additions and 3 deletions

View File

@ -96,6 +96,7 @@ namespace Aurora::Memory
{ {
if (!Resize(offset + requestLength)) if (!Resize(offset + requestLength))
{ {
this->flagWriteError = true;
return 0; return 0;
} }

View File

@ -117,7 +117,7 @@ namespace Aurora::Memory
bool ByteBuffer::IsValid() const bool ByteBuffer::IsValid() const
{ {
return !IsEmpty() && !HasStreamError(); return (!IsEmpty() || this->flagExpandable) && !HasStreamError();
} }
bool ByteBuffer::IsEmpty() const bool ByteBuffer::IsEmpty() const

View File

@ -247,7 +247,7 @@ namespace Aurora::IO::FS
return false; return false;
} }
auto fileHandle = CreateFileW(win32Path.c_str(), GENERIC_READ, FILE_SHARE_READ, NULL, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL); auto fileHandle = CreateFileW(win32Path.c_str(), GENERIC_READ, FILE_SHARE_READ | FILE_SHARE_WRITE, NULL, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL);
if (fileHandle == INVALID_HANDLE_VALUE) if (fileHandle == INVALID_HANDLE_VALUE)
{ {
SysPushErrorIO("Couldn't open handle: {}", path); SysPushErrorIO("Couldn't open handle: {}", path);
@ -263,7 +263,8 @@ namespace Aurora::IO::FS
writeView = buffer.GetOrAllocateLinearWriteable(length.QuadPart); writeView = buffer.GetOrAllocateLinearWriteable(length.QuadPart);
if (!writeView) if (!writeView)
{ {
return {}; SysPushErrorMem();
goto out;
} }
while (length.QuadPart) while (length.QuadPart)