mirror of
https://github.com/denoland/deno.git
synced 2025-01-07 06:46:59 -05:00
refactor: remove Deno[Deno.internal].nodeUnstable namespace (#18449)
Since we can preserve ops in the snapshot these days, we no longer need to have "Deno[Deno.internal].nodeUnstable" namespace. Instead, various built-in Node.js modules can use appropriate APIs directly.
This commit is contained in:
parent
e06bd19a69
commit
8b7524bcef
5 changed files with 19 additions and 80 deletions
|
@ -1,5 +1,7 @@
|
||||||
// Copyright 2018-2023 the Deno authors. All rights reserved. MIT license.
|
// Copyright 2018-2023 the Deno authors. All rights reserved. MIT license.
|
||||||
|
|
||||||
|
const core = globalThis.Deno.core;
|
||||||
|
const ops = core.ops;
|
||||||
import { TextEncoder } from "ext:deno_web/08_text_encoding.js";
|
import { TextEncoder } from "ext:deno_web/08_text_encoding.js";
|
||||||
import { type Deferred, deferred } from "ext:deno_node/_util/async.ts";
|
import { type Deferred, deferred } from "ext:deno_node/_util/async.ts";
|
||||||
import { _normalizeArgs, ListenOptions, Socket } from "ext:deno_node/net.ts";
|
import { _normalizeArgs, ListenOptions, Socket } from "ext:deno_node/net.ts";
|
||||||
|
@ -17,6 +19,7 @@ import { Agent } from "ext:deno_node/_http_agent.mjs";
|
||||||
import { chunkExpression as RE_TE_CHUNKED } from "ext:deno_node/_http_common.ts";
|
import { chunkExpression as RE_TE_CHUNKED } from "ext:deno_node/_http_common.ts";
|
||||||
import { urlToHttpOptions } from "ext:deno_node/internal/url.ts";
|
import { urlToHttpOptions } from "ext:deno_node/internal/url.ts";
|
||||||
import { constants, TCP } from "ext:deno_node/internal_binding/tcp_wrap.ts";
|
import { constants, TCP } from "ext:deno_node/internal_binding/tcp_wrap.ts";
|
||||||
|
import * as flash from "ext:deno_flash/01_http.js";
|
||||||
|
|
||||||
enum STATUS_CODES {
|
enum STATUS_CODES {
|
||||||
/** RFC 7231, 6.2.1 */
|
/** RFC 7231, 6.2.1 */
|
||||||
|
@ -188,11 +191,8 @@ const METHODS = [
|
||||||
|
|
||||||
type Chunk = string | Buffer | Uint8Array;
|
type Chunk = string | Buffer | Uint8Array;
|
||||||
|
|
||||||
// @ts-ignore Deno[Deno.internal] is used on purpose here
|
const DenoServe = flash.createServe(ops.op_node_unstable_flash_serve);
|
||||||
const DenoServe = Deno[Deno.internal]?.nodeUnstable?.serve || Deno.serve;
|
const DenoUpgradeHttpRaw = flash.upgradeHttpRaw;
|
||||||
// @ts-ignore Deno[Deno.internal] is used on purpose here
|
|
||||||
const DenoUpgradeHttpRaw = Deno[Deno.internal]?.nodeUnstable?.upgradeHttpRaw ||
|
|
||||||
Deno.upgradeHttpRaw;
|
|
||||||
|
|
||||||
const ENCODER = new TextEncoder();
|
const ENCODER = new TextEncoder();
|
||||||
|
|
||||||
|
|
|
@ -20,6 +20,8 @@
|
||||||
// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
|
// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
|
||||||
// USE OR OTHER DEALINGS IN THE SOFTWARE.
|
// USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
|
||||||
|
const core = globalThis.Deno.core;
|
||||||
|
const ops = core.ops;
|
||||||
import {
|
import {
|
||||||
AsyncWrap,
|
AsyncWrap,
|
||||||
providerType,
|
providerType,
|
||||||
|
@ -32,12 +34,13 @@ import { notImplemented } from "ext:deno_node/_utils.ts";
|
||||||
import { Buffer } from "ext:deno_node/buffer.ts";
|
import { Buffer } from "ext:deno_node/buffer.ts";
|
||||||
import type { ErrnoException } from "ext:deno_node/internal/errors.ts";
|
import type { ErrnoException } from "ext:deno_node/internal/errors.ts";
|
||||||
import { isIP } from "ext:deno_node/internal/net.ts";
|
import { isIP } from "ext:deno_node/internal/net.ts";
|
||||||
|
import * as net from "ext:deno_net/01_net.js";
|
||||||
import { isLinux, isWindows } from "ext:deno_node/_util/os.ts";
|
import { isLinux, isWindows } from "ext:deno_node/_util/os.ts";
|
||||||
|
|
||||||
// @ts-ignore Deno[Deno.internal] is used on purpose here
|
const DenoListenDatagram = net.createListenDatagram(
|
||||||
const DenoListenDatagram = Deno[Deno.internal]?.nodeUnstable?.listenDatagram ||
|
ops.op_node_unstable_net_listen_udp,
|
||||||
Deno.listenDatagram;
|
ops.op_node_unstable_net_listen_unixpacket,
|
||||||
|
);
|
||||||
|
|
||||||
type MessageType = string | Uint8Array | Buffer | DataView;
|
type MessageType = string | Uint8Array | Buffer | DataView;
|
||||||
|
|
||||||
|
|
|
@ -25,15 +25,11 @@ import { validateIntegerRange } from "ext:deno_node/_utils.ts";
|
||||||
import process from "ext:deno_node/process.ts";
|
import process from "ext:deno_node/process.ts";
|
||||||
import { isWindows, osType } from "ext:deno_node/_util/os.ts";
|
import { isWindows, osType } from "ext:deno_node/_util/os.ts";
|
||||||
import { os } from "ext:deno_node/internal_binding/constants.ts";
|
import { os } from "ext:deno_node/internal_binding/constants.ts";
|
||||||
|
import { osUptime } from "ext:runtime/30_os.js";
|
||||||
export const constants = os;
|
export const constants = os;
|
||||||
|
|
||||||
const SEE_GITHUB_ISSUE = "See https://github.com/denoland/deno_std/issues/1436";
|
const SEE_GITHUB_ISSUE = "See https://github.com/denoland/deno_std/issues/1436";
|
||||||
|
|
||||||
// @ts-ignore Deno[Deno.internal] is used on purpose here
|
|
||||||
const DenoOsUptime = Deno[Deno.internal]?.nodeUnstable?.osUptime ||
|
|
||||||
Deno.osUptime;
|
|
||||||
|
|
||||||
interface CPUTimes {
|
interface CPUTimes {
|
||||||
/** The number of milliseconds the CPU has spent in user mode */
|
/** The number of milliseconds the CPU has spent in user mode */
|
||||||
user: number;
|
user: number;
|
||||||
|
@ -310,7 +306,7 @@ export function type(): string {
|
||||||
|
|
||||||
/** Returns the Operating System uptime in number of seconds. */
|
/** Returns the Operating System uptime in number of seconds. */
|
||||||
export function uptime(): number {
|
export function uptime(): number {
|
||||||
return DenoOsUptime();
|
return osUptime();
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Not yet implemented */
|
/** Not yet implemented */
|
||||||
|
|
|
@ -153,7 +153,10 @@ const denoNs = {
|
||||||
};
|
};
|
||||||
|
|
||||||
const denoNsUnstable = {
|
const denoNsUnstable = {
|
||||||
listenDatagram: net.listenDatagram,
|
listenDatagram: net.createListenDatagram(
|
||||||
|
ops.op_net_listen_udp,
|
||||||
|
ops.op_net_listen_unixpacket,
|
||||||
|
),
|
||||||
umask: fs.umask,
|
umask: fs.umask,
|
||||||
HttpClient: httpClient.HttpClient,
|
HttpClient: httpClient.HttpClient,
|
||||||
createHttpClient: httpClient.createHttpClient,
|
createHttpClient: httpClient.createHttpClient,
|
||||||
|
@ -170,6 +173,7 @@ const denoNsUnstable = {
|
||||||
funlockSync: fs.funlockSync,
|
funlockSync: fs.funlockSync,
|
||||||
upgradeHttp: http.upgradeHttp,
|
upgradeHttp: http.upgradeHttp,
|
||||||
upgradeHttpRaw: flash.upgradeHttpRaw,
|
upgradeHttpRaw: flash.upgradeHttpRaw,
|
||||||
|
serve: flash.createServe(ops.op_flash_serve),
|
||||||
openKv: kv.openKv,
|
openKv: kv.openKv,
|
||||||
Kv: kv.Kv,
|
Kv: kv.Kv,
|
||||||
KvU64: kv.KvU64,
|
KvU64: kv.KvU64,
|
||||||
|
|
|
@ -45,7 +45,6 @@ import * as version from "ext:runtime/01_version.ts";
|
||||||
import * as os from "ext:runtime/30_os.js";
|
import * as os from "ext:runtime/30_os.js";
|
||||||
import * as timers from "ext:deno_web/02_timers.js";
|
import * as timers from "ext:deno_web/02_timers.js";
|
||||||
import * as colors from "ext:deno_console/01_colors.js";
|
import * as colors from "ext:deno_console/01_colors.js";
|
||||||
import * as net from "ext:deno_net/01_net.js";
|
|
||||||
import {
|
import {
|
||||||
inspectArgs,
|
inspectArgs,
|
||||||
quoteString,
|
quoteString,
|
||||||
|
@ -59,7 +58,6 @@ import { denoNs, denoNsUnstable } from "ext:runtime/90_deno_ns.js";
|
||||||
import { errors } from "ext:runtime/01_errors.js";
|
import { errors } from "ext:runtime/01_errors.js";
|
||||||
import * as webidl from "ext:deno_webidl/00_webidl.js";
|
import * as webidl from "ext:deno_webidl/00_webidl.js";
|
||||||
import DOMException from "ext:deno_web/01_dom_exception.js";
|
import DOMException from "ext:deno_web/01_dom_exception.js";
|
||||||
import * as flash from "ext:deno_flash/01_http.js";
|
|
||||||
import {
|
import {
|
||||||
mainRuntimeGlobalProperties,
|
mainRuntimeGlobalProperties,
|
||||||
setLanguage,
|
setLanguage,
|
||||||
|
@ -455,27 +453,6 @@ function bootstrapMainRuntime(runtimeOptions) {
|
||||||
setUserAgent(runtimeOptions.userAgent);
|
setUserAgent(runtimeOptions.userAgent);
|
||||||
setLanguage(runtimeOptions.locale);
|
setLanguage(runtimeOptions.locale);
|
||||||
|
|
||||||
// These have to initialized here and not in `90_deno_ns.js` because
|
|
||||||
// the op function that needs to be passed will be invalidated by creating
|
|
||||||
// a snapshot
|
|
||||||
ObjectAssign(internals, {
|
|
||||||
nodeUnstable: {
|
|
||||||
serve: flash.createServe(ops.op_node_unstable_flash_serve),
|
|
||||||
upgradeHttpRaw: flash.upgradeHttpRaw,
|
|
||||||
listenDatagram: net.createListenDatagram(
|
|
||||||
ops.op_node_unstable_net_listen_udp,
|
|
||||||
ops.op_node_unstable_net_listen_unixpacket,
|
|
||||||
),
|
|
||||||
},
|
|
||||||
});
|
|
||||||
|
|
||||||
// FIXME(bartlomieju): temporarily add whole `Deno.core` to
|
|
||||||
// `Deno[Deno.internal]` namespace. It should be removed and only necessary
|
|
||||||
// methods should be left there.
|
|
||||||
ObjectAssign(internals, {
|
|
||||||
core,
|
|
||||||
});
|
|
||||||
|
|
||||||
ObjectDefineProperties(finalDenoNs, {
|
ObjectDefineProperties(finalDenoNs, {
|
||||||
pid: util.readOnly(runtimeOptions.pid),
|
pid: util.readOnly(runtimeOptions.pid),
|
||||||
ppid: util.readOnly(runtimeOptions.ppid),
|
ppid: util.readOnly(runtimeOptions.ppid),
|
||||||
|
@ -486,16 +463,6 @@ function bootstrapMainRuntime(runtimeOptions) {
|
||||||
|
|
||||||
if (runtimeOptions.unstableFlag) {
|
if (runtimeOptions.unstableFlag) {
|
||||||
ObjectAssign(finalDenoNs, denoNsUnstable);
|
ObjectAssign(finalDenoNs, denoNsUnstable);
|
||||||
// These have to initialized here and not in `90_deno_ns.js` because
|
|
||||||
// the op function that needs to be passed will be invalidated by creating
|
|
||||||
// a snapshot
|
|
||||||
ObjectAssign(finalDenoNs, {
|
|
||||||
serve: flash.createServe(ops.op_flash_serve),
|
|
||||||
listenDatagram: net.createListenDatagram(
|
|
||||||
ops.op_net_listen_udp,
|
|
||||||
ops.op_net_listen_unixpacket,
|
|
||||||
),
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Setup `Deno` global - we're actually overriding already existing global
|
// Setup `Deno` global - we're actually overriding already existing global
|
||||||
|
@ -573,39 +540,8 @@ function bootstrapWorkerRuntime(
|
||||||
|
|
||||||
globalThis.pollForMessages = pollForMessages;
|
globalThis.pollForMessages = pollForMessages;
|
||||||
|
|
||||||
// These have to initialized here and not in `90_deno_ns.js` because
|
|
||||||
// the op function that needs to be passed will be invalidated by creating
|
|
||||||
// a snapshot
|
|
||||||
ObjectAssign(internals, {
|
|
||||||
nodeUnstable: {
|
|
||||||
serve: flash.createServe(ops.op_node_unstable_flash_serve),
|
|
||||||
upgradeHttpRaw: flash.upgradeHttpRaw,
|
|
||||||
listenDatagram: net.createListenDatagram(
|
|
||||||
ops.op_node_unstable_net_listen_udp,
|
|
||||||
ops.op_node_unstable_net_listen_unixpacket,
|
|
||||||
),
|
|
||||||
},
|
|
||||||
});
|
|
||||||
|
|
||||||
// FIXME(bartlomieju): temporarily add whole `Deno.core` to
|
|
||||||
// `Deno[Deno.internal]` namespace. It should be removed and only necessary
|
|
||||||
// methods should be left there.
|
|
||||||
ObjectAssign(internals, {
|
|
||||||
core,
|
|
||||||
});
|
|
||||||
|
|
||||||
if (runtimeOptions.unstableFlag) {
|
if (runtimeOptions.unstableFlag) {
|
||||||
ObjectAssign(finalDenoNs, denoNsUnstable);
|
ObjectAssign(finalDenoNs, denoNsUnstable);
|
||||||
// These have to initialized here and not in `90_deno_ns.js` because
|
|
||||||
// the op function that needs to be passed will be invalidated by creating
|
|
||||||
// a snapshot
|
|
||||||
ObjectAssign(finalDenoNs, {
|
|
||||||
serve: flash.createServe(ops.op_flash_serve),
|
|
||||||
listenDatagram: net.createListenDatagram(
|
|
||||||
ops.op_net_listen_udp,
|
|
||||||
ops.op_net_listen_unixpacket,
|
|
||||||
),
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
ObjectDefineProperties(finalDenoNs, {
|
ObjectDefineProperties(finalDenoNs, {
|
||||||
pid: util.readOnly(runtimeOptions.pid),
|
pid: util.readOnly(runtimeOptions.pid),
|
||||||
|
|
Loading…
Reference in a new issue