101
									
								
								packages/nodejs/src/fs/index.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										101
									
								
								packages/nodejs/src/fs/index.ts
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,101 @@
 | 
			
		||||
import '@ms/nashorn'
 | 
			
		||||
import { URL } from "url";
 | 
			
		||||
 | 
			
		||||
const Path = Java.type("java.nio.file.Path");
 | 
			
		||||
const JavaString = Java.type("java.lang.String");
 | 
			
		||||
const File = Java.type("java.io.File");
 | 
			
		||||
const Files = Java.type("java.nio.file.Files");
 | 
			
		||||
const Collector = Java.type("java.util.stream.Collector")
 | 
			
		||||
const separatorChar = File.separatorChar;
 | 
			
		||||
const StandardCopyOption = Java.type("java.nio.file.StandardCopyOption");
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Valid types for path values in "fs".
 | 
			
		||||
 */
 | 
			
		||||
type PathLike = string | Buffer | URL;
 | 
			
		||||
 | 
			
		||||
function javaFile(...opts: any[]) {
 | 
			
		||||
    if (!opts[0]) {
 | 
			
		||||
        console.warn("文件名称不得为 undefined 或者 null !");
 | 
			
		||||
    }
 | 
			
		||||
    switch (opts.length) {
 | 
			
		||||
        case 1:
 | 
			
		||||
            var f = opts[0];
 | 
			
		||||
            if (f instanceof File) {
 | 
			
		||||
                return f;
 | 
			
		||||
            }
 | 
			
		||||
            if (typeof f === "string") {
 | 
			
		||||
                return new File(f);
 | 
			
		||||
            }
 | 
			
		||||
            if (f instanceof Path) {
 | 
			
		||||
                return f.toFile();
 | 
			
		||||
            }
 | 
			
		||||
            break;
 | 
			
		||||
        default:
 | 
			
		||||
            return new File(javaFile(opts[0]), opts[1]);
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function renameSync(oldPath: PathLike, newPath: PathLike): void {
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
export function truncateSync() {
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
export function chownSync() {
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
export function chmodSync() {
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
export function statSync() {
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
export function symlinkSync() {
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
export function readlinkSync() {
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
export function realpathSync() {
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
export function unlinkSync() {
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
export function rmdirSync() {
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
export function mkdirSync() {
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
export function mkdtempSync() {
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
export function readdirSync() {
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
export function readFileSync() {
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
export function writeFileSync() {
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
export function appendFileSync() {
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
export function watchFile() {
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
export function unwatchFile() {
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
export function existsSync() {
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
export function accessSync() {
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
export function copyFileSync() {
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
@@ -1,51 +1 @@
 | 
			
		||||
/// <reference types="@ms/nashorn" />
 | 
			
		||||
import * as yaml from 'js-yaml'
 | 
			
		||||
 | 
			
		||||
const File = Java.type("java.io.File");
 | 
			
		||||
const separatorChar = File.separatorChar;
 | 
			
		||||
 | 
			
		||||
let langMap = {};
 | 
			
		||||
let fallbackMap = {};
 | 
			
		||||
 | 
			
		||||
type TranslateParam = { [key: string]: any }
 | 
			
		||||
 | 
			
		||||
function translate(name: string, param?: TranslateParam) {
 | 
			
		||||
    let langText: string = langMap[name] || fallbackMap[name];
 | 
			
		||||
    if (!langText) { return '[WARN] @ms/i18n miss lang translate: ' + name }
 | 
			
		||||
    for (const key in param) {
 | 
			
		||||
        langText = langText.replace("{" + key + "}", param[key])
 | 
			
		||||
    }
 | 
			
		||||
    return langText;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function initialize(lang: string = 'zh_cn', fallback: string = 'zh_cn') {
 | 
			
		||||
    langMap = readYamlFile(root, lang) || readYamlFile(concat(__dirname, '..'), lang)
 | 
			
		||||
    fallbackMap = readYamlFile(root, fallback) || readYamlFile(concat(__dirname, '..'), fallback)
 | 
			
		||||
    console.i18n = function i18n(name: string, param?: TranslateParam) {
 | 
			
		||||
        console.log(translate(name, param))
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function readYamlFile(dir: string, name: string) {
 | 
			
		||||
    let langFile = concat(dir, 'languages', name + '.yml');
 | 
			
		||||
    return exists(langFile) && yaml.safeLoad(base.read(langFile))
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function concat(...args: string[]) {
 | 
			
		||||
    return args.join(separatorChar)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function exists(path: string) {
 | 
			
		||||
    return new File(path).exists()
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
declare global {
 | 
			
		||||
    interface Console {
 | 
			
		||||
        i18n(name: string, param?: TranslateParam);
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export default {
 | 
			
		||||
    initialize,
 | 
			
		||||
    translate
 | 
			
		||||
};
 | 
			
		||||
export { }
 | 
			
		||||
							
								
								
									
										626
									
								
								packages/nodejs/src/path/index.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										626
									
								
								packages/nodejs/src/path/index.ts
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,626 @@
 | 
			
		||||
// Copyright Joyent, Inc. and other Node contributors.
 | 
			
		||||
//
 | 
			
		||||
// Permission is hereby granted, free of charge, to any person obtaining a
 | 
			
		||||
// copy of this software and associated documentation files (the
 | 
			
		||||
// "Software"), to deal in the Software without restriction, including
 | 
			
		||||
// without limitation the rights to use, copy, modify, merge, publish,
 | 
			
		||||
// distribute, sublicense, and/or sell copies of the Software, and to permit
 | 
			
		||||
// persons to whom the Software is furnished to do so, subject to the
 | 
			
		||||
// following conditions:
 | 
			
		||||
//
 | 
			
		||||
// The above copyright notice and this permission notice shall be included
 | 
			
		||||
// in all copies or substantial portions of the Software.
 | 
			
		||||
//
 | 
			
		||||
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
 | 
			
		||||
// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
 | 
			
		||||
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
 | 
			
		||||
// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
 | 
			
		||||
// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
 | 
			
		||||
// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
 | 
			
		||||
// USE OR OTHER DEALINGS IN THE SOFTWARE.
 | 
			
		||||
 | 
			
		||||
'use strict';
 | 
			
		||||
 | 
			
		||||
// @ts-ignore
 | 
			
		||||
var isWindows = java.lang.System.getProperties().getProperty("os.name").toUpperCase().indexOf("WINDOWS") != -1;
 | 
			
		||||
// @ts-ignore
 | 
			
		||||
var util = require('util');
 | 
			
		||||
 | 
			
		||||
// resolves . and .. elements in a path array with directory names there
 | 
			
		||||
// must be no slashes or device names (c:\) in the array
 | 
			
		||||
// (so also no leading and trailing slashes - it does not distinguish
 | 
			
		||||
// relative and absolute paths)
 | 
			
		||||
function normalizeArray(parts, allowAboveRoot) {
 | 
			
		||||
    var res = [];
 | 
			
		||||
    for (var i = 0; i < parts.length; i++) {
 | 
			
		||||
        var p = parts[i];
 | 
			
		||||
 | 
			
		||||
        // ignore empty parts
 | 
			
		||||
        if (!p || p === '.')
 | 
			
		||||
            continue;
 | 
			
		||||
 | 
			
		||||
        if (p === '..') {
 | 
			
		||||
            if (res.length && res[res.length - 1] !== '..') {
 | 
			
		||||
                res.pop();
 | 
			
		||||
            } else if (allowAboveRoot) {
 | 
			
		||||
                res.push('..');
 | 
			
		||||
            }
 | 
			
		||||
        } else {
 | 
			
		||||
            res.push(p);
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    return res;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// returns an array with empty elements removed from either end of the input
 | 
			
		||||
// array or the original array if no elements need to be removed
 | 
			
		||||
function trimArray(arr) {
 | 
			
		||||
    var lastIndex = arr.length - 1;
 | 
			
		||||
    var start = 0;
 | 
			
		||||
    for (; start <= lastIndex; start++) {
 | 
			
		||||
        if (arr[start])
 | 
			
		||||
            break;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    var end = lastIndex;
 | 
			
		||||
    for (; end >= 0; end--) {
 | 
			
		||||
        if (arr[end])
 | 
			
		||||
            break;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    if (start === 0 && end === lastIndex)
 | 
			
		||||
        return arr;
 | 
			
		||||
    if (start > end)
 | 
			
		||||
        return [];
 | 
			
		||||
    return arr.slice(start, end + 1);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Regex to split a windows path into three parts: [*, device, slash,
 | 
			
		||||
// tail] windows-only
 | 
			
		||||
var splitDeviceRe =
 | 
			
		||||
    /^([a-zA-Z]:|[\\\/]{2}[^\\\/]+[\\\/]+[^\\\/]+)?([\\\/])?([\s\S]*?)$/;
 | 
			
		||||
 | 
			
		||||
// Regex to split the tail part of the above into [*, dir, basename, ext]
 | 
			
		||||
var splitTailRe =
 | 
			
		||||
    /^([\s\S]*?)((?:\.{1,2}|[^\\\/]+?|)(\.[^.\/\\]*|))(?:[\\\/]*)$/;
 | 
			
		||||
 | 
			
		||||
var win32: any = {};
 | 
			
		||||
 | 
			
		||||
// Function to split a filename into [root, dir, basename, ext]
 | 
			
		||||
function win32SplitPath(filename) {
 | 
			
		||||
    // Separate device+slash from tail
 | 
			
		||||
    var result = splitDeviceRe.exec(filename),
 | 
			
		||||
        device = (result[1] || '') + (result[2] || ''),
 | 
			
		||||
        tail = result[3] || '';
 | 
			
		||||
    // Split the tail into dir, basename and extension
 | 
			
		||||
    var result2 = splitTailRe.exec(tail),
 | 
			
		||||
        dir = result2[1],
 | 
			
		||||
        basename = result2[2],
 | 
			
		||||
        ext = result2[3];
 | 
			
		||||
    return [device, dir, basename, ext];
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function win32StatPath(path) {
 | 
			
		||||
    var result = splitDeviceRe.exec(path),
 | 
			
		||||
        device = result[1] || '',
 | 
			
		||||
        isUnc = !!device && device[1] !== ':';
 | 
			
		||||
    return {
 | 
			
		||||
        device: device,
 | 
			
		||||
        isUnc: isUnc,
 | 
			
		||||
        isAbsolute: isUnc || !!result[2], // UNC paths are always absolute
 | 
			
		||||
        tail: result[3]
 | 
			
		||||
    };
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function normalizeUNCRoot(device) {
 | 
			
		||||
    return '\\\\' + device.replace(/^[\\\/]+/, '').replace(/[\\\/]+/g, '\\');
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// path.resolve([from ...], to)
 | 
			
		||||
win32.resolve = function () {
 | 
			
		||||
    var resolvedDevice = '',
 | 
			
		||||
        resolvedTail = '',
 | 
			
		||||
        resolvedAbsolute = false;
 | 
			
		||||
 | 
			
		||||
    for (var i = arguments.length - 1; i >= -1; i--) {
 | 
			
		||||
        var path;
 | 
			
		||||
        if (i >= 0) {
 | 
			
		||||
            path = arguments[i];
 | 
			
		||||
        } else if (!resolvedDevice) {
 | 
			
		||||
            path = process.cwd();
 | 
			
		||||
        } else {
 | 
			
		||||
            // Windows has the concept of drive-specific current working
 | 
			
		||||
            // directories. If we've resolved a drive letter but not yet an
 | 
			
		||||
            // absolute path, get cwd for that drive. We're sure the device is not
 | 
			
		||||
            // an unc path at this points, because unc paths are always absolute.
 | 
			
		||||
            path = process.env['=' + resolvedDevice];
 | 
			
		||||
            // Verify that a drive-local cwd was found and that it actually points
 | 
			
		||||
            // to our drive. If not, default to the drive's root.
 | 
			
		||||
            if (!path || path.substr(0, 3).toLowerCase() !==
 | 
			
		||||
                resolvedDevice.toLowerCase() + '\\') {
 | 
			
		||||
                path = resolvedDevice + '\\';
 | 
			
		||||
            }
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        // Skip empty and invalid entries
 | 
			
		||||
        if (!util.isString(path)) {
 | 
			
		||||
            throw new TypeError('Arguments to path.resolve must be strings');
 | 
			
		||||
        } else if (!path) {
 | 
			
		||||
            continue;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        var result = win32StatPath(path),
 | 
			
		||||
            device = result.device,
 | 
			
		||||
            isUnc = result.isUnc,
 | 
			
		||||
            isAbsolute = result.isAbsolute,
 | 
			
		||||
            tail = result.tail;
 | 
			
		||||
 | 
			
		||||
        if (device &&
 | 
			
		||||
            resolvedDevice &&
 | 
			
		||||
            device.toLowerCase() !== resolvedDevice.toLowerCase()) {
 | 
			
		||||
            // This path points to another device so it is not applicable
 | 
			
		||||
            continue;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        if (!resolvedDevice) {
 | 
			
		||||
            resolvedDevice = device;
 | 
			
		||||
        }
 | 
			
		||||
        if (!resolvedAbsolute) {
 | 
			
		||||
            resolvedTail = tail + '\\' + resolvedTail;
 | 
			
		||||
            resolvedAbsolute = isAbsolute;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        if (resolvedDevice && resolvedAbsolute) {
 | 
			
		||||
            break;
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    // Convert slashes to backslashes when `resolvedDevice` points to an UNC
 | 
			
		||||
    // root. Also squash multiple slashes into a single one where appropriate.
 | 
			
		||||
    if (isUnc) {
 | 
			
		||||
        resolvedDevice = normalizeUNCRoot(resolvedDevice);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    // At this point the path should be resolved to a full absolute path,
 | 
			
		||||
    // but handle relative paths to be safe (might happen when process.cwd()
 | 
			
		||||
    // fails)
 | 
			
		||||
 | 
			
		||||
    // Normalize the tail path
 | 
			
		||||
    resolvedTail = normalizeArray(resolvedTail.split(/[\\\/]+/),
 | 
			
		||||
        !resolvedAbsolute).join('\\');
 | 
			
		||||
 | 
			
		||||
    return (resolvedDevice + (resolvedAbsolute ? '\\' : '') + resolvedTail) ||
 | 
			
		||||
        '.';
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
win32.normalize = function (path) {
 | 
			
		||||
    var result = win32StatPath(path),
 | 
			
		||||
        device = result.device,
 | 
			
		||||
        isUnc = result.isUnc,
 | 
			
		||||
        isAbsolute = result.isAbsolute,
 | 
			
		||||
        tail = result.tail,
 | 
			
		||||
        trailingSlash = /[\\\/]$/.test(tail);
 | 
			
		||||
 | 
			
		||||
    // Normalize the tail path
 | 
			
		||||
    tail = normalizeArray(tail.split(/[\\\/]+/), !isAbsolute).join('\\');
 | 
			
		||||
 | 
			
		||||
    if (!tail && !isAbsolute) {
 | 
			
		||||
        tail = '.';
 | 
			
		||||
    }
 | 
			
		||||
    if (tail && trailingSlash) {
 | 
			
		||||
        tail += '\\';
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    // Convert slashes to backslashes when `device` points to an UNC root.
 | 
			
		||||
    // Also squash multiple slashes into a single one where appropriate.
 | 
			
		||||
    if (isUnc) {
 | 
			
		||||
        device = normalizeUNCRoot(device);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    return device + (isAbsolute ? '\\' : '') + tail;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
win32.isAbsolute = function (path) {
 | 
			
		||||
    return win32StatPath(path).isAbsolute;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
win32.join = function () {
 | 
			
		||||
    var paths = [];
 | 
			
		||||
    for (var i = 0; i < arguments.length; i++) {
 | 
			
		||||
        var arg = arguments[i];
 | 
			
		||||
        if (!util.isString(arg)) {
 | 
			
		||||
            throw new TypeError('Arguments to path.join must be strings');
 | 
			
		||||
        }
 | 
			
		||||
        if (arg) {
 | 
			
		||||
            paths.push(arg);
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    var joined = paths.join('\\');
 | 
			
		||||
 | 
			
		||||
    // Make sure that the joined path doesn't start with two slashes, because
 | 
			
		||||
    // normalize() will mistake it for an UNC path then.
 | 
			
		||||
    //
 | 
			
		||||
    // This step is skipped when it is very clear that the user actually
 | 
			
		||||
    // intended to point at an UNC path. This is assumed when the first
 | 
			
		||||
    // non-empty string arguments starts with exactly two slashes followed by
 | 
			
		||||
    // at least one more non-slash character.
 | 
			
		||||
    //
 | 
			
		||||
    // Note that for normalize() to treat a path as an UNC path it needs to
 | 
			
		||||
    // have at least 2 components, so we don't filter for that here.
 | 
			
		||||
    // This means that the user can use join to construct UNC paths from
 | 
			
		||||
    // a server name and a share name; for example:
 | 
			
		||||
    //   path.join('//server', 'share') -> '\\\\server\\share\')
 | 
			
		||||
    if (!/^[\\\/]{2}[^\\\/]/.test(paths[0])) {
 | 
			
		||||
        joined = joined.replace(/^[\\\/]{2,}/, '\\');
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    return win32.normalize(joined);
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
// path.relative(from, to)
 | 
			
		||||
// it will solve the relative path from 'from' to 'to', for instance:
 | 
			
		||||
// from = 'C:\\orandea\\test\\aaa'
 | 
			
		||||
// to = 'C:\\orandea\\impl\\bbb'
 | 
			
		||||
// The output of the function should be: '..\\..\\impl\\bbb'
 | 
			
		||||
win32.relative = function (from, to) {
 | 
			
		||||
    from = win32.resolve(from);
 | 
			
		||||
    to = win32.resolve(to);
 | 
			
		||||
 | 
			
		||||
    // windows is not case sensitive
 | 
			
		||||
    var lowerFrom = from.toLowerCase();
 | 
			
		||||
    var lowerTo = to.toLowerCase();
 | 
			
		||||
 | 
			
		||||
    var toParts = trimArray(to.split('\\'));
 | 
			
		||||
 | 
			
		||||
    var lowerFromParts = trimArray(lowerFrom.split('\\'));
 | 
			
		||||
    var lowerToParts = trimArray(lowerTo.split('\\'));
 | 
			
		||||
 | 
			
		||||
    var length = Math.min(lowerFromParts.length, lowerToParts.length);
 | 
			
		||||
    var samePartsLength = length;
 | 
			
		||||
    for (var i = 0; i < length; i++) {
 | 
			
		||||
        if (lowerFromParts[i] !== lowerToParts[i]) {
 | 
			
		||||
            samePartsLength = i;
 | 
			
		||||
            break;
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    if (samePartsLength == 0) {
 | 
			
		||||
        return to;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    var outputParts = [];
 | 
			
		||||
    for (var i = samePartsLength; i < lowerFromParts.length; i++) {
 | 
			
		||||
        outputParts.push('..');
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    outputParts = outputParts.concat(toParts.slice(samePartsLength));
 | 
			
		||||
 | 
			
		||||
    return outputParts.join('\\');
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
win32._makeLong = function (path) {
 | 
			
		||||
    // Note: this will *probably* throw somewhere.
 | 
			
		||||
    if (!util.isString(path))
 | 
			
		||||
        return path;
 | 
			
		||||
 | 
			
		||||
    if (!path) {
 | 
			
		||||
        return '';
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    var resolvedPath = win32.resolve(path);
 | 
			
		||||
 | 
			
		||||
    if (/^[a-zA-Z]\:\\/.test(resolvedPath)) {
 | 
			
		||||
        // path is local filesystem path, which needs to be converted
 | 
			
		||||
        // to long UNC path.
 | 
			
		||||
        return '\\\\?\\' + resolvedPath;
 | 
			
		||||
    } else if (/^\\\\[^?.]/.test(resolvedPath)) {
 | 
			
		||||
        // path is network UNC path, which needs to be converted
 | 
			
		||||
        // to long UNC path.
 | 
			
		||||
        return '\\\\?\\UNC\\' + resolvedPath.substring(2);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    return path;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
win32.dirname = function (path) {
 | 
			
		||||
    var result = win32SplitPath(path),
 | 
			
		||||
        root = result[0],
 | 
			
		||||
        dir = result[1];
 | 
			
		||||
 | 
			
		||||
    if (!root && !dir) {
 | 
			
		||||
        // No dirname whatsoever
 | 
			
		||||
        return '.';
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    if (dir) {
 | 
			
		||||
        // It has a dirname, strip trailing slash
 | 
			
		||||
        dir = dir.substr(0, dir.length - 1);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    return root + dir;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
win32.basename = function (path, ext) {
 | 
			
		||||
    var f = win32SplitPath(path)[2];
 | 
			
		||||
    // TODO: make this comparison case-insensitive on windows?
 | 
			
		||||
    if (ext && f.substr(-1 * ext.length) === ext) {
 | 
			
		||||
        f = f.substr(0, f.length - ext.length);
 | 
			
		||||
    }
 | 
			
		||||
    return f;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
win32.extname = function (path) {
 | 
			
		||||
    return win32SplitPath(path)[3];
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
win32.format = function (pathObject) {
 | 
			
		||||
    if (!util.isObject(pathObject)) {
 | 
			
		||||
        throw new TypeError(
 | 
			
		||||
            "Parameter 'pathObject' must be an object, not " + typeof pathObject
 | 
			
		||||
        );
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    var root = pathObject.root || '';
 | 
			
		||||
 | 
			
		||||
    if (!util.isString(root)) {
 | 
			
		||||
        throw new TypeError(
 | 
			
		||||
            "'pathObject.root' must be a string or undefined, not " +
 | 
			
		||||
            typeof pathObject.root
 | 
			
		||||
        );
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    var dir = pathObject.dir;
 | 
			
		||||
    var base = pathObject.base || '';
 | 
			
		||||
    if (!dir) {
 | 
			
		||||
        return base;
 | 
			
		||||
    }
 | 
			
		||||
    if (dir[dir.length - 1] === win32.sep) {
 | 
			
		||||
        return dir + base;
 | 
			
		||||
    }
 | 
			
		||||
    return dir + win32.sep + base;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
win32.parse = function (pathString) {
 | 
			
		||||
    if (!util.isString(pathString)) {
 | 
			
		||||
        throw new TypeError(
 | 
			
		||||
            "Parameter 'pathString' must be a string, not " + typeof pathString
 | 
			
		||||
        );
 | 
			
		||||
    }
 | 
			
		||||
    var allParts = win32SplitPath(pathString);
 | 
			
		||||
    if (!allParts || allParts.length !== 4) {
 | 
			
		||||
        throw new TypeError("Invalid path '" + pathString + "'");
 | 
			
		||||
    }
 | 
			
		||||
    return {
 | 
			
		||||
        root: allParts[0],
 | 
			
		||||
        dir: allParts[0] + allParts[1].slice(0, -1),
 | 
			
		||||
        base: allParts[2],
 | 
			
		||||
        ext: allParts[3],
 | 
			
		||||
        name: allParts[2].slice(0, allParts[2].length - allParts[3].length)
 | 
			
		||||
    };
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
win32.sep = '\\';
 | 
			
		||||
win32.delimiter = ';';
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
// Split a filename into [root, dir, basename, ext], unix version
 | 
			
		||||
// 'root' is just a slash, or nothing.
 | 
			
		||||
var splitPathRe =
 | 
			
		||||
    /^(\/?|)([\s\S]*?)((?:\.{1,2}|[^\/]+?|)(\.[^.\/]*|))(?:[\/]*)$/;
 | 
			
		||||
var posix: any = {};
 | 
			
		||||
 | 
			
		||||
function posixSplitPath(filename) {
 | 
			
		||||
    return splitPathRe.exec(filename).slice(1);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// path.resolve([from ...], to)
 | 
			
		||||
// posix version
 | 
			
		||||
posix.resolve = function () {
 | 
			
		||||
    var resolvedPath = '',
 | 
			
		||||
        resolvedAbsolute = false;
 | 
			
		||||
 | 
			
		||||
    for (var i = arguments.length - 1; i >= -1 && !resolvedAbsolute; i--) {
 | 
			
		||||
        var path = (i >= 0) ? arguments[i] : process.cwd();
 | 
			
		||||
 | 
			
		||||
        // Skip empty and invalid entries
 | 
			
		||||
        if (!util.isString(path)) {
 | 
			
		||||
            throw new TypeError('Arguments to path.resolve must be strings');
 | 
			
		||||
        } else if (!path) {
 | 
			
		||||
            continue;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        resolvedPath = path + '/' + resolvedPath;
 | 
			
		||||
        resolvedAbsolute = path[0] === '/';
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    // At this point the path should be resolved to a full absolute path, but
 | 
			
		||||
    // handle relative paths to be safe (might happen when process.cwd() fails)
 | 
			
		||||
 | 
			
		||||
    // Normalize the path
 | 
			
		||||
    resolvedPath = normalizeArray(resolvedPath.split('/'),
 | 
			
		||||
        !resolvedAbsolute).join('/');
 | 
			
		||||
 | 
			
		||||
    return ((resolvedAbsolute ? '/' : '') + resolvedPath) || '.';
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
// path.normalize(path)
 | 
			
		||||
// posix version
 | 
			
		||||
posix.normalize = function (path) {
 | 
			
		||||
    var isAbsolute = posix.isAbsolute(path),
 | 
			
		||||
        trailingSlash = path && path[path.length - 1] === '/';
 | 
			
		||||
 | 
			
		||||
    // Normalize the path
 | 
			
		||||
    path = normalizeArray(path.split('/'), !isAbsolute).join('/');
 | 
			
		||||
 | 
			
		||||
    if (!path && !isAbsolute) {
 | 
			
		||||
        path = '.';
 | 
			
		||||
    }
 | 
			
		||||
    if (path && trailingSlash) {
 | 
			
		||||
        path += '/';
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    return (isAbsolute ? '/' : '') + path;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
// posix version
 | 
			
		||||
posix.isAbsolute = function (path) {
 | 
			
		||||
    return path.charAt(0) === '/';
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
// posix version
 | 
			
		||||
posix.join = function () {
 | 
			
		||||
    var path = '';
 | 
			
		||||
    for (var i = 0; i < arguments.length; i++) {
 | 
			
		||||
        var segment = arguments[i];
 | 
			
		||||
        if (!util.isString(segment)) {
 | 
			
		||||
            throw new TypeError('Arguments to path.join must be strings');
 | 
			
		||||
        }
 | 
			
		||||
        if (segment) {
 | 
			
		||||
            if (!path) {
 | 
			
		||||
                path += segment;
 | 
			
		||||
            } else {
 | 
			
		||||
                path += '/' + segment;
 | 
			
		||||
            }
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
    return posix.normalize(path);
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
// path.relative(from, to)
 | 
			
		||||
// posix version
 | 
			
		||||
posix.relative = function (from, to) {
 | 
			
		||||
    from = posix.resolve(from).substr(1);
 | 
			
		||||
    to = posix.resolve(to).substr(1);
 | 
			
		||||
 | 
			
		||||
    var fromParts = trimArray(from.split('/'));
 | 
			
		||||
    var toParts = trimArray(to.split('/'));
 | 
			
		||||
 | 
			
		||||
    var length = Math.min(fromParts.length, toParts.length);
 | 
			
		||||
    var samePartsLength = length;
 | 
			
		||||
    for (var i = 0; i < length; i++) {
 | 
			
		||||
        if (fromParts[i] !== toParts[i]) {
 | 
			
		||||
            samePartsLength = i;
 | 
			
		||||
            break;
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    var outputParts = [];
 | 
			
		||||
    for (var i = samePartsLength; i < fromParts.length; i++) {
 | 
			
		||||
        outputParts.push('..');
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    outputParts = outputParts.concat(toParts.slice(samePartsLength));
 | 
			
		||||
 | 
			
		||||
    return outputParts.join('/');
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
posix._makeLong = function (path) {
 | 
			
		||||
    return path;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
posix.dirname = function (path) {
 | 
			
		||||
    var result = posixSplitPath(path),
 | 
			
		||||
        root = result[0],
 | 
			
		||||
        dir = result[1];
 | 
			
		||||
 | 
			
		||||
    if (!root && !dir) {
 | 
			
		||||
        // No dirname whatsoever
 | 
			
		||||
        return '.';
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    if (dir) {
 | 
			
		||||
        // It has a dirname, strip trailing slash
 | 
			
		||||
        dir = dir.substr(0, dir.length - 1);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    return root + dir;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
posix.basename = function (path, ext) {
 | 
			
		||||
    var f = posixSplitPath(path)[2];
 | 
			
		||||
    // TODO: make this comparison case-insensitive on windows?
 | 
			
		||||
    if (ext && f.substr(-1 * ext.length) === ext) {
 | 
			
		||||
        f = f.substr(0, f.length - ext.length);
 | 
			
		||||
    }
 | 
			
		||||
    return f;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
posix.extname = function (path) {
 | 
			
		||||
    return posixSplitPath(path)[3];
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
posix.format = function (pathObject) {
 | 
			
		||||
    if (!util.isObject(pathObject)) {
 | 
			
		||||
        throw new TypeError(
 | 
			
		||||
            "Parameter 'pathObject' must be an object, not " + typeof pathObject
 | 
			
		||||
        );
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    var root = pathObject.root || '';
 | 
			
		||||
 | 
			
		||||
    if (!util.isString(root)) {
 | 
			
		||||
        throw new TypeError(
 | 
			
		||||
            "'pathObject.root' must be a string or undefined, not " +
 | 
			
		||||
            typeof pathObject.root
 | 
			
		||||
        );
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    var dir = pathObject.dir ? pathObject.dir + posix.sep : '';
 | 
			
		||||
    var base = pathObject.base || '';
 | 
			
		||||
    return dir + base;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
posix.parse = function (pathString) {
 | 
			
		||||
    if (!util.isString(pathString)) {
 | 
			
		||||
        throw new TypeError(
 | 
			
		||||
            "Parameter 'pathString' must be a string, not " + typeof pathString
 | 
			
		||||
        );
 | 
			
		||||
    }
 | 
			
		||||
    var allParts = posixSplitPath(pathString);
 | 
			
		||||
    if (!allParts || allParts.length !== 4) {
 | 
			
		||||
        throw new TypeError("Invalid path '" + pathString + "'");
 | 
			
		||||
    }
 | 
			
		||||
    allParts[1] = allParts[1] || '';
 | 
			
		||||
    allParts[2] = allParts[2] || '';
 | 
			
		||||
    allParts[3] = allParts[3] || '';
 | 
			
		||||
 | 
			
		||||
    return {
 | 
			
		||||
        root: allParts[0],
 | 
			
		||||
        dir: allParts[0] + allParts[1].slice(0, -1),
 | 
			
		||||
        base: allParts[2],
 | 
			
		||||
        ext: allParts[3],
 | 
			
		||||
        name: allParts[2].slice(0, allParts[2].length - allParts[3].length)
 | 
			
		||||
    };
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
posix.sep = '/';
 | 
			
		||||
posix.delimiter = ':';
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
if (isWindows)
 | 
			
		||||
    module.exports = win32;
 | 
			
		||||
else /* posix */
 | 
			
		||||
    module.exports = posix;
 | 
			
		||||
 | 
			
		||||
module.exports.posix = posix;
 | 
			
		||||
module.exports.win32 = win32;
 | 
			
		||||
							
								
								
									
										81
									
								
								packages/nodejs/src/querystring/decode.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										81
									
								
								packages/nodejs/src/querystring/decode.ts
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,81 @@
 | 
			
		||||
// Copyright Joyent, Inc. and other Node contributors.
 | 
			
		||||
//
 | 
			
		||||
// Permission is hereby granted, free of charge, to any person obtaining a
 | 
			
		||||
// copy of this software and associated documentation files (the
 | 
			
		||||
// "Software"), to deal in the Software without restriction, including
 | 
			
		||||
// without limitation the rights to use, copy, modify, merge, publish,
 | 
			
		||||
// distribute, sublicense, and/or sell copies of the Software, and to permit
 | 
			
		||||
// persons to whom the Software is furnished to do so, subject to the
 | 
			
		||||
// following conditions:
 | 
			
		||||
//
 | 
			
		||||
// The above copyright notice and this permission notice shall be included
 | 
			
		||||
// in all copies or substantial portions of the Software.
 | 
			
		||||
//
 | 
			
		||||
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
 | 
			
		||||
// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
 | 
			
		||||
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
 | 
			
		||||
// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
 | 
			
		||||
// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
 | 
			
		||||
// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
 | 
			
		||||
// USE OR OTHER DEALINGS IN THE SOFTWARE.
 | 
			
		||||
 | 
			
		||||
'use strict';
 | 
			
		||||
 | 
			
		||||
// If obj.hasOwnProperty has been overridden, then calling
 | 
			
		||||
// obj.hasOwnProperty(prop) will break.
 | 
			
		||||
// See: https://github.com/joyent/node/issues/1707
 | 
			
		||||
// @ts-ignore
 | 
			
		||||
function hasOwnProperty(obj, prop) {
 | 
			
		||||
    return Object.prototype.hasOwnProperty.call(obj, prop);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
module.exports = function (qs, sep, eq, options) {
 | 
			
		||||
    sep = sep || '&';
 | 
			
		||||
    eq = eq || '=';
 | 
			
		||||
    var obj = {};
 | 
			
		||||
 | 
			
		||||
    if (typeof qs !== 'string' || qs.length === 0) {
 | 
			
		||||
        return obj;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    var regexp = /\+/g;
 | 
			
		||||
    qs = qs.split(sep);
 | 
			
		||||
 | 
			
		||||
    var maxKeys = 1000;
 | 
			
		||||
    if (options && typeof options.maxKeys === 'number') {
 | 
			
		||||
        maxKeys = options.maxKeys;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    var len = qs.length;
 | 
			
		||||
    // maxKeys <= 0 means that we should not limit keys count
 | 
			
		||||
    if (maxKeys > 0 && len > maxKeys) {
 | 
			
		||||
        len = maxKeys;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    for (var i = 0; i < len; ++i) {
 | 
			
		||||
        var x = qs[i].replace(regexp, '%20'),
 | 
			
		||||
            idx = x.indexOf(eq),
 | 
			
		||||
            kstr, vstr, k, v;
 | 
			
		||||
 | 
			
		||||
        if (idx >= 0) {
 | 
			
		||||
            kstr = x.substr(0, idx);
 | 
			
		||||
            vstr = x.substr(idx + 1);
 | 
			
		||||
        } else {
 | 
			
		||||
            kstr = x;
 | 
			
		||||
            vstr = '';
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        k = decodeURIComponent(kstr);
 | 
			
		||||
        v = decodeURIComponent(vstr);
 | 
			
		||||
 | 
			
		||||
        if (!hasOwnProperty(obj, k)) {
 | 
			
		||||
            obj[k] = v;
 | 
			
		||||
        } else if (Array.isArray(obj[k])) {
 | 
			
		||||
            obj[k].push(v);
 | 
			
		||||
        } else {
 | 
			
		||||
            obj[k] = [obj[k], v];
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    return obj;
 | 
			
		||||
};
 | 
			
		||||
							
								
								
									
										64
									
								
								packages/nodejs/src/querystring/encode.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										64
									
								
								packages/nodejs/src/querystring/encode.ts
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,64 @@
 | 
			
		||||
// Copyright Joyent, Inc. and other Node contributors.
 | 
			
		||||
//
 | 
			
		||||
// Permission is hereby granted, free of charge, to any person obtaining a
 | 
			
		||||
// copy of this software and associated documentation files (the
 | 
			
		||||
// "Software"), to deal in the Software without restriction, including
 | 
			
		||||
// without limitation the rights to use, copy, modify, merge, publish,
 | 
			
		||||
// distribute, sublicense, and/or sell copies of the Software, and to permit
 | 
			
		||||
// persons to whom the Software is furnished to do so, subject to the
 | 
			
		||||
// following conditions:
 | 
			
		||||
//
 | 
			
		||||
// The above copyright notice and this permission notice shall be included
 | 
			
		||||
// in all copies or substantial portions of the Software.
 | 
			
		||||
//
 | 
			
		||||
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
 | 
			
		||||
// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
 | 
			
		||||
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
 | 
			
		||||
// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
 | 
			
		||||
// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
 | 
			
		||||
// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
 | 
			
		||||
// USE OR OTHER DEALINGS IN THE SOFTWARE.
 | 
			
		||||
 | 
			
		||||
'use strict';
 | 
			
		||||
 | 
			
		||||
var stringifyPrimitive = function (v) {
 | 
			
		||||
    switch (typeof v) {
 | 
			
		||||
        case 'string':
 | 
			
		||||
            return v;
 | 
			
		||||
 | 
			
		||||
        case 'boolean':
 | 
			
		||||
            return v ? 'true' : 'false';
 | 
			
		||||
 | 
			
		||||
        case 'number':
 | 
			
		||||
            return isFinite(v) ? v : '';
 | 
			
		||||
 | 
			
		||||
        default:
 | 
			
		||||
            return '';
 | 
			
		||||
    }
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
module.exports = function (obj, sep, eq, name) {
 | 
			
		||||
    sep = sep || '&';
 | 
			
		||||
    eq = eq || '=';
 | 
			
		||||
    if (obj === null) {
 | 
			
		||||
        obj = undefined;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    if (typeof obj === 'object') {
 | 
			
		||||
        return Object.keys(obj).map(function (k) {
 | 
			
		||||
            var ks = encodeURIComponent(stringifyPrimitive(k)) + eq;
 | 
			
		||||
            if (Array.isArray(obj[k])) {
 | 
			
		||||
                return obj[k].map(function (v) {
 | 
			
		||||
                    return ks + encodeURIComponent(stringifyPrimitive(v));
 | 
			
		||||
                }).join(sep);
 | 
			
		||||
            } else {
 | 
			
		||||
                return ks + encodeURIComponent(stringifyPrimitive(obj[k]));
 | 
			
		||||
            }
 | 
			
		||||
        }).filter(Boolean).join(sep);
 | 
			
		||||
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    if (!name) return '';
 | 
			
		||||
    return encodeURIComponent(stringifyPrimitive(name)) + eq +
 | 
			
		||||
        encodeURIComponent(stringifyPrimitive(obj));
 | 
			
		||||
};
 | 
			
		||||
							
								
								
									
										4
									
								
								packages/nodejs/src/querystring/index.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								packages/nodejs/src/querystring/index.ts
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,4 @@
 | 
			
		||||
'use strict';
 | 
			
		||||
 | 
			
		||||
exports.decode = exports.parse = require('./decode');
 | 
			
		||||
exports.encode = exports.stringify = require('./encode');
 | 
			
		||||
							
								
								
									
										747
									
								
								packages/nodejs/src/url/index.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										747
									
								
								packages/nodejs/src/url/index.ts
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,747 @@
 | 
			
		||||
// Copyright Joyent, Inc. and other Node contributors.
 | 
			
		||||
//
 | 
			
		||||
// Permission is hereby granted, free of charge, to any person obtaining a
 | 
			
		||||
// copy of this software and associated documentation files (the
 | 
			
		||||
// "Software"), to deal in the Software without restriction, including
 | 
			
		||||
// without limitation the rights to use, copy, modify, merge, publish,
 | 
			
		||||
// distribute, sublicense, and/or sell copies of the Software, and to permit
 | 
			
		||||
// persons to whom the Software is furnished to do so, subject to the
 | 
			
		||||
// following conditions:
 | 
			
		||||
//
 | 
			
		||||
// The above copyright notice and this permission notice shall be included
 | 
			
		||||
// in all copies or substantial portions of the Software.
 | 
			
		||||
//
 | 
			
		||||
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
 | 
			
		||||
// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
 | 
			
		||||
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
 | 
			
		||||
// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
 | 
			
		||||
// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
 | 
			
		||||
// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
 | 
			
		||||
// USE OR OTHER DEALINGS IN THE SOFTWARE.
 | 
			
		||||
 | 
			
		||||
'use strict';
 | 
			
		||||
 | 
			
		||||
var punycode = require('punycode');
 | 
			
		||||
// @ts-ignore
 | 
			
		||||
var util = {
 | 
			
		||||
    isString: function (arg) {
 | 
			
		||||
        return typeof (arg) === 'string';
 | 
			
		||||
    },
 | 
			
		||||
    isObject: function (arg) {
 | 
			
		||||
        return typeof (arg) === 'object' && arg !== null;
 | 
			
		||||
    },
 | 
			
		||||
    isNull: function (arg) {
 | 
			
		||||
        return arg === null;
 | 
			
		||||
    },
 | 
			
		||||
    isNullOrUndefined: function (arg) {
 | 
			
		||||
        return arg == null;
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
exports.parse = urlParse;
 | 
			
		||||
exports.resolve = urlResolve;
 | 
			
		||||
exports.resolveObject = urlResolveObject;
 | 
			
		||||
exports.format = urlFormat;
 | 
			
		||||
 | 
			
		||||
exports.Url = Url;
 | 
			
		||||
 | 
			
		||||
function Url(this: any) {
 | 
			
		||||
    this.protocol = null;
 | 
			
		||||
    this.slashes = null;
 | 
			
		||||
    this.auth = null;
 | 
			
		||||
    this.host = null;
 | 
			
		||||
    this.port = null;
 | 
			
		||||
    this.hostname = null;
 | 
			
		||||
    this.hash = null;
 | 
			
		||||
    this.search = null;
 | 
			
		||||
    this.query = null;
 | 
			
		||||
    this.pathname = null;
 | 
			
		||||
    this.path = null;
 | 
			
		||||
    this.href = null;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Reference: RFC 3986, RFC 1808, RFC 2396
 | 
			
		||||
 | 
			
		||||
// define these here so at least they only have to be
 | 
			
		||||
// compiled once on the first module load.
 | 
			
		||||
var protocolPattern = /^([a-z0-9.+-]+:)/i,
 | 
			
		||||
    portPattern = /:[0-9]*$/,
 | 
			
		||||
 | 
			
		||||
    // Special case for a simple path URL
 | 
			
		||||
    simplePathPattern = /^(\/\/?(?!\/)[^\?\s]*)(\?[^\s]*)?$/,
 | 
			
		||||
 | 
			
		||||
    // RFC 2396: characters reserved for delimiting URLs.
 | 
			
		||||
    // We actually just auto-escape these.
 | 
			
		||||
    delims = ['<', '>', '"', '`', ' ', '\r', '\n', '\t'],
 | 
			
		||||
 | 
			
		||||
    // RFC 2396: characters not allowed for various reasons.
 | 
			
		||||
    unwise = ['{', '}', '|', '\\', '^', '`'].concat(delims),
 | 
			
		||||
 | 
			
		||||
    // Allowed by RFCs, but cause of XSS attacks.  Always escape these.
 | 
			
		||||
    autoEscape = ['\''].concat(unwise),
 | 
			
		||||
    // Characters that are never ever allowed in a hostname.
 | 
			
		||||
    // Note that any invalid chars are also handled, but these
 | 
			
		||||
    // are the ones that are *expected* to be seen, so we fast-path
 | 
			
		||||
    // them.
 | 
			
		||||
    nonHostChars = ['%', '/', '?', ';', '#'].concat(autoEscape),
 | 
			
		||||
    hostEndingChars = ['/', '?', '#'],
 | 
			
		||||
    hostnameMaxLen = 255,
 | 
			
		||||
    hostnamePartPattern = /^[+a-z0-9A-Z_-]{0,63}$/,
 | 
			
		||||
    hostnamePartStart = /^([+a-z0-9A-Z_-]{0,63})(.*)$/,
 | 
			
		||||
    // protocols that can allow "unsafe" and "unwise" chars.
 | 
			
		||||
    unsafeProtocol = {
 | 
			
		||||
        'javascript': true,
 | 
			
		||||
        'javascript:': true
 | 
			
		||||
    },
 | 
			
		||||
    // protocols that never have a hostname.
 | 
			
		||||
    hostlessProtocol = {
 | 
			
		||||
        'javascript': true,
 | 
			
		||||
        'javascript:': true
 | 
			
		||||
    },
 | 
			
		||||
    // protocols that always contain a // bit.
 | 
			
		||||
    slashedProtocol = {
 | 
			
		||||
        'http': true,
 | 
			
		||||
        'https': true,
 | 
			
		||||
        'ftp': true,
 | 
			
		||||
        'gopher': true,
 | 
			
		||||
        'file': true,
 | 
			
		||||
        'http:': true,
 | 
			
		||||
        'https:': true,
 | 
			
		||||
        'ftp:': true,
 | 
			
		||||
        'gopher:': true,
 | 
			
		||||
        'file:': true
 | 
			
		||||
    },
 | 
			
		||||
    querystring = require('querystring');
 | 
			
		||||
 | 
			
		||||
function urlParse(url, parseQueryString?, slashesDenoteHost?) {
 | 
			
		||||
    if (url && util.isObject(url) && url instanceof Url) return url;
 | 
			
		||||
 | 
			
		||||
    var u = new Url;
 | 
			
		||||
    u.parse(url, parseQueryString, slashesDenoteHost);
 | 
			
		||||
    return u;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
Url.prototype.parse = function (url, parseQueryString, slashesDenoteHost) {
 | 
			
		||||
    if (!util.isString(url)) {
 | 
			
		||||
        throw new TypeError("Parameter 'url' must be a string, not " + typeof url);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    // Copy chrome, IE, opera backslash-handling behavior.
 | 
			
		||||
    // Back slashes before the query string get converted to forward slashes
 | 
			
		||||
    // See: https://code.google.com/p/chromium/issues/detail?id=25916
 | 
			
		||||
    var queryIndex = url.indexOf('?'),
 | 
			
		||||
        splitter =
 | 
			
		||||
            (queryIndex !== -1 && queryIndex < url.indexOf('#')) ? '?' : '#',
 | 
			
		||||
        uSplit = url.split(splitter),
 | 
			
		||||
        slashRegex = /\\/g;
 | 
			
		||||
    uSplit[0] = uSplit[0].replace(slashRegex, '/');
 | 
			
		||||
    url = uSplit.join(splitter);
 | 
			
		||||
 | 
			
		||||
    var rest = url;
 | 
			
		||||
 | 
			
		||||
    // trim before proceeding.
 | 
			
		||||
    // This is to support parse stuff like "  http://foo.com  \n"
 | 
			
		||||
    rest = rest.trim();
 | 
			
		||||
 | 
			
		||||
    if (!slashesDenoteHost && url.split('#').length === 1) {
 | 
			
		||||
        // Try fast path regexp
 | 
			
		||||
        var simplePath = simplePathPattern.exec(rest);
 | 
			
		||||
        if (simplePath) {
 | 
			
		||||
            this.path = rest;
 | 
			
		||||
            this.href = rest;
 | 
			
		||||
            this.pathname = simplePath[1];
 | 
			
		||||
            if (simplePath[2]) {
 | 
			
		||||
                this.search = simplePath[2];
 | 
			
		||||
                if (parseQueryString) {
 | 
			
		||||
                    this.query = querystring.parse(this.search.substr(1));
 | 
			
		||||
                } else {
 | 
			
		||||
                    this.query = this.search.substr(1);
 | 
			
		||||
                }
 | 
			
		||||
            } else if (parseQueryString) {
 | 
			
		||||
                this.search = '';
 | 
			
		||||
                this.query = {};
 | 
			
		||||
            }
 | 
			
		||||
            return this;
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    var proto: any = protocolPattern.exec(rest);
 | 
			
		||||
    if (proto) {
 | 
			
		||||
        proto = proto[0];
 | 
			
		||||
        var lowerProto = proto.toLowerCase();
 | 
			
		||||
        this.protocol = lowerProto;
 | 
			
		||||
        rest = rest.substr(proto.length);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    // figure out if it's got a host
 | 
			
		||||
    // user@server is *always* interpreted as a hostname, and url
 | 
			
		||||
    // resolution will treat //foo/bar as host=foo,path=bar because that's
 | 
			
		||||
    // how the browser resolves relative URLs.
 | 
			
		||||
    if (slashesDenoteHost || proto || rest.match(/^\/\/[^@\/]+@[^@\/]+/)) {
 | 
			
		||||
        var slashes = rest.substr(0, 2) === '//';
 | 
			
		||||
        if (slashes && !(proto && hostlessProtocol[proto])) {
 | 
			
		||||
            rest = rest.substr(2);
 | 
			
		||||
            this.slashes = true;
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    if (!hostlessProtocol[proto] &&
 | 
			
		||||
        (slashes || (proto && !slashedProtocol[proto]))) {
 | 
			
		||||
 | 
			
		||||
        // there's a hostname.
 | 
			
		||||
        // the first instance of /, ?, ;, or # ends the host.
 | 
			
		||||
        //
 | 
			
		||||
        // If there is an @ in the hostname, then non-host chars *are* allowed
 | 
			
		||||
        // to the left of the last @ sign, unless some host-ending character
 | 
			
		||||
        // comes *before* the @-sign.
 | 
			
		||||
        // URLs are obnoxious.
 | 
			
		||||
        //
 | 
			
		||||
        // ex:
 | 
			
		||||
        // http://a@b@c/ => user:a@b host:c
 | 
			
		||||
        // http://a@b?@c => user:a host:c path:/?@c
 | 
			
		||||
 | 
			
		||||
        // v0.12 TODO(isaacs): This is not quite how Chrome does things.
 | 
			
		||||
        // Review our test case against browsers more comprehensively.
 | 
			
		||||
 | 
			
		||||
        // find the first instance of any hostEndingChars
 | 
			
		||||
        var hostEnd = -1;
 | 
			
		||||
        for (var i = 0; i < hostEndingChars.length; i++) {
 | 
			
		||||
            var hec = rest.indexOf(hostEndingChars[i]);
 | 
			
		||||
            if (hec !== -1 && (hostEnd === -1 || hec < hostEnd))
 | 
			
		||||
                hostEnd = hec;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        // at this point, either we have an explicit point where the
 | 
			
		||||
        // auth portion cannot go past, or the last @ char is the decider.
 | 
			
		||||
        var auth, atSign;
 | 
			
		||||
        if (hostEnd === -1) {
 | 
			
		||||
            // atSign can be anywhere.
 | 
			
		||||
            atSign = rest.lastIndexOf('@');
 | 
			
		||||
        } else {
 | 
			
		||||
            // atSign must be in auth portion.
 | 
			
		||||
            // http://a@b/c@d => host:b auth:a path:/c@d
 | 
			
		||||
            atSign = rest.lastIndexOf('@', hostEnd);
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        // Now we have a portion which is definitely the auth.
 | 
			
		||||
        // Pull that off.
 | 
			
		||||
        if (atSign !== -1) {
 | 
			
		||||
            auth = rest.slice(0, atSign);
 | 
			
		||||
            rest = rest.slice(atSign + 1);
 | 
			
		||||
            this.auth = decodeURIComponent(auth);
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        // the host is the remaining to the left of the first non-host char
 | 
			
		||||
        hostEnd = -1;
 | 
			
		||||
        for (var i = 0; i < nonHostChars.length; i++) {
 | 
			
		||||
            var hec = rest.indexOf(nonHostChars[i]);
 | 
			
		||||
            if (hec !== -1 && (hostEnd === -1 || hec < hostEnd))
 | 
			
		||||
                hostEnd = hec;
 | 
			
		||||
        }
 | 
			
		||||
        // if we still have not hit it, then the entire thing is a host.
 | 
			
		||||
        if (hostEnd === -1)
 | 
			
		||||
            hostEnd = rest.length;
 | 
			
		||||
 | 
			
		||||
        this.host = rest.slice(0, hostEnd);
 | 
			
		||||
        rest = rest.slice(hostEnd);
 | 
			
		||||
 | 
			
		||||
        // pull out port.
 | 
			
		||||
        this.parseHost();
 | 
			
		||||
 | 
			
		||||
        // we've indicated that there is a hostname,
 | 
			
		||||
        // so even if it's empty, it has to be present.
 | 
			
		||||
        this.hostname = this.hostname || '';
 | 
			
		||||
 | 
			
		||||
        // if hostname begins with [ and ends with ]
 | 
			
		||||
        // assume that it's an IPv6 address.
 | 
			
		||||
        var ipv6Hostname = this.hostname[0] === '[' &&
 | 
			
		||||
            this.hostname[this.hostname.length - 1] === ']';
 | 
			
		||||
 | 
			
		||||
        // validate a little.
 | 
			
		||||
        if (!ipv6Hostname) {
 | 
			
		||||
            var hostparts = this.hostname.split(/\./);
 | 
			
		||||
            for (var i = 0, l = hostparts.length; i < l; i++) {
 | 
			
		||||
                var part = hostparts[i];
 | 
			
		||||
                if (!part) continue;
 | 
			
		||||
                if (!part.match(hostnamePartPattern)) {
 | 
			
		||||
                    var newpart = '';
 | 
			
		||||
                    for (var j = 0, k = part.length; j < k; j++) {
 | 
			
		||||
                        if (part.charCodeAt(j) > 127) {
 | 
			
		||||
                            // we replace non-ASCII char with a temporary placeholder
 | 
			
		||||
                            // we need this to make sure size of hostname is not
 | 
			
		||||
                            // broken by replacing non-ASCII by nothing
 | 
			
		||||
                            newpart += 'x';
 | 
			
		||||
                        } else {
 | 
			
		||||
                            newpart += part[j];
 | 
			
		||||
                        }
 | 
			
		||||
                    }
 | 
			
		||||
                    // we test again with ASCII char only
 | 
			
		||||
                    if (!newpart.match(hostnamePartPattern)) {
 | 
			
		||||
                        var validParts = hostparts.slice(0, i);
 | 
			
		||||
                        var notHost = hostparts.slice(i + 1);
 | 
			
		||||
                        var bit = part.match(hostnamePartStart);
 | 
			
		||||
                        if (bit) {
 | 
			
		||||
                            validParts.push(bit[1]);
 | 
			
		||||
                            notHost.unshift(bit[2]);
 | 
			
		||||
                        }
 | 
			
		||||
                        if (notHost.length) {
 | 
			
		||||
                            rest = '/' + notHost.join('.') + rest;
 | 
			
		||||
                        }
 | 
			
		||||
                        this.hostname = validParts.join('.');
 | 
			
		||||
                        break;
 | 
			
		||||
                    }
 | 
			
		||||
                }
 | 
			
		||||
            }
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        if (this.hostname.length > hostnameMaxLen) {
 | 
			
		||||
            this.hostname = '';
 | 
			
		||||
        } else {
 | 
			
		||||
            // hostnames are always lower case.
 | 
			
		||||
            this.hostname = this.hostname.toLowerCase();
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        if (!ipv6Hostname) {
 | 
			
		||||
            // IDNA Support: Returns a punycoded representation of "domain".
 | 
			
		||||
            // It only converts parts of the domain name that
 | 
			
		||||
            // have non-ASCII characters, i.e. it doesn't matter if
 | 
			
		||||
            // you call it with a domain that already is ASCII-only.
 | 
			
		||||
            this.hostname = punycode.toASCII(this.hostname);
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        var p = this.port ? ':' + this.port : '';
 | 
			
		||||
        var h = this.hostname || '';
 | 
			
		||||
        this.host = h + p;
 | 
			
		||||
        this.href += this.host;
 | 
			
		||||
 | 
			
		||||
        // strip [ and ] from the hostname
 | 
			
		||||
        // the host field still retains them, though
 | 
			
		||||
        if (ipv6Hostname) {
 | 
			
		||||
            this.hostname = this.hostname.substr(1, this.hostname.length - 2);
 | 
			
		||||
            if (rest[0] !== '/') {
 | 
			
		||||
                rest = '/' + rest;
 | 
			
		||||
            }
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    // now rest is set to the post-host stuff.
 | 
			
		||||
    // chop off any delim chars.
 | 
			
		||||
    if (!unsafeProtocol[lowerProto]) {
 | 
			
		||||
 | 
			
		||||
        // First, make 100% sure that any "autoEscape" chars get
 | 
			
		||||
        // escaped, even if encodeURIComponent doesn't think they
 | 
			
		||||
        // need to be.
 | 
			
		||||
        for (var i = 0, m = autoEscape.length; i < m; i++) {
 | 
			
		||||
            var ae = autoEscape[i];
 | 
			
		||||
            if (rest.indexOf(ae) === -1)
 | 
			
		||||
                continue;
 | 
			
		||||
            var esc = encodeURIComponent(ae);
 | 
			
		||||
            if (esc === ae) {
 | 
			
		||||
                esc = escape(ae);
 | 
			
		||||
            }
 | 
			
		||||
            rest = rest.split(ae).join(esc);
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    // chop off from the tail first.
 | 
			
		||||
    var hash = rest.indexOf('#');
 | 
			
		||||
    if (hash !== -1) {
 | 
			
		||||
        // got a fragment string.
 | 
			
		||||
        this.hash = rest.substr(hash);
 | 
			
		||||
        rest = rest.slice(0, hash);
 | 
			
		||||
    }
 | 
			
		||||
    var qm = rest.indexOf('?');
 | 
			
		||||
    if (qm !== -1) {
 | 
			
		||||
        this.search = rest.substr(qm);
 | 
			
		||||
        this.query = rest.substr(qm + 1);
 | 
			
		||||
        if (parseQueryString) {
 | 
			
		||||
            this.query = querystring.parse(this.query);
 | 
			
		||||
        }
 | 
			
		||||
        rest = rest.slice(0, qm);
 | 
			
		||||
    } else if (parseQueryString) {
 | 
			
		||||
        // no query string, but parseQueryString still requested
 | 
			
		||||
        this.search = '';
 | 
			
		||||
        this.query = {};
 | 
			
		||||
    }
 | 
			
		||||
    if (rest) this.pathname = rest;
 | 
			
		||||
    if (slashedProtocol[lowerProto] &&
 | 
			
		||||
        this.hostname && !this.pathname) {
 | 
			
		||||
        this.pathname = '/';
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    //to support http.request
 | 
			
		||||
    if (this.pathname || this.search) {
 | 
			
		||||
        var q = this.pathname || '';
 | 
			
		||||
        var s = this.search || '';
 | 
			
		||||
        this.path = q + s;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    // finally, reconstruct the href based on what has been validated.
 | 
			
		||||
    this.href = this.format();
 | 
			
		||||
    return this;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
// format a parsed object into a url string
 | 
			
		||||
function urlFormat(obj) {
 | 
			
		||||
    // ensure it's an object, and not a string url.
 | 
			
		||||
    // If it's an obj, this is a no-op.
 | 
			
		||||
    // this way, you can call url_format() on strings
 | 
			
		||||
    // to clean up potentially wonky urls.
 | 
			
		||||
    if (util.isString(obj)) obj = urlParse(obj);
 | 
			
		||||
    if (!(obj instanceof Url)) return Url.prototype.format.call(obj);
 | 
			
		||||
    // @ts-ignore
 | 
			
		||||
    return obj.format();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
Url.prototype.format = function () {
 | 
			
		||||
    var auth = this.auth || '';
 | 
			
		||||
    if (auth) {
 | 
			
		||||
        auth = encodeURIComponent(auth);
 | 
			
		||||
        auth = auth.replace(/%3A/i, ':');
 | 
			
		||||
        auth += '@';
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    var protocol = this.protocol || '',
 | 
			
		||||
        pathname = this.pathname || '',
 | 
			
		||||
        hash = this.hash || '',
 | 
			
		||||
        host: any = false,
 | 
			
		||||
        query = '';
 | 
			
		||||
 | 
			
		||||
    if (this.host) {
 | 
			
		||||
        host = auth + this.host;
 | 
			
		||||
    } else if (this.hostname) {
 | 
			
		||||
        host = auth + (this.hostname.indexOf(':') === -1 ?
 | 
			
		||||
            this.hostname :
 | 
			
		||||
            '[' + this.hostname + ']');
 | 
			
		||||
        if (this.port) {
 | 
			
		||||
            host += ':' + this.port;
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    if (this.query &&
 | 
			
		||||
        util.isObject(this.query) &&
 | 
			
		||||
        Object.keys(this.query).length) {
 | 
			
		||||
        query = querystring.stringify(this.query);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    var search = this.search || (query && ('?' + query)) || '';
 | 
			
		||||
 | 
			
		||||
    if (protocol && protocol.substr(-1) !== ':') protocol += ':';
 | 
			
		||||
 | 
			
		||||
    // only the slashedProtocols get the //.  Not mailto:, xmpp:, etc.
 | 
			
		||||
    // unless they had them to begin with.
 | 
			
		||||
    if (this.slashes ||
 | 
			
		||||
        (!protocol || slashedProtocol[protocol]) && host !== false) {
 | 
			
		||||
        host = '//' + (host || '');
 | 
			
		||||
        if (pathname && pathname.charAt(0) !== '/') pathname = '/' + pathname;
 | 
			
		||||
    } else if (!host) {
 | 
			
		||||
        host = '';
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    if (hash && hash.charAt(0) !== '#') hash = '#' + hash;
 | 
			
		||||
    if (search && search.charAt(0) !== '?') search = '?' + search;
 | 
			
		||||
 | 
			
		||||
    pathname = pathname.replace(/[?#]/g, function (match) {
 | 
			
		||||
        return encodeURIComponent(match);
 | 
			
		||||
    });
 | 
			
		||||
    search = search.replace('#', '%23');
 | 
			
		||||
 | 
			
		||||
    return protocol + host + pathname + search + hash;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
function urlResolve(source, relative) {
 | 
			
		||||
    return urlParse(source, false, true).resolve(relative);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
Url.prototype.resolve = function (relative) {
 | 
			
		||||
    return this.resolveObject(urlParse(relative, false, true)).format();
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
function urlResolveObject(source, relative) {
 | 
			
		||||
    if (!source) return relative;
 | 
			
		||||
    return urlParse(source, false, true).resolveObject(relative);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
Url.prototype.resolveObject = function (relative) {
 | 
			
		||||
    if (util.isString(relative)) {
 | 
			
		||||
        var rel = new Url();
 | 
			
		||||
        rel.parse(relative, false, true);
 | 
			
		||||
        relative = rel;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    var result = new Url();
 | 
			
		||||
    var tkeys = Object.keys(this);
 | 
			
		||||
    for (var tk = 0; tk < tkeys.length; tk++) {
 | 
			
		||||
        var tkey = tkeys[tk];
 | 
			
		||||
        result[tkey] = this[tkey];
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    // hash is always overridden, no matter what.
 | 
			
		||||
    // even href="" will remove it.
 | 
			
		||||
    result.hash = relative.hash;
 | 
			
		||||
 | 
			
		||||
    // if the relative url is empty, then there's nothing left to do here.
 | 
			
		||||
    if (relative.href === '') {
 | 
			
		||||
        result.href = result.format();
 | 
			
		||||
        return result;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    // hrefs like //foo/bar always cut to the protocol.
 | 
			
		||||
    if (relative.slashes && !relative.protocol) {
 | 
			
		||||
        // take everything except the protocol from relative
 | 
			
		||||
        var rkeys = Object.keys(relative);
 | 
			
		||||
        for (var rk = 0; rk < rkeys.length; rk++) {
 | 
			
		||||
            var rkey = rkeys[rk];
 | 
			
		||||
            if (rkey !== 'protocol')
 | 
			
		||||
                result[rkey] = relative[rkey];
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        //urlParse appends trailing / to urls like http://www.example.com
 | 
			
		||||
        if (slashedProtocol[result.protocol] &&
 | 
			
		||||
            result.hostname && !result.pathname) {
 | 
			
		||||
            result.path = result.pathname = '/';
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        result.href = result.format();
 | 
			
		||||
        return result;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    if (relative.protocol && relative.protocol !== result.protocol) {
 | 
			
		||||
        // if it's a known url protocol, then changing
 | 
			
		||||
        // the protocol does weird things
 | 
			
		||||
        // first, if it's not file:, then we MUST have a host,
 | 
			
		||||
        // and if there was a path
 | 
			
		||||
        // to begin with, then we MUST have a path.
 | 
			
		||||
        // if it is file:, then the host is dropped,
 | 
			
		||||
        // because that's known to be hostless.
 | 
			
		||||
        // anything else is assumed to be absolute.
 | 
			
		||||
        if (!slashedProtocol[relative.protocol]) {
 | 
			
		||||
            var keys = Object.keys(relative);
 | 
			
		||||
            for (var v = 0; v < keys.length; v++) {
 | 
			
		||||
                var k = keys[v];
 | 
			
		||||
                result[k] = relative[k];
 | 
			
		||||
            }
 | 
			
		||||
            result.href = result.format();
 | 
			
		||||
            return result;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        result.protocol = relative.protocol;
 | 
			
		||||
        if (!relative.host && !hostlessProtocol[relative.protocol]) {
 | 
			
		||||
            var relPath = (relative.pathname || '').split('/');
 | 
			
		||||
            while (relPath.length && !(relative.host = relPath.shift()));
 | 
			
		||||
            if (!relative.host) relative.host = '';
 | 
			
		||||
            if (!relative.hostname) relative.hostname = '';
 | 
			
		||||
            if (relPath[0] !== '') relPath.unshift('');
 | 
			
		||||
            if (relPath.length < 2) relPath.unshift('');
 | 
			
		||||
            result.pathname = relPath.join('/');
 | 
			
		||||
        } else {
 | 
			
		||||
            result.pathname = relative.pathname;
 | 
			
		||||
        }
 | 
			
		||||
        result.search = relative.search;
 | 
			
		||||
        result.query = relative.query;
 | 
			
		||||
        result.host = relative.host || '';
 | 
			
		||||
        result.auth = relative.auth;
 | 
			
		||||
        result.hostname = relative.hostname || relative.host;
 | 
			
		||||
        result.port = relative.port;
 | 
			
		||||
        // to support http.request
 | 
			
		||||
        if (result.pathname || result.search) {
 | 
			
		||||
            var p = result.pathname || '';
 | 
			
		||||
            var s = result.search || '';
 | 
			
		||||
            result.path = p + s;
 | 
			
		||||
        }
 | 
			
		||||
        result.slashes = result.slashes || relative.slashes;
 | 
			
		||||
        result.href = result.format();
 | 
			
		||||
        return result;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    var isSourceAbs = (result.pathname && result.pathname.charAt(0) === '/'),
 | 
			
		||||
        isRelAbs = (
 | 
			
		||||
            relative.host ||
 | 
			
		||||
            relative.pathname && relative.pathname.charAt(0) === '/'
 | 
			
		||||
        ),
 | 
			
		||||
        mustEndAbs = (isRelAbs || isSourceAbs ||
 | 
			
		||||
            (result.host && relative.pathname)),
 | 
			
		||||
        removeAllDots = mustEndAbs,
 | 
			
		||||
        srcPath = result.pathname && result.pathname.split('/') || [],
 | 
			
		||||
        relPath = relative.pathname && relative.pathname.split('/') || [],
 | 
			
		||||
        psychotic = result.protocol && !slashedProtocol[result.protocol];
 | 
			
		||||
 | 
			
		||||
    // if the url is a non-slashed url, then relative
 | 
			
		||||
    // links like ../.. should be able
 | 
			
		||||
    // to crawl up to the hostname, as well.  This is strange.
 | 
			
		||||
    // result.protocol has already been set by now.
 | 
			
		||||
    // Later on, put the first path part into the host field.
 | 
			
		||||
    if (psychotic) {
 | 
			
		||||
        result.hostname = '';
 | 
			
		||||
        result.port = null;
 | 
			
		||||
        if (result.host) {
 | 
			
		||||
            if (srcPath[0] === '') srcPath[0] = result.host;
 | 
			
		||||
            else srcPath.unshift(result.host);
 | 
			
		||||
        }
 | 
			
		||||
        result.host = '';
 | 
			
		||||
        if (relative.protocol) {
 | 
			
		||||
            relative.hostname = null;
 | 
			
		||||
            relative.port = null;
 | 
			
		||||
            if (relative.host) {
 | 
			
		||||
                if (relPath[0] === '') relPath[0] = relative.host;
 | 
			
		||||
                else relPath.unshift(relative.host);
 | 
			
		||||
            }
 | 
			
		||||
            relative.host = null;
 | 
			
		||||
        }
 | 
			
		||||
        mustEndAbs = mustEndAbs && (relPath[0] === '' || srcPath[0] === '');
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    if (isRelAbs) {
 | 
			
		||||
        // it's absolute.
 | 
			
		||||
        result.host = (relative.host || relative.host === '') ?
 | 
			
		||||
            relative.host : result.host;
 | 
			
		||||
        result.hostname = (relative.hostname || relative.hostname === '') ?
 | 
			
		||||
            relative.hostname : result.hostname;
 | 
			
		||||
        result.search = relative.search;
 | 
			
		||||
        result.query = relative.query;
 | 
			
		||||
        srcPath = relPath;
 | 
			
		||||
        // fall through to the dot-handling below.
 | 
			
		||||
    } else if (relPath.length) {
 | 
			
		||||
        // it's relative
 | 
			
		||||
        // throw away the existing file, and take the new path instead.
 | 
			
		||||
        if (!srcPath) srcPath = [];
 | 
			
		||||
        srcPath.pop();
 | 
			
		||||
        srcPath = srcPath.concat(relPath);
 | 
			
		||||
        result.search = relative.search;
 | 
			
		||||
        result.query = relative.query;
 | 
			
		||||
    } else if (!util.isNullOrUndefined(relative.search)) {
 | 
			
		||||
        // just pull out the search.
 | 
			
		||||
        // like href='?foo'.
 | 
			
		||||
        // Put this after the other two cases because it simplifies the booleans
 | 
			
		||||
        if (psychotic) {
 | 
			
		||||
            result.hostname = result.host = srcPath.shift();
 | 
			
		||||
            //occationaly the auth can get stuck only in host
 | 
			
		||||
            //this especially happens in cases like
 | 
			
		||||
            //url.resolveObject('mailto:local1@domain1', 'local2@domain2')
 | 
			
		||||
            var authInHost = result.host && result.host.indexOf('@') > 0 ?
 | 
			
		||||
                result.host.split('@') : false;
 | 
			
		||||
            if (authInHost) {
 | 
			
		||||
                result.auth = authInHost.shift();
 | 
			
		||||
                result.host = result.hostname = authInHost.shift();
 | 
			
		||||
            }
 | 
			
		||||
        }
 | 
			
		||||
        result.search = relative.search;
 | 
			
		||||
        result.query = relative.query;
 | 
			
		||||
        //to support http.request
 | 
			
		||||
        if (!util.isNull(result.pathname) || !util.isNull(result.search)) {
 | 
			
		||||
            result.path = (result.pathname ? result.pathname : '') +
 | 
			
		||||
                (result.search ? result.search : '');
 | 
			
		||||
        }
 | 
			
		||||
        result.href = result.format();
 | 
			
		||||
        return result;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    if (!srcPath.length) {
 | 
			
		||||
        // no path at all.  easy.
 | 
			
		||||
        // we've already handled the other stuff above.
 | 
			
		||||
        result.pathname = null;
 | 
			
		||||
        //to support http.request
 | 
			
		||||
        if (result.search) {
 | 
			
		||||
            result.path = '/' + result.search;
 | 
			
		||||
        } else {
 | 
			
		||||
            result.path = null;
 | 
			
		||||
        }
 | 
			
		||||
        result.href = result.format();
 | 
			
		||||
        return result;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    // if a url ENDs in . or .., then it must get a trailing slash.
 | 
			
		||||
    // however, if it ends in anything else non-slashy,
 | 
			
		||||
    // then it must NOT get a trailing slash.
 | 
			
		||||
    var last = srcPath.slice(-1)[0];
 | 
			
		||||
    var hasTrailingSlash = (
 | 
			
		||||
        (result.host || relative.host || srcPath.length > 1) &&
 | 
			
		||||
        (last === '.' || last === '..') || last === '');
 | 
			
		||||
 | 
			
		||||
    // strip single dots, resolve double dots to parent dir
 | 
			
		||||
    // if the path tries to go above the root, `up` ends up > 0
 | 
			
		||||
    var up = 0;
 | 
			
		||||
    for (var i = srcPath.length; i >= 0; i--) {
 | 
			
		||||
        last = srcPath[i];
 | 
			
		||||
        if (last === '.') {
 | 
			
		||||
            srcPath.splice(i, 1);
 | 
			
		||||
        } else if (last === '..') {
 | 
			
		||||
            srcPath.splice(i, 1);
 | 
			
		||||
            up++;
 | 
			
		||||
        } else if (up) {
 | 
			
		||||
            srcPath.splice(i, 1);
 | 
			
		||||
            up--;
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    // if the path is allowed to go above the root, restore leading ..s
 | 
			
		||||
    if (!mustEndAbs && !removeAllDots) {
 | 
			
		||||
        for (; up--; up) {
 | 
			
		||||
            srcPath.unshift('..');
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    if (mustEndAbs && srcPath[0] !== '' &&
 | 
			
		||||
        (!srcPath[0] || srcPath[0].charAt(0) !== '/')) {
 | 
			
		||||
        srcPath.unshift('');
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    if (hasTrailingSlash && (srcPath.join('/').substr(-1) !== '/')) {
 | 
			
		||||
        srcPath.push('');
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    var isAbsolute = srcPath[0] === '' ||
 | 
			
		||||
        (srcPath[0] && srcPath[0].charAt(0) === '/');
 | 
			
		||||
 | 
			
		||||
    // put the host back
 | 
			
		||||
    if (psychotic) {
 | 
			
		||||
        result.hostname = result.host = isAbsolute ? '' :
 | 
			
		||||
            srcPath.length ? srcPath.shift() : '';
 | 
			
		||||
        //occationaly the auth can get stuck only in host
 | 
			
		||||
        //this especially happens in cases like
 | 
			
		||||
        //url.resolveObject('mailto:local1@domain1', 'local2@domain2')
 | 
			
		||||
        var authInHost = result.host && result.host.indexOf('@') > 0 ?
 | 
			
		||||
            result.host.split('@') : false;
 | 
			
		||||
        if (authInHost) {
 | 
			
		||||
            result.auth = authInHost.shift();
 | 
			
		||||
            result.host = result.hostname = authInHost.shift();
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    mustEndAbs = mustEndAbs || (result.host && srcPath.length);
 | 
			
		||||
 | 
			
		||||
    if (mustEndAbs && !isAbsolute) {
 | 
			
		||||
        srcPath.unshift('');
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    if (!srcPath.length) {
 | 
			
		||||
        result.pathname = null;
 | 
			
		||||
        result.path = null;
 | 
			
		||||
    } else {
 | 
			
		||||
        result.pathname = srcPath.join('/');
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    //to support request.http
 | 
			
		||||
    if (!util.isNull(result.pathname) || !util.isNull(result.search)) {
 | 
			
		||||
        result.path = (result.pathname ? result.pathname : '') +
 | 
			
		||||
            (result.search ? result.search : '');
 | 
			
		||||
    }
 | 
			
		||||
    result.auth = relative.auth || result.auth;
 | 
			
		||||
    result.slashes = result.slashes || relative.slashes;
 | 
			
		||||
    result.href = result.format();
 | 
			
		||||
    return result;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
Url.prototype.parseHost = function () {
 | 
			
		||||
    var host = this.host;
 | 
			
		||||
    var port: any = portPattern.exec(host);
 | 
			
		||||
    if (port) {
 | 
			
		||||
        port = port[0];
 | 
			
		||||
        if (port !== ':') {
 | 
			
		||||
            this.port = port.substr(1);
 | 
			
		||||
        }
 | 
			
		||||
        host = host.substr(0, host.length - port.length);
 | 
			
		||||
    }
 | 
			
		||||
    if (host) this.hostname = host;
 | 
			
		||||
};
 | 
			
		||||
							
								
								
									
										727
									
								
								packages/nodejs/src/util/index.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										727
									
								
								packages/nodejs/src/util/index.ts
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,727 @@
 | 
			
		||||
// Copyright Joyent, Inc. and other Node contributors.
 | 
			
		||||
//
 | 
			
		||||
// Permission is hereby granted, free of charge, to any person obtaining a
 | 
			
		||||
// copy of this software and associated documentation files (the
 | 
			
		||||
// "Software"), to deal in the Software without restriction, including
 | 
			
		||||
// without limitation the rights to use, copy, modify, merge, publish,
 | 
			
		||||
// distribute, sublicense, and/or sell copies of the Software, and to permit
 | 
			
		||||
// persons to whom the Software is furnished to do so, subject to the
 | 
			
		||||
// following conditions:
 | 
			
		||||
//
 | 
			
		||||
// The above copyright notice and this permission notice shall be included
 | 
			
		||||
// in all copies or substantial portions of the Software.
 | 
			
		||||
//
 | 
			
		||||
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
 | 
			
		||||
// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
 | 
			
		||||
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
 | 
			
		||||
// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
 | 
			
		||||
// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
 | 
			
		||||
// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
 | 
			
		||||
// USE OR OTHER DEALINGS IN THE SOFTWARE.
 | 
			
		||||
 | 
			
		||||
var getOwnPropertyDescriptors = Object.getOwnPropertyDescriptors ||
 | 
			
		||||
    function getOwnPropertyDescriptors(obj) {
 | 
			
		||||
        var keys = Object.keys(obj);
 | 
			
		||||
        var descriptors = {};
 | 
			
		||||
        for (var i = 0; i < keys.length; i++) {
 | 
			
		||||
            descriptors[keys[i]] = Object.getOwnPropertyDescriptor(obj, keys[i]);
 | 
			
		||||
        }
 | 
			
		||||
        return descriptors;
 | 
			
		||||
    };
 | 
			
		||||
 | 
			
		||||
var formatRegExp = /%[sdj%]/g;
 | 
			
		||||
exports.format = function (f) {
 | 
			
		||||
    if (!isString(f)) {
 | 
			
		||||
        var objects = [];
 | 
			
		||||
        for (var i = 0; i < arguments.length; i++) {
 | 
			
		||||
            objects.push(inspect(arguments[i]));
 | 
			
		||||
        }
 | 
			
		||||
        return objects.join(' ');
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    var i = 1;
 | 
			
		||||
    var args = arguments;
 | 
			
		||||
    var len = args.length;
 | 
			
		||||
    // @ts-ignore
 | 
			
		||||
    var str = String(f).replace(formatRegExp, function (x) {
 | 
			
		||||
        if (x === '%%') return '%';
 | 
			
		||||
        if (i >= len) return x;
 | 
			
		||||
        switch (x) {
 | 
			
		||||
            case '%s': return String(args[i++]);
 | 
			
		||||
            case '%d': return Number(args[i++]);
 | 
			
		||||
            case '%j':
 | 
			
		||||
                try {
 | 
			
		||||
                    return JSON.stringify(args[i++]);
 | 
			
		||||
                } catch (_) {
 | 
			
		||||
                    return '[Circular]';
 | 
			
		||||
                }
 | 
			
		||||
            default:
 | 
			
		||||
                return x;
 | 
			
		||||
        }
 | 
			
		||||
    });
 | 
			
		||||
    for (var x = args[i]; i < len; x = args[++i]) {
 | 
			
		||||
        if (isNull(x) || !isObject(x)) {
 | 
			
		||||
            str += ' ' + x;
 | 
			
		||||
        } else {
 | 
			
		||||
            str += ' ' + inspect(x);
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
    return str;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
// Mark that a method should not be used.
 | 
			
		||||
// Returns a modified function which warns once by default.
 | 
			
		||||
// If --no-deprecation is set, then it is a no-op.
 | 
			
		||||
exports.deprecate = function (fn, msg) {
 | 
			
		||||
    // @ts-ignore
 | 
			
		||||
    if (typeof process !== 'undefined' && process.noDeprecation === true) {
 | 
			
		||||
        return fn;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    // Allow for deprecating things in the process of starting up.
 | 
			
		||||
    if (typeof process === 'undefined') {
 | 
			
		||||
        return function () {
 | 
			
		||||
            // @ts-ignore
 | 
			
		||||
            return exports.deprecate(fn, msg).apply(this, arguments);
 | 
			
		||||
        };
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    var warned = false;
 | 
			
		||||
    function deprecated() {
 | 
			
		||||
        if (!warned) {
 | 
			
		||||
            // @ts-ignore
 | 
			
		||||
            if (process.throwDeprecation) {
 | 
			
		||||
                throw new Error(msg);
 | 
			
		||||
                // @ts-ignore
 | 
			
		||||
            } else if (process.traceDeprecation) {
 | 
			
		||||
                console.trace(msg);
 | 
			
		||||
            } else {
 | 
			
		||||
                console.error(msg);
 | 
			
		||||
            }
 | 
			
		||||
            warned = true;
 | 
			
		||||
        }
 | 
			
		||||
        // @ts-ignore
 | 
			
		||||
        return fn.apply(this, arguments);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    return deprecated;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
var debugs = {};
 | 
			
		||||
var debugEnvRegex = /^$/;
 | 
			
		||||
 | 
			
		||||
if (process.env.NODE_DEBUG) {
 | 
			
		||||
    var debugEnv = process.env.NODE_DEBUG;
 | 
			
		||||
    debugEnv = debugEnv.replace(/[|\\{}()[\]^$+?.]/g, '\\$&')
 | 
			
		||||
        .replace(/\*/g, '.*')
 | 
			
		||||
        .replace(/,/g, '$|^')
 | 
			
		||||
        .toUpperCase();
 | 
			
		||||
    debugEnvRegex = new RegExp('^' + debugEnv + '$', 'i');
 | 
			
		||||
}
 | 
			
		||||
exports.debuglog = function (set) {
 | 
			
		||||
    set = set.toUpperCase();
 | 
			
		||||
    if (!debugs[set]) {
 | 
			
		||||
        if (debugEnvRegex.test(set)) {
 | 
			
		||||
            var pid = process.pid;
 | 
			
		||||
            debugs[set] = function () {
 | 
			
		||||
                var msg = exports.format.apply(exports, arguments);
 | 
			
		||||
                console.error('%s %d: %s', set, pid, msg);
 | 
			
		||||
            };
 | 
			
		||||
        } else {
 | 
			
		||||
            debugs[set] = function () { };
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
    return debugs[set];
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Echos the value of a value. Trys to print the value out
 | 
			
		||||
 * in the best way possible given the different types.
 | 
			
		||||
 *
 | 
			
		||||
 * @param {Object} obj The object to print out.
 | 
			
		||||
 * @param {Object} opts Optional options object that alters the output.
 | 
			
		||||
 */
 | 
			
		||||
/* legacy: obj, showHidden, depth, colors*/
 | 
			
		||||
function inspect(obj, opts?) {
 | 
			
		||||
    // default options
 | 
			
		||||
    var ctx: any = {
 | 
			
		||||
        seen: [],
 | 
			
		||||
        stylize: stylizeNoColor
 | 
			
		||||
    };
 | 
			
		||||
    // legacy...
 | 
			
		||||
    if (arguments.length >= 3) ctx.depth = arguments[2];
 | 
			
		||||
    if (arguments.length >= 4) ctx.colors = arguments[3];
 | 
			
		||||
    if (isBoolean(opts)) {
 | 
			
		||||
        // legacy...
 | 
			
		||||
        ctx.showHidden = opts;
 | 
			
		||||
    } else if (opts) {
 | 
			
		||||
        // got an "options" object
 | 
			
		||||
        exports._extend(ctx, opts);
 | 
			
		||||
    }
 | 
			
		||||
    // set default options
 | 
			
		||||
    if (isUndefined(ctx.showHidden)) ctx.showHidden = false;
 | 
			
		||||
    if (isUndefined(ctx.depth)) ctx.depth = 2;
 | 
			
		||||
    if (isUndefined(ctx.colors)) ctx.colors = false;
 | 
			
		||||
    if (isUndefined(ctx.customInspect)) ctx.customInspect = true;
 | 
			
		||||
    if (ctx.colors) ctx.stylize = stylizeWithColor;
 | 
			
		||||
    return formatValue(ctx, obj, ctx.depth);
 | 
			
		||||
}
 | 
			
		||||
exports.inspect = inspect;
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
// http://en.wikipedia.org/wiki/ANSI_escape_code#graphics
 | 
			
		||||
inspect.colors = {
 | 
			
		||||
    'bold': [1, 22],
 | 
			
		||||
    'italic': [3, 23],
 | 
			
		||||
    'underline': [4, 24],
 | 
			
		||||
    'inverse': [7, 27],
 | 
			
		||||
    'white': [37, 39],
 | 
			
		||||
    'grey': [90, 39],
 | 
			
		||||
    'black': [30, 39],
 | 
			
		||||
    'blue': [34, 39],
 | 
			
		||||
    'cyan': [36, 39],
 | 
			
		||||
    'green': [32, 39],
 | 
			
		||||
    'magenta': [35, 39],
 | 
			
		||||
    'red': [31, 39],
 | 
			
		||||
    'yellow': [33, 39]
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
// Don't use 'blue' not visible on cmd.exe
 | 
			
		||||
inspect.styles = {
 | 
			
		||||
    'special': 'cyan',
 | 
			
		||||
    'number': 'yellow',
 | 
			
		||||
    'boolean': 'yellow',
 | 
			
		||||
    'undefined': 'grey',
 | 
			
		||||
    'null': 'bold',
 | 
			
		||||
    'string': 'green',
 | 
			
		||||
    'date': 'magenta',
 | 
			
		||||
    // "name": intentionally not styling
 | 
			
		||||
    'regexp': 'red'
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
function stylizeWithColor(str, styleType) {
 | 
			
		||||
    var style = inspect.styles[styleType];
 | 
			
		||||
 | 
			
		||||
    if (style) {
 | 
			
		||||
        return '\u001b[' + inspect.colors[style][0] + 'm' + str +
 | 
			
		||||
            '\u001b[' + inspect.colors[style][1] + 'm';
 | 
			
		||||
    } else {
 | 
			
		||||
        return str;
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
function stylizeNoColor(str, styleType) {
 | 
			
		||||
    return str;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
function arrayToHash(array) {
 | 
			
		||||
    var hash = {};
 | 
			
		||||
 | 
			
		||||
    array.forEach(function (val, idx) {
 | 
			
		||||
        hash[val] = true;
 | 
			
		||||
    });
 | 
			
		||||
 | 
			
		||||
    return hash;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
function formatValue(ctx, value, recurseTimes) {
 | 
			
		||||
    // Provide a hook for user-specified inspect functions.
 | 
			
		||||
    // Check that value is an object with an inspect function on it
 | 
			
		||||
    if (ctx.customInspect &&
 | 
			
		||||
        value &&
 | 
			
		||||
        isFunction(value.inspect) &&
 | 
			
		||||
        // Filter out the util module, it's inspect function is special
 | 
			
		||||
        value.inspect !== exports.inspect &&
 | 
			
		||||
        // Also filter out any prototype objects using the circular check.
 | 
			
		||||
        !(value.constructor && value.constructor.prototype === value)) {
 | 
			
		||||
        var ret = value.inspect(recurseTimes, ctx);
 | 
			
		||||
        if (!isString(ret)) {
 | 
			
		||||
            ret = formatValue(ctx, ret, recurseTimes);
 | 
			
		||||
        }
 | 
			
		||||
        return ret;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    // Primitive types cannot have properties
 | 
			
		||||
    var primitive = formatPrimitive(ctx, value);
 | 
			
		||||
    if (primitive) {
 | 
			
		||||
        return primitive;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    // Look up the keys of the object.
 | 
			
		||||
    var keys = Object.keys(value);
 | 
			
		||||
    var visibleKeys = arrayToHash(keys);
 | 
			
		||||
 | 
			
		||||
    if (ctx.showHidden) {
 | 
			
		||||
        keys = Object.getOwnPropertyNames(value);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    // IE doesn't make error fields non-enumerable
 | 
			
		||||
    // http://msdn.microsoft.com/en-us/library/ie/dww52sbt(v=vs.94).aspx
 | 
			
		||||
    if (isError(value)
 | 
			
		||||
        && (keys.indexOf('message') >= 0 || keys.indexOf('description') >= 0)) {
 | 
			
		||||
        return formatError(value);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    // Some type of object without properties can be shortcutted.
 | 
			
		||||
    if (keys.length === 0) {
 | 
			
		||||
        if (isFunction(value)) {
 | 
			
		||||
            var name = value.name ? ': ' + value.name : '';
 | 
			
		||||
            return ctx.stylize('[Function' + name + ']', 'special');
 | 
			
		||||
        }
 | 
			
		||||
        if (isRegExp(value)) {
 | 
			
		||||
            return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp');
 | 
			
		||||
        }
 | 
			
		||||
        if (isDate(value)) {
 | 
			
		||||
            return ctx.stylize(Date.prototype.toString.call(value), 'date');
 | 
			
		||||
        }
 | 
			
		||||
        if (isError(value)) {
 | 
			
		||||
            return formatError(value);
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    var base = '', array = false, braces = ['{', '}'];
 | 
			
		||||
 | 
			
		||||
    // Make Array say that they are Array
 | 
			
		||||
    if (isArray(value)) {
 | 
			
		||||
        array = true;
 | 
			
		||||
        braces = ['[', ']'];
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    // Make functions say that they are functions
 | 
			
		||||
    if (isFunction(value)) {
 | 
			
		||||
        var n = value.name ? ': ' + value.name : '';
 | 
			
		||||
        base = ' [Function' + n + ']';
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    // Make RegExps say that they are RegExps
 | 
			
		||||
    if (isRegExp(value)) {
 | 
			
		||||
        base = ' ' + RegExp.prototype.toString.call(value);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    // Make dates with properties first say the date
 | 
			
		||||
    if (isDate(value)) {
 | 
			
		||||
        base = ' ' + Date.prototype.toUTCString.call(value);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    // Make error with message first say the error
 | 
			
		||||
    if (isError(value)) {
 | 
			
		||||
        base = ' ' + formatError(value);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    if (keys.length === 0 && (!array || value.length == 0)) {
 | 
			
		||||
        return braces[0] + base + braces[1];
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    if (recurseTimes < 0) {
 | 
			
		||||
        if (isRegExp(value)) {
 | 
			
		||||
            return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp');
 | 
			
		||||
        } else {
 | 
			
		||||
            return ctx.stylize('[Object]', 'special');
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    ctx.seen.push(value);
 | 
			
		||||
 | 
			
		||||
    var output;
 | 
			
		||||
    if (array) {
 | 
			
		||||
        output = formatArray(ctx, value, recurseTimes, visibleKeys, keys);
 | 
			
		||||
    } else {
 | 
			
		||||
        output = keys.map(function (key) {
 | 
			
		||||
            return formatProperty(ctx, value, recurseTimes, visibleKeys, key, array);
 | 
			
		||||
        });
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    ctx.seen.pop();
 | 
			
		||||
 | 
			
		||||
    return reduceToSingleString(output, base, braces);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
function formatPrimitive(ctx, value) {
 | 
			
		||||
    if (isUndefined(value))
 | 
			
		||||
        return ctx.stylize('undefined', 'undefined');
 | 
			
		||||
    if (isString(value)) {
 | 
			
		||||
        var simple = '\'' + JSON.stringify(value).replace(/^"|"$/g, '')
 | 
			
		||||
            .replace(/'/g, "\\'")
 | 
			
		||||
            .replace(/\\"/g, '"') + '\'';
 | 
			
		||||
        return ctx.stylize(simple, 'string');
 | 
			
		||||
    }
 | 
			
		||||
    if (isNumber(value))
 | 
			
		||||
        return ctx.stylize('' + value, 'number');
 | 
			
		||||
    if (isBoolean(value))
 | 
			
		||||
        return ctx.stylize('' + value, 'boolean');
 | 
			
		||||
    // For some reason typeof null is "object", so special case here.
 | 
			
		||||
    if (isNull(value))
 | 
			
		||||
        return ctx.stylize('null', 'null');
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
function formatError(value) {
 | 
			
		||||
    return '[' + Error.prototype.toString.call(value) + ']';
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
function formatArray(ctx, value, recurseTimes, visibleKeys, keys) {
 | 
			
		||||
    var output = [];
 | 
			
		||||
    for (var i = 0, l = value.length; i < l; ++i) {
 | 
			
		||||
        if (hasOwnProperty(value, String(i))) {
 | 
			
		||||
            output.push(formatProperty(ctx, value, recurseTimes, visibleKeys,
 | 
			
		||||
                String(i), true));
 | 
			
		||||
        } else {
 | 
			
		||||
            output.push('');
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
    keys.forEach(function (key) {
 | 
			
		||||
        if (!key.match(/^\d+$/)) {
 | 
			
		||||
            output.push(formatProperty(ctx, value, recurseTimes, visibleKeys,
 | 
			
		||||
                key, true));
 | 
			
		||||
        }
 | 
			
		||||
    });
 | 
			
		||||
    return output;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
function formatProperty(ctx, value, recurseTimes, visibleKeys, key, array) {
 | 
			
		||||
    var name, str, desc;
 | 
			
		||||
    desc = Object.getOwnPropertyDescriptor(value, key) || { value: value[key] };
 | 
			
		||||
    if (desc.get) {
 | 
			
		||||
        if (desc.set) {
 | 
			
		||||
            str = ctx.stylize('[Getter/Setter]', 'special');
 | 
			
		||||
        } else {
 | 
			
		||||
            str = ctx.stylize('[Getter]', 'special');
 | 
			
		||||
        }
 | 
			
		||||
    } else {
 | 
			
		||||
        if (desc.set) {
 | 
			
		||||
            str = ctx.stylize('[Setter]', 'special');
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
    if (!hasOwnProperty(visibleKeys, key)) {
 | 
			
		||||
        name = '[' + key + ']';
 | 
			
		||||
    }
 | 
			
		||||
    if (!str) {
 | 
			
		||||
        if (ctx.seen.indexOf(desc.value) < 0) {
 | 
			
		||||
            if (isNull(recurseTimes)) {
 | 
			
		||||
                str = formatValue(ctx, desc.value, null);
 | 
			
		||||
            } else {
 | 
			
		||||
                str = formatValue(ctx, desc.value, recurseTimes - 1);
 | 
			
		||||
            }
 | 
			
		||||
            if (str.indexOf('\n') > -1) {
 | 
			
		||||
                if (array) {
 | 
			
		||||
                    str = str.split('\n').map(function (line) {
 | 
			
		||||
                        return '  ' + line;
 | 
			
		||||
                    }).join('\n').substr(2);
 | 
			
		||||
                } else {
 | 
			
		||||
                    str = '\n' + str.split('\n').map(function (line) {
 | 
			
		||||
                        return '   ' + line;
 | 
			
		||||
                    }).join('\n');
 | 
			
		||||
                }
 | 
			
		||||
            }
 | 
			
		||||
        } else {
 | 
			
		||||
            str = ctx.stylize('[Circular]', 'special');
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
    if (isUndefined(name)) {
 | 
			
		||||
        if (array && key.match(/^\d+$/)) {
 | 
			
		||||
            return str;
 | 
			
		||||
        }
 | 
			
		||||
        name = JSON.stringify('' + key);
 | 
			
		||||
        if (name.match(/^"([a-zA-Z_][a-zA-Z_0-9]*)"$/)) {
 | 
			
		||||
            name = name.substr(1, name.length - 2);
 | 
			
		||||
            name = ctx.stylize(name, 'name');
 | 
			
		||||
        } else {
 | 
			
		||||
            name = name.replace(/'/g, "\\'")
 | 
			
		||||
                .replace(/\\"/g, '"')
 | 
			
		||||
                .replace(/(^"|"$)/g, "'");
 | 
			
		||||
            name = ctx.stylize(name, 'string');
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    return name + ': ' + str;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
function reduceToSingleString(output, base, braces) {
 | 
			
		||||
    var numLinesEst = 0;
 | 
			
		||||
    var length = output.reduce(function (prev, cur) {
 | 
			
		||||
        numLinesEst++;
 | 
			
		||||
        if (cur.indexOf('\n') >= 0) numLinesEst++;
 | 
			
		||||
        return prev + cur.replace(/\u001b\[\d\d?m/g, '').length + 1;
 | 
			
		||||
    }, 0);
 | 
			
		||||
 | 
			
		||||
    if (length > 60) {
 | 
			
		||||
        return braces[0] +
 | 
			
		||||
            (base === '' ? '' : 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.types = require('./support/types');
 | 
			
		||||
 | 
			
		||||
function isArray(ar) {
 | 
			
		||||
    return Array.isArray(ar);
 | 
			
		||||
}
 | 
			
		||||
exports.isArray = 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;
 | 
			
		||||
}
 | 
			
		||||
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 === void 0;
 | 
			
		||||
}
 | 
			
		||||
exports.isUndefined = isUndefined;
 | 
			
		||||
 | 
			
		||||
function isRegExp(re) {
 | 
			
		||||
    return isObject(re) && objectToString(re) === '[object RegExp]';
 | 
			
		||||
}
 | 
			
		||||
exports.isRegExp = isRegExp;
 | 
			
		||||
exports.types.isRegExp = isRegExp;
 | 
			
		||||
 | 
			
		||||
function isObject(arg) {
 | 
			
		||||
    return typeof arg === 'object' && arg !== null;
 | 
			
		||||
}
 | 
			
		||||
exports.isObject = isObject;
 | 
			
		||||
 | 
			
		||||
function isDate(d) {
 | 
			
		||||
    return isObject(d) && objectToString(d) === '[object Date]';
 | 
			
		||||
}
 | 
			
		||||
exports.isDate = isDate;
 | 
			
		||||
exports.types.isDate = isDate;
 | 
			
		||||
 | 
			
		||||
function isError(e) {
 | 
			
		||||
    return isObject(e) &&
 | 
			
		||||
        (objectToString(e) === '[object Error]' || e instanceof Error);
 | 
			
		||||
}
 | 
			
		||||
exports.isError = isError;
 | 
			
		||||
exports.types.isNativeError = isError;
 | 
			
		||||
 | 
			
		||||
function isFunction(arg) {
 | 
			
		||||
    return typeof arg === 'function';
 | 
			
		||||
}
 | 
			
		||||
exports.isFunction = isFunction;
 | 
			
		||||
 | 
			
		||||
function isPrimitive(arg) {
 | 
			
		||||
    return arg === null ||
 | 
			
		||||
        typeof arg === 'boolean' ||
 | 
			
		||||
        typeof arg === 'number' ||
 | 
			
		||||
        typeof arg === 'string' ||
 | 
			
		||||
        typeof arg === 'symbol' ||  // ES6 symbol
 | 
			
		||||
        typeof arg === 'undefined';
 | 
			
		||||
}
 | 
			
		||||
exports.isPrimitive = isPrimitive;
 | 
			
		||||
 | 
			
		||||
exports.isBuffer = require('./support/isBuffer');
 | 
			
		||||
 | 
			
		||||
function objectToString(o) {
 | 
			
		||||
    return Object.prototype.toString.call(o);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
function pad(n) {
 | 
			
		||||
    return n < 10 ? '0' + n.toString(10) : n.toString(10);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
var months = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep',
 | 
			
		||||
    'Oct', 'Nov', 'Dec'];
 | 
			
		||||
 | 
			
		||||
// 26 Feb 16:19:34
 | 
			
		||||
function timestamp() {
 | 
			
		||||
    var d = new Date();
 | 
			
		||||
    var time = [pad(d.getHours()),
 | 
			
		||||
    pad(d.getMinutes()),
 | 
			
		||||
    pad(d.getSeconds())].join(':');
 | 
			
		||||
    return [d.getDate(), months[d.getMonth()], time].join(' ');
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
// log is just a thin wrapper to console.log that prepends a timestamp
 | 
			
		||||
exports.log = function () {
 | 
			
		||||
    console.log('%s - %s', timestamp(), exports.format.apply(exports, arguments));
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Inherit the prototype methods from one constructor into another.
 | 
			
		||||
 *
 | 
			
		||||
 * The Function.prototype.inherits from lang.js rewritten as a standalone
 | 
			
		||||
 * function (not on Function.prototype). NOTE: If this file is to be loaded
 | 
			
		||||
 * during bootstrapping this function needs to be rewritten using some native
 | 
			
		||||
 * functions as prototype setup using normal JavaScript does not work as
 | 
			
		||||
 * expected during bootstrapping (see mirror.js in r114903).
 | 
			
		||||
 *
 | 
			
		||||
 * @param {function} ctor Constructor function which needs to inherit the
 | 
			
		||||
 *     prototype.
 | 
			
		||||
 * @param {function} superCtor Constructor function to inherit prototype from.
 | 
			
		||||
 */
 | 
			
		||||
exports.inherits = require('inherits');
 | 
			
		||||
 | 
			
		||||
exports._extend = function (origin, add) {
 | 
			
		||||
    // Don't do anything if add isn't an object
 | 
			
		||||
    if (!add || !isObject(add)) return origin;
 | 
			
		||||
 | 
			
		||||
    var keys = Object.keys(add);
 | 
			
		||||
    var i = keys.length;
 | 
			
		||||
    while (i--) {
 | 
			
		||||
        origin[keys[i]] = add[keys[i]];
 | 
			
		||||
    }
 | 
			
		||||
    return origin;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
// @ts-ignore
 | 
			
		||||
function hasOwnProperty(obj, prop) {
 | 
			
		||||
    return Object.prototype.hasOwnProperty.call(obj, prop);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
var kCustomPromisifiedSymbol = typeof Symbol !== 'undefined' ? Symbol('util.promisify.custom') : undefined;
 | 
			
		||||
 | 
			
		||||
exports.promisify = function promisify(original) {
 | 
			
		||||
    if (typeof original !== 'function')
 | 
			
		||||
        throw new TypeError('The "original" argument must be of type Function');
 | 
			
		||||
 | 
			
		||||
    if (kCustomPromisifiedSymbol && original[kCustomPromisifiedSymbol]) {
 | 
			
		||||
        // @ts-ignore
 | 
			
		||||
        var fn = original[kCustomPromisifiedSymbol];
 | 
			
		||||
        if (typeof fn !== 'function') {
 | 
			
		||||
            throw new TypeError('The "util.promisify.custom" argument must be of type Function');
 | 
			
		||||
        }
 | 
			
		||||
        Object.defineProperty(fn, kCustomPromisifiedSymbol, {
 | 
			
		||||
            value: fn, enumerable: false, writable: false, configurable: true
 | 
			
		||||
        });
 | 
			
		||||
        return fn;
 | 
			
		||||
    }
 | 
			
		||||
    // @ts-ignore
 | 
			
		||||
    function fn() {
 | 
			
		||||
        var promiseResolve, promiseReject;
 | 
			
		||||
        var promise = new Promise(function (resolve, reject) {
 | 
			
		||||
            promiseResolve = resolve;
 | 
			
		||||
            promiseReject = reject;
 | 
			
		||||
        });
 | 
			
		||||
 | 
			
		||||
        var args = [];
 | 
			
		||||
        for (var i = 0; i < arguments.length; i++) {
 | 
			
		||||
            args.push(arguments[i]);
 | 
			
		||||
        }
 | 
			
		||||
        args.push(function (err, value) {
 | 
			
		||||
            if (err) {
 | 
			
		||||
                promiseReject(err);
 | 
			
		||||
            } else {
 | 
			
		||||
                promiseResolve(value);
 | 
			
		||||
            }
 | 
			
		||||
        });
 | 
			
		||||
 | 
			
		||||
        try {
 | 
			
		||||
            // @ts-ignore
 | 
			
		||||
            original.apply(this, args);
 | 
			
		||||
        } catch (err) {
 | 
			
		||||
            promiseReject(err);
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        return promise;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    Object.setPrototypeOf(fn, Object.getPrototypeOf(original));
 | 
			
		||||
 | 
			
		||||
    if (kCustomPromisifiedSymbol) Object.defineProperty(fn, kCustomPromisifiedSymbol, {
 | 
			
		||||
        value: fn, enumerable: false, writable: false, configurable: true
 | 
			
		||||
    });
 | 
			
		||||
    return Object.defineProperties(
 | 
			
		||||
        fn,
 | 
			
		||||
        getOwnPropertyDescriptors(original)
 | 
			
		||||
    );
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
exports.promisify.custom = kCustomPromisifiedSymbol
 | 
			
		||||
 | 
			
		||||
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
 | 
			
		||||
    // occurred", we error-wrap so the callback consumer can distinguish between
 | 
			
		||||
    // "the promise rejected with null" or "the promise fulfilled with undefined".
 | 
			
		||||
    if (!reason) {
 | 
			
		||||
        var newReason = new Error('Promise was rejected with a falsy value');
 | 
			
		||||
        // @ts-ignore
 | 
			
		||||
        newReason.reason = reason;
 | 
			
		||||
        reason = newReason;
 | 
			
		||||
    }
 | 
			
		||||
    return cb(reason);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function callbackify(original) {
 | 
			
		||||
    if (typeof original !== 'function') {
 | 
			
		||||
        throw new TypeError('The "original" argument must be of type Function');
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    // We DO NOT return the promise as it gives the user a false sense that
 | 
			
		||||
    // the promise is actually somehow related to the callback's execution
 | 
			
		||||
    // and that the callback throwing will reject the promise.
 | 
			
		||||
    function callbackified() {
 | 
			
		||||
        var args = [];
 | 
			
		||||
        for (var i = 0; i < arguments.length; i++) {
 | 
			
		||||
            args.push(arguments[i]);
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        var maybeCb = args.pop();
 | 
			
		||||
        if (typeof maybeCb !== 'function') {
 | 
			
		||||
            throw new TypeError('The last argument must be of type Function');
 | 
			
		||||
        }
 | 
			
		||||
        // @ts-ignore
 | 
			
		||||
        var self = this;
 | 
			
		||||
        var cb = function () {
 | 
			
		||||
            return maybeCb.apply(self, arguments);
 | 
			
		||||
        };
 | 
			
		||||
        // In true node style we process the callback on `nextTick` with all the
 | 
			
		||||
        // implications (stack, `uncaughtException`, `async_hooks`)
 | 
			
		||||
        // @ts-ignore
 | 
			
		||||
        original.apply(this, args)
 | 
			
		||||
            .then(function (ret) { process.nextTick(cb.bind(null, null, ret)) },
 | 
			
		||||
                function (rej) { process.nextTick(callbackifyOnRejected.bind(null, rej, cb)) });
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    Object.setPrototypeOf(callbackified, Object.getPrototypeOf(original));
 | 
			
		||||
    Object.defineProperties(callbackified,
 | 
			
		||||
        getOwnPropertyDescriptors(original));
 | 
			
		||||
    return callbackified;
 | 
			
		||||
}
 | 
			
		||||
exports.callbackify = callbackify;
 | 
			
		||||
							
								
								
									
										3
									
								
								packages/nodejs/src/util/support/isBuffer.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								packages/nodejs/src/util/support/isBuffer.ts
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,3 @@
 | 
			
		||||
module.exports = function isBuffer(arg) {
 | 
			
		||||
    return arg instanceof Buffer;
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										6
									
								
								packages/nodejs/src/util/support/isBufferBrowser.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								packages/nodejs/src/util/support/isBufferBrowser.ts
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,6 @@
 | 
			
		||||
module.exports = function isBuffer(arg) {
 | 
			
		||||
    return arg && typeof arg === 'object'
 | 
			
		||||
        && typeof arg.copy === 'function'
 | 
			
		||||
        && typeof arg.fill === 'function'
 | 
			
		||||
        && typeof arg.readUInt8 === 'function';
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										424
									
								
								packages/nodejs/src/util/support/types.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										424
									
								
								packages/nodejs/src/util/support/types.ts
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,424 @@
 | 
			
		||||
// Currently in sync with Node.js lib/internal/util/types.js
 | 
			
		||||
// https://github.com/nodejs/node/commit/112cc7c27551254aa2b17098fb774867f05ed0d9
 | 
			
		||||
 | 
			
		||||
'use strict';
 | 
			
		||||
 | 
			
		||||
var isBuffer = require('./isBuffer');
 | 
			
		||||
 | 
			
		||||
var isArgumentsObject = require('is-arguments');
 | 
			
		||||
var isGeneratorFunction = require('is-generator-function');
 | 
			
		||||
 | 
			
		||||
function uncurryThis(f) {
 | 
			
		||||
    return f.call.bind(f);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
var BigIntSupported = typeof BigInt !== 'undefined';
 | 
			
		||||
var SymbolSupported = typeof Symbol !== 'undefined';
 | 
			
		||||
var SymbolToStringTagSupported = SymbolSupported && typeof Symbol.toStringTag !== 'undefined';
 | 
			
		||||
var Uint8ArraySupported = typeof Uint8Array !== 'undefined';
 | 
			
		||||
var ArrayBufferSupported = typeof ArrayBuffer !== 'undefined';
 | 
			
		||||
 | 
			
		||||
if (Uint8ArraySupported && SymbolToStringTagSupported) {
 | 
			
		||||
    var TypedArrayPrototype = Object.getPrototypeOf(Uint8Array.prototype);
 | 
			
		||||
 | 
			
		||||
    var TypedArrayProto_toStringTag =
 | 
			
		||||
        uncurryThis(
 | 
			
		||||
            Object.getOwnPropertyDescriptor(TypedArrayPrototype,
 | 
			
		||||
                Symbol.toStringTag).get);
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
var ObjectToString = uncurryThis(Object.prototype.toString);
 | 
			
		||||
 | 
			
		||||
var numberValue = uncurryThis(Number.prototype.valueOf);
 | 
			
		||||
var stringValue = uncurryThis(String.prototype.valueOf);
 | 
			
		||||
var booleanValue = uncurryThis(Boolean.prototype.valueOf);
 | 
			
		||||
 | 
			
		||||
if (BigIntSupported) {
 | 
			
		||||
    var bigIntValue = uncurryThis(BigInt.prototype.valueOf);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
if (SymbolSupported) {
 | 
			
		||||
    var symbolValue = uncurryThis(Symbol.prototype.valueOf);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function checkBoxedPrimitive(value, prototypeValueOf) {
 | 
			
		||||
    if (typeof value !== 'object') {
 | 
			
		||||
        return false;
 | 
			
		||||
    }
 | 
			
		||||
    try {
 | 
			
		||||
        prototypeValueOf(value);
 | 
			
		||||
        return true;
 | 
			
		||||
    } catch (e) {
 | 
			
		||||
        return false;
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
exports.isArgumentsObject = isArgumentsObject;
 | 
			
		||||
 | 
			
		||||
exports.isGeneratorFunction = isGeneratorFunction;
 | 
			
		||||
 | 
			
		||||
// Taken from here and modified for better browser support
 | 
			
		||||
// https://github.com/sindresorhus/p-is-promise/blob/cda35a513bda03f977ad5cde3a079d237e82d7ef/index.js
 | 
			
		||||
function isPromise(input) {
 | 
			
		||||
    return (
 | 
			
		||||
        (
 | 
			
		||||
            typeof Promise !== 'undefined' &&
 | 
			
		||||
            input instanceof Promise
 | 
			
		||||
        ) ||
 | 
			
		||||
        (
 | 
			
		||||
            input !== null &&
 | 
			
		||||
            typeof input === 'object' &&
 | 
			
		||||
            typeof input.then === 'function' &&
 | 
			
		||||
            typeof input.catch === 'function'
 | 
			
		||||
        )
 | 
			
		||||
    );
 | 
			
		||||
}
 | 
			
		||||
exports.isPromise = isPromise;
 | 
			
		||||
 | 
			
		||||
function isArrayBufferView(value) {
 | 
			
		||||
    if (ArrayBufferSupported && ArrayBuffer.isView) {
 | 
			
		||||
        return ArrayBuffer.isView(value);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    return (
 | 
			
		||||
        isTypedArray(value) ||
 | 
			
		||||
        isDataView(value)
 | 
			
		||||
    );
 | 
			
		||||
}
 | 
			
		||||
exports.isArrayBufferView = isArrayBufferView;
 | 
			
		||||
 | 
			
		||||
function isTypedArray(value) {
 | 
			
		||||
    if (Uint8ArraySupported && SymbolToStringTagSupported) {
 | 
			
		||||
        return TypedArrayProto_toStringTag(value) !== undefined;
 | 
			
		||||
    } else {
 | 
			
		||||
        return (
 | 
			
		||||
            isUint8Array(value) ||
 | 
			
		||||
            isUint8ClampedArray(value) ||
 | 
			
		||||
            isUint16Array(value) ||
 | 
			
		||||
            isUint32Array(value) ||
 | 
			
		||||
            isInt8Array(value) ||
 | 
			
		||||
            isInt16Array(value) ||
 | 
			
		||||
            isInt32Array(value) ||
 | 
			
		||||
            isFloat32Array(value) ||
 | 
			
		||||
            isFloat64Array(value) ||
 | 
			
		||||
            isBigInt64Array(value) ||
 | 
			
		||||
            isBigUint64Array(value)
 | 
			
		||||
        );
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
exports.isTypedArray = isTypedArray;
 | 
			
		||||
 | 
			
		||||
function isUint8Array(value) {
 | 
			
		||||
    if (Uint8ArraySupported && SymbolToStringTagSupported) {
 | 
			
		||||
        return TypedArrayProto_toStringTag(value) === 'Uint8Array';
 | 
			
		||||
    } else {
 | 
			
		||||
        return (
 | 
			
		||||
            ObjectToString(value) === '[object Uint8Array]' ||
 | 
			
		||||
            // If it's a Buffer instance _and_ has a `.buffer` property,
 | 
			
		||||
            // this is an ArrayBuffer based buffer; thus it's an Uint8Array
 | 
			
		||||
            // (Old Node.js had a custom non-Uint8Array implementation)
 | 
			
		||||
            isBuffer(value) && value.buffer !== undefined
 | 
			
		||||
        );
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
exports.isUint8Array = isUint8Array;
 | 
			
		||||
 | 
			
		||||
function isUint8ClampedArray(value) {
 | 
			
		||||
    if (Uint8ArraySupported && SymbolToStringTagSupported) {
 | 
			
		||||
        return TypedArrayProto_toStringTag(value) === 'Uint8ClampedArray';
 | 
			
		||||
    } else {
 | 
			
		||||
        return ObjectToString(value) === '[object Uint8ClampedArray]';
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
exports.isUint8ClampedArray = isUint8ClampedArray;
 | 
			
		||||
 | 
			
		||||
function isUint16Array(value) {
 | 
			
		||||
    if (Uint8ArraySupported && SymbolToStringTagSupported) {
 | 
			
		||||
        return TypedArrayProto_toStringTag(value) === 'Uint16Array';
 | 
			
		||||
    } else {
 | 
			
		||||
        return ObjectToString(value) === '[object Uint16Array]';
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
exports.isUint16Array = isUint16Array;
 | 
			
		||||
 | 
			
		||||
function isUint32Array(value) {
 | 
			
		||||
    if (Uint8ArraySupported && SymbolToStringTagSupported) {
 | 
			
		||||
        return TypedArrayProto_toStringTag(value) === 'Uint32Array';
 | 
			
		||||
    } else {
 | 
			
		||||
        return ObjectToString(value) === '[object Uint32Array]';
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
exports.isUint32Array = isUint32Array;
 | 
			
		||||
 | 
			
		||||
function isInt8Array(value) {
 | 
			
		||||
    if (Uint8ArraySupported && SymbolToStringTagSupported) {
 | 
			
		||||
        return TypedArrayProto_toStringTag(value) === 'Int8Array';
 | 
			
		||||
    } else {
 | 
			
		||||
        return ObjectToString(value) === '[object Int8Array]';
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
exports.isInt8Array = isInt8Array;
 | 
			
		||||
 | 
			
		||||
function isInt16Array(value) {
 | 
			
		||||
    if (Uint8ArraySupported && SymbolToStringTagSupported) {
 | 
			
		||||
        return TypedArrayProto_toStringTag(value) === 'Int16Array';
 | 
			
		||||
    } else {
 | 
			
		||||
        return ObjectToString(value) === '[object Int16Array]';
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
exports.isInt16Array = isInt16Array;
 | 
			
		||||
 | 
			
		||||
function isInt32Array(value) {
 | 
			
		||||
    if (Uint8ArraySupported && SymbolToStringTagSupported) {
 | 
			
		||||
        return TypedArrayProto_toStringTag(value) === 'Int32Array';
 | 
			
		||||
    } else {
 | 
			
		||||
        return ObjectToString(value) === '[object Int32Array]';
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
exports.isInt32Array = isInt32Array;
 | 
			
		||||
 | 
			
		||||
function isFloat32Array(value) {
 | 
			
		||||
    if (Uint8ArraySupported && SymbolToStringTagSupported) {
 | 
			
		||||
        return TypedArrayProto_toStringTag(value) === 'Float32Array';
 | 
			
		||||
    } else {
 | 
			
		||||
        return ObjectToString(value) === '[object Float32Array]';
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
exports.isFloat32Array = isFloat32Array;
 | 
			
		||||
 | 
			
		||||
function isFloat64Array(value) {
 | 
			
		||||
    if (Uint8ArraySupported && SymbolToStringTagSupported) {
 | 
			
		||||
        return TypedArrayProto_toStringTag(value) === 'Float64Array';
 | 
			
		||||
    } else {
 | 
			
		||||
        return ObjectToString(value) === '[object Float64Array]';
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
exports.isFloat64Array = isFloat64Array;
 | 
			
		||||
 | 
			
		||||
function isBigInt64Array(value) {
 | 
			
		||||
    if (Uint8ArraySupported && SymbolToStringTagSupported) {
 | 
			
		||||
        return TypedArrayProto_toStringTag(value) === 'BigInt64Array';
 | 
			
		||||
    } else {
 | 
			
		||||
        return ObjectToString(value) === '[object BigInt64Array]';
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
exports.isBigInt64Array = isBigInt64Array;
 | 
			
		||||
 | 
			
		||||
function isBigUint64Array(value) {
 | 
			
		||||
    if (Uint8ArraySupported && SymbolToStringTagSupported) {
 | 
			
		||||
        return TypedArrayProto_toStringTag(value) === 'BigUint64Array';
 | 
			
		||||
    } else {
 | 
			
		||||
        return ObjectToString(value) === '[object BigUint64Array]';
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
exports.isBigUint64Array = isBigUint64Array;
 | 
			
		||||
 | 
			
		||||
function isMapToString(value) {
 | 
			
		||||
    return ObjectToString(value) === '[object Map]';
 | 
			
		||||
}
 | 
			
		||||
isMapToString.working = (
 | 
			
		||||
    typeof Map !== 'undefined' &&
 | 
			
		||||
    isMapToString(new Map())
 | 
			
		||||
);
 | 
			
		||||
 | 
			
		||||
function isMap(value) {
 | 
			
		||||
    if (typeof Map === 'undefined') {
 | 
			
		||||
        return false;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    return isMapToString.working
 | 
			
		||||
        ? isMapToString(value)
 | 
			
		||||
        : value instanceof Map;
 | 
			
		||||
}
 | 
			
		||||
exports.isMap = isMap;
 | 
			
		||||
 | 
			
		||||
function isSetToString(value) {
 | 
			
		||||
    return ObjectToString(value) === '[object Set]';
 | 
			
		||||
}
 | 
			
		||||
isSetToString.working = (
 | 
			
		||||
    typeof Set !== 'undefined' &&
 | 
			
		||||
    isSetToString(new Set())
 | 
			
		||||
);
 | 
			
		||||
function isSet(value) {
 | 
			
		||||
    if (typeof Set === 'undefined') {
 | 
			
		||||
        return false;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    return isSetToString.working
 | 
			
		||||
        ? isSetToString(value)
 | 
			
		||||
        : value instanceof Set;
 | 
			
		||||
}
 | 
			
		||||
exports.isSet = isSet;
 | 
			
		||||
 | 
			
		||||
function isWeakMapToString(value) {
 | 
			
		||||
    return ObjectToString(value) === '[object WeakMap]';
 | 
			
		||||
}
 | 
			
		||||
isWeakMapToString.working = (
 | 
			
		||||
    typeof WeakMap !== 'undefined' &&
 | 
			
		||||
    isWeakMapToString(new WeakMap())
 | 
			
		||||
);
 | 
			
		||||
function isWeakMap(value) {
 | 
			
		||||
    if (typeof WeakMap === 'undefined') {
 | 
			
		||||
        return false;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    return isWeakMapToString.working
 | 
			
		||||
        ? isWeakMapToString(value)
 | 
			
		||||
        : value instanceof WeakMap;
 | 
			
		||||
}
 | 
			
		||||
exports.isWeakMap = isWeakMap;
 | 
			
		||||
 | 
			
		||||
function isWeakSetToString(value) {
 | 
			
		||||
    return ObjectToString(value) === '[object WeakSet]';
 | 
			
		||||
}
 | 
			
		||||
isWeakSetToString.working = (
 | 
			
		||||
    typeof WeakSet !== 'undefined' &&
 | 
			
		||||
    isWeakSetToString(new WeakSet())
 | 
			
		||||
);
 | 
			
		||||
function isWeakSet(value) {
 | 
			
		||||
    return isWeakSetToString(value);
 | 
			
		||||
    if (typeof WeakSet === 'undefined') {
 | 
			
		||||
        return false;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    return isWeakSetToString.working
 | 
			
		||||
        ? isWeakSetToString(value)
 | 
			
		||||
        : value instanceof WeakSet;
 | 
			
		||||
}
 | 
			
		||||
exports.isWeakSet = isWeakSet;
 | 
			
		||||
 | 
			
		||||
function isArrayBufferToString(value) {
 | 
			
		||||
    return ObjectToString(value) === '[object ArrayBuffer]';
 | 
			
		||||
}
 | 
			
		||||
isArrayBufferToString.working = (
 | 
			
		||||
    typeof ArrayBuffer !== 'undefined' &&
 | 
			
		||||
    // @ts-ignore
 | 
			
		||||
    isArrayBufferToString(new ArrayBuffer())
 | 
			
		||||
);
 | 
			
		||||
function isArrayBuffer(value) {
 | 
			
		||||
    if (typeof ArrayBuffer === 'undefined') {
 | 
			
		||||
        return false;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    return isArrayBufferToString.working
 | 
			
		||||
        ? isArrayBufferToString(value)
 | 
			
		||||
        : value instanceof ArrayBuffer;
 | 
			
		||||
}
 | 
			
		||||
exports.isArrayBuffer = isArrayBuffer;
 | 
			
		||||
 | 
			
		||||
function isDataViewToString(value) {
 | 
			
		||||
    return ObjectToString(value) === '[object DataView]';
 | 
			
		||||
}
 | 
			
		||||
isDataViewToString.working = (
 | 
			
		||||
    typeof ArrayBuffer !== 'undefined' &&
 | 
			
		||||
    typeof DataView !== 'undefined' &&
 | 
			
		||||
    isDataViewToString(new DataView(new ArrayBuffer(1), 0, 1))
 | 
			
		||||
);
 | 
			
		||||
function isDataView(value) {
 | 
			
		||||
    if (typeof DataView === 'undefined') {
 | 
			
		||||
        return false;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    return isDataViewToString.working
 | 
			
		||||
        ? isDataViewToString(value)
 | 
			
		||||
        : value instanceof DataView;
 | 
			
		||||
}
 | 
			
		||||
exports.isDataView = isDataView;
 | 
			
		||||
 | 
			
		||||
function isSharedArrayBufferToString(value) {
 | 
			
		||||
    return ObjectToString(value) === '[object SharedArrayBuffer]';
 | 
			
		||||
}
 | 
			
		||||
isSharedArrayBufferToString.working = (
 | 
			
		||||
    typeof SharedArrayBuffer !== 'undefined' &&
 | 
			
		||||
    // @ts-ignore
 | 
			
		||||
    isSharedArrayBufferToString(new SharedArrayBuffer())
 | 
			
		||||
);
 | 
			
		||||
function isSharedArrayBuffer(value) {
 | 
			
		||||
    if (typeof SharedArrayBuffer === 'undefined') {
 | 
			
		||||
        return false;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    return isSharedArrayBufferToString.working
 | 
			
		||||
        ? isSharedArrayBufferToString(value)
 | 
			
		||||
        : value instanceof SharedArrayBuffer;
 | 
			
		||||
}
 | 
			
		||||
exports.isSharedArrayBuffer = isSharedArrayBuffer;
 | 
			
		||||
 | 
			
		||||
function isAsyncFunction(value) {
 | 
			
		||||
    return ObjectToString(value) === '[object AsyncFunction]';
 | 
			
		||||
}
 | 
			
		||||
exports.isAsyncFunction = isAsyncFunction;
 | 
			
		||||
 | 
			
		||||
function isMapIterator(value) {
 | 
			
		||||
    return ObjectToString(value) === '[object Map Iterator]';
 | 
			
		||||
}
 | 
			
		||||
exports.isMapIterator = isMapIterator;
 | 
			
		||||
 | 
			
		||||
function isSetIterator(value) {
 | 
			
		||||
    return ObjectToString(value) === '[object Set Iterator]';
 | 
			
		||||
}
 | 
			
		||||
exports.isSetIterator = isSetIterator;
 | 
			
		||||
 | 
			
		||||
function isGeneratorObject(value) {
 | 
			
		||||
    return ObjectToString(value) === '[object Generator]';
 | 
			
		||||
}
 | 
			
		||||
exports.isGeneratorObject = isGeneratorObject;
 | 
			
		||||
 | 
			
		||||
function isWebAssemblyCompiledModule(value) {
 | 
			
		||||
    return ObjectToString(value) === '[object WebAssembly.Module]';
 | 
			
		||||
}
 | 
			
		||||
exports.isWebAssemblyCompiledModule = isWebAssemblyCompiledModule;
 | 
			
		||||
 | 
			
		||||
function isNumberObject(value) {
 | 
			
		||||
    return checkBoxedPrimitive(value, numberValue);
 | 
			
		||||
}
 | 
			
		||||
exports.isNumberObject = isNumberObject;
 | 
			
		||||
 | 
			
		||||
function isStringObject(value) {
 | 
			
		||||
    return checkBoxedPrimitive(value, stringValue);
 | 
			
		||||
}
 | 
			
		||||
exports.isStringObject = isStringObject;
 | 
			
		||||
 | 
			
		||||
function isBooleanObject(value) {
 | 
			
		||||
    return checkBoxedPrimitive(value, booleanValue);
 | 
			
		||||
}
 | 
			
		||||
exports.isBooleanObject = isBooleanObject;
 | 
			
		||||
 | 
			
		||||
function isBigIntObject(value) {
 | 
			
		||||
    return BigIntSupported && checkBoxedPrimitive(value, bigIntValue);
 | 
			
		||||
}
 | 
			
		||||
exports.isBigIntObject = isBigIntObject;
 | 
			
		||||
 | 
			
		||||
function isSymbolObject(value) {
 | 
			
		||||
    return SymbolSupported && checkBoxedPrimitive(value, symbolValue);
 | 
			
		||||
}
 | 
			
		||||
exports.isSymbolObject = isSymbolObject;
 | 
			
		||||
 | 
			
		||||
function isBoxedPrimitive(value) {
 | 
			
		||||
    return (
 | 
			
		||||
        isNumberObject(value) ||
 | 
			
		||||
        isStringObject(value) ||
 | 
			
		||||
        isBooleanObject(value) ||
 | 
			
		||||
        isBigIntObject(value) ||
 | 
			
		||||
        isSymbolObject(value)
 | 
			
		||||
    );
 | 
			
		||||
}
 | 
			
		||||
exports.isBoxedPrimitive = isBoxedPrimitive;
 | 
			
		||||
 | 
			
		||||
function isAnyArrayBuffer(value) {
 | 
			
		||||
    return Uint8ArraySupported && (
 | 
			
		||||
        isArrayBuffer(value) ||
 | 
			
		||||
        isSharedArrayBuffer(value)
 | 
			
		||||
    );
 | 
			
		||||
}
 | 
			
		||||
exports.isAnyArrayBuffer = isAnyArrayBuffer;
 | 
			
		||||
 | 
			
		||||
['isProxy', 'isExternal', 'isModuleNamespaceObject'].forEach(function (method) {
 | 
			
		||||
    Object.defineProperty(exports, method, {
 | 
			
		||||
        enumerable: false,
 | 
			
		||||
        value: function () {
 | 
			
		||||
            throw new Error(method + ' is not supported in userland');
 | 
			
		||||
        }
 | 
			
		||||
    });
 | 
			
		||||
});
 | 
			
		||||
		Reference in New Issue
	
	Block a user