Files
discord-clone/node_modules/vite-node/dist/client.cjs
2023-01-03 09:29:04 -06:00

380 lines
12 KiB
JavaScript

'use strict';
Object.defineProperty(exports, '__esModule', { value: true });
var module$1 = require('module');
var url = require('url');
var vm = require('vm');
var pathe = require('pathe');
var mlly = require('mlly');
var createDebug = require('debug');
var utils = require('./utils.cjs');
var sourceMap = require('./source-map.cjs');
require('fs');
require('source-map-support');
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
function _interopNamespace(e) {
if (e && e.__esModule) return e;
var n = Object.create(null);
if (e) {
Object.keys(e).forEach(function (k) {
if (k !== 'default') {
var d = Object.getOwnPropertyDescriptor(e, k);
Object.defineProperty(n, k, d.get ? d : {
enumerable: true,
get: function () { return e[k]; }
});
}
});
}
n["default"] = e;
return Object.freeze(n);
}
var vm__default = /*#__PURE__*/_interopDefaultLegacy(vm);
var createDebug__default = /*#__PURE__*/_interopDefaultLegacy(createDebug);
const debugExecute = createDebug__default["default"]("vite-node:client:execute");
const debugNative = createDebug__default["default"]("vite-node:client:native");
const DEFAULT_REQUEST_STUBS = {
"/@vite/client": {
injectQuery: (id) => id,
createHotContext() {
return {
accept: () => {
},
prune: () => {
},
dispose: () => {
},
decline: () => {
},
invalidate: () => {
},
on: () => {
}
};
},
updateStyle(id, css) {
if (typeof document === "undefined")
return;
const element = document.getElementById(id);
if (element)
element.remove();
const head = document.querySelector("head");
const style = document.createElement("style");
style.setAttribute("type", "text/css");
style.id = id;
style.innerHTML = css;
head == null ? void 0 : head.appendChild(style);
}
}
};
class ModuleCacheMap extends Map {
normalizePath(fsPath) {
return utils.normalizeModuleId(fsPath);
}
update(fsPath, mod) {
fsPath = this.normalizePath(fsPath);
if (!super.has(fsPath))
super.set(fsPath, mod);
else
Object.assign(super.get(fsPath), mod);
return this;
}
set(fsPath, mod) {
fsPath = this.normalizePath(fsPath);
return super.set(fsPath, mod);
}
get(fsPath) {
fsPath = this.normalizePath(fsPath);
if (!super.has(fsPath))
super.set(fsPath, {});
return super.get(fsPath);
}
delete(fsPath) {
fsPath = this.normalizePath(fsPath);
return super.delete(fsPath);
}
invalidateDepTree(ids, invalidated = /* @__PURE__ */ new Set()) {
for (const _id of ids) {
const id = this.normalizePath(_id);
if (invalidated.has(id))
continue;
invalidated.add(id);
const mod = super.get(id);
if (mod == null ? void 0 : mod.importers)
this.invalidateDepTree(mod.importers, invalidated);
super.delete(id);
}
return invalidated;
}
invalidateSubDepTree(ids, invalidated = /* @__PURE__ */ new Set()) {
for (const _id of ids) {
const id = this.normalizePath(_id);
if (invalidated.has(id))
continue;
invalidated.add(id);
const subIds = Array.from(super.entries()).filter(([, mod]) => {
var _a;
return (_a = mod.importers) == null ? void 0 : _a.has(id);
}).map(([key]) => key);
subIds.length && this.invalidateSubDepTree(subIds, invalidated);
super.delete(id);
}
return invalidated;
}
getSourceMap(id) {
const cache = this.get(id);
if (cache.map)
return cache.map;
const map = cache.code && sourceMap.extractSourceMap(cache.code);
if (map) {
cache.map = map;
return map;
}
return null;
}
}
class ViteNodeRunner {
constructor(options) {
this.options = options;
this.root = options.root ?? process.cwd();
this.moduleCache = options.moduleCache ?? new ModuleCacheMap();
this.debug = options.debug ?? (typeof process !== "undefined" ? !!process.env.VITE_NODE_DEBUG_RUNNER : false);
}
async executeFile(file) {
return await this.cachedRequest(`/@fs/${utils.slash(pathe.resolve(file))}`, []);
}
async executeId(id) {
return await this.cachedRequest(id, []);
}
getSourceMap(id) {
return this.moduleCache.getSourceMap(id);
}
async cachedRequest(rawId, callstack) {
const id = utils.normalizeRequestId(rawId, this.options.base);
const fsPath = utils.toFilePath(id, this.root);
const mod = this.moduleCache.get(fsPath);
const importee = callstack[callstack.length - 1];
if (!mod.importers)
mod.importers = /* @__PURE__ */ new Set();
if (importee)
mod.importers.add(importee);
if (callstack.includes(fsPath) && mod.exports)
return mod.exports;
if (mod.promise)
return mod.promise;
const promise = this.directRequest(id, fsPath, callstack);
Object.assign(mod, { promise, evaluated: false });
try {
return await promise;
} finally {
mod.evaluated = true;
}
}
async directRequest(id, fsPath, _callstack) {
const callstack = [..._callstack, fsPath];
let mod = this.moduleCache.get(fsPath);
const request = async (dep2) => {
var _a;
const depFsPath = utils.toFilePath(utils.normalizeRequestId(dep2, this.options.base), this.root);
const getStack = () => {
return `stack:
${[...callstack, depFsPath].reverse().map((p) => `- ${p}`).join("\n")}`;
};
let debugTimer;
if (this.debug)
debugTimer = setTimeout(() => console.warn(() => `module ${depFsPath} takes over 2s to load.
${getStack()}`), 2e3);
try {
if (callstack.includes(depFsPath)) {
const depExports = (_a = this.moduleCache.get(depFsPath)) == null ? void 0 : _a.exports;
if (depExports)
return depExports;
throw new Error(`[vite-node] Failed to resolve circular dependency, ${getStack()}`);
}
return await this.cachedRequest(dep2, callstack);
} finally {
if (debugTimer)
clearTimeout(debugTimer);
}
};
Object.defineProperty(request, "callstack", { get: () => callstack });
const resolveId = async (dep2, callstackPosition = 1) => {
if (this.options.resolveId && this.shouldResolveId(dep2)) {
let importer = callstack[callstack.length - callstackPosition];
if (importer && !dep2.startsWith("."))
importer = void 0;
if (importer && importer.startsWith("mock:"))
importer = importer.slice(5);
const resolved = await this.options.resolveId(utils.normalizeRequestId(dep2), importer);
return [dep2, resolved == null ? void 0 : resolved.id];
}
return [dep2, void 0];
};
const [dep, resolvedId] = await resolveId(id, 2);
const requestStubs = this.options.requestStubs || DEFAULT_REQUEST_STUBS;
if (id in requestStubs)
return requestStubs[id];
let { code: transformed, externalize } = await this.options.fetchModule(resolvedId || dep);
if (resolvedId && !fsPath.includes("?") && fsPath !== resolvedId) {
if (this.moduleCache.has(resolvedId)) {
mod = this.moduleCache.get(resolvedId);
this.moduleCache.set(fsPath, mod);
if (mod.promise)
return mod.promise;
if (mod.exports)
return mod.exports;
} else {
this.moduleCache.set(resolvedId, mod);
}
}
if (externalize) {
debugNative(externalize);
const exports2 = await this.interopedImport(externalize);
mod.exports = exports2;
return exports2;
}
if (transformed == null)
throw new Error(`[vite-node] Failed to load ${id}`);
const file = utils.cleanUrl(resolvedId || fsPath);
const url$1 = url.pathToFileURL(file).href;
const meta = { url: url$1 };
const exports = /* @__PURE__ */ Object.create(null);
Object.defineProperty(exports, Symbol.toStringTag, {
value: "Module",
enumerable: false,
configurable: false
});
const cjsExports = new Proxy(exports, {
set(_, p, value) {
if (!Reflect.has(exports, "default"))
exports.default = {};
if (utils.isPrimitive(exports.default)) {
defineExport(exports, p, () => void 0);
return true;
}
exports.default[p] = value;
if (p !== "default")
defineExport(exports, p, () => value);
return true;
}
});
Object.assign(mod, { code: transformed, exports });
const __filename = url.fileURLToPath(url$1);
const moduleProxy = {
set exports(value) {
exportAll(cjsExports, value);
exports.default = value;
},
get exports() {
return cjsExports;
}
};
let hotContext;
if (this.options.createHotContext) {
Object.defineProperty(meta, "hot", {
enumerable: true,
get: () => {
var _a, _b;
hotContext || (hotContext = (_b = (_a = this.options).createHotContext) == null ? void 0 : _b.call(_a, this, `/@fs/${fsPath}`));
return hotContext;
}
});
}
const context = this.prepareContext({
__vite_ssr_import__: request,
__vite_ssr_dynamic_import__: request,
__vite_ssr_exports__: exports,
__vite_ssr_exportAll__: (obj) => exportAll(exports, obj),
__vite_ssr_import_meta__: meta,
__vitest_resolve_id__: resolveId,
require: module$1.createRequire(url$1),
exports: cjsExports,
module: moduleProxy,
__filename,
__dirname: pathe.dirname(__filename)
});
debugExecute(__filename);
if (transformed[0] === "#")
transformed = transformed.replace(/^\#\!.*/, (s) => " ".repeat(s.length));
const codeDefinition = `'use strict';async (${Object.keys(context).join(",")})=>{{`;
const code = `${codeDefinition}${transformed}
}}`;
const fn = vm__default["default"].runInThisContext(code, {
filename: __filename,
lineOffset: 0,
columnOffset: -codeDefinition.length
});
await fn(...Object.values(context));
return exports;
}
prepareContext(context) {
return context;
}
shouldResolveId(dep) {
if (mlly.isNodeBuiltin(dep) || dep in (this.options.requestStubs || DEFAULT_REQUEST_STUBS) || dep.startsWith("/@vite"))
return false;
return !pathe.isAbsolute(dep) || !pathe.extname(dep);
}
shouldInterop(path, mod) {
if (this.options.interopDefault === false)
return false;
return !path.endsWith(".mjs") && "default" in mod;
}
async interopedImport(path) {
const mod = await (function (t) { return Promise.resolve().then(function () { return /*#__PURE__*/_interopNamespace(require(t)); }); })(path);
if (this.shouldInterop(path, mod)) {
const tryDefault = this.hasNestedDefault(mod);
return new Proxy(mod, {
get: proxyMethod("get", tryDefault),
set: proxyMethod("set", tryDefault),
has: proxyMethod("has", tryDefault),
deleteProperty: proxyMethod("deleteProperty", tryDefault)
});
}
return mod;
}
hasNestedDefault(target) {
return "__esModule" in target && target.__esModule && "default" in target.default;
}
}
function proxyMethod(name, tryDefault) {
return function(target, key, ...args) {
const result = Reflect[name](target, key, ...args);
if (utils.isPrimitive(target.default))
return result;
if (tryDefault && key === "default" || typeof result === "undefined")
return Reflect[name](target.default, key, ...args);
return result;
};
}
function defineExport(exports, key, value) {
Object.defineProperty(exports, key, {
enumerable: true,
configurable: true,
get: value
});
}
function exportAll(exports, sourceModule) {
if (exports === sourceModule)
return;
if (utils.isPrimitive(sourceModule) || Array.isArray(sourceModule))
return;
for (const key in sourceModule) {
if (key !== "default") {
try {
defineExport(exports, key, () => sourceModule[key]);
} catch (_err) {
}
}
}
}
exports.DEFAULT_REQUEST_STUBS = DEFAULT_REQUEST_STUBS;
exports.ModuleCacheMap = ModuleCacheMap;
exports.ViteNodeRunner = ViteNodeRunner;