1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2024-12-23 15:49:44 -05:00
denoland-deno/cli/js/stat.ts

85 lines
2.3 KiB
TypeScript
Raw Normal View History

2020-01-02 15:13:47 -05:00
// Copyright 2018-2020 the Deno authors. All rights reserved. MIT license.
import { sendSync, sendAsync } from "./dispatch_json.ts";
import { FileInfo, FileInfoImpl } from "./file_info.ts";
2018-09-11 15:38:53 -04:00
/** @internal */
2019-08-26 10:18:42 -04:00
export interface StatResponse {
isFile: boolean;
isSymlink: boolean;
len: number;
modified: number;
accessed: number;
created: number;
name: string | null;
// Unix only members
dev: number;
ino: number;
mode: number;
nlink: number;
uid: number;
gid: number;
rdev: number;
blksize: number;
blocks: number;
}
/** Resolves to a `Deno.FileInfo` for the specified path. If path is a
* symlink, information for the symlink will be returned.
2018-09-11 15:38:53 -04:00
*
* const fileInfo = await Deno.lstat("hello.txt");
2018-10-14 16:29:50 -04:00
* assert(fileInfo.isFile());
*
* Requires `allow-read` permission. */
2018-09-11 15:38:53 -04:00
export async function lstat(filename: string): Promise<FileInfo> {
2020-02-25 09:14:27 -05:00
const res = (await sendAsync("op_stat", {
2019-08-26 10:18:42 -04:00
filename,
lstat: true
})) as StatResponse;
return new FileInfoImpl(res);
2018-09-11 15:38:53 -04:00
}
/** Synchronously returns a `Deno.FileInfo` for the specified path. If
* path is a symlink, information for the symlink will be returned.
2018-09-11 15:38:53 -04:00
*
* const fileInfo = Deno.lstatSync("hello.txt");
2018-10-14 16:29:50 -04:00
* assert(fileInfo.isFile());
*
* Requires `allow-read` permission. */
2018-09-11 15:38:53 -04:00
export function lstatSync(filename: string): FileInfo {
2020-02-25 09:14:27 -05:00
const res = sendSync("op_stat", {
2019-08-26 10:18:42 -04:00
filename,
lstat: true
}) as StatResponse;
return new FileInfoImpl(res);
2018-09-11 15:38:53 -04:00
}
/** Resolves to a `Deno.FileInfo` for the specified path. Will always follow
* symlinks.
2018-09-11 15:38:53 -04:00
*
* const fileInfo = await Deno.stat("hello.txt");
2018-10-14 16:29:50 -04:00
* assert(fileInfo.isFile());
*
* Requires `allow-read` permission. */
2018-09-11 15:38:53 -04:00
export async function stat(filename: string): Promise<FileInfo> {
2020-02-25 09:14:27 -05:00
const res = (await sendAsync("op_stat", {
2019-08-26 10:18:42 -04:00
filename,
lstat: false
})) as StatResponse;
return new FileInfoImpl(res);
2018-09-11 15:38:53 -04:00
}
/** Synchronously returns a `Deno.FileInfo` for the specified path. Will
* always follow symlinks.
2018-09-11 15:38:53 -04:00
*
* const fileInfo = Deno.statSync("hello.txt");
2018-10-14 16:29:50 -04:00
* assert(fileInfo.isFile());
*
* Requires `allow-read` permission. */
2018-09-11 15:38:53 -04:00
export function statSync(filename: string): FileInfo {
2020-02-25 09:14:27 -05:00
const res = sendSync("op_stat", {
2019-08-26 10:18:42 -04:00
filename,
lstat: false
}) as StatResponse;
return new FileInfoImpl(res);
2018-09-11 15:38:53 -04:00
}