diff options
author | Dominik Picheta <dominikpicheta@googlemail.com> | 2017-04-08 12:24:21 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-04-08 12:24:21 +0200 |
commit | 27ede215041fb5269670fef98bb655c15a2724a8 (patch) | |
tree | 3ecb4a6b70c1c1e739c83f7cfa45f840c7ef0b7e /lib/pure | |
parent | cdfcc12529d716786683c997f1f673bd423432b6 (diff) | |
parent | bc5c2d8414f053281beeb1f3af9c4e03ac49184a (diff) | |
download | Nim-27ede215041fb5269670fef98bb655c15a2724a8.tar.gz |
Merge pull request #5612 from ehmry/AsyncFile.setLen
asyncfile: setLen procedure for files
Diffstat (limited to 'lib/pure')
-rw-r--r-- | lib/pure/asyncfile.nim | 24 |
1 files changed, 21 insertions, 3 deletions
diff --git a/lib/pure/asyncfile.nim b/lib/pure/asyncfile.nim index c58e6c11b..86cd8d1be 100644 --- a/lib/pure/asyncfile.nim +++ b/lib/pure/asyncfile.nim @@ -70,14 +70,16 @@ else: result = O_RDWR result = result or O_NONBLOCK -proc getFileSize(f: AsyncFile): int64 = +proc getFileSize*(f: AsyncFile): int64 = ## Retrieves the specified file's size. when defined(windows) or defined(nimdoc): var high: DWord let low = getFileSize(f.fd.Handle, addr high) if low == INVALID_FILE_SIZE: raiseOSError(osLastError()) - return (high shl 32) or low + result = (high shl 32) or low + else: + result = lseek(f.fd.cint, 0, SEEK_END) proc openAsync*(filename: string, mode = fmRead): AsyncFile = ## Opens a file specified by the path in ``filename`` using @@ -466,6 +468,22 @@ proc write*(f: AsyncFile, data: string): Future[void] = addWrite(f.fd, cb) return retFuture +proc setFileSize*(f: AsyncFile, length: int64) = + ## Set a file length. + when defined(windows) or defined(nimdoc): + var + high = (length shr 32).Dword + let + low = (length and 0xffffffff).Dword + status = setFilePointer(f.fd.Handle, low, addr high, 0) + lastErr = osLastError() + if (status == INVALID_SET_FILE_POINTER and lastErr.int32 != NO_ERROR) or + (setEndOfFile(f.fd.Handle) == 0): + raiseOSError(osLastError()) + else: + if ftruncate(f.fd.cint, length) == -1: + raiseOSError(osLastError()) + proc close*(f: AsyncFile) = ## Closes the file specified. unregister(f.fd) @@ -498,4 +516,4 @@ proc readToStream*(f: AsyncFile, fs: FutureStream[string]) {.async.} = break await fs.write(data) - fs.complete() \ No newline at end of file + fs.complete() |