1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2025-01-18 20:04:03 -05:00
denoland-deno/js/make_temp_dir.ts

71 lines
2.4 KiB
TypeScript
Raw Normal View History

2019-01-22 04:03:30 +09:00
// Copyright 2018-2019 the Deno authors. All rights reserved. MIT license.
2018-10-03 21:18:23 -04:00
import * as msg from "gen/msg_generated";
import * as flatbuffers from "./flatbuffers";
2018-09-13 11:04:45 +09:00
import * as dispatch from "./dispatch";
import { assert } from "./util";
export interface MakeTempDirOptions {
dir?: string;
prefix?: string;
suffix?: string;
}
function req({
dir,
prefix,
suffix
2018-10-03 21:18:23 -04:00
}: MakeTempDirOptions): [flatbuffers.Builder, msg.Any, flatbuffers.Offset] {
const builder = flatbuffers.createBuilder();
2018-09-13 11:04:45 +09:00
const fbDir = dir == null ? -1 : builder.createString(dir);
const fbPrefix = prefix == null ? -1 : builder.createString(prefix);
const fbSuffix = suffix == null ? -1 : builder.createString(suffix);
2018-10-03 21:18:23 -04:00
msg.MakeTempDir.startMakeTempDir(builder);
2018-09-13 11:04:45 +09:00
if (dir != null) {
2018-10-03 21:18:23 -04:00
msg.MakeTempDir.addDir(builder, fbDir);
2018-09-13 11:04:45 +09:00
}
if (prefix != null) {
2018-10-03 21:18:23 -04:00
msg.MakeTempDir.addPrefix(builder, fbPrefix);
2018-09-13 11:04:45 +09:00
}
if (suffix != null) {
2018-10-03 21:18:23 -04:00
msg.MakeTempDir.addSuffix(builder, fbSuffix);
2018-09-13 11:04:45 +09:00
}
2018-10-03 21:18:23 -04:00
const inner = msg.MakeTempDir.endMakeTempDir(builder);
return [builder, msg.Any.MakeTempDir, inner];
2018-09-13 11:04:45 +09:00
}
2018-10-03 21:18:23 -04:00
function res(baseRes: null | msg.Base): string {
2018-09-13 11:04:45 +09:00
assert(baseRes != null);
2018-10-03 21:18:23 -04:00
assert(msg.Any.MakeTempDirRes === baseRes!.innerType());
const res = new msg.MakeTempDirRes();
assert(baseRes!.inner(res) != null);
2018-09-13 11:04:45 +09:00
const path = res.path();
assert(path != null);
return path!;
}
/** makeTempDirSync is the synchronous version of `makeTempDir`.
*
* const tempDirName0 = Deno.makeTempDirSync();
* const tempDirName1 = Deno.makeTempDirSync({ prefix: 'my_temp' });
*/
export function makeTempDirSync(options: MakeTempDirOptions = {}): string {
return res(dispatch.sendSync(...req(options)));
}
/** makeTempDir creates a new temporary directory in the directory `dir`, its
* name beginning with `prefix` and ending with `suffix`.
* It returns the full path to the newly created directory.
* If `dir` is unspecified, tempDir uses the default directory for temporary
* files. Multiple programs calling tempDir simultaneously will not choose the
* same directory. It is the caller's responsibility to remove the directory
* when no longer needed.
*
* const tempDirName0 = await Deno.makeTempDir();
* const tempDirName1 = await Deno.makeTempDir({ prefix: 'my_temp' });
*/
export async function makeTempDir(
options: MakeTempDirOptions = {}
): Promise<string> {
return res(await dispatch.sendAsync(...req(options)));
}