mirror of https://github.com/nodejs/node.git
util: refactor util module
* refactor util exports * early capture of prototype methods * use template strings and args consistently PR-URL: https://github.com/nodejs/node/pull/13803 Reviewed-By: Alexey Orlenko <eaglexrlnk@gmail.com> Reviewed-By: Colin Ihrig <cjihrig@gmail.com>
This commit is contained in:
parent
4d1e0862ce
commit
b1355ba6fa
289
lib/util.js
289
lib/util.js
|
@ -21,13 +21,35 @@
|
|||
|
||||
'use strict';
|
||||
|
||||
const uv = process.binding('uv');
|
||||
const Buffer = require('buffer').Buffer;
|
||||
const internalUtil = require('internal/util');
|
||||
const binding = process.binding('util');
|
||||
const errors = require('internal/errors');
|
||||
|
||||
const isError = internalUtil.isError;
|
||||
const { errname } = process.binding('uv');
|
||||
|
||||
const {
|
||||
getPromiseDetails,
|
||||
getProxyDetails,
|
||||
isAnyArrayBuffer,
|
||||
isDataView,
|
||||
isExternal,
|
||||
isMap,
|
||||
isMapIterator,
|
||||
isPromise,
|
||||
isSet,
|
||||
isSetIterator,
|
||||
isTypedArray,
|
||||
isRegExp: _isRegExp,
|
||||
isDate: _isDate,
|
||||
kPending,
|
||||
kRejected,
|
||||
} = process.binding('util');
|
||||
|
||||
const {
|
||||
customInspectSymbol,
|
||||
deprecate,
|
||||
getConstructorOf,
|
||||
isError,
|
||||
promisify
|
||||
} = require('internal/util');
|
||||
|
||||
const inspectDefaultOptions = Object.seal({
|
||||
showHidden: false,
|
||||
|
@ -41,6 +63,12 @@ const inspectDefaultOptions = Object.seal({
|
|||
|
||||
const numbersOnlyRE = /^\d+$/;
|
||||
|
||||
const objectHasOwnProperty = Object.prototype.hasOwnProperty;
|
||||
const propertyIsEnumerable = Object.prototype.propertyIsEnumerable;
|
||||
const regExpToString = RegExp.prototype.toString;
|
||||
const dateToISOString = Date.prototype.toISOString;
|
||||
const errorToString = Error.prototype.toString;
|
||||
|
||||
var CIRCULAR_ERROR_MESSAGE;
|
||||
var Debug;
|
||||
|
||||
|
@ -62,7 +90,7 @@ function tryStringify(arg) {
|
|||
}
|
||||
}
|
||||
|
||||
exports.format = function(f) {
|
||||
function format(f) {
|
||||
if (typeof f !== 'string') {
|
||||
const objects = new Array(arguments.length);
|
||||
for (var index = 0; index < arguments.length; index++) {
|
||||
|
@ -132,21 +160,19 @@ exports.format = function(f) {
|
|||
while (a < arguments.length) {
|
||||
const x = arguments[a++];
|
||||
if (x === null || (typeof x !== 'object' && typeof x !== 'symbol')) {
|
||||
str += ' ' + x;
|
||||
str += ` ${x}`;
|
||||
} else {
|
||||
str += ' ' + inspect(x);
|
||||
str += ` ${inspect(x)}`;
|
||||
}
|
||||
}
|
||||
return str;
|
||||
};
|
||||
|
||||
|
||||
exports.deprecate = internalUtil.deprecate;
|
||||
}
|
||||
|
||||
|
||||
var debugs = {};
|
||||
var debugEnviron;
|
||||
exports.debuglog = function(set) {
|
||||
|
||||
function debuglog(set) {
|
||||
if (debugEnviron === undefined) {
|
||||
debugEnviron = new Set(
|
||||
(process.env.NODE_DEBUG || '').split(',').map((s) => s.toUpperCase()));
|
||||
|
@ -164,7 +190,7 @@ exports.debuglog = function(set) {
|
|||
}
|
||||
}
|
||||
return debugs[set];
|
||||
};
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
|
@ -198,6 +224,7 @@ function inspect(obj, opts) {
|
|||
if (ctx.maxArrayLength === null) ctx.maxArrayLength = Infinity;
|
||||
return formatValue(ctx, obj, ctx.depth);
|
||||
}
|
||||
inspect.custom = customInspectSymbol;
|
||||
|
||||
Object.defineProperty(inspect, 'defaultOptions', {
|
||||
get: function() {
|
||||
|
@ -243,11 +270,6 @@ inspect.styles = Object.assign(Object.create(null), {
|
|||
'regexp': 'red'
|
||||
});
|
||||
|
||||
const customInspectSymbol = internalUtil.customInspectSymbol;
|
||||
|
||||
exports.inspect = inspect;
|
||||
exports.inspect.custom = customInspectSymbol;
|
||||
|
||||
function stylizeWithColor(str, styleType) {
|
||||
var style = inspect.styles[styleType];
|
||||
|
||||
|
@ -304,7 +326,7 @@ function formatValue(ctx, value, recurseTimes) {
|
|||
// Otherwise, it'll return an array. The first item
|
||||
// is the target, the second item is the handler.
|
||||
// We ignore (and do not return) the Proxy isRevoked property.
|
||||
proxy = binding.getProxyDetails(value);
|
||||
proxy = getProxyDetails(value);
|
||||
if (proxy) {
|
||||
// We know for a fact that this isn't a Proxy.
|
||||
// Mark it as having already been evaluated.
|
||||
|
@ -322,7 +344,7 @@ function formatValue(ctx, value, recurseTimes) {
|
|||
proxyCache.set(value, proxy);
|
||||
}
|
||||
if (proxy) {
|
||||
return 'Proxy ' + formatValue(ctx, proxy, recurseTimes);
|
||||
return `Proxy ${formatValue(ctx, proxy, recurseTimes)}`;
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -360,7 +382,7 @@ function formatValue(ctx, value, recurseTimes) {
|
|||
var visibleKeys = arrayToHash(keys);
|
||||
const symbolKeys = Object.getOwnPropertySymbols(value);
|
||||
const enumSymbolKeys = symbolKeys
|
||||
.filter((key) => Object.prototype.propertyIsEnumerable.call(value, key));
|
||||
.filter((key) => propertyIsEnumerable.call(value, key));
|
||||
keys = keys.concat(enumSymbolKeys);
|
||||
|
||||
if (ctx.showHidden) {
|
||||
|
@ -393,7 +415,7 @@ function formatValue(ctx, value, recurseTimes) {
|
|||
});
|
||||
}
|
||||
|
||||
var constructor = internalUtil.getConstructorOf(value);
|
||||
var constructor = getConstructorOf(value);
|
||||
|
||||
// Some type of object without properties can be shortcutted.
|
||||
if (keys.length === 0) {
|
||||
|
@ -403,13 +425,13 @@ function formatValue(ctx, value, recurseTimes) {
|
|||
`[${ctorName}${value.name ? `: ${value.name}` : ''}]`, 'special');
|
||||
}
|
||||
if (isRegExp(value)) {
|
||||
return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp');
|
||||
return ctx.stylize(regExpToString.call(value), 'regexp');
|
||||
}
|
||||
if (isDate(value)) {
|
||||
if (Number.isNaN(value.getTime())) {
|
||||
return ctx.stylize(value.toString(), 'date');
|
||||
} else {
|
||||
return ctx.stylize(Date.prototype.toISOString.call(value), 'date');
|
||||
return ctx.stylize(dateToISOString.call(value), 'date');
|
||||
}
|
||||
}
|
||||
if (isError(value)) {
|
||||
|
@ -435,11 +457,11 @@ function formatValue(ctx, value, recurseTimes) {
|
|||
// Fast path for ArrayBuffer and SharedArrayBuffer.
|
||||
// Can't do the same for DataView because it has a non-primitive
|
||||
// .buffer property that we need to recurse for.
|
||||
if (binding.isAnyArrayBuffer(value)) {
|
||||
if (isAnyArrayBuffer(value)) {
|
||||
return `${constructor.name}` +
|
||||
` { byteLength: ${formatNumber(ctx, value.byteLength)} }`;
|
||||
}
|
||||
if (binding.isExternal(value)) {
|
||||
if (isExternal(value)) {
|
||||
return ctx.stylize('[External]', 'special');
|
||||
}
|
||||
}
|
||||
|
@ -461,7 +483,7 @@ function formatValue(ctx, value, recurseTimes) {
|
|||
braces = ['[', ']'];
|
||||
empty = value.length === 0;
|
||||
formatter = formatArray;
|
||||
} else if (binding.isSet(value)) {
|
||||
} else if (isSet(value)) {
|
||||
braces = ['{', '}'];
|
||||
// With `showHidden`, `length` will display as a hidden property for
|
||||
// arrays. For consistency's sake, do the same for `size`, even though this
|
||||
|
@ -470,25 +492,25 @@ function formatValue(ctx, value, recurseTimes) {
|
|||
keys.unshift('size');
|
||||
empty = value.size === 0;
|
||||
formatter = formatSet;
|
||||
} else if (binding.isMap(value)) {
|
||||
} else if (isMap(value)) {
|
||||
braces = ['{', '}'];
|
||||
// Ditto.
|
||||
if (ctx.showHidden)
|
||||
keys.unshift('size');
|
||||
empty = value.size === 0;
|
||||
formatter = formatMap;
|
||||
} else if (binding.isAnyArrayBuffer(value)) {
|
||||
} else if (isAnyArrayBuffer(value)) {
|
||||
braces = ['{', '}'];
|
||||
keys.unshift('byteLength');
|
||||
visibleKeys.byteLength = true;
|
||||
} else if (binding.isDataView(value)) {
|
||||
} else if (isDataView(value)) {
|
||||
braces = ['{', '}'];
|
||||
// .buffer goes last, it's not a primitive like the others.
|
||||
keys.unshift('byteLength', 'byteOffset', 'buffer');
|
||||
visibleKeys.byteLength = true;
|
||||
visibleKeys.byteOffset = true;
|
||||
visibleKeys.buffer = true;
|
||||
} else if (binding.isTypedArray(value)) {
|
||||
} else if (isTypedArray(value)) {
|
||||
braces = ['[', ']'];
|
||||
formatter = formatTypedArray;
|
||||
if (ctx.showHidden) {
|
||||
|
@ -499,15 +521,15 @@ function formatValue(ctx, value, recurseTimes) {
|
|||
'byteOffset',
|
||||
'buffer');
|
||||
}
|
||||
} else if (binding.isPromise(value)) {
|
||||
} else if (isPromise(value)) {
|
||||
braces = ['{', '}'];
|
||||
formatter = formatPromise;
|
||||
} else if (binding.isMapIterator(value)) {
|
||||
} else if (isMapIterator(value)) {
|
||||
constructor = { name: 'MapIterator' };
|
||||
braces = ['{', '}'];
|
||||
empty = false;
|
||||
formatter = formatCollectionIterator;
|
||||
} else if (binding.isSetIterator(value)) {
|
||||
} else if (isSetIterator(value)) {
|
||||
constructor = { name: 'SetIterator' };
|
||||
braces = ['{', '}'];
|
||||
empty = false;
|
||||
|
@ -530,17 +552,17 @@ function formatValue(ctx, value, recurseTimes) {
|
|||
|
||||
// Make RegExps say that they are RegExps
|
||||
if (isRegExp(value)) {
|
||||
base = ' ' + RegExp.prototype.toString.call(value);
|
||||
base = ` ${regExpToString.call(value)}`;
|
||||
}
|
||||
|
||||
// Make dates with properties first say the date
|
||||
if (isDate(value)) {
|
||||
base = ' ' + Date.prototype.toISOString.call(value);
|
||||
base = ` ${dateToISOString.call(value)}`;
|
||||
}
|
||||
|
||||
// Make error with message first say the error
|
||||
if (isError(value)) {
|
||||
base = ' ' + formatError(value);
|
||||
base = ` ${formatError(value)}`;
|
||||
}
|
||||
|
||||
// Make boxed primitive Strings look like such
|
||||
|
@ -566,12 +588,12 @@ function formatValue(ctx, value, recurseTimes) {
|
|||
braces[0] = `${constructor.name} ${braces[0]}`;
|
||||
|
||||
if (empty === true) {
|
||||
return braces[0] + base + braces[1];
|
||||
return `${braces[0]}${base}${braces[1]}`;
|
||||
}
|
||||
|
||||
if (recurseTimes < 0) {
|
||||
if (isRegExp(value)) {
|
||||
return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp');
|
||||
return ctx.stylize(regExpToString.call(value), 'regexp');
|
||||
} else if (Array.isArray(value)) {
|
||||
return ctx.stylize('[Array]', 'special');
|
||||
} else {
|
||||
|
@ -593,7 +615,7 @@ function formatNumber(ctx, value) {
|
|||
// Format -0 as '-0'. Strict equality won't distinguish 0 from -0.
|
||||
if (Object.is(value, -0))
|
||||
return ctx.stylize('-0', 'number');
|
||||
return ctx.stylize('' + value, 'number');
|
||||
return ctx.stylize(`${value}`, 'number');
|
||||
}
|
||||
|
||||
|
||||
|
@ -608,18 +630,16 @@ function formatPrimitive(ctx, value) {
|
|||
var type = typeof value;
|
||||
|
||||
if (type === 'string') {
|
||||
var simple = '\'' +
|
||||
JSON.stringify(value)
|
||||
var simple = JSON.stringify(value)
|
||||
.replace(/^"|"$/g, '')
|
||||
.replace(/'/g, "\\'")
|
||||
.replace(/\\"/g, '"') +
|
||||
'\'';
|
||||
return ctx.stylize(simple, 'string');
|
||||
.replace(/\\"/g, '"');
|
||||
return ctx.stylize(`'${simple}'`, 'string');
|
||||
}
|
||||
if (type === 'number')
|
||||
return formatNumber(ctx, value);
|
||||
if (type === 'boolean')
|
||||
return ctx.stylize('' + value, 'boolean');
|
||||
return ctx.stylize(`${value}`, 'boolean');
|
||||
// es6 symbol primitive
|
||||
if (type === 'symbol')
|
||||
return ctx.stylize(value.toString(), 'symbol');
|
||||
|
@ -636,7 +656,7 @@ function formatPrimitiveNoColor(ctx, value) {
|
|||
|
||||
|
||||
function formatError(value) {
|
||||
return value.stack || `[${Error.prototype.toString.call(value)}]`;
|
||||
return value.stack || `[${errorToString.call(value)}]`;
|
||||
}
|
||||
|
||||
|
||||
|
@ -747,15 +767,15 @@ function formatCollectionIterator(ctx, value, recurseTimes, visibleKeys, keys) {
|
|||
|
||||
function formatPromise(ctx, value, recurseTimes, visibleKeys, keys) {
|
||||
const output = [];
|
||||
const [state, result] = binding.getPromiseDetails(value);
|
||||
const [state, result] = getPromiseDetails(value);
|
||||
|
||||
if (state === binding.kPending) {
|
||||
if (state === kPending) {
|
||||
output.push('<pending>');
|
||||
} else {
|
||||
var nextRecurseTimes = recurseTimes === null ? null : recurseTimes - 1;
|
||||
var str = formatValue(ctx, result, nextRecurseTimes);
|
||||
if (state === binding.kRejected) {
|
||||
output.push('<rejected> ' + str);
|
||||
if (state === kRejected) {
|
||||
output.push(`<rejected> ${str}`);
|
||||
} else {
|
||||
output.push(str);
|
||||
}
|
||||
|
@ -811,7 +831,7 @@ function formatProperty(ctx, value, recurseTimes, visibleKeys, key, array) {
|
|||
if (array && numbersOnlyRE.test(key)) {
|
||||
return str;
|
||||
}
|
||||
name = JSON.stringify('' + key);
|
||||
name = JSON.stringify(`${key}`);
|
||||
if (/^"[a-zA-Z_][a-zA-Z_0-9]*"$/.test(name)) {
|
||||
name = name.substr(1, name.length - 2);
|
||||
name = ctx.stylize(name, 'name');
|
||||
|
@ -838,85 +858,64 @@ function reduceToSingleString(output, base, braces, breakLength) {
|
|||
// If the opening "brace" is too large, like in the case of "Set {",
|
||||
// we need to force the first item to be on the next line or the
|
||||
// items will not line up correctly.
|
||||
(base === '' && braces[0].length === 1 ? '' : base + '\n ') +
|
||||
(base === '' && braces[0].length === 1 ? '' : `${base}\n `) +
|
||||
` ${output.join(',\n ')} ${braces[1]}`;
|
||||
}
|
||||
|
||||
return `${braces[0]}${base} ${output.join(', ')} ${braces[1]}`;
|
||||
}
|
||||
|
||||
|
||||
// NOTE: These type checking functions intentionally don't use `instanceof`
|
||||
// because it is fragile and can be easily faked with `Object.create()`.
|
||||
exports.isArray = Array.isArray;
|
||||
|
||||
function isBoolean(arg) {
|
||||
return typeof arg === 'boolean';
|
||||
}
|
||||
exports.isBoolean = isBoolean;
|
||||
|
||||
function isNull(arg) {
|
||||
return arg === null;
|
||||
}
|
||||
exports.isNull = isNull;
|
||||
|
||||
function isNullOrUndefined(arg) {
|
||||
return arg === null || arg === undefined;
|
||||
}
|
||||
exports.isNullOrUndefined = isNullOrUndefined;
|
||||
|
||||
function isNumber(arg) {
|
||||
return typeof arg === 'number';
|
||||
}
|
||||
exports.isNumber = isNumber;
|
||||
|
||||
function isString(arg) {
|
||||
return typeof arg === 'string';
|
||||
}
|
||||
exports.isString = isString;
|
||||
|
||||
function isSymbol(arg) {
|
||||
return typeof arg === 'symbol';
|
||||
}
|
||||
exports.isSymbol = isSymbol;
|
||||
|
||||
function isUndefined(arg) {
|
||||
return arg === undefined;
|
||||
}
|
||||
exports.isUndefined = isUndefined;
|
||||
|
||||
function isRegExp(re) {
|
||||
return binding.isRegExp(re);
|
||||
return _isRegExp(re);
|
||||
}
|
||||
exports.isRegExp = isRegExp;
|
||||
|
||||
function isObject(arg) {
|
||||
return arg !== null && typeof arg === 'object';
|
||||
}
|
||||
exports.isObject = isObject;
|
||||
|
||||
function isDate(d) {
|
||||
return binding.isDate(d);
|
||||
return _isDate(d);
|
||||
}
|
||||
exports.isDate = isDate;
|
||||
|
||||
exports.isError = isError;
|
||||
|
||||
function isFunction(arg) {
|
||||
return typeof arg === 'function';
|
||||
}
|
||||
exports.isFunction = isFunction;
|
||||
|
||||
function isPrimitive(arg) {
|
||||
return arg === null ||
|
||||
typeof arg !== 'object' && typeof arg !== 'function';
|
||||
}
|
||||
exports.isPrimitive = isPrimitive;
|
||||
|
||||
exports.isBuffer = Buffer.isBuffer;
|
||||
|
||||
function pad(n) {
|
||||
return n < 10 ? '0' + n.toString(10) : n.toString(10);
|
||||
return n < 10 ? `0${n.toString(10)}` : n.toString(10);
|
||||
}
|
||||
|
||||
|
||||
|
@ -934,9 +933,9 @@ function timestamp() {
|
|||
|
||||
|
||||
// log is just a thin wrapper to console.log that prepends a timestamp
|
||||
exports.log = function() {
|
||||
function log() {
|
||||
console.log('%s - %s', timestamp(), exports.format.apply(exports, arguments));
|
||||
};
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
|
@ -954,7 +953,7 @@ exports.log = function() {
|
|||
* @throws {TypeError} Will error if either constructor is null, or if
|
||||
* the super constructor lacks a prototype.
|
||||
*/
|
||||
exports.inherits = function(ctor, superCtor) {
|
||||
function inherits(ctor, superCtor) {
|
||||
|
||||
if (ctor === undefined || ctor === null)
|
||||
throw new errors.TypeError('ERR_INVALID_ARG_TYPE', 'ctor', 'function');
|
||||
|
@ -968,9 +967,9 @@ exports.inherits = function(ctor, superCtor) {
|
|||
}
|
||||
ctor.super_ = superCtor;
|
||||
Object.setPrototypeOf(ctor.prototype, superCtor.prototype);
|
||||
};
|
||||
}
|
||||
|
||||
exports._extend = function(target, source) {
|
||||
function _extend(target, source) {
|
||||
// Don't do anything if source isn't an object
|
||||
if (source === null || typeof source !== 'object') return target;
|
||||
|
||||
|
@ -980,59 +979,55 @@ exports._extend = function(target, source) {
|
|||
target[keys[i]] = source[keys[i]];
|
||||
}
|
||||
return target;
|
||||
};
|
||||
}
|
||||
|
||||
function hasOwnProperty(obj, prop) {
|
||||
return Object.prototype.hasOwnProperty.call(obj, prop);
|
||||
return objectHasOwnProperty.call(obj, prop);
|
||||
}
|
||||
|
||||
|
||||
// Deprecated old stuff.
|
||||
|
||||
exports.print = internalUtil.deprecate(function() {
|
||||
for (var i = 0, len = arguments.length; i < len; ++i) {
|
||||
process.stdout.write(String(arguments[i]));
|
||||
function print(...args) {
|
||||
for (var i = 0, len = args.length; i < len; ++i) {
|
||||
process.stdout.write(String(args[i]));
|
||||
}
|
||||
}, 'util.print is deprecated. Use console.log instead.', 'DEP0026');
|
||||
}
|
||||
|
||||
|
||||
exports.puts = internalUtil.deprecate(function() {
|
||||
for (var i = 0, len = arguments.length; i < len; ++i) {
|
||||
process.stdout.write(arguments[i] + '\n');
|
||||
function puts(...args) {
|
||||
for (var i = 0, len = args.length; i < len; ++i) {
|
||||
process.stdout.write(`${args[i]}\n`);
|
||||
}
|
||||
}, 'util.puts is deprecated. Use console.log instead.', 'DEP0027');
|
||||
}
|
||||
|
||||
|
||||
exports.debug = internalUtil.deprecate(function(x) {
|
||||
function debug(x) {
|
||||
process.stderr.write(`DEBUG: ${x}\n`);
|
||||
}, 'util.debug is deprecated. Use console.error instead.', 'DEP0028');
|
||||
}
|
||||
|
||||
|
||||
exports.error = internalUtil.deprecate(function(x) {
|
||||
for (var i = 0, len = arguments.length; i < len; ++i) {
|
||||
process.stderr.write(arguments[i] + '\n');
|
||||
function error(...args) {
|
||||
for (var i = 0, len = args.length; i < len; ++i) {
|
||||
process.stderr.write(`${args[i]}\n`);
|
||||
}
|
||||
}, 'util.error is deprecated. Use console.error instead.', 'DEP0029');
|
||||
}
|
||||
|
||||
|
||||
exports._errnoException = function(err, syscall, original) {
|
||||
var errname = uv.errname(err);
|
||||
var message = `${syscall} ${errname}`;
|
||||
function _errnoException(err, syscall, original) {
|
||||
var name = errname(err);
|
||||
var message = `${syscall} ${name}`;
|
||||
if (original)
|
||||
message += ' ' + original;
|
||||
message += ` ${original}`;
|
||||
var e = new Error(message);
|
||||
e.code = errname;
|
||||
e.errno = errname;
|
||||
e.code = name;
|
||||
e.errno = name;
|
||||
e.syscall = syscall;
|
||||
return e;
|
||||
};
|
||||
}
|
||||
|
||||
|
||||
exports._exceptionWithHostPort = function(err,
|
||||
syscall,
|
||||
address,
|
||||
port,
|
||||
additional) {
|
||||
function _exceptionWithHostPort(err,
|
||||
syscall,
|
||||
address,
|
||||
port,
|
||||
additional) {
|
||||
var details;
|
||||
if (port && port > 0) {
|
||||
details = `${address}:${port}`;
|
||||
|
@ -1049,14 +1044,12 @@ exports._exceptionWithHostPort = function(err,
|
|||
ex.port = port;
|
||||
}
|
||||
return ex;
|
||||
};
|
||||
}
|
||||
|
||||
// process.versions needs a custom function as some values are lazy-evaluated.
|
||||
process.versions[exports.inspect.custom] =
|
||||
process.versions[inspect.custom] =
|
||||
() => exports.format(JSON.parse(JSON.stringify(process.versions)));
|
||||
|
||||
exports.promisify = internalUtil.promisify;
|
||||
|
||||
function callbackifyOnRejected(reason, cb) {
|
||||
// `!reason` guard inspired by bluebird (Ref: https://goo.gl/t5IS6M).
|
||||
// Because `null` is a special error value in callbacks which means "no error
|
||||
|
@ -1105,4 +1098,60 @@ function callbackify(original) {
|
|||
return callbackified;
|
||||
}
|
||||
|
||||
exports.callbackify = callbackify;
|
||||
// Keep the `exports =` so that various functions can still be monkeypatched
|
||||
module.exports = exports = {
|
||||
_errnoException,
|
||||
_exceptionWithHostPort,
|
||||
_extend,
|
||||
callbackify,
|
||||
debuglog,
|
||||
deprecate,
|
||||
format,
|
||||
inherits,
|
||||
inspect,
|
||||
isArray: Array.isArray,
|
||||
isBoolean,
|
||||
isNull,
|
||||
isNullOrUndefined,
|
||||
isNumber,
|
||||
isString,
|
||||
isSymbol,
|
||||
isUndefined,
|
||||
isRegExp,
|
||||
isObject,
|
||||
isDate,
|
||||
isError,
|
||||
isFunction,
|
||||
isPrimitive,
|
||||
log,
|
||||
promisify,
|
||||
|
||||
// Deprecated Old Stuff
|
||||
debug: deprecate(debug,
|
||||
'util.debug is deprecated. Use console.error instead.',
|
||||
'DEP0028'),
|
||||
error: deprecate(error,
|
||||
'util.error is deprecated. Use console.error instead.',
|
||||
'DEP0029'),
|
||||
print: deprecate(print,
|
||||
'util.print is deprecated. Use console.log instead.',
|
||||
'DEP0026'),
|
||||
puts: deprecate(puts,
|
||||
'util.puts is deprecated. Use console.log instead.',
|
||||
'DEP0027')
|
||||
};
|
||||
|
||||
// Avoid a circular dependency
|
||||
var isBuffer;
|
||||
Object.defineProperty(exports, 'isBuffer', {
|
||||
configurable: true,
|
||||
enumerable: true,
|
||||
get() {
|
||||
if (!isBuffer)
|
||||
isBuffer = require('buffer').Buffer.isBuffer;
|
||||
return isBuffer;
|
||||
},
|
||||
set(val) {
|
||||
isBuffer = val;
|
||||
}
|
||||
});
|
||||
|
|
Loading…
Reference in New Issue