1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2024-12-30 11:16:38 -05:00
denoland-deno/cli/js/os.ts

150 lines
4.4 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 { core } from "./core.ts";
import * as dispatch from "./dispatch.ts";
import { sendSync } from "./dispatch_json.ts";
import { assert } from "./util.ts";
import * as util from "./util.ts";
import { window } from "./window.ts";
import { OperatingSystem, Arch } from "./build.ts";
2019-02-02 22:05:30 -05:00
/** Check if running in terminal.
*
* console.log(Deno.isTTY().stdout);
2019-02-02 22:05:30 -05:00
*/
export function isTTY(): { stdin: boolean; stdout: boolean; stderr: boolean } {
2019-08-26 08:50:21 -04:00
return sendSync(dispatch.OP_IS_TTY);
2019-02-02 22:05:30 -05:00
}
2019-09-27 19:09:42 -04:00
/** Get the hostname.
* Requires the `--allow-env` flag.
*
* console.log(Deno.hostname());
*/
export function hostname(): string {
return sendSync(dispatch.OP_HOSTNAME);
}
2018-10-14 16:29:50 -04:00
/** Exit the Deno process with optional exit code. */
export function exit(code = 0): never {
2019-08-26 08:50:21 -04:00
sendSync(dispatch.OP_EXIT, { code });
return util.unreachable();
}
function setEnv(key: string, value: string): void {
2019-08-26 08:50:21 -04:00
sendSync(dispatch.OP_SET_ENV, { key, value });
}
function getEnv(key: string): string | undefined {
return sendSync(dispatch.OP_GET_ENV, { key })[0];
}
2018-10-14 16:29:50 -04:00
/** Returns a snapshot of the environment variables at invocation. Mutating a
* property in the object will set that variable in the environment for
* the process. The environment object will only accept `string`s
* as values.
*
* console.log(Deno.env("SHELL"));
* const myEnv = Deno.env();
2018-10-14 16:29:50 -04:00
* console.log(myEnv.SHELL);
* myEnv.TEST_VAR = "HELLO";
* const newEnv = Deno.env();
2018-10-14 16:29:50 -04:00
* console.log(myEnv.TEST_VAR == newEnv.TEST_VAR);
*/
export function env(): { [index: string]: string };
export function env(key: string): string | undefined;
export function env(
key?: string
): { [index: string]: string } | string | undefined {
if (key) {
return getEnv(key);
}
2019-08-26 08:50:21 -04:00
const env = sendSync(dispatch.OP_ENV);
return new Proxy(env, {
set(obj, prop: string, value: string): boolean {
setEnv(prop, value);
return Reflect.set(obj, prop, value);
}
});
}
2019-08-26 08:50:21 -04:00
interface Start {
cwd: string;
pid: number;
argv: string[];
mainModule: string; // Absolute URL.
debugFlag: boolean;
depsFlag: boolean;
typesFlag: boolean;
versionFlag: boolean;
denoVersion: string;
v8Version: string;
tsVersion: string;
2019-08-26 08:50:21 -04:00
noColor: boolean;
os: OperatingSystem;
arch: Arch;
}
// This function bootstraps an environment within Deno, it is shared both by
// the runtime and the compiler environments.
// @internal
2019-08-26 08:50:21 -04:00
export function start(preserveDenoNamespace = true, source?: string): Start {
core.setAsyncHandler(dispatch.asyncMsgFromRust);
const ops = core.ops();
// TODO(bartlomieju): this is a prototype, we should come up with
// something a bit more sophisticated
for (const [name, opId] of Object.entries(ops)) {
const opName = `OP_${name.toUpperCase()}`;
// Assign op ids to actual variables
// TODO(ry) This type casting is gross and should be fixed.
((dispatch as unknown) as { [key: string]: number })[opName] = opId;
}
// First we send an empty `Start` message to let the privileged side know we
// are ready. The response should be a `StartRes` message containing the CLI
// args and other info.
const startResponse = sendSync(dispatch.OP_START);
const { pid, noColor, debugFlag } = startResponse;
util.setLogDebug(debugFlag, source);
// pid and noColor need to be set in the Deno module before it's set to be
// frozen.
util.immutableDefine(window.Deno, "pid", pid);
util.immutableDefine(window.Deno, "noColor", noColor);
Object.freeze(window.Deno);
if (preserveDenoNamespace) {
util.immutableDefine(window, "Deno", window.Deno);
// Deno.core could ONLY be safely frozen here (not in globals.ts)
// since shared_queue.js will modify core properties.
Object.freeze(window.Deno.core);
// core.sharedQueue is an object so we should also freeze it.
Object.freeze(window.Deno.core.sharedQueue);
} else {
// Remove window.Deno
delete window.Deno;
assert(window.Deno === undefined);
}
return startResponse;
}
2019-06-25 12:05:41 -04:00
/**
* Returns the current user's home directory.
* Requires the `--allow-env` flag.
2019-06-25 12:05:41 -04:00
*/
export function homeDir(): string {
2019-08-26 08:50:21 -04:00
const path = sendSync(dispatch.OP_HOME_DIR);
2019-06-25 12:05:41 -04:00
if (!path) {
throw new Error("Could not get home directory.");
}
return path;
}
2019-08-06 20:32:25 -04:00
/**
* Returns the path to the current deno executable.
* Requires the `--allow-env` flag.
*/
export function execPath(): string {
2019-08-26 08:50:21 -04:00
return sendSync(dispatch.OP_EXEC_PATH);
}