mirror of
https://github.com/denoland/deno.git
synced 2024-12-28 18:19:08 -05:00
acf0958e94
There's a lot of variation in doc comments and internal code about whether the first parameter to file system calls is `path` or `name` or `filename`. For consistency, have made it always be `path`.
33 lines
885 B
TypeScript
33 lines
885 B
TypeScript
// Copyright 2018-2020 the Deno authors. All rights reserved. MIT license.
|
|
import { sendSync, sendAsync } from "./dispatch_json.ts";
|
|
|
|
function coerceLen(len?: number): number {
|
|
if (!len) {
|
|
return 0;
|
|
}
|
|
|
|
if (len < 0) {
|
|
return 0;
|
|
}
|
|
|
|
return len;
|
|
}
|
|
|
|
/** Synchronously truncates or extends the specified file, to reach the
|
|
* specified `len`.
|
|
*
|
|
* Deno.truncateSync("hello.txt", 10);
|
|
*
|
|
* Requires `allow-write` permission. */
|
|
export function truncateSync(path: string, len?: number): void {
|
|
sendSync("op_truncate", { path, len: coerceLen(len) });
|
|
}
|
|
|
|
/** Truncates or extends the specified file, to reach the specified `len`.
|
|
*
|
|
* await Deno.truncate("hello.txt", 10);
|
|
*
|
|
* Requires `allow-write` permission. */
|
|
export async function truncate(path: string, len?: number): Promise<void> {
|
|
await sendAsync("op_truncate", { path, len: coerceLen(len) });
|
|
}
|