1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2024-12-31 03:29:10 -05:00
denoland-deno/runtime/js/30_os.js
2022-01-31 14:44:19 +09:00

103 lines
2.1 KiB
JavaScript

// Copyright 2018-2022 the Deno authors. All rights reserved. MIT license.
"use strict";
((window) => {
const core = window.Deno.core;
const {
Error,
SymbolFor,
} = window.__bootstrap.primordials;
function loadavg() {
return core.opSync("op_loadavg");
}
function hostname() {
return core.opSync("op_hostname");
}
function osRelease() {
return core.opSync("op_os_release");
}
function systemMemoryInfo() {
return core.opSync("op_system_memory_info");
}
function networkInterfaces() {
return core.opSync("op_network_interfaces");
}
function getUid() {
return core.opSync("op_getuid");
}
// This is an internal only method used by the test harness to override the
// behavior of exit when the exit sanitizer is enabled.
let exitHandler = null;
function setExitHandler(fn) {
exitHandler = fn;
}
function exit(code) {
// Set exit code first so unload event listeners can override it.
if (typeof code === "number") {
core.opSync("op_set_exit_code", code);
} else {
code = 0;
}
// Dispatches `unload` only when it's not dispatched yet.
if (!window[SymbolFor("isUnloadDispatched")]) {
// Invokes the `unload` hooks before exiting
// ref: https://github.com/denoland/deno/issues/3603
window.dispatchEvent(new Event("unload"));
}
if (exitHandler) {
exitHandler(code);
return;
}
core.opSync("op_exit");
throw new Error("Code not reachable");
}
function setEnv(key, value) {
core.opSync("op_set_env", key, value);
}
function getEnv(key) {
return core.opSync("op_get_env", key) ?? undefined;
}
function deleteEnv(key) {
core.opSync("op_delete_env", key);
}
const env = {
get: getEnv,
toObject() {
return core.opSync("op_env");
},
set: setEnv,
delete: deleteEnv,
};
function execPath() {
return core.opSync("op_exec_path");
}
window.__bootstrap.os = {
env,
execPath,
exit,
getUid,
hostname,
loadavg,
networkInterfaces,
osRelease,
setExitHandler,
systemMemoryInfo,
};
})(this);