0
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2024-10-31 09:14:20 -04:00
denoland-deno/js/files.ts

133 lines
4.1 KiB
TypeScript
Raw Normal View History

2019-01-21 14:03:30 -05:00
// Copyright 2018-2019 the Deno authors. All rights reserved. MIT license.
import { Reader, Writer, Closer, ReadResult } from "./io";
import * as dispatch from "./dispatch";
2018-10-03 21:18:23 -04:00
import * as msg from "gen/msg_generated";
import { assert } from "./util";
import * as flatbuffers from "./flatbuffers";
2018-10-14 16:29:50 -04:00
/** The Deno abstraction for reading and writing files. */
export class File implements Reader, Writer, Closer {
2018-10-10 11:59:36 -04:00
constructor(readonly rid: number) {}
write(p: Uint8Array): Promise<number> {
2018-10-10 11:59:36 -04:00
return write(this.rid, p);
}
read(p: Uint8Array): Promise<ReadResult> {
2018-10-10 11:59:36 -04:00
return read(this.rid, p);
}
close(): void {
2018-10-10 11:59:36 -04:00
close(this.rid);
}
}
2018-10-14 16:29:50 -04:00
/** An instance of `File` for stdin. */
export const stdin = new File(0);
2018-10-14 16:29:50 -04:00
/** An instance of `File` for stdout. */
export const stdout = new File(1);
2018-10-14 16:29:50 -04:00
/** An instance of `File` for stderr. */
export const stderr = new File(2);
2018-12-13 16:20:37 -05:00
export type OpenMode =
2018-12-12 12:05:58 -05:00
/** Read-only. Default. Starts at beginning of file. */
| "r"
/** Read-write. Start at beginning of file. */
| "r+"
/** Write-only. Opens and truncates existing file or creates new one for
* writing only.
*/
| "w"
/** Read-write. Opens and truncates existing file or creates new one for
* writing and reading.
*/
| "w+"
/** Write-only. Opens existing file or creates new one. Each write appends
* content to the end of file.
*/
| "a"
/** Read-write. Behaves like "a" and allows to read from file. */
| "a+"
/** Write-only. Exclusive create - creates new file only if one doesn't exist
* already.
*/
| "x"
/** Read-write. Behaves like `x` and allows to read from file. */
| "x+";
2018-10-14 16:29:50 -04:00
/** A factory function for creating instances of `File` associated with the
* supplied file name.
*/
export function create(filename: string): Promise<File> {
2018-12-12 12:05:58 -05:00
return open(filename, "w+");
}
2018-10-14 16:29:50 -04:00
/** Open a file and return an instance of the `File` object.
*
* (async () => {
* const file = await Deno.open("/foo/bar.txt");
2018-10-14 16:29:50 -04:00
* })();
*/
export async function open(
filename: string,
mode: OpenMode = "r"
): Promise<File> {
const builder = flatbuffers.createBuilder();
const filename_ = builder.createString(filename);
2018-12-12 12:05:58 -05:00
const mode_ = builder.createString(mode);
2018-10-03 21:18:23 -04:00
msg.Open.startOpen(builder);
msg.Open.addFilename(builder, filename_);
2018-12-12 12:05:58 -05:00
msg.Open.addMode(builder, mode_);
2018-10-03 21:18:23 -04:00
const inner = msg.Open.endOpen(builder);
const baseRes = await dispatch.sendAsync(builder, msg.Any.Open, inner);
assert(baseRes != null);
2018-10-03 21:18:23 -04:00
assert(msg.Any.OpenRes === baseRes!.innerType());
const res = new msg.OpenRes();
assert(baseRes!.inner(res) != null);
2018-10-10 11:59:36 -04:00
const rid = res.rid();
return new File(rid);
}
2018-10-14 16:29:50 -04:00
/** Read from a file ID into an array buffer.
*
* Resolves with the `ReadResult` for the operation.
*/
export async function read(rid: number, p: Uint8Array): Promise<ReadResult> {
const builder = flatbuffers.createBuilder();
2018-10-03 21:18:23 -04:00
msg.Read.startRead(builder);
2018-10-10 11:59:36 -04:00
msg.Read.addRid(builder, rid);
2018-10-03 21:18:23 -04:00
const inner = msg.Read.endRead(builder);
const baseRes = await dispatch.sendAsync(builder, msg.Any.Read, inner, p);
assert(baseRes != null);
2018-10-03 21:18:23 -04:00
assert(msg.Any.ReadRes === baseRes!.innerType());
const res = new msg.ReadRes();
assert(baseRes!.inner(res) != null);
return { nread: res.nread(), eof: res.eof() };
}
2018-10-14 16:29:50 -04:00
/** Write to the file ID the contents of the array buffer.
*
* Resolves with the number of bytes written.
*/
export async function write(rid: number, p: Uint8Array): Promise<number> {
const builder = flatbuffers.createBuilder();
2018-10-03 21:18:23 -04:00
msg.Write.startWrite(builder);
2018-10-10 11:59:36 -04:00
msg.Write.addRid(builder, rid);
2018-10-03 21:18:23 -04:00
const inner = msg.Write.endWrite(builder);
const baseRes = await dispatch.sendAsync(builder, msg.Any.Write, inner, p);
assert(baseRes != null);
2018-10-03 21:18:23 -04:00
assert(msg.Any.WriteRes === baseRes!.innerType());
const res = new msg.WriteRes();
assert(baseRes!.inner(res) != null);
return res.nbyte();
}
2018-10-14 16:29:50 -04:00
/** Close the file ID. */
2018-10-10 11:59:36 -04:00
export function close(rid: number): void {
const builder = flatbuffers.createBuilder();
2018-10-03 21:18:23 -04:00
msg.Close.startClose(builder);
2018-10-10 11:59:36 -04:00
msg.Close.addRid(builder, rid);
2018-10-03 21:18:23 -04:00
const inner = msg.Close.endClose(builder);
dispatch.sendSync(builder, msg.Any.Close, inner);
}