mirror of
https://github.com/nodejs/node.git
synced 2024-11-21 10:59:27 +00:00
90f56dbad9
PR-URL: https://github.com/nodejs/node/pull/55332 Reviewed-By: Richard Lau <rlau@redhat.com> Reviewed-By: Jacob Smith <jacob@frende.me> Reviewed-By: Chemi Atlow <chemi@atlow.co.il> Reviewed-By: Antoine du Hamel <duhamelantoine1995@gmail.com>
1897 lines
66 KiB
JavaScript
1897 lines
66 KiB
JavaScript
/* eslint node-core/documented-errors: "error" */
|
|
/* eslint node-core/alphabetize-errors: ["error", {checkErrorDeclarations: true}] */
|
|
/* eslint node-core/prefer-util-format-errors: "error" */
|
|
|
|
'use strict';
|
|
|
|
// The whole point behind this internal module is to allow Node.js to no
|
|
// longer be forced to treat every error message change as a semver-major
|
|
// change. The NodeError classes here all expose a `code` property whose
|
|
// value statically and permanently identifies the error. While the error
|
|
// message may change, the code should not.
|
|
|
|
const {
|
|
AggregateError,
|
|
ArrayIsArray,
|
|
ArrayPrototypeFilter,
|
|
ArrayPrototypeIncludes,
|
|
ArrayPrototypeIndexOf,
|
|
ArrayPrototypeJoin,
|
|
ArrayPrototypeMap,
|
|
ArrayPrototypePush,
|
|
ArrayPrototypeSlice,
|
|
ArrayPrototypeSplice,
|
|
ArrayPrototypeUnshift,
|
|
Error,
|
|
ErrorCaptureStackTrace,
|
|
ErrorPrototypeToString,
|
|
JSONStringify,
|
|
MapPrototypeGet,
|
|
MathAbs,
|
|
MathMax,
|
|
Number,
|
|
NumberIsInteger,
|
|
ObjectAssign,
|
|
ObjectDefineProperties,
|
|
ObjectDefineProperty,
|
|
ObjectGetOwnPropertyDescriptor,
|
|
ObjectIsExtensible,
|
|
ObjectKeys,
|
|
ObjectPrototypeHasOwnProperty,
|
|
RangeError,
|
|
ReflectApply,
|
|
RegExpPrototypeExec,
|
|
SafeArrayIterator,
|
|
SafeMap,
|
|
SafeWeakMap,
|
|
String,
|
|
StringPrototypeEndsWith,
|
|
StringPrototypeIncludes,
|
|
StringPrototypeIndexOf,
|
|
StringPrototypeSlice,
|
|
StringPrototypeSplit,
|
|
StringPrototypeStartsWith,
|
|
StringPrototypeToLowerCase,
|
|
Symbol,
|
|
SymbolFor,
|
|
SyntaxError,
|
|
TypeError,
|
|
URIError,
|
|
} = primordials;
|
|
|
|
const kIsNodeError = Symbol('kIsNodeError');
|
|
|
|
const isWindows = process.platform === 'win32';
|
|
|
|
const messages = new SafeMap();
|
|
const codes = {};
|
|
|
|
const classRegExp = /^[A-Z][a-zA-Z0-9]*$/;
|
|
|
|
// Sorted by a rough estimate on most frequently used entries.
|
|
const kTypes = [
|
|
'string',
|
|
'function',
|
|
'number',
|
|
'object',
|
|
// Accept 'Function' and 'Object' as alternative to the lower cased version.
|
|
'Function',
|
|
'Object',
|
|
'boolean',
|
|
'bigint',
|
|
'symbol',
|
|
];
|
|
|
|
const MainContextError = Error;
|
|
const overrideStackTrace = new SafeWeakMap();
|
|
let internalPrepareStackTrace = defaultPrepareStackTrace;
|
|
|
|
/**
|
|
* The default implementation of `Error.prepareStackTrace` with simple
|
|
* concatenation of stack frames.
|
|
* Read more about `Error.prepareStackTrace` at https://v8.dev/docs/stack-trace-api#customizing-stack-traces.
|
|
*/
|
|
function defaultPrepareStackTrace(error, trace) {
|
|
// Normal error formatting:
|
|
//
|
|
// Error: Message
|
|
// at function (file)
|
|
// at file
|
|
let errorString;
|
|
if (kIsNodeError in error) {
|
|
errorString = `${error.name} [${error.code}]: ${error.message}`;
|
|
} else {
|
|
errorString = ErrorPrototypeToString(error);
|
|
}
|
|
if (trace.length === 0) {
|
|
return errorString;
|
|
}
|
|
return `${errorString}\n at ${ArrayPrototypeJoin(trace, '\n at ')}`;
|
|
}
|
|
|
|
function setInternalPrepareStackTrace(callback) {
|
|
internalPrepareStackTrace = callback;
|
|
}
|
|
|
|
/**
|
|
* Every realm has its own prepareStackTraceCallback. When `error.stack` is
|
|
* accessed, if the error is created in a shadow realm, the shadow realm's
|
|
* prepareStackTraceCallback is invoked. Otherwise, the principal realm's
|
|
* prepareStackTraceCallback is invoked. Note that accessing `error.stack`
|
|
* of error objects created in a VM Context will always invoke the
|
|
* prepareStackTraceCallback of the principal realm.
|
|
* @param {object} globalThis The global object of the realm that the error was
|
|
* created in. When the error object is created in a VM Context, this is the
|
|
* global object of that VM Context.
|
|
* @param {object} error The error object.
|
|
* @param {CallSite[]} trace An array of CallSite objects, read more at https://v8.dev/docs/stack-trace-api#customizing-stack-traces.
|
|
* @returns {string}
|
|
*/
|
|
function prepareStackTraceCallback(globalThis, error, trace) {
|
|
// API for node internals to override error stack formatting
|
|
// without interfering with userland code.
|
|
if (overrideStackTrace.has(error)) {
|
|
const f = overrideStackTrace.get(error);
|
|
overrideStackTrace.delete(error);
|
|
return f(error, trace);
|
|
}
|
|
|
|
// Polyfill of V8's Error.prepareStackTrace API.
|
|
// https://crbug.com/v8/7848
|
|
// `globalThis` is the global that contains the constructor which
|
|
// created `error`.
|
|
if (typeof globalThis.Error?.prepareStackTrace === 'function') {
|
|
return globalThis.Error.prepareStackTrace(error, trace);
|
|
}
|
|
// We still have legacy usage that depends on the main context's `Error`
|
|
// being used, even when the error is from a different context.
|
|
// TODO(devsnek): evaluate if this can be eventually deprecated/removed.
|
|
if (typeof MainContextError.prepareStackTrace === 'function') {
|
|
return MainContextError.prepareStackTrace(error, trace);
|
|
}
|
|
|
|
// If the Error.prepareStackTrace was not a function, fallback to the
|
|
// internal implementation.
|
|
return internalPrepareStackTrace(error, trace);
|
|
}
|
|
|
|
/**
|
|
* The default Error.prepareStackTrace implementation.
|
|
*/
|
|
function ErrorPrepareStackTrace(error, trace) {
|
|
return internalPrepareStackTrace(error, trace);
|
|
}
|
|
|
|
const aggregateTwoErrors = (innerError, outerError) => {
|
|
if (innerError && outerError && innerError !== outerError) {
|
|
if (ArrayIsArray(outerError.errors)) {
|
|
// If `outerError` is already an `AggregateError`.
|
|
ArrayPrototypePush(outerError.errors, innerError);
|
|
return outerError;
|
|
}
|
|
let err;
|
|
if (isErrorStackTraceLimitWritable()) {
|
|
const limit = Error.stackTraceLimit;
|
|
Error.stackTraceLimit = 0;
|
|
// eslint-disable-next-line no-restricted-syntax
|
|
err = new AggregateError(new SafeArrayIterator([
|
|
outerError,
|
|
innerError,
|
|
]), outerError.message);
|
|
Error.stackTraceLimit = limit;
|
|
ErrorCaptureStackTrace(err, aggregateTwoErrors);
|
|
} else {
|
|
// eslint-disable-next-line no-restricted-syntax
|
|
err = new AggregateError(new SafeArrayIterator([
|
|
outerError,
|
|
innerError,
|
|
]), outerError.message);
|
|
}
|
|
err.code = outerError.code;
|
|
return err;
|
|
}
|
|
return innerError || outerError;
|
|
};
|
|
|
|
class NodeAggregateError extends AggregateError {
|
|
constructor(errors, message) {
|
|
super(new SafeArrayIterator(errors), message);
|
|
this.code = errors[0]?.code;
|
|
}
|
|
|
|
get [kIsNodeError]() {
|
|
return true;
|
|
}
|
|
|
|
get ['constructor']() {
|
|
return AggregateError;
|
|
}
|
|
}
|
|
|
|
const assert = require('internal/assert');
|
|
|
|
// Lazily loaded
|
|
let util;
|
|
|
|
let internalUtil = null;
|
|
function lazyInternalUtil() {
|
|
internalUtil ??= require('internal/util');
|
|
return internalUtil;
|
|
}
|
|
|
|
let internalUtilInspect = null;
|
|
function lazyInternalUtilInspect() {
|
|
internalUtilInspect ??= require('internal/util/inspect');
|
|
return internalUtilInspect;
|
|
}
|
|
|
|
let utilColors;
|
|
function lazyUtilColors() {
|
|
utilColors ??= require('internal/util/colors');
|
|
return utilColors;
|
|
}
|
|
|
|
let buffer;
|
|
function lazyBuffer() {
|
|
buffer ??= require('buffer').Buffer;
|
|
return buffer;
|
|
}
|
|
|
|
function isErrorStackTraceLimitWritable() {
|
|
// Do no touch Error.stackTraceLimit as V8 would attempt to install
|
|
// it again during deserialization.
|
|
if (require('internal/v8/startup_snapshot').namespace.isBuildingSnapshot()) {
|
|
return false;
|
|
}
|
|
|
|
const desc = ObjectGetOwnPropertyDescriptor(Error, 'stackTraceLimit');
|
|
if (desc === undefined) {
|
|
return ObjectIsExtensible(Error);
|
|
}
|
|
|
|
return ObjectPrototypeHasOwnProperty(desc, 'writable') ?
|
|
desc.writable :
|
|
desc.set !== undefined;
|
|
}
|
|
|
|
function inspectWithNoCustomRetry(obj, options) {
|
|
const utilInspect = lazyInternalUtilInspect();
|
|
|
|
try {
|
|
return utilInspect.inspect(obj, options);
|
|
} catch {
|
|
return utilInspect.inspect(obj, { ...options, customInspect: false });
|
|
}
|
|
}
|
|
|
|
// A specialized Error that includes an additional info property with
|
|
// additional information about the error condition.
|
|
// It has the properties present in a UVException but with a custom error
|
|
// message followed by the uv error code and uv error message.
|
|
// It also has its own error code with the original uv error context put into
|
|
// `err.info`.
|
|
// The context passed into this error must have .code, .syscall and .message,
|
|
// and may have .path and .dest.
|
|
class SystemError extends Error {
|
|
constructor(key, context) {
|
|
super();
|
|
const prefix = getMessage(key, [], this);
|
|
let message = `${prefix}: ${context.syscall} returned ` +
|
|
`${context.code} (${context.message})`;
|
|
|
|
if (context.path !== undefined)
|
|
message += ` ${context.path}`;
|
|
if (context.dest !== undefined)
|
|
message += ` => ${context.dest}`;
|
|
|
|
this.code = key;
|
|
|
|
ObjectDefineProperties(this, {
|
|
[kIsNodeError]: {
|
|
__proto__: null,
|
|
value: true,
|
|
enumerable: false,
|
|
writable: false,
|
|
configurable: true,
|
|
},
|
|
name: {
|
|
__proto__: null,
|
|
value: 'SystemError',
|
|
enumerable: false,
|
|
writable: true,
|
|
configurable: true,
|
|
},
|
|
message: {
|
|
__proto__: null,
|
|
value: message,
|
|
enumerable: false,
|
|
writable: true,
|
|
configurable: true,
|
|
},
|
|
info: {
|
|
__proto__: null,
|
|
value: context,
|
|
enumerable: true,
|
|
configurable: true,
|
|
writable: false,
|
|
},
|
|
errno: {
|
|
__proto__: null,
|
|
get() {
|
|
return context.errno;
|
|
},
|
|
set: (value) => {
|
|
context.errno = value;
|
|
},
|
|
enumerable: true,
|
|
configurable: true,
|
|
},
|
|
syscall: {
|
|
__proto__: null,
|
|
get() {
|
|
return context.syscall;
|
|
},
|
|
set: (value) => {
|
|
context.syscall = value;
|
|
},
|
|
enumerable: true,
|
|
configurable: true,
|
|
},
|
|
});
|
|
|
|
if (context.path !== undefined) {
|
|
// TODO(BridgeAR): Investigate why and when the `.toString()` was
|
|
// introduced. The `path` and `dest` properties in the context seem to
|
|
// always be of type string. We should probably just remove the
|
|
// `.toString()` and `Buffer.from()` operations and set the value on the
|
|
// context as the user did.
|
|
ObjectDefineProperty(this, 'path', {
|
|
__proto__: null,
|
|
get() {
|
|
return context.path != null ?
|
|
context.path.toString() : context.path;
|
|
},
|
|
set: (value) => {
|
|
context.path = value ?
|
|
lazyBuffer().from(value.toString()) : undefined;
|
|
},
|
|
enumerable: true,
|
|
configurable: true,
|
|
});
|
|
}
|
|
|
|
if (context.dest !== undefined) {
|
|
ObjectDefineProperty(this, 'dest', {
|
|
__proto__: null,
|
|
get() {
|
|
return context.dest != null ?
|
|
context.dest.toString() : context.dest;
|
|
},
|
|
set: (value) => {
|
|
context.dest = value ?
|
|
lazyBuffer().from(value.toString()) : undefined;
|
|
},
|
|
enumerable: true,
|
|
configurable: true,
|
|
});
|
|
}
|
|
}
|
|
|
|
toString() {
|
|
return `${this.name} [${this.code}]: ${this.message}`;
|
|
}
|
|
|
|
[SymbolFor('nodejs.util.inspect.custom')](recurseTimes, ctx) {
|
|
return lazyInternalUtilInspect().inspect(this, {
|
|
...ctx,
|
|
getters: true,
|
|
customInspect: false,
|
|
});
|
|
}
|
|
}
|
|
|
|
function makeSystemErrorWithCode(key) {
|
|
return class NodeError extends SystemError {
|
|
constructor(ctx) {
|
|
super(key, ctx);
|
|
}
|
|
};
|
|
}
|
|
|
|
// This is a special error type that is only used for the E function.
|
|
class HideStackFramesError extends Error {
|
|
}
|
|
|
|
function makeNodeErrorForHideStackFrame(Base, clazz) {
|
|
class HideStackFramesError extends Base {
|
|
constructor(...args) {
|
|
if (isErrorStackTraceLimitWritable()) {
|
|
const limit = Error.stackTraceLimit;
|
|
Error.stackTraceLimit = 0;
|
|
super(...args);
|
|
Error.stackTraceLimit = limit;
|
|
} else {
|
|
super(...args);
|
|
}
|
|
}
|
|
|
|
// This is a workaround for wpt tests that expect that the error
|
|
// constructor has a `name` property of the base class.
|
|
get ['constructor']() {
|
|
return clazz;
|
|
}
|
|
}
|
|
|
|
return HideStackFramesError;
|
|
}
|
|
|
|
function makeNodeErrorWithCode(Base, key) {
|
|
const msg = messages.get(key);
|
|
const expectedLength = typeof msg !== 'string' ? -1 : getExpectedArgumentLength(msg);
|
|
|
|
switch (expectedLength) {
|
|
case 0: {
|
|
class NodeError extends Base {
|
|
code = key;
|
|
|
|
constructor(...args) {
|
|
assert(
|
|
args.length === 0,
|
|
`Code: ${key}; The provided arguments length (${args.length}) does not ` +
|
|
`match the required ones (${expectedLength}).`,
|
|
);
|
|
super(msg);
|
|
}
|
|
|
|
// This is a workaround for wpt tests that expect that the error
|
|
// constructor has a `name` property of the base class.
|
|
get ['constructor']() {
|
|
return Base;
|
|
}
|
|
|
|
get [kIsNodeError]() {
|
|
return true;
|
|
}
|
|
|
|
toString() {
|
|
return `${this.name} [${key}]: ${this.message}`;
|
|
}
|
|
}
|
|
return NodeError;
|
|
}
|
|
case -1: {
|
|
class NodeError extends Base {
|
|
code = key;
|
|
|
|
constructor(...args) {
|
|
super();
|
|
ObjectDefineProperty(this, 'message', {
|
|
__proto__: null,
|
|
value: getMessage(key, args, this),
|
|
enumerable: false,
|
|
writable: true,
|
|
configurable: true,
|
|
});
|
|
}
|
|
|
|
// This is a workaround for wpt tests that expect that the error
|
|
// constructor has a `name` property of the base class.
|
|
get ['constructor']() {
|
|
return Base;
|
|
}
|
|
|
|
get [kIsNodeError]() {
|
|
return true;
|
|
}
|
|
|
|
toString() {
|
|
return `${this.name} [${key}]: ${this.message}`;
|
|
}
|
|
}
|
|
return NodeError;
|
|
}
|
|
default: {
|
|
|
|
class NodeError extends Base {
|
|
code = key;
|
|
|
|
constructor(...args) {
|
|
assert(
|
|
args.length === expectedLength,
|
|
`Code: ${key}; The provided arguments length (${args.length}) does not ` +
|
|
`match the required ones (${expectedLength}).`,
|
|
);
|
|
|
|
ArrayPrototypeUnshift(args, msg);
|
|
super(ReflectApply(lazyInternalUtilInspect().format, null, args));
|
|
}
|
|
|
|
// This is a workaround for wpt tests that expect that the error
|
|
// constructor has a `name` property of the base class.
|
|
get ['constructor']() {
|
|
return Base;
|
|
}
|
|
|
|
get [kIsNodeError]() {
|
|
return true;
|
|
}
|
|
|
|
toString() {
|
|
return `${this.name} [${key}]: ${this.message}`;
|
|
}
|
|
}
|
|
return NodeError;
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* This function removes unnecessary frames from Node.js core errors.
|
|
* @template {(...args: unknown[]) => unknown} T
|
|
* @param {T} fn
|
|
* @returns {T}
|
|
*/
|
|
function hideStackFrames(fn) {
|
|
function wrappedFn(...args) {
|
|
try {
|
|
return ReflectApply(fn, this, args);
|
|
} catch (error) {
|
|
Error.stackTraceLimit && ErrorCaptureStackTrace(error, wrappedFn);
|
|
throw error;
|
|
}
|
|
}
|
|
wrappedFn.withoutStackTrace = fn;
|
|
return wrappedFn;
|
|
}
|
|
|
|
// Utility function for registering the error codes. Only used here. Exported
|
|
// *only* to allow for testing.
|
|
function E(sym, val, def, ...otherClasses) {
|
|
// Special case for SystemError that formats the error message differently
|
|
// The SystemErrors only have SystemError as their base classes.
|
|
messages.set(sym, val);
|
|
|
|
const ErrClass = def === SystemError ?
|
|
makeSystemErrorWithCode(sym) :
|
|
makeNodeErrorWithCode(def, sym);
|
|
|
|
if (otherClasses.length !== 0) {
|
|
if (otherClasses.includes(HideStackFramesError)) {
|
|
if (otherClasses.length !== 1) {
|
|
otherClasses.forEach((clazz) => {
|
|
if (clazz !== HideStackFramesError) {
|
|
ErrClass[clazz.name] = makeNodeErrorWithCode(clazz, sym);
|
|
ErrClass[clazz.name].HideStackFramesError = makeNodeErrorForHideStackFrame(ErrClass[clazz.name], clazz);
|
|
}
|
|
});
|
|
}
|
|
} else {
|
|
otherClasses.forEach((clazz) => {
|
|
ErrClass[clazz.name] = makeNodeErrorWithCode(clazz, sym);
|
|
});
|
|
}
|
|
}
|
|
|
|
if (otherClasses.includes(HideStackFramesError)) {
|
|
ErrClass.HideStackFramesError = makeNodeErrorForHideStackFrame(ErrClass, def);
|
|
}
|
|
|
|
codes[sym] = ErrClass;
|
|
}
|
|
|
|
function getExpectedArgumentLength(msg) {
|
|
let expectedLength = 0;
|
|
const regex = /%[dfijoOs]/g;
|
|
while (RegExpPrototypeExec(regex, msg) !== null) expectedLength++;
|
|
return expectedLength;
|
|
}
|
|
|
|
function getMessage(key, args, self) {
|
|
const msg = messages.get(key);
|
|
|
|
if (typeof msg === 'function') {
|
|
assert(
|
|
msg.length <= args.length, // Default options do not count.
|
|
`Code: ${key}; The provided arguments length (${args.length}) does not ` +
|
|
`match the required ones (${msg.length}).`,
|
|
);
|
|
return ReflectApply(msg, self, args);
|
|
}
|
|
|
|
const expectedLength = getExpectedArgumentLength(msg);
|
|
assert(
|
|
expectedLength === args.length,
|
|
`Code: ${key}; The provided arguments length (${args.length}) does not ` +
|
|
`match the required ones (${expectedLength}).`,
|
|
);
|
|
if (args.length === 0)
|
|
return msg;
|
|
|
|
ArrayPrototypeUnshift(args, msg);
|
|
return ReflectApply(lazyInternalUtilInspect().format, null, args);
|
|
}
|
|
|
|
let uvBinding;
|
|
|
|
function lazyUv() {
|
|
uvBinding ??= internalBinding('uv');
|
|
return uvBinding;
|
|
}
|
|
|
|
const uvUnmappedError = ['UNKNOWN', 'unknown error'];
|
|
|
|
function uvErrmapGet(name) {
|
|
uvBinding = lazyUv();
|
|
uvBinding.errmap ??= uvBinding.getErrorMap();
|
|
return MapPrototypeGet(uvBinding.errmap, name);
|
|
}
|
|
|
|
/**
|
|
* This creates an error compatible with errors produced in the C++
|
|
* function UVException using a context object with data assembled in C++.
|
|
* The goal is to migrate them to ERR_* errors later when compatibility is
|
|
* not a concern.
|
|
*/
|
|
class UVException extends Error {
|
|
/**
|
|
* @param {object} ctx
|
|
*/
|
|
constructor(ctx) {
|
|
const { 0: code, 1: uvmsg } = uvErrmapGet(ctx.errno) || uvUnmappedError;
|
|
let message = `${code}: ${ctx.message || uvmsg}, ${ctx.syscall}`;
|
|
|
|
let path;
|
|
let dest;
|
|
if (ctx.path) {
|
|
path = ctx.path.toString();
|
|
message += ` '${path}'`;
|
|
}
|
|
if (ctx.dest) {
|
|
dest = ctx.dest.toString();
|
|
message += ` -> '${dest}'`;
|
|
}
|
|
|
|
super(message);
|
|
|
|
for (const prop of ObjectKeys(ctx)) {
|
|
if (prop === 'message' || prop === 'path' || prop === 'dest') {
|
|
continue;
|
|
}
|
|
this[prop] = ctx[prop];
|
|
}
|
|
|
|
this.code = code;
|
|
if (path) {
|
|
this.path = path;
|
|
}
|
|
if (dest) {
|
|
this.dest = dest;
|
|
}
|
|
}
|
|
|
|
get ['constructor']() {
|
|
return Error;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* This creates an error compatible with errors produced in the C++
|
|
* This function should replace the deprecated
|
|
* `exceptionWithHostPort()` function.
|
|
*/
|
|
class UVExceptionWithHostPort extends Error {
|
|
/**
|
|
* @param {number} err - A libuv error number
|
|
* @param {string} syscall
|
|
* @param {string} address
|
|
* @param {number} [port]
|
|
*/
|
|
constructor(err, syscall, address, port) {
|
|
const { 0: code, 1: uvmsg } = uvErrmapGet(err) || uvUnmappedError;
|
|
const message = `${syscall} ${code}: ${uvmsg}`;
|
|
let details = '';
|
|
|
|
if (port && port > 0) {
|
|
details = ` ${address}:${port}`;
|
|
} else if (address) {
|
|
details = ` ${address}`;
|
|
}
|
|
|
|
super(`${message}${details}`);
|
|
|
|
this.code = code;
|
|
this.errno = err;
|
|
this.syscall = syscall;
|
|
this.address = address;
|
|
if (port) {
|
|
this.port = port;
|
|
}
|
|
}
|
|
|
|
get ['constructor']() {
|
|
return Error;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* This used to be util._errnoException().
|
|
*/
|
|
class ErrnoException extends Error {
|
|
/**
|
|
* @param {number} err - A libuv error number
|
|
* @param {string} syscall
|
|
* @param {string} [original] err
|
|
*/
|
|
constructor(err, syscall, original) {
|
|
// TODO(joyeecheung): We have to use the type-checked
|
|
// getSystemErrorName(err) to guard against invalid arguments from users.
|
|
// This can be replaced with [ code ] = errmap.get(err) when this method
|
|
// is no longer exposed to user land.
|
|
util ??= require('util');
|
|
const code = util.getSystemErrorName(err);
|
|
const message = original ?
|
|
`${syscall} ${code} ${original}` : `${syscall} ${code}`;
|
|
|
|
super(message);
|
|
|
|
this.errno = err;
|
|
this.code = code;
|
|
this.syscall = syscall;
|
|
}
|
|
|
|
get ['constructor']() {
|
|
return Error;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Deprecated, new Error is `UVExceptionWithHostPort()`
|
|
* New function added the error description directly
|
|
* from C++. this method for backwards compatibility
|
|
* @param {number} err - A libuv error number
|
|
* @param {string} syscall
|
|
* @param {string} address
|
|
* @param {number} [port]
|
|
* @param {string} [additional]
|
|
* @returns {Error}
|
|
*/
|
|
class ExceptionWithHostPort extends Error {
|
|
constructor(err, syscall, address, port, additional) {
|
|
// TODO(joyeecheung): We have to use the type-checked
|
|
// getSystemErrorName(err) to guard against invalid arguments from users.
|
|
// This can be replaced with [ code ] = errmap.get(err) when this method
|
|
// is no longer exposed to user land.
|
|
util ??= require('util');
|
|
const code = util.getSystemErrorName(err);
|
|
let details = '';
|
|
if (port && port > 0) {
|
|
details = ` ${address}:${port}`;
|
|
} else if (address) {
|
|
details = ` ${address}`;
|
|
}
|
|
if (additional) {
|
|
details += ` - Local (${additional})`;
|
|
}
|
|
|
|
super(`${syscall} ${code}${details}`);
|
|
|
|
this.errno = err;
|
|
this.code = code;
|
|
this.syscall = syscall;
|
|
this.address = address;
|
|
if (port) {
|
|
this.port = port;
|
|
}
|
|
}
|
|
|
|
get ['constructor']() {
|
|
return Error;
|
|
}
|
|
}
|
|
|
|
class DNSException extends Error {
|
|
/**
|
|
* @param {number|string} code - A libuv error number or a c-ares error code
|
|
* @param {string} syscall
|
|
* @param {string} [hostname]
|
|
*/
|
|
constructor(code, syscall, hostname) {
|
|
let errno;
|
|
// If `code` is of type number, it is a libuv error number, else it is a
|
|
// c-ares error code.
|
|
// TODO(joyeecheung): translate c-ares error codes into numeric ones and
|
|
// make them available in a property that's not error.errno (since they
|
|
// can be in conflict with libuv error codes). Also make sure
|
|
// util.getSystemErrorName() can understand them when an being informed that
|
|
// the number is a c-ares error code.
|
|
if (typeof code === 'number') {
|
|
errno = code;
|
|
// ENOTFOUND is not a proper POSIX error, but this error has been in place
|
|
// long enough that it's not practical to remove it.
|
|
if (code === lazyUv().UV_EAI_NODATA || code === lazyUv().UV_EAI_NONAME) {
|
|
code = 'ENOTFOUND'; // Fabricated error name.
|
|
} else {
|
|
code = lazyInternalUtil().getSystemErrorName(code);
|
|
}
|
|
}
|
|
super(`${syscall} ${code}${hostname ? ` ${hostname}` : ''}`);
|
|
this.errno = errno;
|
|
this.code = code;
|
|
this.syscall = syscall;
|
|
if (hostname) {
|
|
this.hostname = hostname;
|
|
}
|
|
}
|
|
|
|
get ['constructor']() {
|
|
return Error;
|
|
}
|
|
}
|
|
|
|
class ConnResetException extends Error {
|
|
constructor(msg) {
|
|
super(msg);
|
|
this.code = 'ECONNRESET';
|
|
}
|
|
|
|
get ['constructor']() {
|
|
return Error;
|
|
}
|
|
}
|
|
|
|
let maxStack_ErrorName;
|
|
let maxStack_ErrorMessage;
|
|
|
|
/**
|
|
* Returns true if `err.name` and `err.message` are equal to engine-specific
|
|
* values indicating max call stack size has been exceeded.
|
|
* "Maximum call stack size exceeded" in V8.
|
|
* @param {Error} err
|
|
* @returns {boolean}
|
|
*/
|
|
function isStackOverflowError(err) {
|
|
if (maxStack_ErrorMessage === undefined) {
|
|
try {
|
|
function overflowStack() { overflowStack(); }
|
|
overflowStack();
|
|
} catch (err) {
|
|
maxStack_ErrorMessage = err.message;
|
|
maxStack_ErrorName = err.name;
|
|
}
|
|
}
|
|
|
|
return err && err.name === maxStack_ErrorName &&
|
|
err.message === maxStack_ErrorMessage;
|
|
}
|
|
|
|
// Only use this for integers! Decimal numbers do not work with this function.
|
|
function addNumericalSeparator(val) {
|
|
let res = '';
|
|
let i = val.length;
|
|
const start = val[0] === '-' ? 1 : 0;
|
|
for (; i >= start + 4; i -= 3) {
|
|
res = `_${StringPrototypeSlice(val, i - 3, i)}${res}`;
|
|
}
|
|
return `${StringPrototypeSlice(val, 0, i)}${res}`;
|
|
}
|
|
|
|
// Used to enhance the stack that will be picked up by the inspector
|
|
const kEnhanceStackBeforeInspector = Symbol('kEnhanceStackBeforeInspector');
|
|
|
|
// These are supposed to be called only on fatal exceptions before
|
|
// the process exits.
|
|
const fatalExceptionStackEnhancers = {
|
|
beforeInspector(error) {
|
|
if (typeof error[kEnhanceStackBeforeInspector] !== 'function') {
|
|
return error.stack;
|
|
}
|
|
|
|
try {
|
|
// Set the error.stack here so it gets picked up by the
|
|
// inspector.
|
|
error.stack = error[kEnhanceStackBeforeInspector]();
|
|
} catch {
|
|
// We are just enhancing the error. If it fails, ignore it.
|
|
}
|
|
return error.stack;
|
|
},
|
|
afterInspector(error) {
|
|
const originalStack = error.stack;
|
|
let useColors = true;
|
|
// Some consoles do not convert ANSI escape sequences to colors,
|
|
// rather display them directly to the stdout. On those consoles,
|
|
// libuv emulates colors by intercepting stdout stream and calling
|
|
// corresponding Windows API functions for setting console colors.
|
|
// However, fatal error are handled differently and we cannot easily
|
|
// highlight them. On Windows, detecting whether a console supports
|
|
// ANSI escape sequences is not reliable.
|
|
if (isWindows) {
|
|
const info = internalBinding('os').getOSInformation();
|
|
const ver = ArrayPrototypeMap(StringPrototypeSplit(info[2], '.'),
|
|
Number);
|
|
if (ver[0] !== 10 || ver[2] < 14393) {
|
|
useColors = false;
|
|
}
|
|
}
|
|
const {
|
|
inspect,
|
|
inspectDefaultOptions: {
|
|
colors: defaultColors,
|
|
},
|
|
} = lazyInternalUtilInspect();
|
|
const colors = useColors && (lazyUtilColors().shouldColorize(process.stderr) || defaultColors);
|
|
try {
|
|
return inspect(error, {
|
|
colors,
|
|
customInspect: false,
|
|
depth: MathMax(inspect.defaultOptions.depth, 5),
|
|
});
|
|
} catch {
|
|
return originalStack;
|
|
}
|
|
},
|
|
};
|
|
|
|
const {
|
|
privateSymbols: {
|
|
arrow_message_private_symbol,
|
|
},
|
|
} = internalBinding('util');
|
|
// Ensures the printed error line is from user code.
|
|
function setArrowMessage(err, arrowMessage) {
|
|
err[arrow_message_private_symbol] = arrowMessage;
|
|
}
|
|
|
|
// Hide stack lines before the first user code line.
|
|
function hideInternalStackFrames(error) {
|
|
overrideStackTrace.set(error, (error, stackFrames) => {
|
|
let frames = stackFrames;
|
|
if (typeof stackFrames === 'object') {
|
|
frames = ArrayPrototypeFilter(
|
|
stackFrames,
|
|
(frm) => !StringPrototypeStartsWith(frm.getFileName() || '',
|
|
'node:internal'),
|
|
);
|
|
}
|
|
ArrayPrototypeUnshift(frames, error);
|
|
return ArrayPrototypeJoin(frames, '\n at ');
|
|
});
|
|
}
|
|
|
|
// Node uses an AbortError that isn't exactly the same as the DOMException
|
|
// to make usage of the error in userland and readable-stream easier.
|
|
// It is a regular error with `.code` and `.name`.
|
|
class AbortError extends Error {
|
|
constructor(message = 'The operation was aborted', options = undefined) {
|
|
if (options !== undefined && typeof options !== 'object') {
|
|
throw new codes.ERR_INVALID_ARG_TYPE('options', 'Object', options);
|
|
}
|
|
super(message, options);
|
|
this.code = 'ABORT_ERR';
|
|
this.name = 'AbortError';
|
|
}
|
|
}
|
|
|
|
/**
|
|
* This creates a generic Node.js error.
|
|
* @param {string} message The error message.
|
|
* @param {object} errorProperties Object with additional properties to be added to the error.
|
|
* @returns {Error}
|
|
*/
|
|
const genericNodeError = hideStackFrames(function genericNodeError(message, errorProperties) {
|
|
// eslint-disable-next-line no-restricted-syntax
|
|
const err = new Error(message);
|
|
ObjectAssign(err, errorProperties);
|
|
return err;
|
|
});
|
|
|
|
/**
|
|
* Determine the specific type of a value for type-mismatch errors.
|
|
* @param {*} value
|
|
* @returns {string}
|
|
*/
|
|
function determineSpecificType(value) {
|
|
if (value === null) {
|
|
return 'null';
|
|
} else if (value === undefined) {
|
|
return 'undefined';
|
|
}
|
|
|
|
const type = typeof value;
|
|
|
|
switch (type) {
|
|
case 'bigint':
|
|
return `type bigint (${value}n)`;
|
|
case 'number':
|
|
if (value === 0) {
|
|
return 1 / value === -Infinity ? 'type number (-0)' : 'type number (0)';
|
|
} else if (value !== value) { // eslint-disable-line no-self-compare
|
|
return 'type number (NaN)';
|
|
} else if (value === Infinity) {
|
|
return 'type number (Infinity)';
|
|
} else if (value === -Infinity) {
|
|
return 'type number (-Infinity)';
|
|
}
|
|
return `type number (${value})`;
|
|
case 'boolean':
|
|
return value ? 'type boolean (true)' : 'type boolean (false)';
|
|
case 'symbol':
|
|
return `type symbol (${String(value)})`;
|
|
case 'function':
|
|
return `function ${value.name}`;
|
|
case 'object':
|
|
if (value.constructor && 'name' in value.constructor) {
|
|
return `an instance of ${value.constructor.name}`;
|
|
}
|
|
return `${lazyInternalUtilInspect().inspect(value, { depth: -1 })}`;
|
|
case 'string':
|
|
value.length > 28 && (value = `${StringPrototypeSlice(value, 0, 25)}...`);
|
|
if (StringPrototypeIndexOf(value, "'") === -1) {
|
|
return `type string ('${value}')`;
|
|
}
|
|
return `type string (${JSONStringify(value)})`;
|
|
default:
|
|
value = lazyInternalUtilInspect().inspect(value, { colors: false });
|
|
if (value.length > 28) {
|
|
value = `${StringPrototypeSlice(value, 0, 25)}...`;
|
|
}
|
|
|
|
return `type ${type} (${value})`;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Create a list string in the form like 'A and B' or 'A, B, ..., and Z'.
|
|
* We cannot use Intl.ListFormat because it's not available in
|
|
* --without-intl builds.
|
|
* @param {string[]} array An array of strings.
|
|
* @param {string} [type] The list type to be inserted before the last element.
|
|
* @returns {string}
|
|
*/
|
|
function formatList(array, type = 'and') {
|
|
switch (array.length) {
|
|
case 0: return '';
|
|
case 1: return `${array[0]}`;
|
|
case 2: return `${array[0]} ${type} ${array[1]}`;
|
|
case 3: return `${array[0]}, ${array[1]}, ${type} ${array[2]}`;
|
|
default:
|
|
return `${ArrayPrototypeJoin(ArrayPrototypeSlice(array, 0, -1), ', ')}, ${type} ${array[array.length - 1]}`;
|
|
}
|
|
}
|
|
|
|
module.exports = {
|
|
AbortError,
|
|
aggregateTwoErrors,
|
|
NodeAggregateError,
|
|
codes,
|
|
ConnResetException,
|
|
DNSException,
|
|
// This is exported only to facilitate testing.
|
|
determineSpecificType,
|
|
E,
|
|
ErrnoException,
|
|
ExceptionWithHostPort,
|
|
fatalExceptionStackEnhancers,
|
|
formatList,
|
|
genericNodeError,
|
|
getMessage,
|
|
hideInternalStackFrames,
|
|
hideStackFrames,
|
|
inspectWithNoCustomRetry,
|
|
isErrorStackTraceLimitWritable,
|
|
isStackOverflowError,
|
|
kEnhanceStackBeforeInspector,
|
|
kIsNodeError,
|
|
defaultPrepareStackTrace,
|
|
setInternalPrepareStackTrace,
|
|
overrideStackTrace,
|
|
prepareStackTraceCallback,
|
|
ErrorPrepareStackTrace,
|
|
setArrowMessage,
|
|
SystemError,
|
|
uvErrmapGet,
|
|
UVException,
|
|
UVExceptionWithHostPort,
|
|
};
|
|
|
|
// To declare an error message, use the E(sym, val, def) function above. The sym
|
|
// must be an upper case string. The val can be either a function or a string.
|
|
// The def must be an error class.
|
|
// The return value of the function must be a string.
|
|
// Examples:
|
|
// E('EXAMPLE_KEY1', 'This is the error value', Error);
|
|
// E('EXAMPLE_KEY2', (a, b) => return `${a} ${b}`, RangeError);
|
|
//
|
|
// Once an error code has been assigned, the code itself MUST NOT change and
|
|
// any given error code must never be reused to identify a different error.
|
|
//
|
|
// Any error code added here should also be added to the documentation
|
|
//
|
|
// Note: Please try to keep these in alphabetical order
|
|
//
|
|
// Note: Node.js specific errors must begin with the prefix ERR_
|
|
|
|
E('ERR_ACCESS_DENIED',
|
|
function(msg, permission = '', resource = '') {
|
|
this.permission = permission;
|
|
this.resource = resource;
|
|
return msg;
|
|
},
|
|
Error);
|
|
E('ERR_AMBIGUOUS_ARGUMENT', 'The "%s" argument is ambiguous. %s', TypeError);
|
|
E('ERR_ARG_NOT_ITERABLE', '%s must be iterable', TypeError);
|
|
E('ERR_ASSERTION', '%s', Error);
|
|
E('ERR_ASYNC_CALLBACK', '%s must be a function', TypeError);
|
|
E('ERR_ASYNC_TYPE', 'Invalid name for async "type": %s', TypeError);
|
|
E('ERR_BROTLI_INVALID_PARAM', '%s is not a valid Brotli parameter', RangeError);
|
|
E('ERR_BUFFER_OUT_OF_BOUNDS',
|
|
// Using a default argument here is important so the argument is not counted
|
|
// towards `Function#length`.
|
|
(name = undefined) => {
|
|
if (name) {
|
|
return `"${name}" is outside of buffer bounds`;
|
|
}
|
|
return 'Attempt to access memory outside buffer bounds';
|
|
}, RangeError);
|
|
E('ERR_BUFFER_TOO_LARGE',
|
|
'Cannot create a Buffer larger than %s bytes',
|
|
RangeError);
|
|
E('ERR_CANNOT_WATCH_SIGINT', 'Cannot watch for SIGINT signals', Error);
|
|
E('ERR_CHILD_CLOSED_BEFORE_REPLY',
|
|
'Child closed before reply received', Error);
|
|
E('ERR_CHILD_PROCESS_IPC_REQUIRED',
|
|
"Forked processes must have an IPC channel, missing value 'ipc' in %s",
|
|
Error);
|
|
E('ERR_CHILD_PROCESS_STDIO_MAXBUFFER', '%s maxBuffer length exceeded',
|
|
RangeError);
|
|
E('ERR_CONSOLE_WRITABLE_STREAM',
|
|
'Console expects a writable stream instance for %s', TypeError);
|
|
E('ERR_CONTEXT_NOT_INITIALIZED', 'context used is not initialized', Error);
|
|
E('ERR_CRYPTO_CUSTOM_ENGINE_NOT_SUPPORTED',
|
|
'Custom engines not supported by this OpenSSL', Error);
|
|
E('ERR_CRYPTO_ECDH_INVALID_FORMAT', 'Invalid ECDH format: %s', TypeError);
|
|
E('ERR_CRYPTO_ECDH_INVALID_PUBLIC_KEY',
|
|
'Public key is not valid for specified curve', Error);
|
|
E('ERR_CRYPTO_ENGINE_UNKNOWN', 'Engine "%s" was not found', Error);
|
|
E('ERR_CRYPTO_FIPS_FORCED',
|
|
'Cannot set FIPS mode, it was forced with --force-fips at startup.', Error);
|
|
E('ERR_CRYPTO_FIPS_UNAVAILABLE', 'Cannot set FIPS mode in a non-FIPS build.',
|
|
Error);
|
|
E('ERR_CRYPTO_HASH_FINALIZED', 'Digest already called', Error);
|
|
E('ERR_CRYPTO_HASH_UPDATE_FAILED', 'Hash update failed', Error);
|
|
E('ERR_CRYPTO_INCOMPATIBLE_KEY', 'Incompatible %s: %s', Error);
|
|
E('ERR_CRYPTO_INCOMPATIBLE_KEY_OPTIONS', 'The selected key encoding %s %s.',
|
|
Error);
|
|
E('ERR_CRYPTO_INVALID_DIGEST', 'Invalid digest: %s', TypeError);
|
|
E('ERR_CRYPTO_INVALID_JWK', 'Invalid JWK data', TypeError);
|
|
E('ERR_CRYPTO_INVALID_KEY_OBJECT_TYPE',
|
|
'Invalid key object type %s, expected %s.', TypeError);
|
|
E('ERR_CRYPTO_INVALID_STATE', 'Invalid state for operation %s', Error);
|
|
E('ERR_CRYPTO_PBKDF2_ERROR', 'PBKDF2 error', Error);
|
|
E('ERR_CRYPTO_SCRYPT_NOT_SUPPORTED', 'Scrypt algorithm not supported', Error);
|
|
// Switch to TypeError. The current implementation does not seem right.
|
|
E('ERR_CRYPTO_SIGN_KEY_REQUIRED', 'No key provided to sign', Error);
|
|
E('ERR_DEBUGGER_ERROR', '%s', Error);
|
|
E('ERR_DEBUGGER_STARTUP_ERROR', '%s', Error);
|
|
E('ERR_DIR_CLOSED', 'Directory handle was closed', Error);
|
|
E('ERR_DIR_CONCURRENT_OPERATION',
|
|
'Cannot do synchronous work on directory handle with concurrent ' +
|
|
'asynchronous operations', Error);
|
|
E('ERR_DNS_SET_SERVERS_FAILED', 'c-ares failed to set servers: "%s" [%s]',
|
|
Error);
|
|
E('ERR_DOMAIN_CALLBACK_NOT_AVAILABLE',
|
|
'A callback was registered through ' +
|
|
'process.setUncaughtExceptionCaptureCallback(), which is mutually ' +
|
|
'exclusive with using the `domain` module',
|
|
Error);
|
|
E('ERR_DOMAIN_CANNOT_SET_UNCAUGHT_EXCEPTION_CAPTURE',
|
|
'The `domain` module is in use, which is mutually exclusive with calling ' +
|
|
'process.setUncaughtExceptionCaptureCallback()',
|
|
Error);
|
|
E('ERR_DUPLICATE_STARTUP_SNAPSHOT_MAIN_FUNCTION',
|
|
'Deserialize main function is already configured.', Error);
|
|
E('ERR_ENCODING_INVALID_ENCODED_DATA', function(encoding, ret) {
|
|
this.errno = ret;
|
|
return `The encoded data was not valid for encoding ${encoding}`;
|
|
}, TypeError);
|
|
E('ERR_ENCODING_NOT_SUPPORTED', 'The "%s" encoding is not supported',
|
|
RangeError);
|
|
E('ERR_EVAL_ESM_CANNOT_PRINT', '--print cannot be used with ESM input', Error);
|
|
E('ERR_EVENT_RECURSION', 'The event "%s" is already being dispatched', Error);
|
|
E('ERR_FALSY_VALUE_REJECTION', function(reason) {
|
|
this.reason = reason;
|
|
return 'Promise was rejected with falsy value';
|
|
}, Error, HideStackFramesError);
|
|
E('ERR_FEATURE_UNAVAILABLE_ON_PLATFORM',
|
|
'The feature %s is unavailable on the current platform' +
|
|
', which is being used to run Node.js',
|
|
TypeError);
|
|
E('ERR_FS_CP_DIR_TO_NON_DIR',
|
|
'Cannot overwrite non-directory with directory', SystemError);
|
|
E('ERR_FS_CP_EEXIST', 'Target already exists', SystemError);
|
|
E('ERR_FS_CP_EINVAL', 'Invalid src or dest', SystemError);
|
|
E('ERR_FS_CP_FIFO_PIPE', 'Cannot copy a FIFO pipe', SystemError);
|
|
E('ERR_FS_CP_NON_DIR_TO_DIR',
|
|
'Cannot overwrite directory with non-directory', SystemError);
|
|
E('ERR_FS_CP_SOCKET', 'Cannot copy a socket file', SystemError);
|
|
E('ERR_FS_CP_SYMLINK_TO_SUBDIRECTORY',
|
|
'Cannot overwrite symlink in subdirectory of self', SystemError);
|
|
E('ERR_FS_CP_UNKNOWN', 'Cannot copy an unknown file type', SystemError);
|
|
E('ERR_FS_EISDIR', 'Path is a directory', SystemError, HideStackFramesError);
|
|
E('ERR_FS_FILE_TOO_LARGE', 'File size (%s) is greater than 2 GiB', RangeError);
|
|
E('ERR_HTTP2_ALTSVC_INVALID_ORIGIN',
|
|
'HTTP/2 ALTSVC frames require a valid origin', TypeError);
|
|
E('ERR_HTTP2_ALTSVC_LENGTH',
|
|
'HTTP/2 ALTSVC frames are limited to 16382 bytes', TypeError);
|
|
E('ERR_HTTP2_CONNECT_AUTHORITY',
|
|
':authority header is required for CONNECT requests', Error);
|
|
E('ERR_HTTP2_CONNECT_PATH',
|
|
'The :path header is forbidden for CONNECT requests', Error);
|
|
E('ERR_HTTP2_CONNECT_SCHEME',
|
|
'The :scheme header is forbidden for CONNECT requests', Error);
|
|
E('ERR_HTTP2_GOAWAY_SESSION',
|
|
'New streams cannot be created after receiving a GOAWAY', Error);
|
|
E('ERR_HTTP2_HEADERS_AFTER_RESPOND',
|
|
'Cannot specify additional headers after response initiated', Error);
|
|
E('ERR_HTTP2_HEADERS_SENT', 'Response has already been initiated.', Error);
|
|
E('ERR_HTTP2_HEADER_SINGLE_VALUE',
|
|
'Header field "%s" must only have a single value', TypeError);
|
|
E('ERR_HTTP2_INFO_STATUS_NOT_ALLOWED',
|
|
'Informational status codes cannot be used', RangeError);
|
|
E('ERR_HTTP2_INVALID_CONNECTION_HEADERS',
|
|
'HTTP/1 Connection specific headers are forbidden: "%s"', TypeError);
|
|
E('ERR_HTTP2_INVALID_HEADER_VALUE',
|
|
'Invalid value "%s" for header "%s"', TypeError, HideStackFramesError);
|
|
E('ERR_HTTP2_INVALID_INFO_STATUS',
|
|
'Invalid informational status code: %s', RangeError);
|
|
E('ERR_HTTP2_INVALID_ORIGIN',
|
|
'HTTP/2 ORIGIN frames require a valid origin', TypeError);
|
|
E('ERR_HTTP2_INVALID_PACKED_SETTINGS_LENGTH',
|
|
'Packed settings length must be a multiple of six', RangeError);
|
|
E('ERR_HTTP2_INVALID_PSEUDOHEADER',
|
|
'"%s" is an invalid pseudoheader or is used incorrectly', TypeError, HideStackFramesError);
|
|
E('ERR_HTTP2_INVALID_SESSION', 'The session has been destroyed', Error);
|
|
E('ERR_HTTP2_INVALID_SETTING_VALUE',
|
|
// Using default arguments here is important so the arguments are not counted
|
|
// towards `Function#length`.
|
|
function(name, actual, min = undefined, max = undefined) {
|
|
this.actual = actual;
|
|
if (min !== undefined) {
|
|
this.min = min;
|
|
this.max = max;
|
|
}
|
|
return `Invalid value for setting "${name}": ${actual}`;
|
|
}, TypeError, RangeError, HideStackFramesError);
|
|
E('ERR_HTTP2_INVALID_STREAM', 'The stream has been destroyed', Error);
|
|
E('ERR_HTTP2_MAX_PENDING_SETTINGS_ACK',
|
|
'Maximum number of pending settings acknowledgements', Error);
|
|
E('ERR_HTTP2_NESTED_PUSH',
|
|
'A push stream cannot initiate another push stream.', Error);
|
|
E('ERR_HTTP2_NO_MEM', 'Out of memory', Error);
|
|
E('ERR_HTTP2_NO_SOCKET_MANIPULATION',
|
|
'HTTP/2 sockets should not be directly manipulated (e.g. read and written)',
|
|
Error);
|
|
E('ERR_HTTP2_ORIGIN_LENGTH',
|
|
'HTTP/2 ORIGIN frames are limited to 16382 bytes', TypeError);
|
|
E('ERR_HTTP2_OUT_OF_STREAMS',
|
|
'No stream ID is available because maximum stream ID has been reached',
|
|
Error);
|
|
E('ERR_HTTP2_PAYLOAD_FORBIDDEN',
|
|
'Responses with %s status must not have a payload', Error);
|
|
E('ERR_HTTP2_PING_CANCEL', 'HTTP2 ping cancelled', Error);
|
|
E('ERR_HTTP2_PING_LENGTH', 'HTTP2 ping payload must be 8 bytes', RangeError);
|
|
E('ERR_HTTP2_PSEUDOHEADER_NOT_ALLOWED',
|
|
'Cannot set HTTP/2 pseudo-headers', TypeError, HideStackFramesError);
|
|
E('ERR_HTTP2_PUSH_DISABLED', 'HTTP/2 client has disabled push streams', Error);
|
|
E('ERR_HTTP2_SEND_FILE', 'Directories cannot be sent', Error);
|
|
E('ERR_HTTP2_SEND_FILE_NOSEEK',
|
|
'Offset or length can only be specified for regular files', Error);
|
|
E('ERR_HTTP2_SESSION_ERROR', 'Session closed with error code %s', Error);
|
|
E('ERR_HTTP2_SETTINGS_CANCEL', 'HTTP2 session settings canceled', Error);
|
|
E('ERR_HTTP2_SOCKET_BOUND',
|
|
'The socket is already bound to an Http2Session', Error);
|
|
E('ERR_HTTP2_SOCKET_UNBOUND',
|
|
'The socket has been disconnected from the Http2Session', Error);
|
|
E('ERR_HTTP2_STATUS_101',
|
|
'HTTP status code 101 (Switching Protocols) is forbidden in HTTP/2', Error);
|
|
E('ERR_HTTP2_STATUS_INVALID', 'Invalid status code: %s', RangeError);
|
|
E('ERR_HTTP2_STREAM_CANCEL', function(error) {
|
|
let msg = 'The pending stream has been canceled';
|
|
if (error) {
|
|
this.cause = error;
|
|
if (typeof error.message === 'string')
|
|
msg += ` (caused by: ${error.message})`;
|
|
}
|
|
return msg;
|
|
}, Error);
|
|
E('ERR_HTTP2_STREAM_ERROR', 'Stream closed with error code %s', Error);
|
|
E('ERR_HTTP2_STREAM_SELF_DEPENDENCY',
|
|
'A stream cannot depend on itself', Error);
|
|
E('ERR_HTTP2_TOO_MANY_CUSTOM_SETTINGS',
|
|
'Number of custom settings exceeds MAX_ADDITIONAL_SETTINGS', Error);
|
|
E('ERR_HTTP2_TOO_MANY_INVALID_FRAMES', 'Too many invalid HTTP/2 frames', Error);
|
|
E('ERR_HTTP2_TRAILERS_ALREADY_SENT',
|
|
'Trailing headers have already been sent', Error);
|
|
E('ERR_HTTP2_TRAILERS_NOT_READY',
|
|
'Trailing headers cannot be sent until after the wantTrailers event is ' +
|
|
'emitted', Error);
|
|
E('ERR_HTTP2_UNSUPPORTED_PROTOCOL', 'protocol "%s" is unsupported.', Error);
|
|
E('ERR_HTTP_BODY_NOT_ALLOWED',
|
|
'Adding content for this request method or response status is not allowed.', Error);
|
|
E('ERR_HTTP_CONTENT_LENGTH_MISMATCH',
|
|
'Response body\'s content-length of %s byte(s) does not match the content-length of %s byte(s) set in header', Error);
|
|
E('ERR_HTTP_HEADERS_SENT',
|
|
'Cannot %s headers after they are sent to the client', Error);
|
|
E('ERR_HTTP_INVALID_HEADER_VALUE',
|
|
'Invalid value "%s" for header "%s"', TypeError, HideStackFramesError);
|
|
E('ERR_HTTP_INVALID_STATUS_CODE', 'Invalid status code: %s', RangeError);
|
|
E('ERR_HTTP_REQUEST_TIMEOUT', 'Request timeout', Error);
|
|
E('ERR_HTTP_SOCKET_ASSIGNED',
|
|
'ServerResponse has an already assigned socket', Error);
|
|
E('ERR_HTTP_SOCKET_ENCODING',
|
|
'Changing the socket encoding is not allowed per RFC7230 Section 3.', Error);
|
|
E('ERR_HTTP_TRAILER_INVALID',
|
|
'Trailers are invalid with this transfer encoding', Error);
|
|
E('ERR_ILLEGAL_CONSTRUCTOR', 'Illegal constructor', TypeError);
|
|
E('ERR_IMPORT_ATTRIBUTE_MISSING',
|
|
'Module "%s" needs an import attribute of "%s: %s"', TypeError);
|
|
E('ERR_IMPORT_ATTRIBUTE_TYPE_INCOMPATIBLE',
|
|
'Module "%s" is not of type "%s"', TypeError);
|
|
E('ERR_IMPORT_ATTRIBUTE_UNSUPPORTED',
|
|
'Import attribute "%s" with value "%s" is not supported', TypeError);
|
|
E('ERR_INCOMPATIBLE_OPTION_PAIR',
|
|
'Option "%s" cannot be used in combination with option "%s"', TypeError, HideStackFramesError);
|
|
E('ERR_INPUT_TYPE_NOT_ALLOWED', '--input-type can only be used with string ' +
|
|
'input via --eval, --print, or STDIN', Error);
|
|
E('ERR_INSPECTOR_ALREADY_ACTIVATED',
|
|
'Inspector is already activated. Close it with inspector.close() ' +
|
|
'before activating it again.',
|
|
Error);
|
|
E('ERR_INSPECTOR_ALREADY_CONNECTED', '%s is already connected', Error);
|
|
E('ERR_INSPECTOR_CLOSED', 'Session was closed', Error);
|
|
E('ERR_INSPECTOR_COMMAND', 'Inspector error %d: %s', Error);
|
|
E('ERR_INSPECTOR_NOT_ACTIVE', 'Inspector is not active', Error);
|
|
E('ERR_INSPECTOR_NOT_AVAILABLE', 'Inspector is not available', Error);
|
|
E('ERR_INSPECTOR_NOT_CONNECTED', 'Session is not connected', Error);
|
|
E('ERR_INSPECTOR_NOT_WORKER', 'Current thread is not a worker', Error);
|
|
E('ERR_INTERNAL_ASSERTION', (message) => {
|
|
const suffix = 'This is caused by either a bug in Node.js ' +
|
|
'or incorrect usage of Node.js internals.\n' +
|
|
'Please open an issue with this stack trace at ' +
|
|
'https://github.com/nodejs/node/issues\n';
|
|
return message === undefined ? suffix : `${message}\n${suffix}`;
|
|
}, Error);
|
|
E('ERR_INVALID_ADDRESS_FAMILY', function(addressType, host, port) {
|
|
this.host = host;
|
|
this.port = port;
|
|
return `Invalid address family: ${addressType} ${host}:${port}`;
|
|
}, RangeError);
|
|
E('ERR_INVALID_ARG_TYPE',
|
|
(name, expected, actual) => {
|
|
assert(typeof name === 'string', "'name' must be a string");
|
|
if (!ArrayIsArray(expected)) {
|
|
expected = [expected];
|
|
}
|
|
|
|
let msg = 'The ';
|
|
if (StringPrototypeEndsWith(name, ' argument')) {
|
|
// For cases like 'first argument'
|
|
msg += `${name} `;
|
|
} else {
|
|
const type = StringPrototypeIncludes(name, '.') ? 'property' : 'argument';
|
|
msg += `"${name}" ${type} `;
|
|
}
|
|
msg += 'must be ';
|
|
|
|
const types = [];
|
|
const instances = [];
|
|
const other = [];
|
|
|
|
for (const value of expected) {
|
|
assert(typeof value === 'string',
|
|
'All expected entries have to be of type string');
|
|
if (ArrayPrototypeIncludes(kTypes, value)) {
|
|
ArrayPrototypePush(types, StringPrototypeToLowerCase(value));
|
|
} else if (RegExpPrototypeExec(classRegExp, value) !== null) {
|
|
ArrayPrototypePush(instances, value);
|
|
} else {
|
|
assert(value !== 'object',
|
|
'The value "object" should be written as "Object"');
|
|
ArrayPrototypePush(other, value);
|
|
}
|
|
}
|
|
|
|
// Special handle `object` in case other instances are allowed to outline
|
|
// the differences between each other.
|
|
if (instances.length > 0) {
|
|
const pos = ArrayPrototypeIndexOf(types, 'object');
|
|
if (pos !== -1) {
|
|
ArrayPrototypeSplice(types, pos, 1);
|
|
ArrayPrototypePush(instances, 'Object');
|
|
}
|
|
}
|
|
|
|
if (types.length > 0) {
|
|
msg += `${types.length > 1 ? 'one of type' : 'of type'} ${formatList(types, 'or')}`;
|
|
if (instances.length > 0 || other.length > 0)
|
|
msg += ' or ';
|
|
}
|
|
|
|
if (instances.length > 0) {
|
|
msg += `an instance of ${formatList(instances, 'or')}`;
|
|
if (other.length > 0)
|
|
msg += ' or ';
|
|
}
|
|
|
|
if (other.length > 0) {
|
|
if (other.length > 1) {
|
|
msg += `one of ${formatList(other, 'or')}`;
|
|
} else {
|
|
if (StringPrototypeToLowerCase(other[0]) !== other[0])
|
|
msg += 'an ';
|
|
msg += `${other[0]}`;
|
|
}
|
|
}
|
|
|
|
msg += `. Received ${determineSpecificType(actual)}`;
|
|
|
|
return msg;
|
|
}, TypeError, HideStackFramesError);
|
|
E('ERR_INVALID_ARG_VALUE', (name, value, reason = 'is invalid') => {
|
|
let inspected = lazyInternalUtilInspect().inspect(value);
|
|
if (inspected.length > 128) {
|
|
inspected = `${StringPrototypeSlice(inspected, 0, 128)}...`;
|
|
}
|
|
const type = StringPrototypeIncludes(name, '.') ? 'property' : 'argument';
|
|
return `The ${type} '${name}' ${reason}. Received ${inspected}`;
|
|
}, TypeError, RangeError, HideStackFramesError);
|
|
E('ERR_INVALID_ASYNC_ID', 'Invalid %s value: %s', RangeError);
|
|
E('ERR_INVALID_BUFFER_SIZE',
|
|
'Buffer size must be a multiple of %s', RangeError);
|
|
E('ERR_INVALID_CHAR',
|
|
// Using a default argument here is important so the argument is not counted
|
|
// towards `Function#length`.
|
|
(name, field = undefined) => {
|
|
let msg = `Invalid character in ${name}`;
|
|
if (field !== undefined) {
|
|
msg += ` ["${field}"]`;
|
|
}
|
|
return msg;
|
|
}, TypeError, HideStackFramesError);
|
|
E('ERR_INVALID_CURSOR_POS',
|
|
'Cannot set cursor row without setting its column', TypeError);
|
|
E('ERR_INVALID_FD',
|
|
'"fd" must be a positive integer: %s', RangeError);
|
|
E('ERR_INVALID_FD_TYPE', 'Unsupported fd type: %s', TypeError);
|
|
E('ERR_INVALID_FILE_URL_HOST',
|
|
'File URL host must be "localhost" or empty on %s', TypeError);
|
|
E('ERR_INVALID_FILE_URL_PATH', 'File URL path %s', TypeError);
|
|
E('ERR_INVALID_HANDLE_TYPE', 'This handle type cannot be sent', TypeError);
|
|
E('ERR_INVALID_HTTP_TOKEN', '%s must be a valid HTTP token ["%s"]', TypeError, HideStackFramesError);
|
|
E('ERR_INVALID_IP_ADDRESS', 'Invalid IP address: %s', TypeError);
|
|
E('ERR_INVALID_MIME_SYNTAX', (production, str, invalidIndex) => {
|
|
const msg = invalidIndex !== -1 ? ` at ${invalidIndex}` : '';
|
|
return `The MIME syntax for a ${production} in "${str}" is invalid` + msg;
|
|
}, TypeError);
|
|
E('ERR_INVALID_MODULE_SPECIFIER', (request, reason, base = undefined) => {
|
|
return `Invalid module "${request}" ${reason}${base ?
|
|
` imported from ${base}` : ''}`;
|
|
}, TypeError);
|
|
E('ERR_INVALID_PACKAGE_CONFIG', (path, base, message) => {
|
|
return `Invalid package config ${path}${base ? ` while importing ${base}` :
|
|
''}${message ? `. ${message}` : ''}`;
|
|
}, Error);
|
|
E('ERR_INVALID_PACKAGE_TARGET',
|
|
(pkgPath, key, target, isImport = false, base = undefined) => {
|
|
const relError = typeof target === 'string' && !isImport &&
|
|
target.length && !StringPrototypeStartsWith(target, './');
|
|
if (key === '.') {
|
|
assert(isImport === false);
|
|
return `Invalid "exports" main target ${JSONStringify(target)} defined ` +
|
|
`in the package config ${pkgPath}package.json${base ?
|
|
` imported from ${base}` : ''}${relError ?
|
|
'; targets must start with "./"' : ''}`;
|
|
}
|
|
return `Invalid "${isImport ? 'imports' : 'exports'}" target ${
|
|
JSONStringify(target)} defined for '${key}' in the package config ${
|
|
pkgPath}package.json${base ? ` imported from ${base}` : ''}${relError ?
|
|
'; targets must start with "./"' : ''}`;
|
|
}, Error);
|
|
E('ERR_INVALID_PROTOCOL',
|
|
'Protocol "%s" not supported. Expected "%s"',
|
|
TypeError);
|
|
E('ERR_INVALID_REPL_EVAL_CONFIG',
|
|
'Cannot specify both "breakEvalOnSigint" and "eval" for REPL', TypeError);
|
|
E('ERR_INVALID_REPL_INPUT', '%s', TypeError);
|
|
E('ERR_INVALID_RETURN_PROPERTY', (input, name, prop, value) => {
|
|
return `Expected a valid ${input} to be returned for the "${prop}" from the` +
|
|
` "${name}" hook but got ${determineSpecificType(value)}.`;
|
|
}, TypeError);
|
|
E('ERR_INVALID_RETURN_PROPERTY_VALUE', (input, name, prop, value) => {
|
|
return `Expected ${input} to be returned for the "${prop}" from the` +
|
|
` "${name}" hook but got ${determineSpecificType(value)}.`;
|
|
}, TypeError);
|
|
E('ERR_INVALID_RETURN_VALUE', (input, name, value) => {
|
|
const type = determineSpecificType(value);
|
|
|
|
return `Expected ${input} to be returned from the "${name}"` +
|
|
` function but got ${type}.`;
|
|
}, TypeError, RangeError);
|
|
E('ERR_INVALID_STATE', 'Invalid state: %s', Error, TypeError, RangeError);
|
|
E('ERR_INVALID_SYNC_FORK_INPUT',
|
|
'Asynchronous forks do not support ' +
|
|
'Buffer, TypedArray, DataView or string input: %s',
|
|
TypeError);
|
|
E('ERR_INVALID_THIS', 'Value of "this" must be of type %s', TypeError);
|
|
E('ERR_INVALID_TUPLE', '%s must be an iterable %s tuple', TypeError);
|
|
E('ERR_INVALID_TYPESCRIPT_SYNTAX', '%s', SyntaxError);
|
|
E('ERR_INVALID_URI', 'URI malformed', URIError);
|
|
E('ERR_INVALID_URL', function(input, base = null) {
|
|
this.input = input;
|
|
|
|
if (base != null) {
|
|
this.base = base;
|
|
}
|
|
|
|
// Don't include URL in message.
|
|
// (See https://github.com/nodejs/node/pull/38614)
|
|
return 'Invalid URL';
|
|
}, TypeError);
|
|
E('ERR_INVALID_URL_SCHEME',
|
|
(expected) => {
|
|
if (typeof expected === 'string')
|
|
expected = [expected];
|
|
assert(expected.length <= 2);
|
|
const res = expected.length === 2 ?
|
|
`one of scheme ${expected[0]} or ${expected[1]}` :
|
|
`of scheme ${expected[0]}`;
|
|
return `The URL must be ${res}`;
|
|
}, TypeError);
|
|
E('ERR_IPC_CHANNEL_CLOSED', 'Channel closed', Error);
|
|
E('ERR_IPC_DISCONNECTED', 'IPC channel is already disconnected', Error);
|
|
E('ERR_IPC_ONE_PIPE', 'Child process can have only one IPC pipe', Error);
|
|
E('ERR_IPC_SYNC_FORK', 'IPC cannot be used with synchronous forks', Error);
|
|
E(
|
|
'ERR_LOADER_CHAIN_INCOMPLETE',
|
|
'"%s" did not call the next hook in its chain and did not' +
|
|
' explicitly signal a short circuit. If this is intentional, include' +
|
|
' `shortCircuit: true` in the hook\'s return.',
|
|
Error,
|
|
);
|
|
E('ERR_METHOD_NOT_IMPLEMENTED', 'The %s method is not implemented', Error);
|
|
E('ERR_MISSING_ARGS',
|
|
(...args) => {
|
|
assert(args.length > 0, 'At least one arg needs to be specified');
|
|
let msg = 'The ';
|
|
const len = args.length;
|
|
const wrap = (a) => `"${a}"`;
|
|
args = ArrayPrototypeMap(
|
|
args,
|
|
(a) => (ArrayIsArray(a) ?
|
|
ArrayPrototypeJoin(ArrayPrototypeMap(a, wrap), ' or ') :
|
|
wrap(a)),
|
|
);
|
|
msg += `${formatList(args)} argument${len > 1 ? 's' : ''}`;
|
|
return `${msg} must be specified`;
|
|
}, TypeError);
|
|
E('ERR_MISSING_OPTION', '%s is required', TypeError);
|
|
E('ERR_MODULE_NOT_FOUND', function(path, base, exactUrl) {
|
|
if (exactUrl) {
|
|
lazyInternalUtil().setOwnProperty(this, 'url', `${exactUrl}`);
|
|
}
|
|
return `Cannot find ${
|
|
exactUrl ? 'module' : 'package'} '${path}' imported from ${base}`;
|
|
}, Error);
|
|
E('ERR_MULTIPLE_CALLBACK', 'Callback called multiple times', Error);
|
|
E('ERR_NAPI_CONS_FUNCTION', 'Constructor must be a function', TypeError);
|
|
E('ERR_NAPI_INVALID_DATAVIEW_ARGS',
|
|
'byte_offset + byte_length should be less than or equal to the size in ' +
|
|
'bytes of the array passed in',
|
|
RangeError);
|
|
E('ERR_NAPI_INVALID_TYPEDARRAY_ALIGNMENT',
|
|
'start offset of %s should be a multiple of %s', RangeError);
|
|
E('ERR_NAPI_INVALID_TYPEDARRAY_LENGTH',
|
|
'Invalid typed array length', RangeError);
|
|
E('ERR_NOT_BUILDING_SNAPSHOT',
|
|
'Operation cannot be invoked when not building startup snapshot', Error);
|
|
E('ERR_NOT_IN_SINGLE_EXECUTABLE_APPLICATION',
|
|
'Operation cannot be invoked when not in a single-executable application', Error);
|
|
E('ERR_NOT_SUPPORTED_IN_SNAPSHOT', '%s is not supported in startup snapshot', Error);
|
|
E('ERR_NO_CRYPTO',
|
|
'Node.js is not compiled with OpenSSL crypto support', Error);
|
|
E('ERR_NO_ICU',
|
|
'%s is not supported on Node.js compiled without ICU', TypeError);
|
|
E('ERR_NO_TYPESCRIPT',
|
|
'Node.js is not compiled with TypeScript support', Error);
|
|
E('ERR_OPERATION_FAILED', 'Operation failed: %s', Error, TypeError);
|
|
E('ERR_OUT_OF_RANGE',
|
|
(str, range, input, replaceDefaultBoolean = false) => {
|
|
assert(range, 'Missing "range" argument');
|
|
let msg = replaceDefaultBoolean ? str :
|
|
`The value of "${str}" is out of range.`;
|
|
let received;
|
|
if (NumberIsInteger(input) && MathAbs(input) > 2 ** 32) {
|
|
received = addNumericalSeparator(String(input));
|
|
} else if (typeof input === 'bigint') {
|
|
received = String(input);
|
|
if (input > 2n ** 32n || input < -(2n ** 32n)) {
|
|
received = addNumericalSeparator(received);
|
|
}
|
|
received += 'n';
|
|
} else {
|
|
received = lazyInternalUtilInspect().inspect(input);
|
|
}
|
|
msg += ` It must be ${range}. Received ${received}`;
|
|
return msg;
|
|
}, RangeError, HideStackFramesError);
|
|
E('ERR_PACKAGE_IMPORT_NOT_DEFINED', (specifier, packagePath, base) => {
|
|
return `Package import specifier "${specifier}" is not defined${packagePath ?
|
|
` in package ${packagePath}package.json` : ''} imported from ${base}`;
|
|
}, TypeError);
|
|
E('ERR_PACKAGE_PATH_NOT_EXPORTED', (pkgPath, subpath, base = undefined) => {
|
|
if (subpath === '.')
|
|
return `No "exports" main defined in ${pkgPath}package.json${base ?
|
|
` imported from ${base}` : ''}`;
|
|
return `Package subpath '${subpath}' is not defined by "exports" in ${
|
|
pkgPath}package.json${base ? ` imported from ${base}` : ''}`;
|
|
}, Error);
|
|
E('ERR_PARSE_ARGS_INVALID_OPTION_VALUE', '%s', TypeError);
|
|
E('ERR_PARSE_ARGS_UNEXPECTED_POSITIONAL', "Unexpected argument '%s'. This " +
|
|
'command does not take positional arguments', TypeError);
|
|
E('ERR_PARSE_ARGS_UNKNOWN_OPTION', (option, allowPositionals) => {
|
|
const suggestDashDash = allowPositionals ? '. To specify a positional ' +
|
|
"argument starting with a '-', place it at the end of the command after " +
|
|
`'--', as in '-- ${JSONStringify(option)}` : '';
|
|
return `Unknown option '${option}'${suggestDashDash}`;
|
|
}, TypeError);
|
|
E('ERR_PERFORMANCE_INVALID_TIMESTAMP',
|
|
'%d is not a valid timestamp', TypeError);
|
|
E('ERR_PERFORMANCE_MEASURE_INVALID_OPTIONS', '%s', TypeError);
|
|
E('ERR_QUIC_CONNECTION_FAILED', 'QUIC connection failed', Error);
|
|
E('ERR_QUIC_ENDPOINT_CLOSED', 'QUIC endpoint closed: %s (%d)', Error);
|
|
E('ERR_QUIC_OPEN_STREAM_FAILED', 'Failed to open QUIC stream', Error);
|
|
E('ERR_REQUIRE_CYCLE_MODULE', '%s', Error);
|
|
E('ERR_REQUIRE_ESM',
|
|
function(filename, hasEsmSyntax, parentPath = null, packageJsonPath = null) {
|
|
hideInternalStackFrames(this);
|
|
let msg = `require() of ES Module ${filename}${parentPath ? ` from ${
|
|
parentPath}` : ''} not supported.`;
|
|
if (!packageJsonPath) {
|
|
if (StringPrototypeEndsWith(filename, '.mjs'))
|
|
msg += `\nInstead change the require of ${filename} to a dynamic ` +
|
|
'import() which is available in all CommonJS modules.';
|
|
return msg;
|
|
}
|
|
const path = require('path');
|
|
const basename = parentPath && path.basename(filename) ===
|
|
path.basename(parentPath) ? filename : path.basename(filename);
|
|
if (hasEsmSyntax) {
|
|
msg += `\nInstead change the require of ${basename} in ${parentPath} to` +
|
|
' a dynamic import() which is available in all CommonJS modules.';
|
|
return msg;
|
|
}
|
|
msg += `\n${basename} is treated as an ES module file as it is a .js ` +
|
|
'file whose nearest parent package.json contains "type": "module" ' +
|
|
'which declares all .js files in that package scope as ES modules.' +
|
|
`\nInstead either rename ${basename} to end in .cjs, change the requiring ` +
|
|
'code to use dynamic import() which is available in all CommonJS ' +
|
|
'modules, or change "type": "module" to "type": "commonjs" in ' +
|
|
`${packageJsonPath} to treat all .js files as CommonJS (using .mjs for ` +
|
|
'all ES modules instead).\n';
|
|
return msg;
|
|
}, Error);
|
|
E('ERR_SCRIPT_EXECUTION_INTERRUPTED',
|
|
'Script execution was interrupted by `SIGINT`', Error);
|
|
E('ERR_SERVER_ALREADY_LISTEN',
|
|
'Listen method has been called more than once without closing.', Error);
|
|
E('ERR_SERVER_NOT_RUNNING', 'Server is not running.', Error);
|
|
E('ERR_SINGLE_EXECUTABLE_APPLICATION_ASSET_NOT_FOUND',
|
|
'Cannot find asset %s for the single executable application', Error);
|
|
E('ERR_SOCKET_ALREADY_BOUND', 'Socket is already bound', Error);
|
|
E('ERR_SOCKET_BAD_BUFFER_SIZE',
|
|
'Buffer size must be a positive integer', TypeError);
|
|
E('ERR_SOCKET_BAD_PORT', (name, port, allowZero = true) => {
|
|
assert(typeof allowZero === 'boolean',
|
|
"The 'allowZero' argument must be of type boolean.");
|
|
const operator = allowZero ? '>=' : '>';
|
|
return `${name} should be ${operator} 0 and < 65536. Received ${determineSpecificType(port)}.`;
|
|
}, RangeError, HideStackFramesError);
|
|
E('ERR_SOCKET_BAD_TYPE',
|
|
'Bad socket type specified. Valid types are: udp4, udp6', TypeError);
|
|
E('ERR_SOCKET_BUFFER_SIZE',
|
|
'Could not get or set buffer size',
|
|
SystemError);
|
|
E('ERR_SOCKET_CLOSED', 'Socket is closed', Error);
|
|
E('ERR_SOCKET_CLOSED_BEFORE_CONNECTION',
|
|
'Socket closed before the connection was established',
|
|
Error);
|
|
E('ERR_SOCKET_CONNECTION_TIMEOUT',
|
|
'Socket connection timeout', Error);
|
|
E('ERR_SOCKET_DGRAM_IS_CONNECTED', 'Already connected', Error);
|
|
E('ERR_SOCKET_DGRAM_NOT_CONNECTED', 'Not connected', Error);
|
|
E('ERR_SOCKET_DGRAM_NOT_RUNNING', 'Not running', Error);
|
|
E('ERR_SOURCE_MAP_CORRUPT', `The source map for '%s' does not exist or is corrupt.`, Error);
|
|
E('ERR_SOURCE_MAP_MISSING_SOURCE', `Cannot find '%s' imported from the source map for '%s'`, Error);
|
|
E('ERR_SRI_PARSE',
|
|
'Subresource Integrity string %j had an unexpected %j at position %d',
|
|
SyntaxError);
|
|
E('ERR_STREAM_ALREADY_FINISHED',
|
|
'Cannot call %s after a stream was finished',
|
|
Error);
|
|
E('ERR_STREAM_CANNOT_PIPE', 'Cannot pipe, not readable', Error);
|
|
E('ERR_STREAM_DESTROYED', 'Cannot call %s after a stream was destroyed', Error);
|
|
E('ERR_STREAM_NULL_VALUES', 'May not write null values to stream', TypeError);
|
|
E('ERR_STREAM_PREMATURE_CLOSE', 'Premature close', Error);
|
|
E('ERR_STREAM_PUSH_AFTER_EOF', 'stream.push() after EOF', Error);
|
|
E('ERR_STREAM_UNABLE_TO_PIPE', 'Cannot pipe to a closed or destroyed stream', Error);
|
|
E('ERR_STREAM_UNSHIFT_AFTER_END_EVENT',
|
|
'stream.unshift() after end event', Error);
|
|
E('ERR_STREAM_WRAP', 'Stream has StringDecoder set or is in objectMode', Error);
|
|
E('ERR_STREAM_WRITE_AFTER_END', 'write after end', Error);
|
|
E('ERR_SYNTHETIC', 'JavaScript Callstack', Error);
|
|
E('ERR_SYSTEM_ERROR', 'A system error occurred', SystemError, HideStackFramesError);
|
|
E('ERR_TAP_LEXER_ERROR', function(errorMsg) {
|
|
hideInternalStackFrames(this);
|
|
return errorMsg;
|
|
}, Error);
|
|
E('ERR_TAP_PARSER_ERROR', function(errorMsg, details, tokenCausedError, source) {
|
|
hideInternalStackFrames(this);
|
|
this.cause = tokenCausedError;
|
|
const { column, line, start, end } = tokenCausedError.location;
|
|
const errorDetails = `${details} at line ${line}, column ${column} (start ${start}, end ${end})`;
|
|
return errorMsg + errorDetails;
|
|
}, SyntaxError);
|
|
E('ERR_TAP_VALIDATION_ERROR', function(errorMsg) {
|
|
hideInternalStackFrames(this);
|
|
return errorMsg;
|
|
}, Error);
|
|
E('ERR_TEST_FAILURE', function(error, failureType) {
|
|
hideInternalStackFrames(this);
|
|
assert(typeof failureType === 'string' || typeof failureType === 'symbol',
|
|
"The 'failureType' argument must be of type string or symbol.");
|
|
|
|
let msg = error?.message ?? error;
|
|
|
|
if (typeof msg !== 'string') {
|
|
msg = inspectWithNoCustomRetry(msg);
|
|
}
|
|
|
|
this.failureType = failureType;
|
|
this.cause = error;
|
|
return msg;
|
|
}, Error);
|
|
E('ERR_TLS_ALPN_CALLBACK_INVALID_RESULT', (value, protocols) => {
|
|
return `ALPN callback returned a value (${
|
|
value
|
|
}) that did not match any of the client's offered protocols (${
|
|
protocols.join(', ')
|
|
})`;
|
|
}, TypeError);
|
|
E('ERR_TLS_ALPN_CALLBACK_WITH_PROTOCOLS',
|
|
'The ALPNCallback and ALPNProtocols TLS options are mutually exclusive',
|
|
TypeError);
|
|
E('ERR_TLS_CERT_ALTNAME_FORMAT', 'Invalid subject alternative name string',
|
|
SyntaxError);
|
|
E('ERR_TLS_CERT_ALTNAME_INVALID', function(reason, host, cert) {
|
|
this.reason = reason;
|
|
this.host = host;
|
|
this.cert = cert;
|
|
return `Hostname/IP does not match certificate's altnames: ${reason}`;
|
|
}, Error);
|
|
E('ERR_TLS_DH_PARAM_SIZE', 'DH parameter size %s is less than 2048', Error);
|
|
E('ERR_TLS_HANDSHAKE_TIMEOUT', 'TLS handshake timeout', Error);
|
|
E('ERR_TLS_INVALID_CONTEXT', '%s must be a SecureContext', TypeError);
|
|
E('ERR_TLS_INVALID_PROTOCOL_VERSION',
|
|
'%j is not a valid %s TLS protocol version', TypeError);
|
|
E('ERR_TLS_INVALID_STATE', 'TLS socket connection must be securely established',
|
|
Error);
|
|
E('ERR_TLS_PROTOCOL_VERSION_CONFLICT',
|
|
'TLS protocol version %j conflicts with secureProtocol %j', TypeError);
|
|
E('ERR_TLS_RENEGOTIATION_DISABLED',
|
|
'TLS session renegotiation disabled for this socket', Error);
|
|
|
|
// This should probably be a `TypeError`.
|
|
E('ERR_TLS_REQUIRED_SERVER_NAME',
|
|
'"servername" is required parameter for Server.addContext', Error);
|
|
E('ERR_TLS_SESSION_ATTACK', 'TLS session renegotiation attack detected', Error);
|
|
E('ERR_TLS_SNI_FROM_SERVER',
|
|
'Cannot issue SNI from a TLS server-side socket', Error);
|
|
E('ERR_TRACE_EVENTS_CATEGORY_REQUIRED',
|
|
'At least one category is required', TypeError);
|
|
E('ERR_TRACE_EVENTS_UNAVAILABLE', 'Trace events are unavailable', Error);
|
|
|
|
// This should probably be a `RangeError`.
|
|
E('ERR_TTY_INIT_FAILED', 'TTY initialization failed', SystemError);
|
|
E('ERR_UNAVAILABLE_DURING_EXIT', 'Cannot call function in process exit ' +
|
|
'handler', Error);
|
|
E('ERR_UNCAUGHT_EXCEPTION_CAPTURE_ALREADY_SET',
|
|
'`process.setupUncaughtExceptionCapture()` was called while a capture ' +
|
|
'callback was already active',
|
|
Error);
|
|
E('ERR_UNESCAPED_CHARACTERS', '%s contains unescaped characters', TypeError);
|
|
E('ERR_UNHANDLED_ERROR',
|
|
// Using a default argument here is important so the argument is not counted
|
|
// towards `Function#length`.
|
|
(err = undefined) => {
|
|
const msg = 'Unhandled error.';
|
|
if (err === undefined) return msg;
|
|
return `${msg} (${err})`;
|
|
}, Error);
|
|
E('ERR_UNKNOWN_BUILTIN_MODULE', 'No such built-in module: %s', Error);
|
|
E('ERR_UNKNOWN_CREDENTIAL', '%s identifier does not exist: %s', Error);
|
|
E('ERR_UNKNOWN_ENCODING', 'Unknown encoding: %s', TypeError);
|
|
E('ERR_UNKNOWN_FILE_EXTENSION', 'Unknown file extension "%s" for %s', TypeError);
|
|
E('ERR_UNKNOWN_MODULE_FORMAT', 'Unknown module format: %s for URL %s',
|
|
RangeError);
|
|
E('ERR_UNKNOWN_SIGNAL', 'Unknown signal: %s', TypeError, HideStackFramesError);
|
|
E('ERR_UNSUPPORTED_DIR_IMPORT', function(path, base, exactUrl) {
|
|
lazyInternalUtil().setOwnProperty(this, 'url', exactUrl);
|
|
return `Directory import '${path}' is not supported ` +
|
|
`resolving ES modules imported from ${base}`;
|
|
}, Error);
|
|
E('ERR_UNSUPPORTED_ESM_URL_SCHEME', (url, supported) => {
|
|
let msg = `Only URLs with a scheme in: ${formatList(supported)} are supported by the default ESM loader`;
|
|
if (isWindows && url.protocol.length === 2) {
|
|
msg +=
|
|
'. On Windows, absolute paths must be valid file:// URLs';
|
|
}
|
|
msg += `. Received protocol '${url.protocol}'`;
|
|
return msg;
|
|
}, Error);
|
|
E('ERR_UNSUPPORTED_NODE_MODULES_TYPE_STRIPPING',
|
|
'Stripping types is currently unsupported for files under node_modules, for "%s"',
|
|
Error);
|
|
E('ERR_UNSUPPORTED_RESOLVE_REQUEST',
|
|
'Failed to resolve module specifier "%s" from "%s": Invalid relative URL or base scheme is not hierarchical.',
|
|
TypeError);
|
|
E('ERR_USE_AFTER_CLOSE', '%s was closed', Error);
|
|
|
|
// This should probably be a `TypeError`.
|
|
E('ERR_VALID_PERFORMANCE_ENTRY_TYPE',
|
|
'At least one valid performance entry type is required', Error);
|
|
E('ERR_VM_DYNAMIC_IMPORT_CALLBACK_MISSING',
|
|
'A dynamic import callback was not specified.', TypeError);
|
|
E('ERR_VM_DYNAMIC_IMPORT_CALLBACK_MISSING_FLAG',
|
|
'A dynamic import callback was invoked without --experimental-vm-modules',
|
|
TypeError);
|
|
E('ERR_VM_MODULE_ALREADY_LINKED', 'Module has already been linked', Error);
|
|
E('ERR_VM_MODULE_CANNOT_CREATE_CACHED_DATA',
|
|
'Cached data cannot be created for a module which has been evaluated', Error);
|
|
E('ERR_VM_MODULE_DIFFERENT_CONTEXT',
|
|
'Linked modules must use the same context', Error);
|
|
E('ERR_VM_MODULE_LINK_FAILURE', function(message, cause) {
|
|
this.cause = cause;
|
|
return message;
|
|
}, Error);
|
|
E('ERR_VM_MODULE_NOT_MODULE',
|
|
'Provided module is not an instance of Module', Error);
|
|
E('ERR_VM_MODULE_STATUS', 'Module status %s', Error);
|
|
E('ERR_WASI_ALREADY_STARTED', 'WASI instance has already started', Error);
|
|
E('ERR_WEBASSEMBLY_RESPONSE', 'WebAssembly response %s', TypeError);
|
|
E('ERR_WORKER_INIT_FAILED', 'Worker initialization failure: %s', Error);
|
|
E('ERR_WORKER_INVALID_EXEC_ARGV', (errors, msg = 'invalid execArgv flags') =>
|
|
`Initiated Worker with ${msg}: ${ArrayPrototypeJoin(errors, ', ')}`,
|
|
Error);
|
|
E('ERR_WORKER_MESSAGING_ERRORED', 'The destination thread threw an error while processing the message', Error);
|
|
E('ERR_WORKER_MESSAGING_FAILED', 'Cannot find the destination thread or listener', Error);
|
|
E('ERR_WORKER_MESSAGING_SAME_THREAD', 'Cannot sent a message to the same thread', Error);
|
|
E('ERR_WORKER_MESSAGING_TIMEOUT', 'Sending a message to another thread timed out', Error);
|
|
E('ERR_WORKER_NOT_RUNNING', 'Worker instance not running', Error);
|
|
E('ERR_WORKER_OUT_OF_MEMORY',
|
|
'Worker terminated due to reaching memory limit: %s', Error);
|
|
E('ERR_WORKER_PATH', (filename) =>
|
|
'The worker script or module filename must be an absolute path or a ' +
|
|
'relative path starting with \'./\' or \'../\'.' +
|
|
(StringPrototypeStartsWith(filename, 'file://') ?
|
|
' Wrap file:// URLs with `new URL`.' : ''
|
|
) +
|
|
(StringPrototypeStartsWith(filename, 'data:text/javascript') ?
|
|
' Wrap data: URLs with `new URL`.' : ''
|
|
) +
|
|
` Received "${filename}"`,
|
|
TypeError);
|
|
E('ERR_WORKER_UNSERIALIZABLE_ERROR',
|
|
'Serializing an uncaught exception failed', Error);
|
|
E('ERR_WORKER_UNSUPPORTED_OPERATION',
|
|
'%s is not supported in workers', TypeError);
|