1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2024-12-11 10:07:54 -05:00
denoland-deno/runtime/js/30_os.js
Bartek Iwańczuk 201737c518
feat: stabilize Deno.osUptime() (#17554)
This commit stabilizes "Deno.osUptime()" API. The "--unstable" flag is
no longer required to use this API.
2023-02-14 12:35:38 +01:00

120 lines
2.1 KiB
JavaScript

// Copyright 2018-2023 the Deno authors. All rights reserved. MIT license.
const core = globalThis.Deno.core;
const ops = core.ops;
import { Event, EventTarget } from "internal:deno_web/02_event.js";
const primordials = globalThis.__bootstrap.primordials;
const {
Error,
SymbolFor,
} = primordials;
const windowDispatchEvent = EventTarget.prototype.dispatchEvent.bind(
globalThis,
);
function loadavg() {
return ops.op_loadavg();
}
function hostname() {
return ops.op_hostname();
}
function osRelease() {
return ops.op_os_release();
}
function osUptime() {
return ops.op_os_uptime();
}
function systemMemoryInfo() {
return ops.op_system_memory_info();
}
function networkInterfaces() {
return ops.op_network_interfaces();
}
function gid() {
return ops.op_gid();
}
function uid() {
return ops.op_uid();
}
// 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") {
ops.op_set_exit_code(code);
} else {
code = 0;
}
// Dispatches `unload` only when it's not dispatched yet.
if (!globalThis[SymbolFor("isUnloadDispatched")]) {
// Invokes the `unload` hooks before exiting
// ref: https://github.com/denoland/deno/issues/3603
windowDispatchEvent(new Event("unload"));
}
if (exitHandler) {
exitHandler(code);
return;
}
ops.op_exit();
throw new Error("Code not reachable");
}
function setEnv(key, value) {
ops.op_set_env(key, value);
}
function getEnv(key) {
return ops.op_get_env(key) ?? undefined;
}
function deleteEnv(key) {
ops.op_delete_env(key);
}
const env = {
get: getEnv,
toObject() {
return ops.op_env();
},
set: setEnv,
has(key) {
return getEnv(key) !== undefined;
},
delete: deleteEnv,
};
function execPath() {
return ops.op_exec_path();
}
export {
env,
execPath,
exit,
gid,
hostname,
loadavg,
networkInterfaces,
osRelease,
osUptime,
setExitHandler,
systemMemoryInfo,
uid,
};