q9
This commit is contained in:
21
node_modules/vite-plugin-inspect/LICENSE
generated
vendored
Normal file
21
node_modules/vite-plugin-inspect/LICENSE
generated
vendored
Normal file
@@ -0,0 +1,21 @@
|
||||
MIT License
|
||||
|
||||
Copyright (c) 2021-PRESENT Anthony Fu <https://github.com/antfu>
|
||||
|
||||
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.
|
||||
64
node_modules/vite-plugin-inspect/README.md
generated
vendored
Normal file
64
node_modules/vite-plugin-inspect/README.md
generated
vendored
Normal file
@@ -0,0 +1,64 @@
|
||||
# vite-plugin-inspect
|
||||
|
||||
[](https://www.npmjs.com/package/vite-plugin-inspect)
|
||||
|
||||
Inspect the intermediate state of Vite plugins. Useful for debugging and authoring plugins.
|
||||
|
||||
<img width="1304" src="https://user-images.githubusercontent.com/46585162/134683677-487e3e03-fa6b-49ad-bde0-520ebb641a96.png">
|
||||
|
||||

|
||||
|
||||
## Install
|
||||
|
||||
```bash
|
||||
npm i -D vite-plugin-inspect
|
||||
```
|
||||
|
||||
> Since `vite-plugin-inspect@v0.7.0`, Vite v3.1 or above is required.
|
||||
|
||||
Add plugin to your `vite.config.ts`:
|
||||
|
||||
```ts
|
||||
// vite.config.ts
|
||||
import Inspect from 'vite-plugin-inspect'
|
||||
|
||||
export default {
|
||||
plugins: [
|
||||
Inspect()
|
||||
],
|
||||
}
|
||||
```
|
||||
|
||||
Then run `npm run dev` and visit [localhost:5173/__inspect/](http://localhost:5173/__inspect/) to inspect the modules.
|
||||
|
||||
## Build Mode
|
||||
|
||||
To inspect transformation in build mode, you can pass the `build: true` option:
|
||||
|
||||
```ts
|
||||
// vite.config.ts
|
||||
import Inspect from 'vite-plugin-inspect'
|
||||
|
||||
export default {
|
||||
plugins: [
|
||||
Inspect({
|
||||
build: true,
|
||||
outputDir: '.vite-inspect'
|
||||
})
|
||||
],
|
||||
}
|
||||
```
|
||||
|
||||
After running `vite build`, the inspector client will be generated under `.vite-inspect`, where you can use `npx serve .vite-inspect` to check the result.
|
||||
|
||||
## Sponsors
|
||||
|
||||
<p align="center">
|
||||
<a href="https://cdn.jsdelivr.net/gh/antfu/static/sponsors.svg">
|
||||
<img src='https://cdn.jsdelivr.net/gh/antfu/static/sponsors.svg'/>
|
||||
</a>
|
||||
</p>
|
||||
|
||||
## License
|
||||
|
||||
[MIT](./LICENSE) License © 2021-PRESENT [Anthony Fu](https://github.com/antfu)
|
||||
983
node_modules/vite-plugin-inspect/dist/client/assets/diff.worker-CR9ma7Tn.js
generated
vendored
Normal file
983
node_modules/vite-plugin-inspect/dist/client/assets/diff.worker-CR9ma7Tn.js
generated
vendored
Normal file
@@ -0,0 +1,983 @@
|
||||
(function () {
|
||||
'use strict';
|
||||
|
||||
/**
|
||||
* @license
|
||||
* Copyright 2019 Google LLC
|
||||
* SPDX-License-Identifier: Apache-2.0
|
||||
*/
|
||||
const proxyMarker = Symbol("Comlink.proxy");
|
||||
const createEndpoint = Symbol("Comlink.endpoint");
|
||||
const releaseProxy = Symbol("Comlink.releaseProxy");
|
||||
const finalizer = Symbol("Comlink.finalizer");
|
||||
const throwMarker = Symbol("Comlink.thrown");
|
||||
const isObject = (val) => (typeof val === "object" && val !== null) || typeof val === "function";
|
||||
/**
|
||||
* Internal transfer handle to handle objects marked to proxy.
|
||||
*/
|
||||
const proxyTransferHandler = {
|
||||
canHandle: (val) => isObject(val) && val[proxyMarker],
|
||||
serialize(obj) {
|
||||
const { port1, port2 } = new MessageChannel();
|
||||
expose(obj, port1);
|
||||
return [port2, [port2]];
|
||||
},
|
||||
deserialize(port) {
|
||||
port.start();
|
||||
return wrap(port);
|
||||
},
|
||||
};
|
||||
/**
|
||||
* Internal transfer handler to handle thrown exceptions.
|
||||
*/
|
||||
const throwTransferHandler = {
|
||||
canHandle: (value) => isObject(value) && throwMarker in value,
|
||||
serialize({ value }) {
|
||||
let serialized;
|
||||
if (value instanceof Error) {
|
||||
serialized = {
|
||||
isError: true,
|
||||
value: {
|
||||
message: value.message,
|
||||
name: value.name,
|
||||
stack: value.stack,
|
||||
},
|
||||
};
|
||||
}
|
||||
else {
|
||||
serialized = { isError: false, value };
|
||||
}
|
||||
return [serialized, []];
|
||||
},
|
||||
deserialize(serialized) {
|
||||
if (serialized.isError) {
|
||||
throw Object.assign(new Error(serialized.value.message), serialized.value);
|
||||
}
|
||||
throw serialized.value;
|
||||
},
|
||||
};
|
||||
/**
|
||||
* Allows customizing the serialization of certain values.
|
||||
*/
|
||||
const transferHandlers = new Map([
|
||||
["proxy", proxyTransferHandler],
|
||||
["throw", throwTransferHandler],
|
||||
]);
|
||||
function isAllowedOrigin(allowedOrigins, origin) {
|
||||
for (const allowedOrigin of allowedOrigins) {
|
||||
if (origin === allowedOrigin || allowedOrigin === "*") {
|
||||
return true;
|
||||
}
|
||||
if (allowedOrigin instanceof RegExp && allowedOrigin.test(origin)) {
|
||||
return true;
|
||||
}
|
||||
}
|
||||
return false;
|
||||
}
|
||||
function expose(obj, ep = globalThis, allowedOrigins = ["*"]) {
|
||||
ep.addEventListener("message", function callback(ev) {
|
||||
if (!ev || !ev.data) {
|
||||
return;
|
||||
}
|
||||
if (!isAllowedOrigin(allowedOrigins, ev.origin)) {
|
||||
console.warn(`Invalid origin '${ev.origin}' for comlink proxy`);
|
||||
return;
|
||||
}
|
||||
const { id, type, path } = Object.assign({ path: [] }, ev.data);
|
||||
const argumentList = (ev.data.argumentList || []).map(fromWireValue);
|
||||
let returnValue;
|
||||
try {
|
||||
const parent = path.slice(0, -1).reduce((obj, prop) => obj[prop], obj);
|
||||
const rawValue = path.reduce((obj, prop) => obj[prop], obj);
|
||||
switch (type) {
|
||||
case "GET" /* MessageType.GET */:
|
||||
{
|
||||
returnValue = rawValue;
|
||||
}
|
||||
break;
|
||||
case "SET" /* MessageType.SET */:
|
||||
{
|
||||
parent[path.slice(-1)[0]] = fromWireValue(ev.data.value);
|
||||
returnValue = true;
|
||||
}
|
||||
break;
|
||||
case "APPLY" /* MessageType.APPLY */:
|
||||
{
|
||||
returnValue = rawValue.apply(parent, argumentList);
|
||||
}
|
||||
break;
|
||||
case "CONSTRUCT" /* MessageType.CONSTRUCT */:
|
||||
{
|
||||
const value = new rawValue(...argumentList);
|
||||
returnValue = proxy(value);
|
||||
}
|
||||
break;
|
||||
case "ENDPOINT" /* MessageType.ENDPOINT */:
|
||||
{
|
||||
const { port1, port2 } = new MessageChannel();
|
||||
expose(obj, port2);
|
||||
returnValue = transfer(port1, [port1]);
|
||||
}
|
||||
break;
|
||||
case "RELEASE" /* MessageType.RELEASE */:
|
||||
{
|
||||
returnValue = undefined;
|
||||
}
|
||||
break;
|
||||
default:
|
||||
return;
|
||||
}
|
||||
}
|
||||
catch (value) {
|
||||
returnValue = { value, [throwMarker]: 0 };
|
||||
}
|
||||
Promise.resolve(returnValue)
|
||||
.catch((value) => {
|
||||
return { value, [throwMarker]: 0 };
|
||||
})
|
||||
.then((returnValue) => {
|
||||
const [wireValue, transferables] = toWireValue(returnValue);
|
||||
ep.postMessage(Object.assign(Object.assign({}, wireValue), { id }), transferables);
|
||||
if (type === "RELEASE" /* MessageType.RELEASE */) {
|
||||
// detach and deactive after sending release response above.
|
||||
ep.removeEventListener("message", callback);
|
||||
closeEndPoint(ep);
|
||||
if (finalizer in obj && typeof obj[finalizer] === "function") {
|
||||
obj[finalizer]();
|
||||
}
|
||||
}
|
||||
})
|
||||
.catch((error) => {
|
||||
// Send Serialization Error To Caller
|
||||
const [wireValue, transferables] = toWireValue({
|
||||
value: new TypeError("Unserializable return value"),
|
||||
[throwMarker]: 0,
|
||||
});
|
||||
ep.postMessage(Object.assign(Object.assign({}, wireValue), { id }), transferables);
|
||||
});
|
||||
});
|
||||
if (ep.start) {
|
||||
ep.start();
|
||||
}
|
||||
}
|
||||
function isMessagePort(endpoint) {
|
||||
return endpoint.constructor.name === "MessagePort";
|
||||
}
|
||||
function closeEndPoint(endpoint) {
|
||||
if (isMessagePort(endpoint))
|
||||
endpoint.close();
|
||||
}
|
||||
function wrap(ep, target) {
|
||||
return createProxy(ep, [], target);
|
||||
}
|
||||
function throwIfProxyReleased(isReleased) {
|
||||
if (isReleased) {
|
||||
throw new Error("Proxy has been released and is not useable");
|
||||
}
|
||||
}
|
||||
function releaseEndpoint(ep) {
|
||||
return requestResponseMessage(ep, {
|
||||
type: "RELEASE" /* MessageType.RELEASE */,
|
||||
}).then(() => {
|
||||
closeEndPoint(ep);
|
||||
});
|
||||
}
|
||||
const proxyCounter = new WeakMap();
|
||||
const proxyFinalizers = "FinalizationRegistry" in globalThis &&
|
||||
new FinalizationRegistry((ep) => {
|
||||
const newCount = (proxyCounter.get(ep) || 0) - 1;
|
||||
proxyCounter.set(ep, newCount);
|
||||
if (newCount === 0) {
|
||||
releaseEndpoint(ep);
|
||||
}
|
||||
});
|
||||
function registerProxy(proxy, ep) {
|
||||
const newCount = (proxyCounter.get(ep) || 0) + 1;
|
||||
proxyCounter.set(ep, newCount);
|
||||
if (proxyFinalizers) {
|
||||
proxyFinalizers.register(proxy, ep, proxy);
|
||||
}
|
||||
}
|
||||
function unregisterProxy(proxy) {
|
||||
if (proxyFinalizers) {
|
||||
proxyFinalizers.unregister(proxy);
|
||||
}
|
||||
}
|
||||
function createProxy(ep, path = [], target = function () { }) {
|
||||
let isProxyReleased = false;
|
||||
const proxy = new Proxy(target, {
|
||||
get(_target, prop) {
|
||||
throwIfProxyReleased(isProxyReleased);
|
||||
if (prop === releaseProxy) {
|
||||
return () => {
|
||||
unregisterProxy(proxy);
|
||||
releaseEndpoint(ep);
|
||||
isProxyReleased = true;
|
||||
};
|
||||
}
|
||||
if (prop === "then") {
|
||||
if (path.length === 0) {
|
||||
return { then: () => proxy };
|
||||
}
|
||||
const r = requestResponseMessage(ep, {
|
||||
type: "GET" /* MessageType.GET */,
|
||||
path: path.map((p) => p.toString()),
|
||||
}).then(fromWireValue);
|
||||
return r.then.bind(r);
|
||||
}
|
||||
return createProxy(ep, [...path, prop]);
|
||||
},
|
||||
set(_target, prop, rawValue) {
|
||||
throwIfProxyReleased(isProxyReleased);
|
||||
// FIXME: ES6 Proxy Handler `set` methods are supposed to return a
|
||||
// boolean. To show good will, we return true asynchronously ¯\_(ツ)_/¯
|
||||
const [value, transferables] = toWireValue(rawValue);
|
||||
return requestResponseMessage(ep, {
|
||||
type: "SET" /* MessageType.SET */,
|
||||
path: [...path, prop].map((p) => p.toString()),
|
||||
value,
|
||||
}, transferables).then(fromWireValue);
|
||||
},
|
||||
apply(_target, _thisArg, rawArgumentList) {
|
||||
throwIfProxyReleased(isProxyReleased);
|
||||
const last = path[path.length - 1];
|
||||
if (last === createEndpoint) {
|
||||
return requestResponseMessage(ep, {
|
||||
type: "ENDPOINT" /* MessageType.ENDPOINT */,
|
||||
}).then(fromWireValue);
|
||||
}
|
||||
// We just pretend that `bind()` didn’t happen.
|
||||
if (last === "bind") {
|
||||
return createProxy(ep, path.slice(0, -1));
|
||||
}
|
||||
const [argumentList, transferables] = processArguments(rawArgumentList);
|
||||
return requestResponseMessage(ep, {
|
||||
type: "APPLY" /* MessageType.APPLY */,
|
||||
path: path.map((p) => p.toString()),
|
||||
argumentList,
|
||||
}, transferables).then(fromWireValue);
|
||||
},
|
||||
construct(_target, rawArgumentList) {
|
||||
throwIfProxyReleased(isProxyReleased);
|
||||
const [argumentList, transferables] = processArguments(rawArgumentList);
|
||||
return requestResponseMessage(ep, {
|
||||
type: "CONSTRUCT" /* MessageType.CONSTRUCT */,
|
||||
path: path.map((p) => p.toString()),
|
||||
argumentList,
|
||||
}, transferables).then(fromWireValue);
|
||||
},
|
||||
});
|
||||
registerProxy(proxy, ep);
|
||||
return proxy;
|
||||
}
|
||||
function myFlat(arr) {
|
||||
return Array.prototype.concat.apply([], arr);
|
||||
}
|
||||
function processArguments(argumentList) {
|
||||
const processed = argumentList.map(toWireValue);
|
||||
return [processed.map((v) => v[0]), myFlat(processed.map((v) => v[1]))];
|
||||
}
|
||||
const transferCache = new WeakMap();
|
||||
function transfer(obj, transfers) {
|
||||
transferCache.set(obj, transfers);
|
||||
return obj;
|
||||
}
|
||||
function proxy(obj) {
|
||||
return Object.assign(obj, { [proxyMarker]: true });
|
||||
}
|
||||
function toWireValue(value) {
|
||||
for (const [name, handler] of transferHandlers) {
|
||||
if (handler.canHandle(value)) {
|
||||
const [serializedValue, transferables] = handler.serialize(value);
|
||||
return [
|
||||
{
|
||||
type: "HANDLER" /* WireValueType.HANDLER */,
|
||||
name,
|
||||
value: serializedValue,
|
||||
},
|
||||
transferables,
|
||||
];
|
||||
}
|
||||
}
|
||||
return [
|
||||
{
|
||||
type: "RAW" /* WireValueType.RAW */,
|
||||
value,
|
||||
},
|
||||
transferCache.get(value) || [],
|
||||
];
|
||||
}
|
||||
function fromWireValue(value) {
|
||||
switch (value.type) {
|
||||
case "HANDLER" /* WireValueType.HANDLER */:
|
||||
return transferHandlers.get(value.name).deserialize(value.value);
|
||||
case "RAW" /* WireValueType.RAW */:
|
||||
return value.value;
|
||||
}
|
||||
}
|
||||
function requestResponseMessage(ep, msg, transfers) {
|
||||
return new Promise((resolve) => {
|
||||
const id = generateUUID();
|
||||
ep.addEventListener("message", function l(ev) {
|
||||
if (!ev.data || !ev.data.id || ev.data.id !== id) {
|
||||
return;
|
||||
}
|
||||
ep.removeEventListener("message", l);
|
||||
resolve(ev.data);
|
||||
});
|
||||
if (ep.start) {
|
||||
ep.start();
|
||||
}
|
||||
ep.postMessage(Object.assign({ id }, msg), transfers);
|
||||
});
|
||||
}
|
||||
function generateUUID() {
|
||||
return new Array(4)
|
||||
.fill(0)
|
||||
.map(() => Math.floor(Math.random() * Number.MAX_SAFE_INTEGER).toString(16))
|
||||
.join("-");
|
||||
}
|
||||
|
||||
const defaultOptions = /* @__PURE__ */ Object.freeze({
|
||||
diffTimeout: 1,
|
||||
diffEditCost: 4,
|
||||
matchThreshold: 0.5,
|
||||
matchDistance: 1e3,
|
||||
patchDeleteThreshold: 0.5,
|
||||
patchMargin: 4,
|
||||
matchMaxBits: 32
|
||||
});
|
||||
function resolveOptions(options) {
|
||||
if (options?.__resolved)
|
||||
return options;
|
||||
const resolved = {
|
||||
...defaultOptions,
|
||||
...options
|
||||
};
|
||||
Object.defineProperty(resolved, "__resolved", { value: true, enumerable: false });
|
||||
return resolved;
|
||||
}
|
||||
|
||||
const DIFF_DELETE = -1;
|
||||
const DIFF_INSERT = 1;
|
||||
const DIFF_EQUAL = 0;
|
||||
function createDiff(op, text) {
|
||||
return [op, text];
|
||||
}
|
||||
function diffMain(text1, text2, options, opt_checklines = true, opt_deadline) {
|
||||
const resolved = resolveOptions(options);
|
||||
if (typeof opt_deadline == "undefined") {
|
||||
if (resolved.diffTimeout <= 0)
|
||||
opt_deadline = Number.MAX_VALUE;
|
||||
else
|
||||
opt_deadline = (/* @__PURE__ */ new Date()).getTime() + resolved.diffTimeout * 1e3;
|
||||
}
|
||||
const deadline = opt_deadline;
|
||||
if (text1 == null || text2 == null)
|
||||
throw new Error("Null input. (diff_main)");
|
||||
if (text1 === text2) {
|
||||
if (text1)
|
||||
return [createDiff(DIFF_EQUAL, text1)];
|
||||
return [];
|
||||
}
|
||||
const checklines = opt_checklines;
|
||||
let commonlength = diffCommonPrefix(text1, text2);
|
||||
const commonprefix = text1.substring(0, commonlength);
|
||||
text1 = text1.substring(commonlength);
|
||||
text2 = text2.substring(commonlength);
|
||||
commonlength = diffCommonSuffix(text1, text2);
|
||||
const commonsuffix = text1.substring(text1.length - commonlength);
|
||||
text1 = text1.substring(0, text1.length - commonlength);
|
||||
text2 = text2.substring(0, text2.length - commonlength);
|
||||
const diffs = diffCompute(text1, text2, resolved, checklines, deadline);
|
||||
if (commonprefix)
|
||||
diffs.unshift(createDiff(DIFF_EQUAL, commonprefix));
|
||||
if (commonsuffix)
|
||||
diffs.push(createDiff(DIFF_EQUAL, commonsuffix));
|
||||
diffCleanupMerge(diffs);
|
||||
return diffs;
|
||||
}
|
||||
function diffCompute(text1, text2, options, checklines, deadline) {
|
||||
let diffs;
|
||||
if (!text1) {
|
||||
return [createDiff(DIFF_INSERT, text2)];
|
||||
}
|
||||
if (!text2) {
|
||||
return [createDiff(DIFF_DELETE, text1)];
|
||||
}
|
||||
const longtext = text1.length > text2.length ? text1 : text2;
|
||||
const shorttext = text1.length > text2.length ? text2 : text1;
|
||||
const i = longtext.indexOf(shorttext);
|
||||
if (i !== -1) {
|
||||
diffs = [createDiff(DIFF_INSERT, longtext.substring(0, i)), createDiff(DIFF_EQUAL, shorttext), createDiff(DIFF_INSERT, longtext.substring(i + shorttext.length))];
|
||||
if (text1.length > text2.length)
|
||||
diffs[0][0] = diffs[2][0] = DIFF_DELETE;
|
||||
return diffs;
|
||||
}
|
||||
if (shorttext.length === 1) {
|
||||
return [createDiff(DIFF_DELETE, text1), createDiff(DIFF_INSERT, text2)];
|
||||
}
|
||||
const hm = diffHalfMatch(text1, text2, options);
|
||||
if (hm) {
|
||||
const text1_a = hm[0];
|
||||
const text1_b = hm[1];
|
||||
const text2_a = hm[2];
|
||||
const text2_b = hm[3];
|
||||
const mid_common = hm[4];
|
||||
const diffs_a = diffMain(text1_a, text2_a, options, checklines, deadline);
|
||||
const diffs_b = diffMain(text1_b, text2_b, options, checklines, deadline);
|
||||
return diffs_a.concat([createDiff(DIFF_EQUAL, mid_common)], diffs_b);
|
||||
}
|
||||
if (checklines && text1.length > 100 && text2.length > 100)
|
||||
return diffLineMode(text1, text2, options, deadline);
|
||||
return diffBisect(text1, text2, options, deadline);
|
||||
}
|
||||
function diffLineMode(text1, text2, options, deadline) {
|
||||
const a = diffLinesToChars(text1, text2);
|
||||
text1 = a.chars1;
|
||||
text2 = a.chars2;
|
||||
const linearray = a.lineArray;
|
||||
const diffs = diffMain(text1, text2, options, false, deadline);
|
||||
diffCharsToLines(diffs, linearray);
|
||||
diffCleanupSemantic(diffs);
|
||||
diffs.push(createDiff(DIFF_EQUAL, ""));
|
||||
let pointer = 0;
|
||||
let count_delete = 0;
|
||||
let count_insert = 0;
|
||||
let text_delete = "";
|
||||
let text_insert = "";
|
||||
while (pointer < diffs.length) {
|
||||
switch (diffs[pointer][0]) {
|
||||
case DIFF_INSERT:
|
||||
count_insert++;
|
||||
text_insert += diffs[pointer][1];
|
||||
break;
|
||||
case DIFF_DELETE:
|
||||
count_delete++;
|
||||
text_delete += diffs[pointer][1];
|
||||
break;
|
||||
case DIFF_EQUAL:
|
||||
if (count_delete >= 1 && count_insert >= 1) {
|
||||
diffs.splice(pointer - count_delete - count_insert, count_delete + count_insert);
|
||||
pointer = pointer - count_delete - count_insert;
|
||||
const subDiff = diffMain(text_delete, text_insert, options, false, deadline);
|
||||
for (let j = subDiff.length - 1; j >= 0; j--)
|
||||
diffs.splice(pointer, 0, subDiff[j]);
|
||||
pointer = pointer + subDiff.length;
|
||||
}
|
||||
count_insert = 0;
|
||||
count_delete = 0;
|
||||
text_delete = "";
|
||||
text_insert = "";
|
||||
break;
|
||||
}
|
||||
pointer++;
|
||||
}
|
||||
diffs.pop();
|
||||
return diffs;
|
||||
}
|
||||
function diffBisect(text1, text2, options, deadline) {
|
||||
const text1_length = text1.length;
|
||||
const text2_length = text2.length;
|
||||
const max_d = Math.ceil((text1_length + text2_length) / 2);
|
||||
const v_offset = max_d;
|
||||
const v_length = 2 * max_d;
|
||||
const v1 = new Array(v_length);
|
||||
const v2 = new Array(v_length);
|
||||
for (let x = 0; x < v_length; x++) {
|
||||
v1[x] = -1;
|
||||
v2[x] = -1;
|
||||
}
|
||||
v1[v_offset + 1] = 0;
|
||||
v2[v_offset + 1] = 0;
|
||||
const delta = text1_length - text2_length;
|
||||
const front = delta % 2 !== 0;
|
||||
let k1start = 0;
|
||||
let k1end = 0;
|
||||
let k2start = 0;
|
||||
let k2end = 0;
|
||||
for (let d = 0; d < max_d; d++) {
|
||||
if ((/* @__PURE__ */ new Date()).getTime() > deadline)
|
||||
break;
|
||||
for (let k1 = -d + k1start; k1 <= d - k1end; k1 += 2) {
|
||||
const k1_offset = v_offset + k1;
|
||||
let x1;
|
||||
if (k1 === -d || k1 !== d && v1[k1_offset - 1] < v1[k1_offset + 1])
|
||||
x1 = v1[k1_offset + 1];
|
||||
else
|
||||
x1 = v1[k1_offset - 1] + 1;
|
||||
let y1 = x1 - k1;
|
||||
while (x1 < text1_length && y1 < text2_length && text1.charAt(x1) === text2.charAt(y1)) {
|
||||
x1++;
|
||||
y1++;
|
||||
}
|
||||
v1[k1_offset] = x1;
|
||||
if (x1 > text1_length) {
|
||||
k1end += 2;
|
||||
} else if (y1 > text2_length) {
|
||||
k1start += 2;
|
||||
} else if (front) {
|
||||
const k2_offset = v_offset + delta - k1;
|
||||
if (k2_offset >= 0 && k2_offset < v_length && v2[k2_offset] !== -1) {
|
||||
const x2 = text1_length - v2[k2_offset];
|
||||
if (x1 >= x2) {
|
||||
return diffBisectSplit(text1, text2, options, x1, y1, deadline);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
for (let k2 = -d + k2start; k2 <= d - k2end; k2 += 2) {
|
||||
const k2_offset = v_offset + k2;
|
||||
let x2;
|
||||
if (k2 === -d || k2 !== d && v2[k2_offset - 1] < v2[k2_offset + 1])
|
||||
x2 = v2[k2_offset + 1];
|
||||
else
|
||||
x2 = v2[k2_offset - 1] + 1;
|
||||
let y2 = x2 - k2;
|
||||
while (x2 < text1_length && y2 < text2_length && text1.charAt(text1_length - x2 - 1) === text2.charAt(text2_length - y2 - 1)) {
|
||||
x2++;
|
||||
y2++;
|
||||
}
|
||||
v2[k2_offset] = x2;
|
||||
if (x2 > text1_length) {
|
||||
k2end += 2;
|
||||
} else if (y2 > text2_length) {
|
||||
k2start += 2;
|
||||
} else if (!front) {
|
||||
const k1_offset = v_offset + delta - k2;
|
||||
if (k1_offset >= 0 && k1_offset < v_length && v1[k1_offset] !== -1) {
|
||||
const x1 = v1[k1_offset];
|
||||
const y1 = v_offset + x1 - k1_offset;
|
||||
x2 = text1_length - x2;
|
||||
if (x1 >= x2) {
|
||||
return diffBisectSplit(text1, text2, options, x1, y1, deadline);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
return [createDiff(DIFF_DELETE, text1), createDiff(DIFF_INSERT, text2)];
|
||||
}
|
||||
function diffBisectSplit(text1, text2, options, x, y, deadline) {
|
||||
const text1a = text1.substring(0, x);
|
||||
const text2a = text2.substring(0, y);
|
||||
const text1b = text1.substring(x);
|
||||
const text2b = text2.substring(y);
|
||||
const diffs = diffMain(text1a, text2a, options, false, deadline);
|
||||
const diffsb = diffMain(text1b, text2b, options, false, deadline);
|
||||
return diffs.concat(diffsb);
|
||||
}
|
||||
function diffLinesToChars(text1, text2) {
|
||||
const lineArray = [];
|
||||
const lineHash = {};
|
||||
let maxLines = 4e4;
|
||||
lineArray[0] = "";
|
||||
function diffLinesToCharsMunge(text) {
|
||||
let chars = "";
|
||||
let lineStart = 0;
|
||||
let lineEnd = -1;
|
||||
let lineArrayLength = lineArray.length;
|
||||
while (lineEnd < text.length - 1) {
|
||||
lineEnd = text.indexOf("\n", lineStart);
|
||||
if (lineEnd === -1)
|
||||
lineEnd = text.length - 1;
|
||||
let line = text.substring(lineStart, lineEnd + 1);
|
||||
if (lineHash.hasOwnProperty ? Object.prototype.hasOwnProperty.call(lineHash, line) : lineHash[line] !== void 0) {
|
||||
chars += String.fromCharCode(lineHash[line]);
|
||||
} else {
|
||||
if (lineArrayLength === maxLines) {
|
||||
line = text.substring(lineStart);
|
||||
lineEnd = text.length;
|
||||
}
|
||||
chars += String.fromCharCode(lineArrayLength);
|
||||
lineHash[line] = lineArrayLength;
|
||||
lineArray[lineArrayLength++] = line;
|
||||
}
|
||||
lineStart = lineEnd + 1;
|
||||
}
|
||||
return chars;
|
||||
}
|
||||
const chars1 = diffLinesToCharsMunge(text1);
|
||||
maxLines = 65535;
|
||||
const chars2 = diffLinesToCharsMunge(text2);
|
||||
return { chars1, chars2, lineArray };
|
||||
}
|
||||
function diffCharsToLines(diffs, lineArray) {
|
||||
for (let i = 0; i < diffs.length; i++) {
|
||||
const chars = diffs[i][1];
|
||||
const text = [];
|
||||
for (let j = 0; j < chars.length; j++)
|
||||
text[j] = lineArray[chars.charCodeAt(j)];
|
||||
diffs[i][1] = text.join("");
|
||||
}
|
||||
}
|
||||
function diffCommonPrefix(text1, text2) {
|
||||
if (!text1 || !text2 || text1.charAt(0) !== text2.charAt(0))
|
||||
return 0;
|
||||
let pointermin = 0;
|
||||
let pointermax = Math.min(text1.length, text2.length);
|
||||
let pointermid = pointermax;
|
||||
let pointerstart = 0;
|
||||
while (pointermin < pointermid) {
|
||||
if (text1.substring(pointerstart, pointermid) === text2.substring(pointerstart, pointermid)) {
|
||||
pointermin = pointermid;
|
||||
pointerstart = pointermin;
|
||||
} else {
|
||||
pointermax = pointermid;
|
||||
}
|
||||
pointermid = Math.floor((pointermax - pointermin) / 2 + pointermin);
|
||||
}
|
||||
return pointermid;
|
||||
}
|
||||
function diffCommonSuffix(text1, text2) {
|
||||
if (!text1 || !text2 || text1.charAt(text1.length - 1) !== text2.charAt(text2.length - 1))
|
||||
return 0;
|
||||
let pointermin = 0;
|
||||
let pointermax = Math.min(text1.length, text2.length);
|
||||
let pointermid = pointermax;
|
||||
let pointerend = 0;
|
||||
while (pointermin < pointermid) {
|
||||
if (text1.substring(text1.length - pointermid, text1.length - pointerend) === text2.substring(text2.length - pointermid, text2.length - pointerend)) {
|
||||
pointermin = pointermid;
|
||||
pointerend = pointermin;
|
||||
} else {
|
||||
pointermax = pointermid;
|
||||
}
|
||||
pointermid = Math.floor((pointermax - pointermin) / 2 + pointermin);
|
||||
}
|
||||
return pointermid;
|
||||
}
|
||||
function diffCommonOverlap(text1, text2) {
|
||||
const text1_length = text1.length;
|
||||
const text2_length = text2.length;
|
||||
if (text1_length === 0 || text2_length === 0)
|
||||
return 0;
|
||||
if (text1_length > text2_length)
|
||||
text1 = text1.substring(text1_length - text2_length);
|
||||
else if (text1_length < text2_length)
|
||||
text2 = text2.substring(0, text1_length);
|
||||
const text_length = Math.min(text1_length, text2_length);
|
||||
if (text1 === text2)
|
||||
return text_length;
|
||||
let best = 0;
|
||||
let length = 1;
|
||||
while (true) {
|
||||
const pattern = text1.substring(text_length - length);
|
||||
const found = text2.indexOf(pattern);
|
||||
if (found === -1)
|
||||
return best;
|
||||
length += found;
|
||||
if (found === 0 || text1.substring(text_length - length) === text2.substring(0, length)) {
|
||||
best = length;
|
||||
length++;
|
||||
}
|
||||
}
|
||||
}
|
||||
function diffHalfMatch(text1, text2, options) {
|
||||
if (options.diffTimeout <= 0) {
|
||||
return null;
|
||||
}
|
||||
const longtext = text1.length > text2.length ? text1 : text2;
|
||||
const shorttext = text1.length > text2.length ? text2 : text1;
|
||||
if (longtext.length < 4 || shorttext.length * 2 < longtext.length)
|
||||
return null;
|
||||
function diffHalfMatchI(longtext2, shorttext2, i) {
|
||||
const seed = longtext2.substring(i, i + Math.floor(longtext2.length / 4));
|
||||
let j = -1;
|
||||
let best_common = "";
|
||||
let best_longtext_a, best_longtext_b, best_shorttext_a, best_shorttext_b;
|
||||
while ((j = shorttext2.indexOf(seed, j + 1)) !== -1) {
|
||||
const prefixLength = diffCommonPrefix(longtext2.substring(i), shorttext2.substring(j));
|
||||
const suffixLength = diffCommonSuffix(longtext2.substring(0, i), shorttext2.substring(0, j));
|
||||
if (best_common.length < suffixLength + prefixLength) {
|
||||
best_common = shorttext2.substring(j - suffixLength, j) + shorttext2.substring(j, j + prefixLength);
|
||||
best_longtext_a = longtext2.substring(0, i - suffixLength);
|
||||
best_longtext_b = longtext2.substring(i + prefixLength);
|
||||
best_shorttext_a = shorttext2.substring(0, j - suffixLength);
|
||||
best_shorttext_b = shorttext2.substring(j + prefixLength);
|
||||
}
|
||||
}
|
||||
if (best_common.length * 2 >= longtext2.length)
|
||||
return [best_longtext_a, best_longtext_b, best_shorttext_a, best_shorttext_b, best_common];
|
||||
else
|
||||
return null;
|
||||
}
|
||||
const hm1 = diffHalfMatchI(longtext, shorttext, Math.ceil(longtext.length / 4));
|
||||
const hm2 = diffHalfMatchI(longtext, shorttext, Math.ceil(longtext.length / 2));
|
||||
let hm;
|
||||
if (!hm1 && !hm2) {
|
||||
return null;
|
||||
} else if (!hm2) {
|
||||
hm = hm1;
|
||||
} else if (!hm1) {
|
||||
hm = hm2;
|
||||
} else {
|
||||
hm = hm1[4].length > hm2[4].length ? hm1 : hm2;
|
||||
}
|
||||
let text1_a, text1_b, text2_a, text2_b;
|
||||
if (text1.length > text2.length) {
|
||||
text1_a = hm[0];
|
||||
text1_b = hm[1];
|
||||
text2_a = hm[2];
|
||||
text2_b = hm[3];
|
||||
} else {
|
||||
text2_a = hm[0];
|
||||
text2_b = hm[1];
|
||||
text1_a = hm[2];
|
||||
text1_b = hm[3];
|
||||
}
|
||||
const mid_common = hm[4];
|
||||
return [text1_a, text1_b, text2_a, text2_b, mid_common];
|
||||
}
|
||||
function diffCleanupSemantic(diffs) {
|
||||
let changes = false;
|
||||
const equalities = [];
|
||||
let equalitiesLength = 0;
|
||||
let lastEquality = null;
|
||||
let pointer = 0;
|
||||
let length_insertions1 = 0;
|
||||
let length_deletions1 = 0;
|
||||
let length_insertions2 = 0;
|
||||
let length_deletions2 = 0;
|
||||
while (pointer < diffs.length) {
|
||||
if (diffs[pointer][0] === DIFF_EQUAL) {
|
||||
equalities[equalitiesLength++] = pointer;
|
||||
length_insertions1 = length_insertions2;
|
||||
length_deletions1 = length_deletions2;
|
||||
length_insertions2 = 0;
|
||||
length_deletions2 = 0;
|
||||
lastEquality = diffs[pointer][1];
|
||||
} else {
|
||||
if (diffs[pointer][0] === DIFF_INSERT)
|
||||
length_insertions2 += diffs[pointer][1].length;
|
||||
else
|
||||
length_deletions2 += diffs[pointer][1].length;
|
||||
if (lastEquality && lastEquality.length <= Math.max(length_insertions1, length_deletions1) && lastEquality.length <= Math.max(length_insertions2, length_deletions2)) {
|
||||
diffs.splice(equalities[equalitiesLength - 1], 0, createDiff(DIFF_DELETE, lastEquality));
|
||||
diffs[equalities[equalitiesLength - 1] + 1][0] = DIFF_INSERT;
|
||||
equalitiesLength--;
|
||||
equalitiesLength--;
|
||||
pointer = equalitiesLength > 0 ? equalities[equalitiesLength - 1] : -1;
|
||||
length_insertions1 = 0;
|
||||
length_deletions1 = 0;
|
||||
length_insertions2 = 0;
|
||||
length_deletions2 = 0;
|
||||
lastEquality = null;
|
||||
changes = true;
|
||||
}
|
||||
}
|
||||
pointer++;
|
||||
}
|
||||
if (changes)
|
||||
diffCleanupMerge(diffs);
|
||||
diffCleanupSemanticLossless(diffs);
|
||||
pointer = 1;
|
||||
while (pointer < diffs.length) {
|
||||
if (diffs[pointer - 1][0] === DIFF_DELETE && diffs[pointer][0] === DIFF_INSERT) {
|
||||
const deletion = diffs[pointer - 1][1];
|
||||
const insertion = diffs[pointer][1];
|
||||
const overlap_length1 = diffCommonOverlap(deletion, insertion);
|
||||
const overlap_length2 = diffCommonOverlap(insertion, deletion);
|
||||
if (overlap_length1 >= overlap_length2) {
|
||||
if (overlap_length1 >= deletion.length / 2 || overlap_length1 >= insertion.length / 2) {
|
||||
diffs.splice(pointer, 0, createDiff(DIFF_EQUAL, insertion.substring(0, overlap_length1)));
|
||||
diffs[pointer - 1][1] = deletion.substring(0, deletion.length - overlap_length1);
|
||||
diffs[pointer + 1][1] = insertion.substring(overlap_length1);
|
||||
pointer++;
|
||||
}
|
||||
} else {
|
||||
if (overlap_length2 >= deletion.length / 2 || overlap_length2 >= insertion.length / 2) {
|
||||
diffs.splice(pointer, 0, createDiff(DIFF_EQUAL, deletion.substring(0, overlap_length2)));
|
||||
diffs[pointer - 1][0] = DIFF_INSERT;
|
||||
diffs[pointer - 1][1] = insertion.substring(0, insertion.length - overlap_length2);
|
||||
diffs[pointer + 1][0] = DIFF_DELETE;
|
||||
diffs[pointer + 1][1] = deletion.substring(overlap_length2);
|
||||
pointer++;
|
||||
}
|
||||
}
|
||||
pointer++;
|
||||
}
|
||||
pointer++;
|
||||
}
|
||||
}
|
||||
const nonAlphaNumericRegex_ = /[^a-zA-Z0-9]/;
|
||||
const whitespaceRegex_ = /\s/;
|
||||
const linebreakRegex_ = /[\r\n]/;
|
||||
const blanklineEndRegex_ = /\n\r?\n$/;
|
||||
const blanklineStartRegex_ = /^\r?\n\r?\n/;
|
||||
function diffCleanupSemanticLossless(diffs) {
|
||||
function diffCleanupSemanticScore(one, two) {
|
||||
if (!one || !two) {
|
||||
return 6;
|
||||
}
|
||||
const char1 = one.charAt(one.length - 1);
|
||||
const char2 = two.charAt(0);
|
||||
const nonAlphaNumeric1 = char1.match(nonAlphaNumericRegex_);
|
||||
const nonAlphaNumeric2 = char2.match(nonAlphaNumericRegex_);
|
||||
const whitespace1 = nonAlphaNumeric1 && char1.match(whitespaceRegex_);
|
||||
const whitespace2 = nonAlphaNumeric2 && char2.match(whitespaceRegex_);
|
||||
const lineBreak1 = whitespace1 && char1.match(linebreakRegex_);
|
||||
const lineBreak2 = whitespace2 && char2.match(linebreakRegex_);
|
||||
const blankLine1 = lineBreak1 && one.match(blanklineEndRegex_);
|
||||
const blankLine2 = lineBreak2 && two.match(blanklineStartRegex_);
|
||||
if (blankLine1 || blankLine2) {
|
||||
return 5;
|
||||
} else if (lineBreak1 || lineBreak2) {
|
||||
return 4;
|
||||
} else if (nonAlphaNumeric1 && !whitespace1 && whitespace2) {
|
||||
return 3;
|
||||
} else if (whitespace1 || whitespace2) {
|
||||
return 2;
|
||||
} else if (nonAlphaNumeric1 || nonAlphaNumeric2) {
|
||||
return 1;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
let pointer = 1;
|
||||
while (pointer < diffs.length - 1) {
|
||||
if (diffs[pointer - 1][0] === DIFF_EQUAL && diffs[pointer + 1][0] === DIFF_EQUAL) {
|
||||
let equality1 = diffs[pointer - 1][1];
|
||||
let edit = diffs[pointer][1];
|
||||
let equality2 = diffs[pointer + 1][1];
|
||||
const commonOffset = diffCommonSuffix(equality1, edit);
|
||||
if (commonOffset) {
|
||||
const commonString = edit.substring(edit.length - commonOffset);
|
||||
equality1 = equality1.substring(0, equality1.length - commonOffset);
|
||||
edit = commonString + edit.substring(0, edit.length - commonOffset);
|
||||
equality2 = commonString + equality2;
|
||||
}
|
||||
let bestEquality1 = equality1;
|
||||
let bestEdit = edit;
|
||||
let bestEquality2 = equality2;
|
||||
let bestScore = diffCleanupSemanticScore(equality1, edit) + diffCleanupSemanticScore(edit, equality2);
|
||||
while (edit.charAt(0) === equality2.charAt(0)) {
|
||||
equality1 += edit.charAt(0);
|
||||
edit = edit.substring(1) + equality2.charAt(0);
|
||||
equality2 = equality2.substring(1);
|
||||
const score = diffCleanupSemanticScore(equality1, edit) + diffCleanupSemanticScore(edit, equality2);
|
||||
if (score >= bestScore) {
|
||||
bestScore = score;
|
||||
bestEquality1 = equality1;
|
||||
bestEdit = edit;
|
||||
bestEquality2 = equality2;
|
||||
}
|
||||
}
|
||||
if (diffs[pointer - 1][1] !== bestEquality1) {
|
||||
if (bestEquality1) {
|
||||
diffs[pointer - 1][1] = bestEquality1;
|
||||
} else {
|
||||
diffs.splice(pointer - 1, 1);
|
||||
pointer--;
|
||||
}
|
||||
diffs[pointer][1] = bestEdit;
|
||||
if (bestEquality2) {
|
||||
diffs[pointer + 1][1] = bestEquality2;
|
||||
} else {
|
||||
diffs.splice(pointer + 1, 1);
|
||||
pointer--;
|
||||
}
|
||||
}
|
||||
}
|
||||
pointer++;
|
||||
}
|
||||
}
|
||||
function diffCleanupMerge(diffs) {
|
||||
diffs.push(createDiff(DIFF_EQUAL, ""));
|
||||
let pointer = 0;
|
||||
let count_delete = 0;
|
||||
let count_insert = 0;
|
||||
let text_delete = "";
|
||||
let text_insert = "";
|
||||
let commonlength;
|
||||
while (pointer < diffs.length) {
|
||||
switch (diffs[pointer][0]) {
|
||||
case DIFF_INSERT:
|
||||
count_insert++;
|
||||
text_insert += diffs[pointer][1];
|
||||
pointer++;
|
||||
break;
|
||||
case DIFF_DELETE:
|
||||
count_delete++;
|
||||
text_delete += diffs[pointer][1];
|
||||
pointer++;
|
||||
break;
|
||||
case DIFF_EQUAL:
|
||||
if (count_delete + count_insert > 1) {
|
||||
if (count_delete !== 0 && count_insert !== 0) {
|
||||
commonlength = diffCommonPrefix(text_insert, text_delete);
|
||||
if (commonlength !== 0) {
|
||||
if (pointer - count_delete - count_insert > 0 && diffs[pointer - count_delete - count_insert - 1][0] === DIFF_EQUAL) {
|
||||
diffs[pointer - count_delete - count_insert - 1][1] += text_insert.substring(0, commonlength);
|
||||
} else {
|
||||
diffs.splice(0, 0, createDiff(DIFF_EQUAL, text_insert.substring(0, commonlength)));
|
||||
pointer++;
|
||||
}
|
||||
text_insert = text_insert.substring(commonlength);
|
||||
text_delete = text_delete.substring(commonlength);
|
||||
}
|
||||
commonlength = diffCommonSuffix(text_insert, text_delete);
|
||||
if (commonlength !== 0) {
|
||||
diffs[pointer][1] = text_insert.substring(text_insert.length - commonlength) + diffs[pointer][1];
|
||||
text_insert = text_insert.substring(0, text_insert.length - commonlength);
|
||||
text_delete = text_delete.substring(0, text_delete.length - commonlength);
|
||||
}
|
||||
}
|
||||
pointer -= count_delete + count_insert;
|
||||
diffs.splice(pointer, count_delete + count_insert);
|
||||
if (text_delete.length) {
|
||||
diffs.splice(pointer, 0, createDiff(DIFF_DELETE, text_delete));
|
||||
pointer++;
|
||||
}
|
||||
if (text_insert.length) {
|
||||
diffs.splice(pointer, 0, createDiff(DIFF_INSERT, text_insert));
|
||||
pointer++;
|
||||
}
|
||||
pointer++;
|
||||
} else if (pointer !== 0 && diffs[pointer - 1][0] === DIFF_EQUAL) {
|
||||
diffs[pointer - 1][1] += diffs[pointer][1];
|
||||
diffs.splice(pointer, 1);
|
||||
} else {
|
||||
pointer++;
|
||||
}
|
||||
count_insert = 0;
|
||||
count_delete = 0;
|
||||
text_delete = "";
|
||||
text_insert = "";
|
||||
break;
|
||||
}
|
||||
}
|
||||
if (diffs[diffs.length - 1][1] === "")
|
||||
diffs.pop();
|
||||
let changes = false;
|
||||
pointer = 1;
|
||||
while (pointer < diffs.length - 1) {
|
||||
if (diffs[pointer - 1][0] === DIFF_EQUAL && diffs[pointer + 1][0] === DIFF_EQUAL) {
|
||||
if (diffs[pointer][1].substring(diffs[pointer][1].length - diffs[pointer - 1][1].length) === diffs[pointer - 1][1]) {
|
||||
diffs[pointer][1] = diffs[pointer - 1][1] + diffs[pointer][1].substring(0, diffs[pointer][1].length - diffs[pointer - 1][1].length);
|
||||
diffs[pointer + 1][1] = diffs[pointer - 1][1] + diffs[pointer + 1][1];
|
||||
diffs.splice(pointer - 1, 1);
|
||||
changes = true;
|
||||
} else if (diffs[pointer][1].substring(0, diffs[pointer + 1][1].length) === diffs[pointer + 1][1]) {
|
||||
diffs[pointer - 1][1] += diffs[pointer + 1][1];
|
||||
diffs[pointer][1] = diffs[pointer][1].substring(diffs[pointer + 1][1].length) + diffs[pointer + 1][1];
|
||||
diffs.splice(pointer + 1, 1);
|
||||
changes = true;
|
||||
}
|
||||
}
|
||||
pointer++;
|
||||
}
|
||||
if (changes)
|
||||
diffCleanupMerge(diffs);
|
||||
}
|
||||
|
||||
function calculateDiff(left, right) {
|
||||
const changes = diffMain(left, right);
|
||||
diffCleanupSemantic(changes);
|
||||
return changes;
|
||||
}
|
||||
const exports$1 = {
|
||||
calculateDiff
|
||||
};
|
||||
expose(exports$1);
|
||||
|
||||
})();
|
||||
122452
node_modules/vite-plugin-inspect/dist/client/assets/index-970ldLH4.js
generated
vendored
Normal file
122452
node_modules/vite-plugin-inspect/dist/client/assets/index-970ldLH4.js
generated
vendored
Normal file
File diff suppressed because one or more lines are too long
607
node_modules/vite-plugin-inspect/dist/client/assets/index-BePA97H0.js
generated
vendored
Normal file
607
node_modules/vite-plugin-inspect/dist/client/assets/index-BePA97H0.js
generated
vendored
Normal file
@@ -0,0 +1,607 @@
|
||||
const defaults = Object.freeze({
|
||||
ignoreUnknown: false,
|
||||
respectType: false,
|
||||
respectFunctionNames: false,
|
||||
respectFunctionProperties: false,
|
||||
unorderedObjects: true,
|
||||
unorderedArrays: false,
|
||||
unorderedSets: false,
|
||||
excludeKeys: void 0,
|
||||
excludeValues: void 0,
|
||||
replacer: void 0
|
||||
});
|
||||
function objectHash(object, options) {
|
||||
if (options) {
|
||||
options = { ...defaults, ...options };
|
||||
} else {
|
||||
options = defaults;
|
||||
}
|
||||
const hasher = createHasher(options);
|
||||
hasher.dispatch(object);
|
||||
return hasher.toString();
|
||||
}
|
||||
const defaultPrototypesKeys = Object.freeze([
|
||||
"prototype",
|
||||
"__proto__",
|
||||
"constructor"
|
||||
]);
|
||||
function createHasher(options) {
|
||||
let buff = "";
|
||||
let context = /* @__PURE__ */ new Map();
|
||||
const write = (str) => {
|
||||
buff += str;
|
||||
};
|
||||
return {
|
||||
toString() {
|
||||
return buff;
|
||||
},
|
||||
getContext() {
|
||||
return context;
|
||||
},
|
||||
dispatch(value) {
|
||||
if (options.replacer) {
|
||||
value = options.replacer(value);
|
||||
}
|
||||
const type = value === null ? "null" : typeof value;
|
||||
return this[type](value);
|
||||
},
|
||||
object(object) {
|
||||
if (object && typeof object.toJSON === "function") {
|
||||
return this.object(object.toJSON());
|
||||
}
|
||||
const objString = Object.prototype.toString.call(object);
|
||||
let objType = "";
|
||||
const objectLength = objString.length;
|
||||
if (objectLength < 10) {
|
||||
objType = "unknown:[" + objString + "]";
|
||||
} else {
|
||||
objType = objString.slice(8, objectLength - 1);
|
||||
}
|
||||
objType = objType.toLowerCase();
|
||||
let objectNumber = null;
|
||||
if ((objectNumber = context.get(object)) === void 0) {
|
||||
context.set(object, context.size);
|
||||
} else {
|
||||
return this.dispatch("[CIRCULAR:" + objectNumber + "]");
|
||||
}
|
||||
if (typeof Buffer !== "undefined" && Buffer.isBuffer && Buffer.isBuffer(object)) {
|
||||
write("buffer:");
|
||||
return write(object.toString("utf8"));
|
||||
}
|
||||
if (objType !== "object" && objType !== "function" && objType !== "asyncfunction") {
|
||||
if (this[objType]) {
|
||||
this[objType](object);
|
||||
} else if (!options.ignoreUnknown) {
|
||||
this.unkown(object, objType);
|
||||
}
|
||||
} else {
|
||||
let keys = Object.keys(object);
|
||||
if (options.unorderedObjects) {
|
||||
keys = keys.sort();
|
||||
}
|
||||
let extraKeys = [];
|
||||
if (options.respectType !== false && !isNativeFunction(object)) {
|
||||
extraKeys = defaultPrototypesKeys;
|
||||
}
|
||||
if (options.excludeKeys) {
|
||||
keys = keys.filter((key) => {
|
||||
return !options.excludeKeys(key);
|
||||
});
|
||||
extraKeys = extraKeys.filter((key) => {
|
||||
return !options.excludeKeys(key);
|
||||
});
|
||||
}
|
||||
write("object:" + (keys.length + extraKeys.length) + ":");
|
||||
const dispatchForKey = (key) => {
|
||||
this.dispatch(key);
|
||||
write(":");
|
||||
if (!options.excludeValues) {
|
||||
this.dispatch(object[key]);
|
||||
}
|
||||
write(",");
|
||||
};
|
||||
for (const key of keys) {
|
||||
dispatchForKey(key);
|
||||
}
|
||||
for (const key of extraKeys) {
|
||||
dispatchForKey(key);
|
||||
}
|
||||
}
|
||||
},
|
||||
array(arr, unordered) {
|
||||
unordered = unordered === void 0 ? options.unorderedArrays !== false : unordered;
|
||||
write("array:" + arr.length + ":");
|
||||
if (!unordered || arr.length <= 1) {
|
||||
for (const entry of arr) {
|
||||
this.dispatch(entry);
|
||||
}
|
||||
return;
|
||||
}
|
||||
const contextAdditions = /* @__PURE__ */ new Map();
|
||||
const entries = arr.map((entry) => {
|
||||
const hasher = createHasher(options);
|
||||
hasher.dispatch(entry);
|
||||
for (const [key, value] of hasher.getContext()) {
|
||||
contextAdditions.set(key, value);
|
||||
}
|
||||
return hasher.toString();
|
||||
});
|
||||
context = contextAdditions;
|
||||
entries.sort();
|
||||
return this.array(entries, false);
|
||||
},
|
||||
date(date) {
|
||||
return write("date:" + date.toJSON());
|
||||
},
|
||||
symbol(sym) {
|
||||
return write("symbol:" + sym.toString());
|
||||
},
|
||||
unkown(value, type) {
|
||||
write(type);
|
||||
if (!value) {
|
||||
return;
|
||||
}
|
||||
write(":");
|
||||
if (value && typeof value.entries === "function") {
|
||||
return this.array(
|
||||
Array.from(value.entries()),
|
||||
true
|
||||
/* ordered */
|
||||
);
|
||||
}
|
||||
},
|
||||
error(err) {
|
||||
return write("error:" + err.toString());
|
||||
},
|
||||
boolean(bool) {
|
||||
return write("bool:" + bool);
|
||||
},
|
||||
string(string) {
|
||||
write("string:" + string.length + ":");
|
||||
write(string);
|
||||
},
|
||||
function(fn) {
|
||||
write("fn:");
|
||||
if (isNativeFunction(fn)) {
|
||||
this.dispatch("[native]");
|
||||
} else {
|
||||
this.dispatch(fn.toString());
|
||||
}
|
||||
if (options.respectFunctionNames !== false) {
|
||||
this.dispatch("function-name:" + String(fn.name));
|
||||
}
|
||||
if (options.respectFunctionProperties) {
|
||||
this.object(fn);
|
||||
}
|
||||
},
|
||||
number(number) {
|
||||
return write("number:" + number);
|
||||
},
|
||||
xml(xml) {
|
||||
return write("xml:" + xml.toString());
|
||||
},
|
||||
null() {
|
||||
return write("Null");
|
||||
},
|
||||
undefined() {
|
||||
return write("Undefined");
|
||||
},
|
||||
regexp(regex) {
|
||||
return write("regex:" + regex.toString());
|
||||
},
|
||||
uint8array(arr) {
|
||||
write("uint8array:");
|
||||
return this.dispatch(Array.prototype.slice.call(arr));
|
||||
},
|
||||
uint8clampedarray(arr) {
|
||||
write("uint8clampedarray:");
|
||||
return this.dispatch(Array.prototype.slice.call(arr));
|
||||
},
|
||||
int8array(arr) {
|
||||
write("int8array:");
|
||||
return this.dispatch(Array.prototype.slice.call(arr));
|
||||
},
|
||||
uint16array(arr) {
|
||||
write("uint16array:");
|
||||
return this.dispatch(Array.prototype.slice.call(arr));
|
||||
},
|
||||
int16array(arr) {
|
||||
write("int16array:");
|
||||
return this.dispatch(Array.prototype.slice.call(arr));
|
||||
},
|
||||
uint32array(arr) {
|
||||
write("uint32array:");
|
||||
return this.dispatch(Array.prototype.slice.call(arr));
|
||||
},
|
||||
int32array(arr) {
|
||||
write("int32array:");
|
||||
return this.dispatch(Array.prototype.slice.call(arr));
|
||||
},
|
||||
float32array(arr) {
|
||||
write("float32array:");
|
||||
return this.dispatch(Array.prototype.slice.call(arr));
|
||||
},
|
||||
float64array(arr) {
|
||||
write("float64array:");
|
||||
return this.dispatch(Array.prototype.slice.call(arr));
|
||||
},
|
||||
arraybuffer(arr) {
|
||||
write("arraybuffer:");
|
||||
return this.dispatch(new Uint8Array(arr));
|
||||
},
|
||||
url(url) {
|
||||
return write("url:" + url.toString());
|
||||
},
|
||||
map(map) {
|
||||
write("map:");
|
||||
const arr = [...map];
|
||||
return this.array(arr, options.unorderedSets !== false);
|
||||
},
|
||||
set(set) {
|
||||
write("set:");
|
||||
const arr = [...set];
|
||||
return this.array(arr, options.unorderedSets !== false);
|
||||
},
|
||||
file(file) {
|
||||
write("file:");
|
||||
return this.dispatch([file.name, file.size, file.type, file.lastModfied]);
|
||||
},
|
||||
blob() {
|
||||
if (options.ignoreUnknown) {
|
||||
return write("[blob]");
|
||||
}
|
||||
throw new Error(
|
||||
'Hashing Blob objects is currently not supported\nUse "options.replacer" or "options.ignoreUnknown"\n'
|
||||
);
|
||||
},
|
||||
domwindow() {
|
||||
return write("domwindow");
|
||||
},
|
||||
bigint(number) {
|
||||
return write("bigint:" + number.toString());
|
||||
},
|
||||
/* Node.js standard native objects */
|
||||
process() {
|
||||
return write("process");
|
||||
},
|
||||
timer() {
|
||||
return write("timer");
|
||||
},
|
||||
pipe() {
|
||||
return write("pipe");
|
||||
},
|
||||
tcp() {
|
||||
return write("tcp");
|
||||
},
|
||||
udp() {
|
||||
return write("udp");
|
||||
},
|
||||
tty() {
|
||||
return write("tty");
|
||||
},
|
||||
statwatcher() {
|
||||
return write("statwatcher");
|
||||
},
|
||||
securecontext() {
|
||||
return write("securecontext");
|
||||
},
|
||||
connection() {
|
||||
return write("connection");
|
||||
},
|
||||
zlib() {
|
||||
return write("zlib");
|
||||
},
|
||||
context() {
|
||||
return write("context");
|
||||
},
|
||||
nodescript() {
|
||||
return write("nodescript");
|
||||
},
|
||||
httpparser() {
|
||||
return write("httpparser");
|
||||
},
|
||||
dataview() {
|
||||
return write("dataview");
|
||||
},
|
||||
signal() {
|
||||
return write("signal");
|
||||
},
|
||||
fsevent() {
|
||||
return write("fsevent");
|
||||
},
|
||||
tlswrap() {
|
||||
return write("tlswrap");
|
||||
}
|
||||
};
|
||||
}
|
||||
const nativeFunc = "[native code] }";
|
||||
const nativeFuncLength = nativeFunc.length;
|
||||
function isNativeFunction(f) {
|
||||
if (typeof f !== "function") {
|
||||
return false;
|
||||
}
|
||||
return Function.prototype.toString.call(f).slice(-nativeFuncLength) === nativeFunc;
|
||||
}
|
||||
|
||||
class WordArray {
|
||||
constructor(words, sigBytes) {
|
||||
words = this.words = words || [];
|
||||
this.sigBytes = sigBytes === void 0 ? words.length * 4 : sigBytes;
|
||||
}
|
||||
toString(encoder) {
|
||||
return (encoder || Hex).stringify(this);
|
||||
}
|
||||
concat(wordArray) {
|
||||
this.clamp();
|
||||
if (this.sigBytes % 4) {
|
||||
for (let i = 0; i < wordArray.sigBytes; i++) {
|
||||
const thatByte = wordArray.words[i >>> 2] >>> 24 - i % 4 * 8 & 255;
|
||||
this.words[this.sigBytes + i >>> 2] |= thatByte << 24 - (this.sigBytes + i) % 4 * 8;
|
||||
}
|
||||
} else {
|
||||
for (let j = 0; j < wordArray.sigBytes; j += 4) {
|
||||
this.words[this.sigBytes + j >>> 2] = wordArray.words[j >>> 2];
|
||||
}
|
||||
}
|
||||
this.sigBytes += wordArray.sigBytes;
|
||||
return this;
|
||||
}
|
||||
clamp() {
|
||||
this.words[this.sigBytes >>> 2] &= 4294967295 << 32 - this.sigBytes % 4 * 8;
|
||||
this.words.length = Math.ceil(this.sigBytes / 4);
|
||||
}
|
||||
clone() {
|
||||
return new WordArray([...this.words]);
|
||||
}
|
||||
}
|
||||
const Hex = {
|
||||
stringify(wordArray) {
|
||||
const hexChars = [];
|
||||
for (let i = 0; i < wordArray.sigBytes; i++) {
|
||||
const bite = wordArray.words[i >>> 2] >>> 24 - i % 4 * 8 & 255;
|
||||
hexChars.push((bite >>> 4).toString(16), (bite & 15).toString(16));
|
||||
}
|
||||
return hexChars.join("");
|
||||
}
|
||||
};
|
||||
const Base64 = {
|
||||
stringify(wordArray) {
|
||||
const keyStr = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";
|
||||
const base64Chars = [];
|
||||
for (let i = 0; i < wordArray.sigBytes; i += 3) {
|
||||
const byte1 = wordArray.words[i >>> 2] >>> 24 - i % 4 * 8 & 255;
|
||||
const byte2 = wordArray.words[i + 1 >>> 2] >>> 24 - (i + 1) % 4 * 8 & 255;
|
||||
const byte3 = wordArray.words[i + 2 >>> 2] >>> 24 - (i + 2) % 4 * 8 & 255;
|
||||
const triplet = byte1 << 16 | byte2 << 8 | byte3;
|
||||
for (let j = 0; j < 4 && i * 8 + j * 6 < wordArray.sigBytes * 8; j++) {
|
||||
base64Chars.push(keyStr.charAt(triplet >>> 6 * (3 - j) & 63));
|
||||
}
|
||||
}
|
||||
return base64Chars.join("");
|
||||
}
|
||||
};
|
||||
const Latin1 = {
|
||||
parse(latin1Str) {
|
||||
const latin1StrLength = latin1Str.length;
|
||||
const words = [];
|
||||
for (let i = 0; i < latin1StrLength; i++) {
|
||||
words[i >>> 2] |= (latin1Str.charCodeAt(i) & 255) << 24 - i % 4 * 8;
|
||||
}
|
||||
return new WordArray(words, latin1StrLength);
|
||||
}
|
||||
};
|
||||
const Utf8 = {
|
||||
parse(utf8Str) {
|
||||
return Latin1.parse(unescape(encodeURIComponent(utf8Str)));
|
||||
}
|
||||
};
|
||||
class BufferedBlockAlgorithm {
|
||||
constructor() {
|
||||
this._data = new WordArray();
|
||||
this._nDataBytes = 0;
|
||||
this._minBufferSize = 0;
|
||||
this.blockSize = 512 / 32;
|
||||
}
|
||||
reset() {
|
||||
this._data = new WordArray();
|
||||
this._nDataBytes = 0;
|
||||
}
|
||||
_append(data) {
|
||||
if (typeof data === "string") {
|
||||
data = Utf8.parse(data);
|
||||
}
|
||||
this._data.concat(data);
|
||||
this._nDataBytes += data.sigBytes;
|
||||
}
|
||||
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
||||
_doProcessBlock(_dataWords, _offset) {
|
||||
}
|
||||
_process(doFlush) {
|
||||
let processedWords;
|
||||
let nBlocksReady = this._data.sigBytes / (this.blockSize * 4);
|
||||
if (doFlush) {
|
||||
nBlocksReady = Math.ceil(nBlocksReady);
|
||||
} else {
|
||||
nBlocksReady = Math.max((nBlocksReady | 0) - this._minBufferSize, 0);
|
||||
}
|
||||
const nWordsReady = nBlocksReady * this.blockSize;
|
||||
const nBytesReady = Math.min(nWordsReady * 4, this._data.sigBytes);
|
||||
if (nWordsReady) {
|
||||
for (let offset = 0; offset < nWordsReady; offset += this.blockSize) {
|
||||
this._doProcessBlock(this._data.words, offset);
|
||||
}
|
||||
processedWords = this._data.words.splice(0, nWordsReady);
|
||||
this._data.sigBytes -= nBytesReady;
|
||||
}
|
||||
return new WordArray(processedWords, nBytesReady);
|
||||
}
|
||||
}
|
||||
class Hasher extends BufferedBlockAlgorithm {
|
||||
update(messageUpdate) {
|
||||
this._append(messageUpdate);
|
||||
this._process();
|
||||
return this;
|
||||
}
|
||||
finalize(messageUpdate) {
|
||||
if (messageUpdate) {
|
||||
this._append(messageUpdate);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
const H = [
|
||||
1779033703,
|
||||
-1150833019,
|
||||
1013904242,
|
||||
-1521486534,
|
||||
1359893119,
|
||||
-1694144372,
|
||||
528734635,
|
||||
1541459225
|
||||
];
|
||||
const K = [
|
||||
1116352408,
|
||||
1899447441,
|
||||
-1245643825,
|
||||
-373957723,
|
||||
961987163,
|
||||
1508970993,
|
||||
-1841331548,
|
||||
-1424204075,
|
||||
-670586216,
|
||||
310598401,
|
||||
607225278,
|
||||
1426881987,
|
||||
1925078388,
|
||||
-2132889090,
|
||||
-1680079193,
|
||||
-1046744716,
|
||||
-459576895,
|
||||
-272742522,
|
||||
264347078,
|
||||
604807628,
|
||||
770255983,
|
||||
1249150122,
|
||||
1555081692,
|
||||
1996064986,
|
||||
-1740746414,
|
||||
-1473132947,
|
||||
-1341970488,
|
||||
-1084653625,
|
||||
-958395405,
|
||||
-710438585,
|
||||
113926993,
|
||||
338241895,
|
||||
666307205,
|
||||
773529912,
|
||||
1294757372,
|
||||
1396182291,
|
||||
1695183700,
|
||||
1986661051,
|
||||
-2117940946,
|
||||
-1838011259,
|
||||
-1564481375,
|
||||
-1474664885,
|
||||
-1035236496,
|
||||
-949202525,
|
||||
-778901479,
|
||||
-694614492,
|
||||
-200395387,
|
||||
275423344,
|
||||
430227734,
|
||||
506948616,
|
||||
659060556,
|
||||
883997877,
|
||||
958139571,
|
||||
1322822218,
|
||||
1537002063,
|
||||
1747873779,
|
||||
1955562222,
|
||||
2024104815,
|
||||
-2067236844,
|
||||
-1933114872,
|
||||
-1866530822,
|
||||
-1538233109,
|
||||
-1090935817,
|
||||
-965641998
|
||||
];
|
||||
const W = [];
|
||||
class SHA256 extends Hasher {
|
||||
constructor() {
|
||||
super(...arguments);
|
||||
this._hash = new WordArray([...H]);
|
||||
}
|
||||
reset() {
|
||||
super.reset();
|
||||
this._hash = new WordArray([...H]);
|
||||
}
|
||||
_doProcessBlock(M, offset) {
|
||||
const H2 = this._hash.words;
|
||||
let a = H2[0];
|
||||
let b = H2[1];
|
||||
let c = H2[2];
|
||||
let d = H2[3];
|
||||
let e = H2[4];
|
||||
let f = H2[5];
|
||||
let g = H2[6];
|
||||
let h = H2[7];
|
||||
for (let i = 0; i < 64; i++) {
|
||||
if (i < 16) {
|
||||
W[i] = M[offset + i] | 0;
|
||||
} else {
|
||||
const gamma0x = W[i - 15];
|
||||
const gamma0 = (gamma0x << 25 | gamma0x >>> 7) ^ (gamma0x << 14 | gamma0x >>> 18) ^ gamma0x >>> 3;
|
||||
const gamma1x = W[i - 2];
|
||||
const gamma1 = (gamma1x << 15 | gamma1x >>> 17) ^ (gamma1x << 13 | gamma1x >>> 19) ^ gamma1x >>> 10;
|
||||
W[i] = gamma0 + W[i - 7] + gamma1 + W[i - 16];
|
||||
}
|
||||
const ch = e & f ^ ~e & g;
|
||||
const maj = a & b ^ a & c ^ b & c;
|
||||
const sigma0 = (a << 30 | a >>> 2) ^ (a << 19 | a >>> 13) ^ (a << 10 | a >>> 22);
|
||||
const sigma1 = (e << 26 | e >>> 6) ^ (e << 21 | e >>> 11) ^ (e << 7 | e >>> 25);
|
||||
const t1 = h + sigma1 + ch + K[i] + W[i];
|
||||
const t2 = sigma0 + maj;
|
||||
h = g;
|
||||
g = f;
|
||||
f = e;
|
||||
e = d + t1 | 0;
|
||||
d = c;
|
||||
c = b;
|
||||
b = a;
|
||||
a = t1 + t2 | 0;
|
||||
}
|
||||
H2[0] = H2[0] + a | 0;
|
||||
H2[1] = H2[1] + b | 0;
|
||||
H2[2] = H2[2] + c | 0;
|
||||
H2[3] = H2[3] + d | 0;
|
||||
H2[4] = H2[4] + e | 0;
|
||||
H2[5] = H2[5] + f | 0;
|
||||
H2[6] = H2[6] + g | 0;
|
||||
H2[7] = H2[7] + h | 0;
|
||||
}
|
||||
finalize(messageUpdate) {
|
||||
super.finalize(messageUpdate);
|
||||
const nBitsTotal = this._nDataBytes * 8;
|
||||
const nBitsLeft = this._data.sigBytes * 8;
|
||||
this._data.words[nBitsLeft >>> 5] |= 128 << 24 - nBitsLeft % 32;
|
||||
this._data.words[(nBitsLeft + 64 >>> 9 << 4) + 14] = Math.floor(
|
||||
nBitsTotal / 4294967296
|
||||
);
|
||||
this._data.words[(nBitsLeft + 64 >>> 9 << 4) + 15] = nBitsTotal;
|
||||
this._data.sigBytes = this._data.words.length * 4;
|
||||
this._process();
|
||||
return this._hash;
|
||||
}
|
||||
}
|
||||
function sha256base64(message) {
|
||||
return new SHA256().finalize(message).toString(Base64);
|
||||
}
|
||||
|
||||
function hash(object, options = {}) {
|
||||
const hashed = typeof object === "string" ? object : objectHash(object, options);
|
||||
return sha256base64(hashed).slice(0, 10);
|
||||
}
|
||||
|
||||
/* Injected with object hook! */
|
||||
|
||||
export { hash, objectHash, sha256base64 };
|
||||
1037
node_modules/vite-plugin-inspect/dist/client/assets/index-CUG8c4cH.css
generated
vendored
Normal file
1037
node_modules/vite-plugin-inspect/dist/client/assets/index-CUG8c4cH.css
generated
vendored
Normal file
File diff suppressed because one or more lines are too long
21
node_modules/vite-plugin-inspect/dist/client/favicon.svg
generated
vendored
Normal file
21
node_modules/vite-plugin-inspect/dist/client/favicon.svg
generated
vendored
Normal file
@@ -0,0 +1,21 @@
|
||||
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" aria-hidden="true" role="img"
|
||||
class="iconify iconify--carbon" width="32" height="32" preserveAspectRatio="xMidYMid meet" viewBox="0 0 32 32">
|
||||
<style>
|
||||
.a {
|
||||
fill: #333;
|
||||
}
|
||||
|
||||
@media (prefers-color-scheme: dark) {
|
||||
.a {
|
||||
fill: #eee;
|
||||
}
|
||||
}
|
||||
</style>
|
||||
<path class="a" d="M6 17h8v2H6z" />
|
||||
<circle cx="3" cy="18" r="1" class="a" />
|
||||
<circle cx="13" cy="14" r="1" class="a" />
|
||||
<path class="a" d="M2 13h8v2H2zm4-4h8v2H6z" />
|
||||
<circle cx="3" cy="10" r="1" class="a" />
|
||||
<path class="a"
|
||||
d="m30 28.6l-7.4-7.4c1.5-2 2.4-4.5 2.4-7.2c0-6.6-5.4-12-12-12c-3.3 0-6.4 1.3-8.7 3.8l1.5 1.4C7.6 5.1 10.2 4 13 4c5.5 0 10 4.5 10 10s-4.5 10-10 10c-3 0-5.8-1.3-7.7-3.6l-1.5 1.3C6 24.4 9.4 26 13 26c3.2 0 6.1-1.3 8.3-3.3l7.3 7.3l1.4-1.4z" />
|
||||
</svg>
|
||||
|
After Width: | Height: | Size: 857 B |
27
node_modules/vite-plugin-inspect/dist/client/index.html
generated
vendored
Normal file
27
node_modules/vite-plugin-inspect/dist/client/index.html
generated
vendored
Normal file
@@ -0,0 +1,27 @@
|
||||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="UTF-8">
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||
<link rel="icon" href="./favicon.svg" type="image/svg+xml">
|
||||
<title>Vite Inspect</title>
|
||||
<script type="module" crossorigin src="./assets/index-970ldLH4.js"></script>
|
||||
<link rel="stylesheet" crossorigin href="./assets/index-CUG8c4cH.css">
|
||||
</head>
|
||||
<body data-vite-inspect-mode="DEV">
|
||||
<div id="app"></div>
|
||||
<script>
|
||||
(function () {
|
||||
const prefersDark = window.matchMedia && window.matchMedia('(prefers-color-scheme: dark)').matches
|
||||
const setting = localStorage.getItem('color-schema') || 'auto'
|
||||
if (setting === 'dark' || (prefersDark && setting !== 'light'))
|
||||
document.documentElement.classList.toggle('dark', true)
|
||||
})()
|
||||
|
||||
;(function () {
|
||||
if (!location.pathname.endsWith('/'))
|
||||
location.pathname += '/'
|
||||
})()
|
||||
</script>
|
||||
</body>
|
||||
</html>
|
||||
1406
node_modules/vite-plugin-inspect/dist/index.cjs
generated
vendored
Normal file
1406
node_modules/vite-plugin-inspect/dist/index.cjs
generated
vendored
Normal file
File diff suppressed because it is too large
Load Diff
78
node_modules/vite-plugin-inspect/dist/index.d.cts
generated
vendored
Normal file
78
node_modules/vite-plugin-inspect/dist/index.d.cts
generated
vendored
Normal file
@@ -0,0 +1,78 @@
|
||||
import { Plugin } from 'vite';
|
||||
import { Awaitable } from '@antfu/utils';
|
||||
import { StackFrame } from 'error-stack-parser-es';
|
||||
import { O as Options } from './shared/vite-plugin-inspect.2cd7208c.cjs';
|
||||
import '@rollup/pluginutils';
|
||||
|
||||
interface TransformInfo {
|
||||
name: string;
|
||||
result?: string;
|
||||
start: number;
|
||||
end: number;
|
||||
order?: string;
|
||||
sourcemaps?: any;
|
||||
error?: ParsedError;
|
||||
}
|
||||
interface ParsedError {
|
||||
message: string;
|
||||
stack: StackFrame[];
|
||||
raw?: any;
|
||||
}
|
||||
interface ModuleInfo {
|
||||
id: string;
|
||||
plugins: {
|
||||
name: string;
|
||||
transform?: number;
|
||||
resolveId?: number;
|
||||
}[];
|
||||
deps: string[];
|
||||
virtual: boolean;
|
||||
totalTime: number;
|
||||
invokeCount: number;
|
||||
sourceSize: number;
|
||||
distSize: number;
|
||||
}
|
||||
interface ModulesList {
|
||||
root: string;
|
||||
modules: ModuleInfo[];
|
||||
ssrModules: ModuleInfo[];
|
||||
}
|
||||
interface ModuleTransformInfo {
|
||||
resolvedId: string;
|
||||
transforms: TransformInfo[];
|
||||
}
|
||||
interface PluginMetricInfo {
|
||||
name: string;
|
||||
enforce?: string;
|
||||
transform: {
|
||||
invokeCount: number;
|
||||
totalTime: number;
|
||||
};
|
||||
resolveId: {
|
||||
invokeCount: number;
|
||||
totalTime: number;
|
||||
};
|
||||
}
|
||||
interface RPCFunctions {
|
||||
list: () => Awaitable<ModulesList>;
|
||||
getIdInfo: (id: string, ssr: boolean, clear?: boolean) => Awaitable<ModuleTransformInfo>;
|
||||
resolveId: (id: string, ssr: boolean) => Awaitable<string>;
|
||||
clear: (id: string, ssr: boolean) => Awaitable<void>;
|
||||
getPluginMetrics: (ssr: boolean) => Awaitable<PluginMetricInfo[]>;
|
||||
getServerMetrics: () => Awaitable<Record<string, Record<string, {
|
||||
name: string;
|
||||
self: number;
|
||||
total: number;
|
||||
}[]>>>;
|
||||
moduleUpdated: () => void;
|
||||
}
|
||||
|
||||
interface ViteInspectAPI {
|
||||
rpc: RPCFunctions;
|
||||
}
|
||||
declare function PluginInspect(options?: Options): Plugin;
|
||||
declare namespace PluginInspect {
|
||||
var getViteInspectAPI: (plugins: Plugin[]) => ViteInspectAPI | undefined;
|
||||
}
|
||||
|
||||
export { Options, type ViteInspectAPI, PluginInspect as default };
|
||||
78
node_modules/vite-plugin-inspect/dist/index.d.mts
generated
vendored
Normal file
78
node_modules/vite-plugin-inspect/dist/index.d.mts
generated
vendored
Normal file
@@ -0,0 +1,78 @@
|
||||
import { Plugin } from 'vite';
|
||||
import { Awaitable } from '@antfu/utils';
|
||||
import { StackFrame } from 'error-stack-parser-es';
|
||||
import { O as Options } from './shared/vite-plugin-inspect.2cd7208c.mjs';
|
||||
import '@rollup/pluginutils';
|
||||
|
||||
interface TransformInfo {
|
||||
name: string;
|
||||
result?: string;
|
||||
start: number;
|
||||
end: number;
|
||||
order?: string;
|
||||
sourcemaps?: any;
|
||||
error?: ParsedError;
|
||||
}
|
||||
interface ParsedError {
|
||||
message: string;
|
||||
stack: StackFrame[];
|
||||
raw?: any;
|
||||
}
|
||||
interface ModuleInfo {
|
||||
id: string;
|
||||
plugins: {
|
||||
name: string;
|
||||
transform?: number;
|
||||
resolveId?: number;
|
||||
}[];
|
||||
deps: string[];
|
||||
virtual: boolean;
|
||||
totalTime: number;
|
||||
invokeCount: number;
|
||||
sourceSize: number;
|
||||
distSize: number;
|
||||
}
|
||||
interface ModulesList {
|
||||
root: string;
|
||||
modules: ModuleInfo[];
|
||||
ssrModules: ModuleInfo[];
|
||||
}
|
||||
interface ModuleTransformInfo {
|
||||
resolvedId: string;
|
||||
transforms: TransformInfo[];
|
||||
}
|
||||
interface PluginMetricInfo {
|
||||
name: string;
|
||||
enforce?: string;
|
||||
transform: {
|
||||
invokeCount: number;
|
||||
totalTime: number;
|
||||
};
|
||||
resolveId: {
|
||||
invokeCount: number;
|
||||
totalTime: number;
|
||||
};
|
||||
}
|
||||
interface RPCFunctions {
|
||||
list: () => Awaitable<ModulesList>;
|
||||
getIdInfo: (id: string, ssr: boolean, clear?: boolean) => Awaitable<ModuleTransformInfo>;
|
||||
resolveId: (id: string, ssr: boolean) => Awaitable<string>;
|
||||
clear: (id: string, ssr: boolean) => Awaitable<void>;
|
||||
getPluginMetrics: (ssr: boolean) => Awaitable<PluginMetricInfo[]>;
|
||||
getServerMetrics: () => Awaitable<Record<string, Record<string, {
|
||||
name: string;
|
||||
self: number;
|
||||
total: number;
|
||||
}[]>>>;
|
||||
moduleUpdated: () => void;
|
||||
}
|
||||
|
||||
interface ViteInspectAPI {
|
||||
rpc: RPCFunctions;
|
||||
}
|
||||
declare function PluginInspect(options?: Options): Plugin;
|
||||
declare namespace PluginInspect {
|
||||
var getViteInspectAPI: (plugins: Plugin[]) => ViteInspectAPI | undefined;
|
||||
}
|
||||
|
||||
export { Options, type ViteInspectAPI, PluginInspect as default };
|
||||
78
node_modules/vite-plugin-inspect/dist/index.d.ts
generated
vendored
Normal file
78
node_modules/vite-plugin-inspect/dist/index.d.ts
generated
vendored
Normal file
@@ -0,0 +1,78 @@
|
||||
import { Plugin } from 'vite';
|
||||
import { Awaitable } from '@antfu/utils';
|
||||
import { StackFrame } from 'error-stack-parser-es';
|
||||
import { O as Options } from './shared/vite-plugin-inspect.2cd7208c.js';
|
||||
import '@rollup/pluginutils';
|
||||
|
||||
interface TransformInfo {
|
||||
name: string;
|
||||
result?: string;
|
||||
start: number;
|
||||
end: number;
|
||||
order?: string;
|
||||
sourcemaps?: any;
|
||||
error?: ParsedError;
|
||||
}
|
||||
interface ParsedError {
|
||||
message: string;
|
||||
stack: StackFrame[];
|
||||
raw?: any;
|
||||
}
|
||||
interface ModuleInfo {
|
||||
id: string;
|
||||
plugins: {
|
||||
name: string;
|
||||
transform?: number;
|
||||
resolveId?: number;
|
||||
}[];
|
||||
deps: string[];
|
||||
virtual: boolean;
|
||||
totalTime: number;
|
||||
invokeCount: number;
|
||||
sourceSize: number;
|
||||
distSize: number;
|
||||
}
|
||||
interface ModulesList {
|
||||
root: string;
|
||||
modules: ModuleInfo[];
|
||||
ssrModules: ModuleInfo[];
|
||||
}
|
||||
interface ModuleTransformInfo {
|
||||
resolvedId: string;
|
||||
transforms: TransformInfo[];
|
||||
}
|
||||
interface PluginMetricInfo {
|
||||
name: string;
|
||||
enforce?: string;
|
||||
transform: {
|
||||
invokeCount: number;
|
||||
totalTime: number;
|
||||
};
|
||||
resolveId: {
|
||||
invokeCount: number;
|
||||
totalTime: number;
|
||||
};
|
||||
}
|
||||
interface RPCFunctions {
|
||||
list: () => Awaitable<ModulesList>;
|
||||
getIdInfo: (id: string, ssr: boolean, clear?: boolean) => Awaitable<ModuleTransformInfo>;
|
||||
resolveId: (id: string, ssr: boolean) => Awaitable<string>;
|
||||
clear: (id: string, ssr: boolean) => Awaitable<void>;
|
||||
getPluginMetrics: (ssr: boolean) => Awaitable<PluginMetricInfo[]>;
|
||||
getServerMetrics: () => Awaitable<Record<string, Record<string, {
|
||||
name: string;
|
||||
self: number;
|
||||
total: number;
|
||||
}[]>>>;
|
||||
moduleUpdated: () => void;
|
||||
}
|
||||
|
||||
interface ViteInspectAPI {
|
||||
rpc: RPCFunctions;
|
||||
}
|
||||
declare function PluginInspect(options?: Options): Plugin;
|
||||
declare namespace PluginInspect {
|
||||
var getViteInspectAPI: (plugins: Plugin[]) => ViteInspectAPI | undefined;
|
||||
}
|
||||
|
||||
export { Options, type ViteInspectAPI, PluginInspect as default };
|
||||
1395
node_modules/vite-plugin-inspect/dist/index.mjs
generated
vendored
Normal file
1395
node_modules/vite-plugin-inspect/dist/index.mjs
generated
vendored
Normal file
File diff suppressed because it is too large
Load Diff
28
node_modules/vite-plugin-inspect/dist/nuxt.cjs
generated
vendored
Normal file
28
node_modules/vite-plugin-inspect/dist/nuxt.cjs
generated
vendored
Normal file
@@ -0,0 +1,28 @@
|
||||
'use strict';Object.defineProperty(exports, '__esModule', {value: true});
|
||||
|
||||
const kit = require('@nuxt/kit');
|
||||
const index = require('./index.cjs');
|
||||
require('node:process');
|
||||
require('sirv');
|
||||
require('picocolors');
|
||||
require('perfect-debounce');
|
||||
require('node:path');
|
||||
require('node:url');
|
||||
require('node:buffer');
|
||||
require('@rollup/pluginutils');
|
||||
require('debug');
|
||||
require('error-stack-parser-es');
|
||||
require('fs-extra');
|
||||
require('node:http');
|
||||
|
||||
const nuxt = kit.defineNuxtModule({
|
||||
meta: {
|
||||
name: "vite-plugin-inspect",
|
||||
configKey: "inspect"
|
||||
},
|
||||
setup(options) {
|
||||
kit.addVitePlugin(() => index(options));
|
||||
}
|
||||
});
|
||||
|
||||
exports.default = nuxt;
|
||||
6
node_modules/vite-plugin-inspect/dist/nuxt.d.cts
generated
vendored
Normal file
6
node_modules/vite-plugin-inspect/dist/nuxt.d.cts
generated
vendored
Normal file
@@ -0,0 +1,6 @@
|
||||
export { O as ModuleOptions } from './shared/vite-plugin-inspect.2cd7208c.cjs';
|
||||
import '@rollup/pluginutils';
|
||||
|
||||
declare const _default: any;
|
||||
|
||||
export { _default as default };
|
||||
6
node_modules/vite-plugin-inspect/dist/nuxt.d.mts
generated
vendored
Normal file
6
node_modules/vite-plugin-inspect/dist/nuxt.d.mts
generated
vendored
Normal file
@@ -0,0 +1,6 @@
|
||||
export { O as ModuleOptions } from './shared/vite-plugin-inspect.2cd7208c.mjs';
|
||||
import '@rollup/pluginutils';
|
||||
|
||||
declare const _default: any;
|
||||
|
||||
export { _default as default };
|
||||
6
node_modules/vite-plugin-inspect/dist/nuxt.d.ts
generated
vendored
Normal file
6
node_modules/vite-plugin-inspect/dist/nuxt.d.ts
generated
vendored
Normal file
@@ -0,0 +1,6 @@
|
||||
export { O as ModuleOptions } from './shared/vite-plugin-inspect.2cd7208c.js';
|
||||
import '@rollup/pluginutils';
|
||||
|
||||
declare const _default: any;
|
||||
|
||||
export { _default as default };
|
||||
26
node_modules/vite-plugin-inspect/dist/nuxt.mjs
generated
vendored
Normal file
26
node_modules/vite-plugin-inspect/dist/nuxt.mjs
generated
vendored
Normal file
@@ -0,0 +1,26 @@
|
||||
import { defineNuxtModule, addVitePlugin } from '@nuxt/kit';
|
||||
import PluginInspect from './index.mjs';
|
||||
import 'node:process';
|
||||
import 'sirv';
|
||||
import 'picocolors';
|
||||
import 'perfect-debounce';
|
||||
import 'node:path';
|
||||
import 'node:url';
|
||||
import 'node:buffer';
|
||||
import '@rollup/pluginutils';
|
||||
import 'debug';
|
||||
import 'error-stack-parser-es';
|
||||
import 'fs-extra';
|
||||
import 'node:http';
|
||||
|
||||
const nuxt = defineNuxtModule({
|
||||
meta: {
|
||||
name: "vite-plugin-inspect",
|
||||
configKey: "inspect"
|
||||
},
|
||||
setup(options) {
|
||||
addVitePlugin(() => PluginInspect(options));
|
||||
}
|
||||
});
|
||||
|
||||
export { nuxt as default };
|
||||
61
node_modules/vite-plugin-inspect/dist/shared/vite-plugin-inspect.2cd7208c.d.cts
generated
vendored
Normal file
61
node_modules/vite-plugin-inspect/dist/shared/vite-plugin-inspect.2cd7208c.d.cts
generated
vendored
Normal file
@@ -0,0 +1,61 @@
|
||||
import { FilterPattern } from '@rollup/pluginutils';
|
||||
|
||||
interface Options {
|
||||
/**
|
||||
* Enable the inspect plugin in dev mode (could be some performance overhead)
|
||||
*
|
||||
* @default true
|
||||
*/
|
||||
dev?: boolean;
|
||||
/**
|
||||
* Enable the inspect plugin in build mode, and output the report to `.vite-inspect`
|
||||
*
|
||||
* @default false
|
||||
*/
|
||||
build?: boolean;
|
||||
/**
|
||||
* @deprecated use `dev` or `build` option instead.
|
||||
*/
|
||||
enabled?: boolean;
|
||||
/**
|
||||
* Directory for build inspector UI output
|
||||
* Only work in build mode
|
||||
*
|
||||
* @default '.vite-inspect'
|
||||
*/
|
||||
outputDir?: string;
|
||||
/**
|
||||
* Filter for modules to be inspected
|
||||
*/
|
||||
include?: FilterPattern;
|
||||
/**
|
||||
* Filter for modules to not be inspected
|
||||
*/
|
||||
exclude?: FilterPattern;
|
||||
/**
|
||||
* Base URL for inspector UI
|
||||
*
|
||||
* @default read from Vite's config
|
||||
*/
|
||||
base?: string;
|
||||
/**
|
||||
* Print URL output silently in the terminal
|
||||
*
|
||||
* @default false
|
||||
*/
|
||||
silent?: boolean;
|
||||
/**
|
||||
* Automatically open inspect page
|
||||
*
|
||||
* @default false
|
||||
*/
|
||||
open?: boolean;
|
||||
/**
|
||||
* Remove version query `?v=xxx` and treat them as the same module
|
||||
*
|
||||
* @default true
|
||||
*/
|
||||
removeVersionQuery?: boolean;
|
||||
}
|
||||
|
||||
export type { Options as O };
|
||||
61
node_modules/vite-plugin-inspect/dist/shared/vite-plugin-inspect.2cd7208c.d.mts
generated
vendored
Normal file
61
node_modules/vite-plugin-inspect/dist/shared/vite-plugin-inspect.2cd7208c.d.mts
generated
vendored
Normal file
@@ -0,0 +1,61 @@
|
||||
import { FilterPattern } from '@rollup/pluginutils';
|
||||
|
||||
interface Options {
|
||||
/**
|
||||
* Enable the inspect plugin in dev mode (could be some performance overhead)
|
||||
*
|
||||
* @default true
|
||||
*/
|
||||
dev?: boolean;
|
||||
/**
|
||||
* Enable the inspect plugin in build mode, and output the report to `.vite-inspect`
|
||||
*
|
||||
* @default false
|
||||
*/
|
||||
build?: boolean;
|
||||
/**
|
||||
* @deprecated use `dev` or `build` option instead.
|
||||
*/
|
||||
enabled?: boolean;
|
||||
/**
|
||||
* Directory for build inspector UI output
|
||||
* Only work in build mode
|
||||
*
|
||||
* @default '.vite-inspect'
|
||||
*/
|
||||
outputDir?: string;
|
||||
/**
|
||||
* Filter for modules to be inspected
|
||||
*/
|
||||
include?: FilterPattern;
|
||||
/**
|
||||
* Filter for modules to not be inspected
|
||||
*/
|
||||
exclude?: FilterPattern;
|
||||
/**
|
||||
* Base URL for inspector UI
|
||||
*
|
||||
* @default read from Vite's config
|
||||
*/
|
||||
base?: string;
|
||||
/**
|
||||
* Print URL output silently in the terminal
|
||||
*
|
||||
* @default false
|
||||
*/
|
||||
silent?: boolean;
|
||||
/**
|
||||
* Automatically open inspect page
|
||||
*
|
||||
* @default false
|
||||
*/
|
||||
open?: boolean;
|
||||
/**
|
||||
* Remove version query `?v=xxx` and treat them as the same module
|
||||
*
|
||||
* @default true
|
||||
*/
|
||||
removeVersionQuery?: boolean;
|
||||
}
|
||||
|
||||
export type { Options as O };
|
||||
61
node_modules/vite-plugin-inspect/dist/shared/vite-plugin-inspect.2cd7208c.d.ts
generated
vendored
Normal file
61
node_modules/vite-plugin-inspect/dist/shared/vite-plugin-inspect.2cd7208c.d.ts
generated
vendored
Normal file
@@ -0,0 +1,61 @@
|
||||
import { FilterPattern } from '@rollup/pluginutils';
|
||||
|
||||
interface Options {
|
||||
/**
|
||||
* Enable the inspect plugin in dev mode (could be some performance overhead)
|
||||
*
|
||||
* @default true
|
||||
*/
|
||||
dev?: boolean;
|
||||
/**
|
||||
* Enable the inspect plugin in build mode, and output the report to `.vite-inspect`
|
||||
*
|
||||
* @default false
|
||||
*/
|
||||
build?: boolean;
|
||||
/**
|
||||
* @deprecated use `dev` or `build` option instead.
|
||||
*/
|
||||
enabled?: boolean;
|
||||
/**
|
||||
* Directory for build inspector UI output
|
||||
* Only work in build mode
|
||||
*
|
||||
* @default '.vite-inspect'
|
||||
*/
|
||||
outputDir?: string;
|
||||
/**
|
||||
* Filter for modules to be inspected
|
||||
*/
|
||||
include?: FilterPattern;
|
||||
/**
|
||||
* Filter for modules to not be inspected
|
||||
*/
|
||||
exclude?: FilterPattern;
|
||||
/**
|
||||
* Base URL for inspector UI
|
||||
*
|
||||
* @default read from Vite's config
|
||||
*/
|
||||
base?: string;
|
||||
/**
|
||||
* Print URL output silently in the terminal
|
||||
*
|
||||
* @default false
|
||||
*/
|
||||
silent?: boolean;
|
||||
/**
|
||||
* Automatically open inspect page
|
||||
*
|
||||
* @default false
|
||||
*/
|
||||
open?: boolean;
|
||||
/**
|
||||
* Remove version query `?v=xxx` and treat them as the same module
|
||||
*
|
||||
* @default true
|
||||
*/
|
||||
removeVersionQuery?: boolean;
|
||||
}
|
||||
|
||||
export type { Options as O };
|
||||
15
node_modules/vite-plugin-inspect/node_modules/fs-extra/LICENSE
generated
vendored
Normal file
15
node_modules/vite-plugin-inspect/node_modules/fs-extra/LICENSE
generated
vendored
Normal file
@@ -0,0 +1,15 @@
|
||||
(The MIT License)
|
||||
|
||||
Copyright (c) 2011-2017 JP Richardson
|
||||
|
||||
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.
|
||||
292
node_modules/vite-plugin-inspect/node_modules/fs-extra/README.md
generated
vendored
Normal file
292
node_modules/vite-plugin-inspect/node_modules/fs-extra/README.md
generated
vendored
Normal file
@@ -0,0 +1,292 @@
|
||||
Node.js: fs-extra
|
||||
=================
|
||||
|
||||
`fs-extra` adds file system methods that aren't included in the native `fs` module and adds promise support to the `fs` methods. It also uses [`graceful-fs`](https://github.com/isaacs/node-graceful-fs) to prevent `EMFILE` errors. It should be a drop in replacement for `fs`.
|
||||
|
||||
[](https://www.npmjs.org/package/fs-extra)
|
||||
[](https://github.com/jprichardson/node-fs-extra/blob/master/LICENSE)
|
||||
[](https://github.com/jprichardson/node-fs-extra/actions/workflows/ci.yml?query=branch%3Amaster)
|
||||
[](https://www.npmjs.org/package/fs-extra)
|
||||
[](https://standardjs.com)
|
||||
|
||||
Why?
|
||||
----
|
||||
|
||||
I got tired of including `mkdirp`, `rimraf`, and `ncp` in most of my projects.
|
||||
|
||||
|
||||
|
||||
|
||||
Installation
|
||||
------------
|
||||
|
||||
npm install fs-extra
|
||||
|
||||
|
||||
|
||||
Usage
|
||||
-----
|
||||
|
||||
### CommonJS
|
||||
|
||||
`fs-extra` is a drop in replacement for native `fs`. All methods in `fs` are attached to `fs-extra`. All `fs` methods return promises if the callback isn't passed.
|
||||
|
||||
You don't ever need to include the original `fs` module again:
|
||||
|
||||
```js
|
||||
const fs = require('fs') // this is no longer necessary
|
||||
```
|
||||
|
||||
you can now do this:
|
||||
|
||||
```js
|
||||
const fs = require('fs-extra')
|
||||
```
|
||||
|
||||
or if you prefer to make it clear that you're using `fs-extra` and not `fs`, you may want
|
||||
to name your `fs` variable `fse` like so:
|
||||
|
||||
```js
|
||||
const fse = require('fs-extra')
|
||||
```
|
||||
|
||||
you can also keep both, but it's redundant:
|
||||
|
||||
```js
|
||||
const fs = require('fs')
|
||||
const fse = require('fs-extra')
|
||||
```
|
||||
|
||||
### ESM
|
||||
|
||||
There is also an `fs-extra/esm` import, that supports both default and named exports. However, note that `fs` methods are not included in `fs-extra/esm`; you still need to import `fs` and/or `fs/promises` seperately:
|
||||
|
||||
```js
|
||||
import { readFileSync } from 'fs'
|
||||
import { readFile } from 'fs/promises'
|
||||
import { outputFile, outputFileSync } from 'fs-extra/esm'
|
||||
```
|
||||
|
||||
Default exports are supported:
|
||||
|
||||
```js
|
||||
import fs from 'fs'
|
||||
import fse from 'fs-extra/esm'
|
||||
// fse.readFileSync is not a function; must use fs.readFileSync
|
||||
```
|
||||
|
||||
but you probably want to just use regular `fs-extra` instead of `fs-extra/esm` for default exports:
|
||||
|
||||
```js
|
||||
import fs from 'fs-extra'
|
||||
// both fs and fs-extra methods are defined
|
||||
```
|
||||
|
||||
Sync vs Async vs Async/Await
|
||||
-------------
|
||||
Most methods are async by default. All async methods will return a promise if the callback isn't passed.
|
||||
|
||||
Sync methods on the other hand will throw if an error occurs.
|
||||
|
||||
Also Async/Await will throw an error if one occurs.
|
||||
|
||||
Example:
|
||||
|
||||
```js
|
||||
const fs = require('fs-extra')
|
||||
|
||||
// Async with promises:
|
||||
fs.copy('/tmp/myfile', '/tmp/mynewfile')
|
||||
.then(() => console.log('success!'))
|
||||
.catch(err => console.error(err))
|
||||
|
||||
// Async with callbacks:
|
||||
fs.copy('/tmp/myfile', '/tmp/mynewfile', err => {
|
||||
if (err) return console.error(err)
|
||||
console.log('success!')
|
||||
})
|
||||
|
||||
// Sync:
|
||||
try {
|
||||
fs.copySync('/tmp/myfile', '/tmp/mynewfile')
|
||||
console.log('success!')
|
||||
} catch (err) {
|
||||
console.error(err)
|
||||
}
|
||||
|
||||
// Async/Await:
|
||||
async function copyFiles () {
|
||||
try {
|
||||
await fs.copy('/tmp/myfile', '/tmp/mynewfile')
|
||||
console.log('success!')
|
||||
} catch (err) {
|
||||
console.error(err)
|
||||
}
|
||||
}
|
||||
|
||||
copyFiles()
|
||||
```
|
||||
|
||||
|
||||
Methods
|
||||
-------
|
||||
|
||||
### Async
|
||||
|
||||
- [copy](docs/copy.md)
|
||||
- [emptyDir](docs/emptyDir.md)
|
||||
- [ensureFile](docs/ensureFile.md)
|
||||
- [ensureDir](docs/ensureDir.md)
|
||||
- [ensureLink](docs/ensureLink.md)
|
||||
- [ensureSymlink](docs/ensureSymlink.md)
|
||||
- [mkdirp](docs/ensureDir.md)
|
||||
- [mkdirs](docs/ensureDir.md)
|
||||
- [move](docs/move.md)
|
||||
- [outputFile](docs/outputFile.md)
|
||||
- [outputJson](docs/outputJson.md)
|
||||
- [pathExists](docs/pathExists.md)
|
||||
- [readJson](docs/readJson.md)
|
||||
- [remove](docs/remove.md)
|
||||
- [writeJson](docs/writeJson.md)
|
||||
|
||||
### Sync
|
||||
|
||||
- [copySync](docs/copy-sync.md)
|
||||
- [emptyDirSync](docs/emptyDir-sync.md)
|
||||
- [ensureFileSync](docs/ensureFile-sync.md)
|
||||
- [ensureDirSync](docs/ensureDir-sync.md)
|
||||
- [ensureLinkSync](docs/ensureLink-sync.md)
|
||||
- [ensureSymlinkSync](docs/ensureSymlink-sync.md)
|
||||
- [mkdirpSync](docs/ensureDir-sync.md)
|
||||
- [mkdirsSync](docs/ensureDir-sync.md)
|
||||
- [moveSync](docs/move-sync.md)
|
||||
- [outputFileSync](docs/outputFile-sync.md)
|
||||
- [outputJsonSync](docs/outputJson-sync.md)
|
||||
- [pathExistsSync](docs/pathExists-sync.md)
|
||||
- [readJsonSync](docs/readJson-sync.md)
|
||||
- [removeSync](docs/remove-sync.md)
|
||||
- [writeJsonSync](docs/writeJson-sync.md)
|
||||
|
||||
|
||||
**NOTE:** You can still use the native Node.js methods. They are promisified and copied over to `fs-extra`. See [notes on `fs.read()`, `fs.write()`, & `fs.writev()`](docs/fs-read-write-writev.md)
|
||||
|
||||
### What happened to `walk()` and `walkSync()`?
|
||||
|
||||
They were removed from `fs-extra` in v2.0.0. If you need the functionality, `walk` and `walkSync` are available as separate packages, [`klaw`](https://github.com/jprichardson/node-klaw) and [`klaw-sync`](https://github.com/manidlou/node-klaw-sync).
|
||||
|
||||
|
||||
Third Party
|
||||
-----------
|
||||
|
||||
### CLI
|
||||
|
||||
[fse-cli](https://www.npmjs.com/package/@atao60/fse-cli) allows you to run `fs-extra` from a console or from [npm](https://www.npmjs.com) scripts.
|
||||
|
||||
### TypeScript
|
||||
|
||||
If you like TypeScript, you can use `fs-extra` with it: https://github.com/DefinitelyTyped/DefinitelyTyped/tree/master/types/fs-extra
|
||||
|
||||
|
||||
### File / Directory Watching
|
||||
|
||||
If you want to watch for changes to files or directories, then you should use [chokidar](https://github.com/paulmillr/chokidar).
|
||||
|
||||
### Obtain Filesystem (Devices, Partitions) Information
|
||||
|
||||
[fs-filesystem](https://github.com/arthurintelligence/node-fs-filesystem) allows you to read the state of the filesystem of the host on which it is run. It returns information about both the devices and the partitions (volumes) of the system.
|
||||
|
||||
### Misc.
|
||||
|
||||
- [fs-extra-debug](https://github.com/jdxcode/fs-extra-debug) - Send your fs-extra calls to [debug](https://npmjs.org/package/debug).
|
||||
- [mfs](https://github.com/cadorn/mfs) - Monitor your fs-extra calls.
|
||||
|
||||
|
||||
|
||||
Hacking on fs-extra
|
||||
-------------------
|
||||
|
||||
Wanna hack on `fs-extra`? Great! Your help is needed! [fs-extra is one of the most depended upon Node.js packages](http://nodei.co/npm/fs-extra.png?downloads=true&downloadRank=true&stars=true). This project
|
||||
uses [JavaScript Standard Style](https://github.com/feross/standard) - if the name or style choices bother you,
|
||||
you're gonna have to get over it :) If `standard` is good enough for `npm`, it's good enough for `fs-extra`.
|
||||
|
||||
[](https://github.com/feross/standard)
|
||||
|
||||
What's needed?
|
||||
- First, take a look at existing issues. Those are probably going to be where the priority lies.
|
||||
- More tests for edge cases. Specifically on different platforms. There can never be enough tests.
|
||||
- Improve test coverage.
|
||||
|
||||
Note: If you make any big changes, **you should definitely file an issue for discussion first.**
|
||||
|
||||
### Running the Test Suite
|
||||
|
||||
fs-extra contains hundreds of tests.
|
||||
|
||||
- `npm run lint`: runs the linter ([standard](http://standardjs.com/))
|
||||
- `npm run unit`: runs the unit tests
|
||||
- `npm run unit-esm`: runs tests for `fs-extra/esm` exports
|
||||
- `npm test`: runs the linter and all tests
|
||||
|
||||
When running unit tests, set the environment variable `CROSS_DEVICE_PATH` to the absolute path of an empty directory on another device (like a thumb drive) to enable cross-device move tests.
|
||||
|
||||
|
||||
### Windows
|
||||
|
||||
If you run the tests on the Windows and receive a lot of symbolic link `EPERM` permission errors, it's
|
||||
because on Windows you need elevated privilege to create symbolic links. You can add this to your Windows's
|
||||
account by following the instructions here: http://superuser.com/questions/104845/permission-to-make-symbolic-links-in-windows-7
|
||||
However, I didn't have much luck doing this.
|
||||
|
||||
Since I develop on Mac OS X, I use VMWare Fusion for Windows testing. I create a shared folder that I map to a drive on Windows.
|
||||
I open the `Node.js command prompt` and run as `Administrator`. I then map the network drive running the following command:
|
||||
|
||||
net use z: "\\vmware-host\Shared Folders"
|
||||
|
||||
I can then navigate to my `fs-extra` directory and run the tests.
|
||||
|
||||
|
||||
Naming
|
||||
------
|
||||
|
||||
I put a lot of thought into the naming of these functions. Inspired by @coolaj86's request. So he deserves much of the credit for raising the issue. See discussion(s) here:
|
||||
|
||||
* https://github.com/jprichardson/node-fs-extra/issues/2
|
||||
* https://github.com/flatiron/utile/issues/11
|
||||
* https://github.com/ryanmcgrath/wrench-js/issues/29
|
||||
* https://github.com/substack/node-mkdirp/issues/17
|
||||
|
||||
First, I believe that in as many cases as possible, the [Node.js naming schemes](http://nodejs.org/api/fs.html) should be chosen. However, there are problems with the Node.js own naming schemes.
|
||||
|
||||
For example, `fs.readFile()` and `fs.readdir()`: the **F** is capitalized in *File* and the **d** is not capitalized in *dir*. Perhaps a bit pedantic, but they should still be consistent. Also, Node.js has chosen a lot of POSIX naming schemes, which I believe is great. See: `fs.mkdir()`, `fs.rmdir()`, `fs.chown()`, etc.
|
||||
|
||||
We have a dilemma though. How do you consistently name methods that perform the following POSIX commands: `cp`, `cp -r`, `mkdir -p`, and `rm -rf`?
|
||||
|
||||
My perspective: when in doubt, err on the side of simplicity. A directory is just a hierarchical grouping of directories and files. Consider that for a moment. So when you want to copy it or remove it, in most cases you'll want to copy or remove all of its contents. When you want to create a directory, if the directory that it's suppose to be contained in does not exist, then in most cases you'll want to create that too.
|
||||
|
||||
So, if you want to remove a file or a directory regardless of whether it has contents, just call `fs.remove(path)`. If you want to copy a file or a directory whether it has contents, just call `fs.copy(source, destination)`. If you want to create a directory regardless of whether its parent directories exist, just call `fs.mkdirs(path)` or `fs.mkdirp(path)`.
|
||||
|
||||
|
||||
Credit
|
||||
------
|
||||
|
||||
`fs-extra` wouldn't be possible without using the modules from the following authors:
|
||||
|
||||
- [Isaac Shlueter](https://github.com/isaacs)
|
||||
- [Charlie McConnel](https://github.com/avianflu)
|
||||
- [James Halliday](https://github.com/substack)
|
||||
- [Andrew Kelley](https://github.com/andrewrk)
|
||||
|
||||
|
||||
|
||||
|
||||
License
|
||||
-------
|
||||
|
||||
Licensed under MIT
|
||||
|
||||
Copyright (c) 2011-2017 [JP Richardson](https://github.com/jprichardson)
|
||||
|
||||
[1]: http://nodejs.org/docs/latest/api/fs.html
|
||||
|
||||
|
||||
[jsonfile]: https://github.com/jprichardson/node-jsonfile
|
||||
161
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/copy/copy-sync.js
generated
vendored
Normal file
161
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/copy/copy-sync.js
generated
vendored
Normal file
@@ -0,0 +1,161 @@
|
||||
'use strict'
|
||||
|
||||
const fs = require('graceful-fs')
|
||||
const path = require('path')
|
||||
const mkdirsSync = require('../mkdirs').mkdirsSync
|
||||
const utimesMillisSync = require('../util/utimes').utimesMillisSync
|
||||
const stat = require('../util/stat')
|
||||
|
||||
function copySync (src, dest, opts) {
|
||||
if (typeof opts === 'function') {
|
||||
opts = { filter: opts }
|
||||
}
|
||||
|
||||
opts = opts || {}
|
||||
opts.clobber = 'clobber' in opts ? !!opts.clobber : true // default to true for now
|
||||
opts.overwrite = 'overwrite' in opts ? !!opts.overwrite : opts.clobber // overwrite falls back to clobber
|
||||
|
||||
// Warn about using preserveTimestamps on 32-bit node
|
||||
if (opts.preserveTimestamps && process.arch === 'ia32') {
|
||||
process.emitWarning(
|
||||
'Using the preserveTimestamps option in 32-bit node is not recommended;\n\n' +
|
||||
'\tsee https://github.com/jprichardson/node-fs-extra/issues/269',
|
||||
'Warning', 'fs-extra-WARN0002'
|
||||
)
|
||||
}
|
||||
|
||||
const { srcStat, destStat } = stat.checkPathsSync(src, dest, 'copy', opts)
|
||||
stat.checkParentPathsSync(src, srcStat, dest, 'copy')
|
||||
if (opts.filter && !opts.filter(src, dest)) return
|
||||
const destParent = path.dirname(dest)
|
||||
if (!fs.existsSync(destParent)) mkdirsSync(destParent)
|
||||
return getStats(destStat, src, dest, opts)
|
||||
}
|
||||
|
||||
function getStats (destStat, src, dest, opts) {
|
||||
const statSync = opts.dereference ? fs.statSync : fs.lstatSync
|
||||
const srcStat = statSync(src)
|
||||
|
||||
if (srcStat.isDirectory()) return onDir(srcStat, destStat, src, dest, opts)
|
||||
else if (srcStat.isFile() ||
|
||||
srcStat.isCharacterDevice() ||
|
||||
srcStat.isBlockDevice()) return onFile(srcStat, destStat, src, dest, opts)
|
||||
else if (srcStat.isSymbolicLink()) return onLink(destStat, src, dest, opts)
|
||||
else if (srcStat.isSocket()) throw new Error(`Cannot copy a socket file: ${src}`)
|
||||
else if (srcStat.isFIFO()) throw new Error(`Cannot copy a FIFO pipe: ${src}`)
|
||||
throw new Error(`Unknown file: ${src}`)
|
||||
}
|
||||
|
||||
function onFile (srcStat, destStat, src, dest, opts) {
|
||||
if (!destStat) return copyFile(srcStat, src, dest, opts)
|
||||
return mayCopyFile(srcStat, src, dest, opts)
|
||||
}
|
||||
|
||||
function mayCopyFile (srcStat, src, dest, opts) {
|
||||
if (opts.overwrite) {
|
||||
fs.unlinkSync(dest)
|
||||
return copyFile(srcStat, src, dest, opts)
|
||||
} else if (opts.errorOnExist) {
|
||||
throw new Error(`'${dest}' already exists`)
|
||||
}
|
||||
}
|
||||
|
||||
function copyFile (srcStat, src, dest, opts) {
|
||||
fs.copyFileSync(src, dest)
|
||||
if (opts.preserveTimestamps) handleTimestamps(srcStat.mode, src, dest)
|
||||
return setDestMode(dest, srcStat.mode)
|
||||
}
|
||||
|
||||
function handleTimestamps (srcMode, src, dest) {
|
||||
// Make sure the file is writable before setting the timestamp
|
||||
// otherwise open fails with EPERM when invoked with 'r+'
|
||||
// (through utimes call)
|
||||
if (fileIsNotWritable(srcMode)) makeFileWritable(dest, srcMode)
|
||||
return setDestTimestamps(src, dest)
|
||||
}
|
||||
|
||||
function fileIsNotWritable (srcMode) {
|
||||
return (srcMode & 0o200) === 0
|
||||
}
|
||||
|
||||
function makeFileWritable (dest, srcMode) {
|
||||
return setDestMode(dest, srcMode | 0o200)
|
||||
}
|
||||
|
||||
function setDestMode (dest, srcMode) {
|
||||
return fs.chmodSync(dest, srcMode)
|
||||
}
|
||||
|
||||
function setDestTimestamps (src, dest) {
|
||||
// The initial srcStat.atime cannot be trusted
|
||||
// because it is modified by the read(2) system call
|
||||
// (See https://nodejs.org/api/fs.html#fs_stat_time_values)
|
||||
const updatedSrcStat = fs.statSync(src)
|
||||
return utimesMillisSync(dest, updatedSrcStat.atime, updatedSrcStat.mtime)
|
||||
}
|
||||
|
||||
function onDir (srcStat, destStat, src, dest, opts) {
|
||||
if (!destStat) return mkDirAndCopy(srcStat.mode, src, dest, opts)
|
||||
return copyDir(src, dest, opts)
|
||||
}
|
||||
|
||||
function mkDirAndCopy (srcMode, src, dest, opts) {
|
||||
fs.mkdirSync(dest)
|
||||
copyDir(src, dest, opts)
|
||||
return setDestMode(dest, srcMode)
|
||||
}
|
||||
|
||||
function copyDir (src, dest, opts) {
|
||||
fs.readdirSync(src).forEach(item => copyDirItem(item, src, dest, opts))
|
||||
}
|
||||
|
||||
function copyDirItem (item, src, dest, opts) {
|
||||
const srcItem = path.join(src, item)
|
||||
const destItem = path.join(dest, item)
|
||||
if (opts.filter && !opts.filter(srcItem, destItem)) return
|
||||
const { destStat } = stat.checkPathsSync(srcItem, destItem, 'copy', opts)
|
||||
return getStats(destStat, srcItem, destItem, opts)
|
||||
}
|
||||
|
||||
function onLink (destStat, src, dest, opts) {
|
||||
let resolvedSrc = fs.readlinkSync(src)
|
||||
if (opts.dereference) {
|
||||
resolvedSrc = path.resolve(process.cwd(), resolvedSrc)
|
||||
}
|
||||
|
||||
if (!destStat) {
|
||||
return fs.symlinkSync(resolvedSrc, dest)
|
||||
} else {
|
||||
let resolvedDest
|
||||
try {
|
||||
resolvedDest = fs.readlinkSync(dest)
|
||||
} catch (err) {
|
||||
// dest exists and is a regular file or directory,
|
||||
// Windows may throw UNKNOWN error. If dest already exists,
|
||||
// fs throws error anyway, so no need to guard against it here.
|
||||
if (err.code === 'EINVAL' || err.code === 'UNKNOWN') return fs.symlinkSync(resolvedSrc, dest)
|
||||
throw err
|
||||
}
|
||||
if (opts.dereference) {
|
||||
resolvedDest = path.resolve(process.cwd(), resolvedDest)
|
||||
}
|
||||
if (stat.isSrcSubdir(resolvedSrc, resolvedDest)) {
|
||||
throw new Error(`Cannot copy '${resolvedSrc}' to a subdirectory of itself, '${resolvedDest}'.`)
|
||||
}
|
||||
|
||||
// prevent copy if src is a subdir of dest since unlinking
|
||||
// dest in this case would result in removing src contents
|
||||
// and therefore a broken symlink would be created.
|
||||
if (stat.isSrcSubdir(resolvedDest, resolvedSrc)) {
|
||||
throw new Error(`Cannot overwrite '${resolvedDest}' with '${resolvedSrc}'.`)
|
||||
}
|
||||
return copyLink(resolvedSrc, dest)
|
||||
}
|
||||
}
|
||||
|
||||
function copyLink (resolvedSrc, dest) {
|
||||
fs.unlinkSync(dest)
|
||||
return fs.symlinkSync(resolvedSrc, dest)
|
||||
}
|
||||
|
||||
module.exports = copySync
|
||||
177
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/copy/copy.js
generated
vendored
Normal file
177
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/copy/copy.js
generated
vendored
Normal file
@@ -0,0 +1,177 @@
|
||||
'use strict'
|
||||
|
||||
const fs = require('../fs')
|
||||
const path = require('path')
|
||||
const { mkdirs } = require('../mkdirs')
|
||||
const { pathExists } = require('../path-exists')
|
||||
const { utimesMillis } = require('../util/utimes')
|
||||
const stat = require('../util/stat')
|
||||
|
||||
async function copy (src, dest, opts = {}) {
|
||||
if (typeof opts === 'function') {
|
||||
opts = { filter: opts }
|
||||
}
|
||||
|
||||
opts.clobber = 'clobber' in opts ? !!opts.clobber : true // default to true for now
|
||||
opts.overwrite = 'overwrite' in opts ? !!opts.overwrite : opts.clobber // overwrite falls back to clobber
|
||||
|
||||
// Warn about using preserveTimestamps on 32-bit node
|
||||
if (opts.preserveTimestamps && process.arch === 'ia32') {
|
||||
process.emitWarning(
|
||||
'Using the preserveTimestamps option in 32-bit node is not recommended;\n\n' +
|
||||
'\tsee https://github.com/jprichardson/node-fs-extra/issues/269',
|
||||
'Warning', 'fs-extra-WARN0001'
|
||||
)
|
||||
}
|
||||
|
||||
const { srcStat, destStat } = await stat.checkPaths(src, dest, 'copy', opts)
|
||||
|
||||
await stat.checkParentPaths(src, srcStat, dest, 'copy')
|
||||
|
||||
const include = await runFilter(src, dest, opts)
|
||||
|
||||
if (!include) return
|
||||
|
||||
// check if the parent of dest exists, and create it if it doesn't exist
|
||||
const destParent = path.dirname(dest)
|
||||
const dirExists = await pathExists(destParent)
|
||||
if (!dirExists) {
|
||||
await mkdirs(destParent)
|
||||
}
|
||||
|
||||
await getStatsAndPerformCopy(destStat, src, dest, opts)
|
||||
}
|
||||
|
||||
async function runFilter (src, dest, opts) {
|
||||
if (!opts.filter) return true
|
||||
return opts.filter(src, dest)
|
||||
}
|
||||
|
||||
async function getStatsAndPerformCopy (destStat, src, dest, opts) {
|
||||
const statFn = opts.dereference ? fs.stat : fs.lstat
|
||||
const srcStat = await statFn(src)
|
||||
|
||||
if (srcStat.isDirectory()) return onDir(srcStat, destStat, src, dest, opts)
|
||||
|
||||
if (
|
||||
srcStat.isFile() ||
|
||||
srcStat.isCharacterDevice() ||
|
||||
srcStat.isBlockDevice()
|
||||
) return onFile(srcStat, destStat, src, dest, opts)
|
||||
|
||||
if (srcStat.isSymbolicLink()) return onLink(destStat, src, dest, opts)
|
||||
if (srcStat.isSocket()) throw new Error(`Cannot copy a socket file: ${src}`)
|
||||
if (srcStat.isFIFO()) throw new Error(`Cannot copy a FIFO pipe: ${src}`)
|
||||
throw new Error(`Unknown file: ${src}`)
|
||||
}
|
||||
|
||||
async function onFile (srcStat, destStat, src, dest, opts) {
|
||||
if (!destStat) return copyFile(srcStat, src, dest, opts)
|
||||
|
||||
if (opts.overwrite) {
|
||||
await fs.unlink(dest)
|
||||
return copyFile(srcStat, src, dest, opts)
|
||||
}
|
||||
if (opts.errorOnExist) {
|
||||
throw new Error(`'${dest}' already exists`)
|
||||
}
|
||||
}
|
||||
|
||||
async function copyFile (srcStat, src, dest, opts) {
|
||||
await fs.copyFile(src, dest)
|
||||
if (opts.preserveTimestamps) {
|
||||
// Make sure the file is writable before setting the timestamp
|
||||
// otherwise open fails with EPERM when invoked with 'r+'
|
||||
// (through utimes call)
|
||||
if (fileIsNotWritable(srcStat.mode)) {
|
||||
await makeFileWritable(dest, srcStat.mode)
|
||||
}
|
||||
|
||||
// Set timestamps and mode correspondingly
|
||||
|
||||
// Note that The initial srcStat.atime cannot be trusted
|
||||
// because it is modified by the read(2) system call
|
||||
// (See https://nodejs.org/api/fs.html#fs_stat_time_values)
|
||||
const updatedSrcStat = await fs.stat(src)
|
||||
await utimesMillis(dest, updatedSrcStat.atime, updatedSrcStat.mtime)
|
||||
}
|
||||
|
||||
return fs.chmod(dest, srcStat.mode)
|
||||
}
|
||||
|
||||
function fileIsNotWritable (srcMode) {
|
||||
return (srcMode & 0o200) === 0
|
||||
}
|
||||
|
||||
function makeFileWritable (dest, srcMode) {
|
||||
return fs.chmod(dest, srcMode | 0o200)
|
||||
}
|
||||
|
||||
async function onDir (srcStat, destStat, src, dest, opts) {
|
||||
// the dest directory might not exist, create it
|
||||
if (!destStat) {
|
||||
await fs.mkdir(dest)
|
||||
}
|
||||
|
||||
const items = await fs.readdir(src)
|
||||
|
||||
// loop through the files in the current directory to copy everything
|
||||
await Promise.all(items.map(async item => {
|
||||
const srcItem = path.join(src, item)
|
||||
const destItem = path.join(dest, item)
|
||||
|
||||
// skip the item if it is matches by the filter function
|
||||
const include = await runFilter(srcItem, destItem, opts)
|
||||
if (!include) return
|
||||
|
||||
const { destStat } = await stat.checkPaths(srcItem, destItem, 'copy', opts)
|
||||
|
||||
// If the item is a copyable file, `getStatsAndPerformCopy` will copy it
|
||||
// If the item is a directory, `getStatsAndPerformCopy` will call `onDir` recursively
|
||||
return getStatsAndPerformCopy(destStat, srcItem, destItem, opts)
|
||||
}))
|
||||
|
||||
if (!destStat) {
|
||||
await fs.chmod(dest, srcStat.mode)
|
||||
}
|
||||
}
|
||||
|
||||
async function onLink (destStat, src, dest, opts) {
|
||||
let resolvedSrc = await fs.readlink(src)
|
||||
if (opts.dereference) {
|
||||
resolvedSrc = path.resolve(process.cwd(), resolvedSrc)
|
||||
}
|
||||
if (!destStat) {
|
||||
return fs.symlink(resolvedSrc, dest)
|
||||
}
|
||||
|
||||
let resolvedDest = null
|
||||
try {
|
||||
resolvedDest = await fs.readlink(dest)
|
||||
} catch (e) {
|
||||
// dest exists and is a regular file or directory,
|
||||
// Windows may throw UNKNOWN error. If dest already exists,
|
||||
// fs throws error anyway, so no need to guard against it here.
|
||||
if (e.code === 'EINVAL' || e.code === 'UNKNOWN') return fs.symlink(resolvedSrc, dest)
|
||||
throw e
|
||||
}
|
||||
if (opts.dereference) {
|
||||
resolvedDest = path.resolve(process.cwd(), resolvedDest)
|
||||
}
|
||||
if (stat.isSrcSubdir(resolvedSrc, resolvedDest)) {
|
||||
throw new Error(`Cannot copy '${resolvedSrc}' to a subdirectory of itself, '${resolvedDest}'.`)
|
||||
}
|
||||
|
||||
// do not copy if src is a subdir of dest since unlinking
|
||||
// dest in this case would result in removing src contents
|
||||
// and therefore a broken symlink would be created.
|
||||
if (stat.isSrcSubdir(resolvedDest, resolvedSrc)) {
|
||||
throw new Error(`Cannot overwrite '${resolvedDest}' with '${resolvedSrc}'.`)
|
||||
}
|
||||
|
||||
// copy the link
|
||||
await fs.unlink(dest)
|
||||
return fs.symlink(resolvedSrc, dest)
|
||||
}
|
||||
|
||||
module.exports = copy
|
||||
7
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/copy/index.js
generated
vendored
Normal file
7
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/copy/index.js
generated
vendored
Normal file
@@ -0,0 +1,7 @@
|
||||
'use strict'
|
||||
|
||||
const u = require('universalify').fromPromise
|
||||
module.exports = {
|
||||
copy: u(require('./copy')),
|
||||
copySync: require('./copy-sync')
|
||||
}
|
||||
39
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/empty/index.js
generated
vendored
Normal file
39
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/empty/index.js
generated
vendored
Normal file
@@ -0,0 +1,39 @@
|
||||
'use strict'
|
||||
|
||||
const u = require('universalify').fromPromise
|
||||
const fs = require('../fs')
|
||||
const path = require('path')
|
||||
const mkdir = require('../mkdirs')
|
||||
const remove = require('../remove')
|
||||
|
||||
const emptyDir = u(async function emptyDir (dir) {
|
||||
let items
|
||||
try {
|
||||
items = await fs.readdir(dir)
|
||||
} catch {
|
||||
return mkdir.mkdirs(dir)
|
||||
}
|
||||
|
||||
return Promise.all(items.map(item => remove.remove(path.join(dir, item))))
|
||||
})
|
||||
|
||||
function emptyDirSync (dir) {
|
||||
let items
|
||||
try {
|
||||
items = fs.readdirSync(dir)
|
||||
} catch {
|
||||
return mkdir.mkdirsSync(dir)
|
||||
}
|
||||
|
||||
items.forEach(item => {
|
||||
item = path.join(dir, item)
|
||||
remove.removeSync(item)
|
||||
})
|
||||
}
|
||||
|
||||
module.exports = {
|
||||
emptyDirSync,
|
||||
emptydirSync: emptyDirSync,
|
||||
emptyDir,
|
||||
emptydir: emptyDir
|
||||
}
|
||||
66
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/ensure/file.js
generated
vendored
Normal file
66
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/ensure/file.js
generated
vendored
Normal file
@@ -0,0 +1,66 @@
|
||||
'use strict'
|
||||
|
||||
const u = require('universalify').fromPromise
|
||||
const path = require('path')
|
||||
const fs = require('../fs')
|
||||
const mkdir = require('../mkdirs')
|
||||
|
||||
async function createFile (file) {
|
||||
let stats
|
||||
try {
|
||||
stats = await fs.stat(file)
|
||||
} catch { }
|
||||
if (stats && stats.isFile()) return
|
||||
|
||||
const dir = path.dirname(file)
|
||||
|
||||
let dirStats = null
|
||||
try {
|
||||
dirStats = await fs.stat(dir)
|
||||
} catch (err) {
|
||||
// if the directory doesn't exist, make it
|
||||
if (err.code === 'ENOENT') {
|
||||
await mkdir.mkdirs(dir)
|
||||
await fs.writeFile(file, '')
|
||||
return
|
||||
} else {
|
||||
throw err
|
||||
}
|
||||
}
|
||||
|
||||
if (dirStats.isDirectory()) {
|
||||
await fs.writeFile(file, '')
|
||||
} else {
|
||||
// parent is not a directory
|
||||
// This is just to cause an internal ENOTDIR error to be thrown
|
||||
await fs.readdir(dir)
|
||||
}
|
||||
}
|
||||
|
||||
function createFileSync (file) {
|
||||
let stats
|
||||
try {
|
||||
stats = fs.statSync(file)
|
||||
} catch { }
|
||||
if (stats && stats.isFile()) return
|
||||
|
||||
const dir = path.dirname(file)
|
||||
try {
|
||||
if (!fs.statSync(dir).isDirectory()) {
|
||||
// parent is not a directory
|
||||
// This is just to cause an internal ENOTDIR error to be thrown
|
||||
fs.readdirSync(dir)
|
||||
}
|
||||
} catch (err) {
|
||||
// If the stat call above failed because the directory doesn't exist, create it
|
||||
if (err && err.code === 'ENOENT') mkdir.mkdirsSync(dir)
|
||||
else throw err
|
||||
}
|
||||
|
||||
fs.writeFileSync(file, '')
|
||||
}
|
||||
|
||||
module.exports = {
|
||||
createFile: u(createFile),
|
||||
createFileSync
|
||||
}
|
||||
23
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/ensure/index.js
generated
vendored
Normal file
23
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/ensure/index.js
generated
vendored
Normal file
@@ -0,0 +1,23 @@
|
||||
'use strict'
|
||||
|
||||
const { createFile, createFileSync } = require('./file')
|
||||
const { createLink, createLinkSync } = require('./link')
|
||||
const { createSymlink, createSymlinkSync } = require('./symlink')
|
||||
|
||||
module.exports = {
|
||||
// file
|
||||
createFile,
|
||||
createFileSync,
|
||||
ensureFile: createFile,
|
||||
ensureFileSync: createFileSync,
|
||||
// link
|
||||
createLink,
|
||||
createLinkSync,
|
||||
ensureLink: createLink,
|
||||
ensureLinkSync: createLinkSync,
|
||||
// symlink
|
||||
createSymlink,
|
||||
createSymlinkSync,
|
||||
ensureSymlink: createSymlink,
|
||||
ensureSymlinkSync: createSymlinkSync
|
||||
}
|
||||
64
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/ensure/link.js
generated
vendored
Normal file
64
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/ensure/link.js
generated
vendored
Normal file
@@ -0,0 +1,64 @@
|
||||
'use strict'
|
||||
|
||||
const u = require('universalify').fromPromise
|
||||
const path = require('path')
|
||||
const fs = require('../fs')
|
||||
const mkdir = require('../mkdirs')
|
||||
const { pathExists } = require('../path-exists')
|
||||
const { areIdentical } = require('../util/stat')
|
||||
|
||||
async function createLink (srcpath, dstpath) {
|
||||
let dstStat
|
||||
try {
|
||||
dstStat = await fs.lstat(dstpath)
|
||||
} catch {
|
||||
// ignore error
|
||||
}
|
||||
|
||||
let srcStat
|
||||
try {
|
||||
srcStat = await fs.lstat(srcpath)
|
||||
} catch (err) {
|
||||
err.message = err.message.replace('lstat', 'ensureLink')
|
||||
throw err
|
||||
}
|
||||
|
||||
if (dstStat && areIdentical(srcStat, dstStat)) return
|
||||
|
||||
const dir = path.dirname(dstpath)
|
||||
|
||||
const dirExists = await pathExists(dir)
|
||||
|
||||
if (!dirExists) {
|
||||
await mkdir.mkdirs(dir)
|
||||
}
|
||||
|
||||
await fs.link(srcpath, dstpath)
|
||||
}
|
||||
|
||||
function createLinkSync (srcpath, dstpath) {
|
||||
let dstStat
|
||||
try {
|
||||
dstStat = fs.lstatSync(dstpath)
|
||||
} catch {}
|
||||
|
||||
try {
|
||||
const srcStat = fs.lstatSync(srcpath)
|
||||
if (dstStat && areIdentical(srcStat, dstStat)) return
|
||||
} catch (err) {
|
||||
err.message = err.message.replace('lstat', 'ensureLink')
|
||||
throw err
|
||||
}
|
||||
|
||||
const dir = path.dirname(dstpath)
|
||||
const dirExists = fs.existsSync(dir)
|
||||
if (dirExists) return fs.linkSync(srcpath, dstpath)
|
||||
mkdir.mkdirsSync(dir)
|
||||
|
||||
return fs.linkSync(srcpath, dstpath)
|
||||
}
|
||||
|
||||
module.exports = {
|
||||
createLink: u(createLink),
|
||||
createLinkSync
|
||||
}
|
||||
101
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/ensure/symlink-paths.js
generated
vendored
Normal file
101
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/ensure/symlink-paths.js
generated
vendored
Normal file
@@ -0,0 +1,101 @@
|
||||
'use strict'
|
||||
|
||||
const path = require('path')
|
||||
const fs = require('../fs')
|
||||
const { pathExists } = require('../path-exists')
|
||||
|
||||
const u = require('universalify').fromPromise
|
||||
|
||||
/**
|
||||
* Function that returns two types of paths, one relative to symlink, and one
|
||||
* relative to the current working directory. Checks if path is absolute or
|
||||
* relative. If the path is relative, this function checks if the path is
|
||||
* relative to symlink or relative to current working directory. This is an
|
||||
* initiative to find a smarter `srcpath` to supply when building symlinks.
|
||||
* This allows you to determine which path to use out of one of three possible
|
||||
* types of source paths. The first is an absolute path. This is detected by
|
||||
* `path.isAbsolute()`. When an absolute path is provided, it is checked to
|
||||
* see if it exists. If it does it's used, if not an error is returned
|
||||
* (callback)/ thrown (sync). The other two options for `srcpath` are a
|
||||
* relative url. By default Node's `fs.symlink` works by creating a symlink
|
||||
* using `dstpath` and expects the `srcpath` to be relative to the newly
|
||||
* created symlink. If you provide a `srcpath` that does not exist on the file
|
||||
* system it results in a broken symlink. To minimize this, the function
|
||||
* checks to see if the 'relative to symlink' source file exists, and if it
|
||||
* does it will use it. If it does not, it checks if there's a file that
|
||||
* exists that is relative to the current working directory, if does its used.
|
||||
* This preserves the expectations of the original fs.symlink spec and adds
|
||||
* the ability to pass in `relative to current working direcotry` paths.
|
||||
*/
|
||||
|
||||
async function symlinkPaths (srcpath, dstpath) {
|
||||
if (path.isAbsolute(srcpath)) {
|
||||
try {
|
||||
await fs.lstat(srcpath)
|
||||
} catch (err) {
|
||||
err.message = err.message.replace('lstat', 'ensureSymlink')
|
||||
throw err
|
||||
}
|
||||
|
||||
return {
|
||||
toCwd: srcpath,
|
||||
toDst: srcpath
|
||||
}
|
||||
}
|
||||
|
||||
const dstdir = path.dirname(dstpath)
|
||||
const relativeToDst = path.join(dstdir, srcpath)
|
||||
|
||||
const exists = await pathExists(relativeToDst)
|
||||
if (exists) {
|
||||
return {
|
||||
toCwd: relativeToDst,
|
||||
toDst: srcpath
|
||||
}
|
||||
}
|
||||
|
||||
try {
|
||||
await fs.lstat(srcpath)
|
||||
} catch (err) {
|
||||
err.message = err.message.replace('lstat', 'ensureSymlink')
|
||||
throw err
|
||||
}
|
||||
|
||||
return {
|
||||
toCwd: srcpath,
|
||||
toDst: path.relative(dstdir, srcpath)
|
||||
}
|
||||
}
|
||||
|
||||
function symlinkPathsSync (srcpath, dstpath) {
|
||||
if (path.isAbsolute(srcpath)) {
|
||||
const exists = fs.existsSync(srcpath)
|
||||
if (!exists) throw new Error('absolute srcpath does not exist')
|
||||
return {
|
||||
toCwd: srcpath,
|
||||
toDst: srcpath
|
||||
}
|
||||
}
|
||||
|
||||
const dstdir = path.dirname(dstpath)
|
||||
const relativeToDst = path.join(dstdir, srcpath)
|
||||
const exists = fs.existsSync(relativeToDst)
|
||||
if (exists) {
|
||||
return {
|
||||
toCwd: relativeToDst,
|
||||
toDst: srcpath
|
||||
}
|
||||
}
|
||||
|
||||
const srcExists = fs.existsSync(srcpath)
|
||||
if (!srcExists) throw new Error('relative srcpath does not exist')
|
||||
return {
|
||||
toCwd: srcpath,
|
||||
toDst: path.relative(dstdir, srcpath)
|
||||
}
|
||||
}
|
||||
|
||||
module.exports = {
|
||||
symlinkPaths: u(symlinkPaths),
|
||||
symlinkPathsSync
|
||||
}
|
||||
34
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/ensure/symlink-type.js
generated
vendored
Normal file
34
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/ensure/symlink-type.js
generated
vendored
Normal file
@@ -0,0 +1,34 @@
|
||||
'use strict'
|
||||
|
||||
const fs = require('../fs')
|
||||
const u = require('universalify').fromPromise
|
||||
|
||||
async function symlinkType (srcpath, type) {
|
||||
if (type) return type
|
||||
|
||||
let stats
|
||||
try {
|
||||
stats = await fs.lstat(srcpath)
|
||||
} catch {
|
||||
return 'file'
|
||||
}
|
||||
|
||||
return (stats && stats.isDirectory()) ? 'dir' : 'file'
|
||||
}
|
||||
|
||||
function symlinkTypeSync (srcpath, type) {
|
||||
if (type) return type
|
||||
|
||||
let stats
|
||||
try {
|
||||
stats = fs.lstatSync(srcpath)
|
||||
} catch {
|
||||
return 'file'
|
||||
}
|
||||
return (stats && stats.isDirectory()) ? 'dir' : 'file'
|
||||
}
|
||||
|
||||
module.exports = {
|
||||
symlinkType: u(symlinkType),
|
||||
symlinkTypeSync
|
||||
}
|
||||
67
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/ensure/symlink.js
generated
vendored
Normal file
67
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/ensure/symlink.js
generated
vendored
Normal file
@@ -0,0 +1,67 @@
|
||||
'use strict'
|
||||
|
||||
const u = require('universalify').fromPromise
|
||||
const path = require('path')
|
||||
const fs = require('../fs')
|
||||
|
||||
const { mkdirs, mkdirsSync } = require('../mkdirs')
|
||||
|
||||
const { symlinkPaths, symlinkPathsSync } = require('./symlink-paths')
|
||||
const { symlinkType, symlinkTypeSync } = require('./symlink-type')
|
||||
|
||||
const { pathExists } = require('../path-exists')
|
||||
|
||||
const { areIdentical } = require('../util/stat')
|
||||
|
||||
async function createSymlink (srcpath, dstpath, type) {
|
||||
let stats
|
||||
try {
|
||||
stats = await fs.lstat(dstpath)
|
||||
} catch { }
|
||||
|
||||
if (stats && stats.isSymbolicLink()) {
|
||||
const [srcStat, dstStat] = await Promise.all([
|
||||
fs.stat(srcpath),
|
||||
fs.stat(dstpath)
|
||||
])
|
||||
|
||||
if (areIdentical(srcStat, dstStat)) return
|
||||
}
|
||||
|
||||
const relative = await symlinkPaths(srcpath, dstpath)
|
||||
srcpath = relative.toDst
|
||||
const toType = await symlinkType(relative.toCwd, type)
|
||||
const dir = path.dirname(dstpath)
|
||||
|
||||
if (!(await pathExists(dir))) {
|
||||
await mkdirs(dir)
|
||||
}
|
||||
|
||||
return fs.symlink(srcpath, dstpath, toType)
|
||||
}
|
||||
|
||||
function createSymlinkSync (srcpath, dstpath, type) {
|
||||
let stats
|
||||
try {
|
||||
stats = fs.lstatSync(dstpath)
|
||||
} catch { }
|
||||
if (stats && stats.isSymbolicLink()) {
|
||||
const srcStat = fs.statSync(srcpath)
|
||||
const dstStat = fs.statSync(dstpath)
|
||||
if (areIdentical(srcStat, dstStat)) return
|
||||
}
|
||||
|
||||
const relative = symlinkPathsSync(srcpath, dstpath)
|
||||
srcpath = relative.toDst
|
||||
type = symlinkTypeSync(relative.toCwd, type)
|
||||
const dir = path.dirname(dstpath)
|
||||
const exists = fs.existsSync(dir)
|
||||
if (exists) return fs.symlinkSync(srcpath, dstpath, type)
|
||||
mkdirsSync(dir)
|
||||
return fs.symlinkSync(srcpath, dstpath, type)
|
||||
}
|
||||
|
||||
module.exports = {
|
||||
createSymlink: u(createSymlink),
|
||||
createSymlinkSync
|
||||
}
|
||||
68
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/esm.mjs
generated
vendored
Normal file
68
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/esm.mjs
generated
vendored
Normal file
@@ -0,0 +1,68 @@
|
||||
import _copy from './copy/index.js'
|
||||
import _empty from './empty/index.js'
|
||||
import _ensure from './ensure/index.js'
|
||||
import _json from './json/index.js'
|
||||
import _mkdirs from './mkdirs/index.js'
|
||||
import _move from './move/index.js'
|
||||
import _outputFile from './output-file/index.js'
|
||||
import _pathExists from './path-exists/index.js'
|
||||
import _remove from './remove/index.js'
|
||||
|
||||
// NOTE: Only exports fs-extra's functions; fs functions must be imported from "node:fs" or "node:fs/promises"
|
||||
|
||||
export const copy = _copy.copy
|
||||
export const copySync = _copy.copySync
|
||||
export const emptyDirSync = _empty.emptyDirSync
|
||||
export const emptydirSync = _empty.emptydirSync
|
||||
export const emptyDir = _empty.emptyDir
|
||||
export const emptydir = _empty.emptydir
|
||||
export const createFile = _ensure.createFile
|
||||
export const createFileSync = _ensure.createFileSync
|
||||
export const ensureFile = _ensure.ensureFile
|
||||
export const ensureFileSync = _ensure.ensureFileSync
|
||||
export const createLink = _ensure.createLink
|
||||
export const createLinkSync = _ensure.createLinkSync
|
||||
export const ensureLink = _ensure.ensureLink
|
||||
export const ensureLinkSync = _ensure.ensureLinkSync
|
||||
export const createSymlink = _ensure.createSymlink
|
||||
export const createSymlinkSync = _ensure.createSymlinkSync
|
||||
export const ensureSymlink = _ensure.ensureSymlink
|
||||
export const ensureSymlinkSync = _ensure.ensureSymlinkSync
|
||||
export const readJson = _json.readJson
|
||||
export const readJSON = _json.readJSON
|
||||
export const readJsonSync = _json.readJsonSync
|
||||
export const readJSONSync = _json.readJSONSync
|
||||
export const writeJson = _json.writeJson
|
||||
export const writeJSON = _json.writeJSON
|
||||
export const writeJsonSync = _json.writeJsonSync
|
||||
export const writeJSONSync = _json.writeJSONSync
|
||||
export const outputJson = _json.outputJson
|
||||
export const outputJSON = _json.outputJSON
|
||||
export const outputJsonSync = _json.outputJsonSync
|
||||
export const outputJSONSync = _json.outputJSONSync
|
||||
export const mkdirs = _mkdirs.mkdirs
|
||||
export const mkdirsSync = _mkdirs.mkdirsSync
|
||||
export const mkdirp = _mkdirs.mkdirp
|
||||
export const mkdirpSync = _mkdirs.mkdirpSync
|
||||
export const ensureDir = _mkdirs.ensureDir
|
||||
export const ensureDirSync = _mkdirs.ensureDirSync
|
||||
export const move = _move.move
|
||||
export const moveSync = _move.moveSync
|
||||
export const outputFile = _outputFile.outputFile
|
||||
export const outputFileSync = _outputFile.outputFileSync
|
||||
export const pathExists = _pathExists.pathExists
|
||||
export const pathExistsSync = _pathExists.pathExistsSync
|
||||
export const remove = _remove.remove
|
||||
export const removeSync = _remove.removeSync
|
||||
|
||||
export default {
|
||||
..._copy,
|
||||
..._empty,
|
||||
..._ensure,
|
||||
..._json,
|
||||
..._mkdirs,
|
||||
..._move,
|
||||
..._outputFile,
|
||||
..._pathExists,
|
||||
..._remove
|
||||
}
|
||||
140
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/fs/index.js
generated
vendored
Normal file
140
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/fs/index.js
generated
vendored
Normal file
@@ -0,0 +1,140 @@
|
||||
'use strict'
|
||||
// This is adapted from https://github.com/normalize/mz
|
||||
// Copyright (c) 2014-2016 Jonathan Ong me@jongleberry.com and Contributors
|
||||
const u = require('universalify').fromCallback
|
||||
const fs = require('graceful-fs')
|
||||
|
||||
const api = [
|
||||
'access',
|
||||
'appendFile',
|
||||
'chmod',
|
||||
'chown',
|
||||
'close',
|
||||
'copyFile',
|
||||
'fchmod',
|
||||
'fchown',
|
||||
'fdatasync',
|
||||
'fstat',
|
||||
'fsync',
|
||||
'ftruncate',
|
||||
'futimes',
|
||||
'lchmod',
|
||||
'lchown',
|
||||
'link',
|
||||
'lstat',
|
||||
'mkdir',
|
||||
'mkdtemp',
|
||||
'open',
|
||||
'opendir',
|
||||
'readdir',
|
||||
'readFile',
|
||||
'readlink',
|
||||
'realpath',
|
||||
'rename',
|
||||
'rm',
|
||||
'rmdir',
|
||||
'stat',
|
||||
'symlink',
|
||||
'truncate',
|
||||
'unlink',
|
||||
'utimes',
|
||||
'writeFile'
|
||||
].filter(key => {
|
||||
// Some commands are not available on some systems. Ex:
|
||||
// fs.cp was added in Node.js v16.7.0
|
||||
// fs.lchown is not available on at least some Linux
|
||||
return typeof fs[key] === 'function'
|
||||
})
|
||||
|
||||
// Export cloned fs:
|
||||
Object.assign(exports, fs)
|
||||
|
||||
// Universalify async methods:
|
||||
api.forEach(method => {
|
||||
exports[method] = u(fs[method])
|
||||
})
|
||||
|
||||
// We differ from mz/fs in that we still ship the old, broken, fs.exists()
|
||||
// since we are a drop-in replacement for the native module
|
||||
exports.exists = function (filename, callback) {
|
||||
if (typeof callback === 'function') {
|
||||
return fs.exists(filename, callback)
|
||||
}
|
||||
return new Promise(resolve => {
|
||||
return fs.exists(filename, resolve)
|
||||
})
|
||||
}
|
||||
|
||||
// fs.read(), fs.write(), fs.readv(), & fs.writev() need special treatment due to multiple callback args
|
||||
|
||||
exports.read = function (fd, buffer, offset, length, position, callback) {
|
||||
if (typeof callback === 'function') {
|
||||
return fs.read(fd, buffer, offset, length, position, callback)
|
||||
}
|
||||
return new Promise((resolve, reject) => {
|
||||
fs.read(fd, buffer, offset, length, position, (err, bytesRead, buffer) => {
|
||||
if (err) return reject(err)
|
||||
resolve({ bytesRead, buffer })
|
||||
})
|
||||
})
|
||||
}
|
||||
|
||||
// Function signature can be
|
||||
// fs.write(fd, buffer[, offset[, length[, position]]], callback)
|
||||
// OR
|
||||
// fs.write(fd, string[, position[, encoding]], callback)
|
||||
// We need to handle both cases, so we use ...args
|
||||
exports.write = function (fd, buffer, ...args) {
|
||||
if (typeof args[args.length - 1] === 'function') {
|
||||
return fs.write(fd, buffer, ...args)
|
||||
}
|
||||
|
||||
return new Promise((resolve, reject) => {
|
||||
fs.write(fd, buffer, ...args, (err, bytesWritten, buffer) => {
|
||||
if (err) return reject(err)
|
||||
resolve({ bytesWritten, buffer })
|
||||
})
|
||||
})
|
||||
}
|
||||
|
||||
// Function signature is
|
||||
// s.readv(fd, buffers[, position], callback)
|
||||
// We need to handle the optional arg, so we use ...args
|
||||
exports.readv = function (fd, buffers, ...args) {
|
||||
if (typeof args[args.length - 1] === 'function') {
|
||||
return fs.readv(fd, buffers, ...args)
|
||||
}
|
||||
|
||||
return new Promise((resolve, reject) => {
|
||||
fs.readv(fd, buffers, ...args, (err, bytesRead, buffers) => {
|
||||
if (err) return reject(err)
|
||||
resolve({ bytesRead, buffers })
|
||||
})
|
||||
})
|
||||
}
|
||||
|
||||
// Function signature is
|
||||
// s.writev(fd, buffers[, position], callback)
|
||||
// We need to handle the optional arg, so we use ...args
|
||||
exports.writev = function (fd, buffers, ...args) {
|
||||
if (typeof args[args.length - 1] === 'function') {
|
||||
return fs.writev(fd, buffers, ...args)
|
||||
}
|
||||
|
||||
return new Promise((resolve, reject) => {
|
||||
fs.writev(fd, buffers, ...args, (err, bytesWritten, buffers) => {
|
||||
if (err) return reject(err)
|
||||
resolve({ bytesWritten, buffers })
|
||||
})
|
||||
})
|
||||
}
|
||||
|
||||
// fs.realpath.native sometimes not available if fs is monkey-patched
|
||||
if (typeof fs.realpath.native === 'function') {
|
||||
exports.realpath.native = u(fs.realpath.native)
|
||||
} else {
|
||||
process.emitWarning(
|
||||
'fs.realpath.native is not a function. Is fs being monkey-patched?',
|
||||
'Warning', 'fs-extra-WARN0003'
|
||||
)
|
||||
}
|
||||
16
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/index.js
generated
vendored
Normal file
16
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/index.js
generated
vendored
Normal file
@@ -0,0 +1,16 @@
|
||||
'use strict'
|
||||
|
||||
module.exports = {
|
||||
// Export promiseified graceful-fs:
|
||||
...require('./fs'),
|
||||
// Export extra methods:
|
||||
...require('./copy'),
|
||||
...require('./empty'),
|
||||
...require('./ensure'),
|
||||
...require('./json'),
|
||||
...require('./mkdirs'),
|
||||
...require('./move'),
|
||||
...require('./output-file'),
|
||||
...require('./path-exists'),
|
||||
...require('./remove')
|
||||
}
|
||||
16
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/json/index.js
generated
vendored
Normal file
16
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/json/index.js
generated
vendored
Normal file
@@ -0,0 +1,16 @@
|
||||
'use strict'
|
||||
|
||||
const u = require('universalify').fromPromise
|
||||
const jsonFile = require('./jsonfile')
|
||||
|
||||
jsonFile.outputJson = u(require('./output-json'))
|
||||
jsonFile.outputJsonSync = require('./output-json-sync')
|
||||
// aliases
|
||||
jsonFile.outputJSON = jsonFile.outputJson
|
||||
jsonFile.outputJSONSync = jsonFile.outputJsonSync
|
||||
jsonFile.writeJSON = jsonFile.writeJson
|
||||
jsonFile.writeJSONSync = jsonFile.writeJsonSync
|
||||
jsonFile.readJSON = jsonFile.readJson
|
||||
jsonFile.readJSONSync = jsonFile.readJsonSync
|
||||
|
||||
module.exports = jsonFile
|
||||
11
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/json/jsonfile.js
generated
vendored
Normal file
11
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/json/jsonfile.js
generated
vendored
Normal file
@@ -0,0 +1,11 @@
|
||||
'use strict'
|
||||
|
||||
const jsonFile = require('jsonfile')
|
||||
|
||||
module.exports = {
|
||||
// jsonfile exports
|
||||
readJson: jsonFile.readFile,
|
||||
readJsonSync: jsonFile.readFileSync,
|
||||
writeJson: jsonFile.writeFile,
|
||||
writeJsonSync: jsonFile.writeFileSync
|
||||
}
|
||||
12
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/json/output-json-sync.js
generated
vendored
Normal file
12
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/json/output-json-sync.js
generated
vendored
Normal file
@@ -0,0 +1,12 @@
|
||||
'use strict'
|
||||
|
||||
const { stringify } = require('jsonfile/utils')
|
||||
const { outputFileSync } = require('../output-file')
|
||||
|
||||
function outputJsonSync (file, data, options) {
|
||||
const str = stringify(data, options)
|
||||
|
||||
outputFileSync(file, str, options)
|
||||
}
|
||||
|
||||
module.exports = outputJsonSync
|
||||
12
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/json/output-json.js
generated
vendored
Normal file
12
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/json/output-json.js
generated
vendored
Normal file
@@ -0,0 +1,12 @@
|
||||
'use strict'
|
||||
|
||||
const { stringify } = require('jsonfile/utils')
|
||||
const { outputFile } = require('../output-file')
|
||||
|
||||
async function outputJson (file, data, options = {}) {
|
||||
const str = stringify(data, options)
|
||||
|
||||
await outputFile(file, str, options)
|
||||
}
|
||||
|
||||
module.exports = outputJson
|
||||
14
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/mkdirs/index.js
generated
vendored
Normal file
14
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/mkdirs/index.js
generated
vendored
Normal file
@@ -0,0 +1,14 @@
|
||||
'use strict'
|
||||
const u = require('universalify').fromPromise
|
||||
const { makeDir: _makeDir, makeDirSync } = require('./make-dir')
|
||||
const makeDir = u(_makeDir)
|
||||
|
||||
module.exports = {
|
||||
mkdirs: makeDir,
|
||||
mkdirsSync: makeDirSync,
|
||||
// alias
|
||||
mkdirp: makeDir,
|
||||
mkdirpSync: makeDirSync,
|
||||
ensureDir: makeDir,
|
||||
ensureDirSync: makeDirSync
|
||||
}
|
||||
27
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/mkdirs/make-dir.js
generated
vendored
Normal file
27
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/mkdirs/make-dir.js
generated
vendored
Normal file
@@ -0,0 +1,27 @@
|
||||
'use strict'
|
||||
const fs = require('../fs')
|
||||
const { checkPath } = require('./utils')
|
||||
|
||||
const getMode = options => {
|
||||
const defaults = { mode: 0o777 }
|
||||
if (typeof options === 'number') return options
|
||||
return ({ ...defaults, ...options }).mode
|
||||
}
|
||||
|
||||
module.exports.makeDir = async (dir, options) => {
|
||||
checkPath(dir)
|
||||
|
||||
return fs.mkdir(dir, {
|
||||
mode: getMode(options),
|
||||
recursive: true
|
||||
})
|
||||
}
|
||||
|
||||
module.exports.makeDirSync = (dir, options) => {
|
||||
checkPath(dir)
|
||||
|
||||
return fs.mkdirSync(dir, {
|
||||
mode: getMode(options),
|
||||
recursive: true
|
||||
})
|
||||
}
|
||||
21
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/mkdirs/utils.js
generated
vendored
Normal file
21
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/mkdirs/utils.js
generated
vendored
Normal file
@@ -0,0 +1,21 @@
|
||||
// Adapted from https://github.com/sindresorhus/make-dir
|
||||
// Copyright (c) Sindre Sorhus <sindresorhus@gmail.com> (sindresorhus.com)
|
||||
// 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'
|
||||
const path = require('path')
|
||||
|
||||
// https://github.com/nodejs/node/issues/8987
|
||||
// https://github.com/libuv/libuv/pull/1088
|
||||
module.exports.checkPath = function checkPath (pth) {
|
||||
if (process.platform === 'win32') {
|
||||
const pathHasInvalidWinCharacters = /[<>:"|?*]/.test(pth.replace(path.parse(pth).root, ''))
|
||||
|
||||
if (pathHasInvalidWinCharacters) {
|
||||
const error = new Error(`Path contains invalid characters: ${pth}`)
|
||||
error.code = 'EINVAL'
|
||||
throw error
|
||||
}
|
||||
}
|
||||
}
|
||||
7
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/move/index.js
generated
vendored
Normal file
7
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/move/index.js
generated
vendored
Normal file
@@ -0,0 +1,7 @@
|
||||
'use strict'
|
||||
|
||||
const u = require('universalify').fromPromise
|
||||
module.exports = {
|
||||
move: u(require('./move')),
|
||||
moveSync: require('./move-sync')
|
||||
}
|
||||
55
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/move/move-sync.js
generated
vendored
Normal file
55
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/move/move-sync.js
generated
vendored
Normal file
@@ -0,0 +1,55 @@
|
||||
'use strict'
|
||||
|
||||
const fs = require('graceful-fs')
|
||||
const path = require('path')
|
||||
const copySync = require('../copy').copySync
|
||||
const removeSync = require('../remove').removeSync
|
||||
const mkdirpSync = require('../mkdirs').mkdirpSync
|
||||
const stat = require('../util/stat')
|
||||
|
||||
function moveSync (src, dest, opts) {
|
||||
opts = opts || {}
|
||||
const overwrite = opts.overwrite || opts.clobber || false
|
||||
|
||||
const { srcStat, isChangingCase = false } = stat.checkPathsSync(src, dest, 'move', opts)
|
||||
stat.checkParentPathsSync(src, srcStat, dest, 'move')
|
||||
if (!isParentRoot(dest)) mkdirpSync(path.dirname(dest))
|
||||
return doRename(src, dest, overwrite, isChangingCase)
|
||||
}
|
||||
|
||||
function isParentRoot (dest) {
|
||||
const parent = path.dirname(dest)
|
||||
const parsedPath = path.parse(parent)
|
||||
return parsedPath.root === parent
|
||||
}
|
||||
|
||||
function doRename (src, dest, overwrite, isChangingCase) {
|
||||
if (isChangingCase) return rename(src, dest, overwrite)
|
||||
if (overwrite) {
|
||||
removeSync(dest)
|
||||
return rename(src, dest, overwrite)
|
||||
}
|
||||
if (fs.existsSync(dest)) throw new Error('dest already exists.')
|
||||
return rename(src, dest, overwrite)
|
||||
}
|
||||
|
||||
function rename (src, dest, overwrite) {
|
||||
try {
|
||||
fs.renameSync(src, dest)
|
||||
} catch (err) {
|
||||
if (err.code !== 'EXDEV') throw err
|
||||
return moveAcrossDevice(src, dest, overwrite)
|
||||
}
|
||||
}
|
||||
|
||||
function moveAcrossDevice (src, dest, overwrite) {
|
||||
const opts = {
|
||||
overwrite,
|
||||
errorOnExist: true,
|
||||
preserveTimestamps: true
|
||||
}
|
||||
copySync(src, dest, opts)
|
||||
return removeSync(src)
|
||||
}
|
||||
|
||||
module.exports = moveSync
|
||||
59
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/move/move.js
generated
vendored
Normal file
59
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/move/move.js
generated
vendored
Normal file
@@ -0,0 +1,59 @@
|
||||
'use strict'
|
||||
|
||||
const fs = require('../fs')
|
||||
const path = require('path')
|
||||
const { copy } = require('../copy')
|
||||
const { remove } = require('../remove')
|
||||
const { mkdirp } = require('../mkdirs')
|
||||
const { pathExists } = require('../path-exists')
|
||||
const stat = require('../util/stat')
|
||||
|
||||
async function move (src, dest, opts = {}) {
|
||||
const overwrite = opts.overwrite || opts.clobber || false
|
||||
|
||||
const { srcStat, isChangingCase = false } = await stat.checkPaths(src, dest, 'move', opts)
|
||||
|
||||
await stat.checkParentPaths(src, srcStat, dest, 'move')
|
||||
|
||||
// If the parent of dest is not root, make sure it exists before proceeding
|
||||
const destParent = path.dirname(dest)
|
||||
const parsedParentPath = path.parse(destParent)
|
||||
if (parsedParentPath.root !== destParent) {
|
||||
await mkdirp(destParent)
|
||||
}
|
||||
|
||||
return doRename(src, dest, overwrite, isChangingCase)
|
||||
}
|
||||
|
||||
async function doRename (src, dest, overwrite, isChangingCase) {
|
||||
if (!isChangingCase) {
|
||||
if (overwrite) {
|
||||
await remove(dest)
|
||||
} else if (await pathExists(dest)) {
|
||||
throw new Error('dest already exists.')
|
||||
}
|
||||
}
|
||||
|
||||
try {
|
||||
// Try w/ rename first, and try copy + remove if EXDEV
|
||||
await fs.rename(src, dest)
|
||||
} catch (err) {
|
||||
if (err.code !== 'EXDEV') {
|
||||
throw err
|
||||
}
|
||||
await moveAcrossDevice(src, dest, overwrite)
|
||||
}
|
||||
}
|
||||
|
||||
async function moveAcrossDevice (src, dest, overwrite) {
|
||||
const opts = {
|
||||
overwrite,
|
||||
errorOnExist: true,
|
||||
preserveTimestamps: true
|
||||
}
|
||||
|
||||
await copy(src, dest, opts)
|
||||
return remove(src)
|
||||
}
|
||||
|
||||
module.exports = move
|
||||
31
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/output-file/index.js
generated
vendored
Normal file
31
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/output-file/index.js
generated
vendored
Normal file
@@ -0,0 +1,31 @@
|
||||
'use strict'
|
||||
|
||||
const u = require('universalify').fromPromise
|
||||
const fs = require('../fs')
|
||||
const path = require('path')
|
||||
const mkdir = require('../mkdirs')
|
||||
const pathExists = require('../path-exists').pathExists
|
||||
|
||||
async function outputFile (file, data, encoding = 'utf-8') {
|
||||
const dir = path.dirname(file)
|
||||
|
||||
if (!(await pathExists(dir))) {
|
||||
await mkdir.mkdirs(dir)
|
||||
}
|
||||
|
||||
return fs.writeFile(file, data, encoding)
|
||||
}
|
||||
|
||||
function outputFileSync (file, ...args) {
|
||||
const dir = path.dirname(file)
|
||||
if (!fs.existsSync(dir)) {
|
||||
mkdir.mkdirsSync(dir)
|
||||
}
|
||||
|
||||
fs.writeFileSync(file, ...args)
|
||||
}
|
||||
|
||||
module.exports = {
|
||||
outputFile: u(outputFile),
|
||||
outputFileSync
|
||||
}
|
||||
12
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/path-exists/index.js
generated
vendored
Normal file
12
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/path-exists/index.js
generated
vendored
Normal file
@@ -0,0 +1,12 @@
|
||||
'use strict'
|
||||
const u = require('universalify').fromPromise
|
||||
const fs = require('../fs')
|
||||
|
||||
function pathExists (path) {
|
||||
return fs.access(path).then(() => true).catch(() => false)
|
||||
}
|
||||
|
||||
module.exports = {
|
||||
pathExists: u(pathExists),
|
||||
pathExistsSync: fs.existsSync
|
||||
}
|
||||
17
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/remove/index.js
generated
vendored
Normal file
17
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/remove/index.js
generated
vendored
Normal file
@@ -0,0 +1,17 @@
|
||||
'use strict'
|
||||
|
||||
const fs = require('graceful-fs')
|
||||
const u = require('universalify').fromCallback
|
||||
|
||||
function remove (path, callback) {
|
||||
fs.rm(path, { recursive: true, force: true }, callback)
|
||||
}
|
||||
|
||||
function removeSync (path) {
|
||||
fs.rmSync(path, { recursive: true, force: true })
|
||||
}
|
||||
|
||||
module.exports = {
|
||||
remove: u(remove),
|
||||
removeSync
|
||||
}
|
||||
158
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/util/stat.js
generated
vendored
Normal file
158
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/util/stat.js
generated
vendored
Normal file
@@ -0,0 +1,158 @@
|
||||
'use strict'
|
||||
|
||||
const fs = require('../fs')
|
||||
const path = require('path')
|
||||
const u = require('universalify').fromPromise
|
||||
|
||||
function getStats (src, dest, opts) {
|
||||
const statFunc = opts.dereference
|
||||
? (file) => fs.stat(file, { bigint: true })
|
||||
: (file) => fs.lstat(file, { bigint: true })
|
||||
return Promise.all([
|
||||
statFunc(src),
|
||||
statFunc(dest).catch(err => {
|
||||
if (err.code === 'ENOENT') return null
|
||||
throw err
|
||||
})
|
||||
]).then(([srcStat, destStat]) => ({ srcStat, destStat }))
|
||||
}
|
||||
|
||||
function getStatsSync (src, dest, opts) {
|
||||
let destStat
|
||||
const statFunc = opts.dereference
|
||||
? (file) => fs.statSync(file, { bigint: true })
|
||||
: (file) => fs.lstatSync(file, { bigint: true })
|
||||
const srcStat = statFunc(src)
|
||||
try {
|
||||
destStat = statFunc(dest)
|
||||
} catch (err) {
|
||||
if (err.code === 'ENOENT') return { srcStat, destStat: null }
|
||||
throw err
|
||||
}
|
||||
return { srcStat, destStat }
|
||||
}
|
||||
|
||||
async function checkPaths (src, dest, funcName, opts) {
|
||||
const { srcStat, destStat } = await getStats(src, dest, opts)
|
||||
if (destStat) {
|
||||
if (areIdentical(srcStat, destStat)) {
|
||||
const srcBaseName = path.basename(src)
|
||||
const destBaseName = path.basename(dest)
|
||||
if (funcName === 'move' &&
|
||||
srcBaseName !== destBaseName &&
|
||||
srcBaseName.toLowerCase() === destBaseName.toLowerCase()) {
|
||||
return { srcStat, destStat, isChangingCase: true }
|
||||
}
|
||||
throw new Error('Source and destination must not be the same.')
|
||||
}
|
||||
if (srcStat.isDirectory() && !destStat.isDirectory()) {
|
||||
throw new Error(`Cannot overwrite non-directory '${dest}' with directory '${src}'.`)
|
||||
}
|
||||
if (!srcStat.isDirectory() && destStat.isDirectory()) {
|
||||
throw new Error(`Cannot overwrite directory '${dest}' with non-directory '${src}'.`)
|
||||
}
|
||||
}
|
||||
|
||||
if (srcStat.isDirectory() && isSrcSubdir(src, dest)) {
|
||||
throw new Error(errMsg(src, dest, funcName))
|
||||
}
|
||||
|
||||
return { srcStat, destStat }
|
||||
}
|
||||
|
||||
function checkPathsSync (src, dest, funcName, opts) {
|
||||
const { srcStat, destStat } = getStatsSync(src, dest, opts)
|
||||
|
||||
if (destStat) {
|
||||
if (areIdentical(srcStat, destStat)) {
|
||||
const srcBaseName = path.basename(src)
|
||||
const destBaseName = path.basename(dest)
|
||||
if (funcName === 'move' &&
|
||||
srcBaseName !== destBaseName &&
|
||||
srcBaseName.toLowerCase() === destBaseName.toLowerCase()) {
|
||||
return { srcStat, destStat, isChangingCase: true }
|
||||
}
|
||||
throw new Error('Source and destination must not be the same.')
|
||||
}
|
||||
if (srcStat.isDirectory() && !destStat.isDirectory()) {
|
||||
throw new Error(`Cannot overwrite non-directory '${dest}' with directory '${src}'.`)
|
||||
}
|
||||
if (!srcStat.isDirectory() && destStat.isDirectory()) {
|
||||
throw new Error(`Cannot overwrite directory '${dest}' with non-directory '${src}'.`)
|
||||
}
|
||||
}
|
||||
|
||||
if (srcStat.isDirectory() && isSrcSubdir(src, dest)) {
|
||||
throw new Error(errMsg(src, dest, funcName))
|
||||
}
|
||||
return { srcStat, destStat }
|
||||
}
|
||||
|
||||
// recursively check if dest parent is a subdirectory of src.
|
||||
// It works for all file types including symlinks since it
|
||||
// checks the src and dest inodes. It starts from the deepest
|
||||
// parent and stops once it reaches the src parent or the root path.
|
||||
async function checkParentPaths (src, srcStat, dest, funcName) {
|
||||
const srcParent = path.resolve(path.dirname(src))
|
||||
const destParent = path.resolve(path.dirname(dest))
|
||||
if (destParent === srcParent || destParent === path.parse(destParent).root) return
|
||||
|
||||
let destStat
|
||||
try {
|
||||
destStat = await fs.stat(destParent, { bigint: true })
|
||||
} catch (err) {
|
||||
if (err.code === 'ENOENT') return
|
||||
throw err
|
||||
}
|
||||
|
||||
if (areIdentical(srcStat, destStat)) {
|
||||
throw new Error(errMsg(src, dest, funcName))
|
||||
}
|
||||
|
||||
return checkParentPaths(src, srcStat, destParent, funcName)
|
||||
}
|
||||
|
||||
function checkParentPathsSync (src, srcStat, dest, funcName) {
|
||||
const srcParent = path.resolve(path.dirname(src))
|
||||
const destParent = path.resolve(path.dirname(dest))
|
||||
if (destParent === srcParent || destParent === path.parse(destParent).root) return
|
||||
let destStat
|
||||
try {
|
||||
destStat = fs.statSync(destParent, { bigint: true })
|
||||
} catch (err) {
|
||||
if (err.code === 'ENOENT') return
|
||||
throw err
|
||||
}
|
||||
if (areIdentical(srcStat, destStat)) {
|
||||
throw new Error(errMsg(src, dest, funcName))
|
||||
}
|
||||
return checkParentPathsSync(src, srcStat, destParent, funcName)
|
||||
}
|
||||
|
||||
function areIdentical (srcStat, destStat) {
|
||||
return destStat.ino && destStat.dev && destStat.ino === srcStat.ino && destStat.dev === srcStat.dev
|
||||
}
|
||||
|
||||
// return true if dest is a subdir of src, otherwise false.
|
||||
// It only checks the path strings.
|
||||
function isSrcSubdir (src, dest) {
|
||||
const srcArr = path.resolve(src).split(path.sep).filter(i => i)
|
||||
const destArr = path.resolve(dest).split(path.sep).filter(i => i)
|
||||
return srcArr.every((cur, i) => destArr[i] === cur)
|
||||
}
|
||||
|
||||
function errMsg (src, dest, funcName) {
|
||||
return `Cannot ${funcName} '${src}' to a subdirectory of itself, '${dest}'.`
|
||||
}
|
||||
|
||||
module.exports = {
|
||||
// checkPaths
|
||||
checkPaths: u(checkPaths),
|
||||
checkPathsSync,
|
||||
// checkParent
|
||||
checkParentPaths: u(checkParentPaths),
|
||||
checkParentPathsSync,
|
||||
// Misc
|
||||
isSrcSubdir,
|
||||
areIdentical
|
||||
}
|
||||
36
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/util/utimes.js
generated
vendored
Normal file
36
node_modules/vite-plugin-inspect/node_modules/fs-extra/lib/util/utimes.js
generated
vendored
Normal file
@@ -0,0 +1,36 @@
|
||||
'use strict'
|
||||
|
||||
const fs = require('../fs')
|
||||
const u = require('universalify').fromPromise
|
||||
|
||||
async function utimesMillis (path, atime, mtime) {
|
||||
// if (!HAS_MILLIS_RES) return fs.utimes(path, atime, mtime, callback)
|
||||
const fd = await fs.open(path, 'r+')
|
||||
|
||||
let closeErr = null
|
||||
|
||||
try {
|
||||
await fs.futimes(fd, atime, mtime)
|
||||
} finally {
|
||||
try {
|
||||
await fs.close(fd)
|
||||
} catch (e) {
|
||||
closeErr = e
|
||||
}
|
||||
}
|
||||
|
||||
if (closeErr) {
|
||||
throw closeErr
|
||||
}
|
||||
}
|
||||
|
||||
function utimesMillisSync (path, atime, mtime) {
|
||||
const fd = fs.openSync(path, 'r+')
|
||||
fs.futimesSync(fd, atime, mtime)
|
||||
return fs.closeSync(fd)
|
||||
}
|
||||
|
||||
module.exports = {
|
||||
utimesMillis: u(utimesMillis),
|
||||
utimesMillisSync
|
||||
}
|
||||
71
node_modules/vite-plugin-inspect/node_modules/fs-extra/package.json
generated
vendored
Normal file
71
node_modules/vite-plugin-inspect/node_modules/fs-extra/package.json
generated
vendored
Normal file
@@ -0,0 +1,71 @@
|
||||
{
|
||||
"name": "fs-extra",
|
||||
"version": "11.2.0",
|
||||
"description": "fs-extra contains methods that aren't included in the vanilla Node.js fs package. Such as recursive mkdir, copy, and remove.",
|
||||
"engines": {
|
||||
"node": ">=14.14"
|
||||
},
|
||||
"homepage": "https://github.com/jprichardson/node-fs-extra",
|
||||
"repository": {
|
||||
"type": "git",
|
||||
"url": "https://github.com/jprichardson/node-fs-extra"
|
||||
},
|
||||
"keywords": [
|
||||
"fs",
|
||||
"file",
|
||||
"file system",
|
||||
"copy",
|
||||
"directory",
|
||||
"extra",
|
||||
"mkdirp",
|
||||
"mkdir",
|
||||
"mkdirs",
|
||||
"recursive",
|
||||
"json",
|
||||
"read",
|
||||
"write",
|
||||
"extra",
|
||||
"delete",
|
||||
"remove",
|
||||
"touch",
|
||||
"create",
|
||||
"text",
|
||||
"output",
|
||||
"move",
|
||||
"promise"
|
||||
],
|
||||
"author": "JP Richardson <jprichardson@gmail.com>",
|
||||
"license": "MIT",
|
||||
"dependencies": {
|
||||
"graceful-fs": "^4.2.0",
|
||||
"jsonfile": "^6.0.1",
|
||||
"universalify": "^2.0.0"
|
||||
},
|
||||
"devDependencies": {
|
||||
"klaw": "^2.1.1",
|
||||
"klaw-sync": "^3.0.2",
|
||||
"minimist": "^1.1.1",
|
||||
"mocha": "^10.1.0",
|
||||
"nyc": "^15.0.0",
|
||||
"proxyquire": "^2.0.1",
|
||||
"read-dir-files": "^0.1.1",
|
||||
"standard": "^17.0.0"
|
||||
},
|
||||
"main": "./lib/index.js",
|
||||
"exports": {
|
||||
".": "./lib/index.js",
|
||||
"./esm": "./lib/esm.mjs"
|
||||
},
|
||||
"files": [
|
||||
"lib/",
|
||||
"!lib/**/__tests__/"
|
||||
],
|
||||
"scripts": {
|
||||
"lint": "standard",
|
||||
"test-find": "find ./lib/**/__tests__ -name *.test.js | xargs mocha",
|
||||
"test": "npm run lint && npm run unit && npm run unit-esm",
|
||||
"unit": "nyc node test.js",
|
||||
"unit-esm": "node test.mjs"
|
||||
},
|
||||
"sideEffects": false
|
||||
}
|
||||
194
node_modules/vite-plugin-inspect/node_modules/sirv/build.js
generated
vendored
Normal file
194
node_modules/vite-plugin-inspect/node_modules/sirv/build.js
generated
vendored
Normal file
@@ -0,0 +1,194 @@
|
||||
const fs = require('fs');
|
||||
const { join, normalize, resolve } = require('path');
|
||||
const { totalist } = require('totalist/sync');
|
||||
const { parse } = require('@polka/url');
|
||||
const { lookup } = require('mrmime');
|
||||
|
||||
const noop = () => {};
|
||||
|
||||
function isMatch(uri, arr) {
|
||||
for (let i=0; i < arr.length; i++) {
|
||||
if (arr[i].test(uri)) return true;
|
||||
}
|
||||
}
|
||||
|
||||
function toAssume(uri, extns) {
|
||||
let i=0, x, len=uri.length - 1;
|
||||
if (uri.charCodeAt(len) === 47) {
|
||||
uri = uri.substring(0, len);
|
||||
}
|
||||
|
||||
let arr=[], tmp=`${uri}/index`;
|
||||
for (; i < extns.length; i++) {
|
||||
x = extns[i] ? `.${extns[i]}` : '';
|
||||
if (uri) arr.push(uri + x);
|
||||
arr.push(tmp + x);
|
||||
}
|
||||
|
||||
return arr;
|
||||
}
|
||||
|
||||
function viaCache(cache, uri, extns) {
|
||||
let i=0, data, arr=toAssume(uri, extns);
|
||||
for (; i < arr.length; i++) {
|
||||
if (data = cache[arr[i]]) return data;
|
||||
}
|
||||
}
|
||||
|
||||
function viaLocal(dir, isEtag, uri, extns) {
|
||||
let i=0, arr=toAssume(uri, extns);
|
||||
let abs, stats, name, headers;
|
||||
for (; i < arr.length; i++) {
|
||||
abs = normalize(join(dir, name=arr[i]));
|
||||
if (abs.startsWith(dir) && fs.existsSync(abs)) {
|
||||
stats = fs.statSync(abs);
|
||||
if (stats.isDirectory()) continue;
|
||||
headers = toHeaders(name, stats, isEtag);
|
||||
headers['Cache-Control'] = isEtag ? 'no-cache' : 'no-store';
|
||||
return { abs, stats, headers };
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
function is404(req, res) {
|
||||
return (res.statusCode=404,res.end());
|
||||
}
|
||||
|
||||
function send(req, res, file, stats, headers) {
|
||||
let code=200, tmp, opts={};
|
||||
headers = { ...headers };
|
||||
|
||||
for (let key in headers) {
|
||||
tmp = res.getHeader(key);
|
||||
if (tmp) headers[key] = tmp;
|
||||
}
|
||||
|
||||
if (tmp = res.getHeader('content-type')) {
|
||||
headers['Content-Type'] = tmp;
|
||||
}
|
||||
|
||||
if (req.headers.range) {
|
||||
code = 206;
|
||||
let [x, y] = req.headers.range.replace('bytes=', '').split('-');
|
||||
let end = opts.end = parseInt(y, 10) || stats.size - 1;
|
||||
let start = opts.start = parseInt(x, 10) || 0;
|
||||
|
||||
if (end >= stats.size) {
|
||||
end = stats.size - 1;
|
||||
}
|
||||
|
||||
if (start >= stats.size) {
|
||||
res.setHeader('Content-Range', `bytes */${stats.size}`);
|
||||
res.statusCode = 416;
|
||||
return res.end();
|
||||
}
|
||||
|
||||
headers['Content-Range'] = `bytes ${start}-${end}/${stats.size}`;
|
||||
headers['Content-Length'] = (end - start + 1);
|
||||
headers['Accept-Ranges'] = 'bytes';
|
||||
}
|
||||
|
||||
res.writeHead(code, headers);
|
||||
fs.createReadStream(file, opts).pipe(res);
|
||||
}
|
||||
|
||||
const ENCODING = {
|
||||
'.br': 'br',
|
||||
'.gz': 'gzip',
|
||||
};
|
||||
|
||||
function toHeaders(name, stats, isEtag) {
|
||||
let enc = ENCODING[name.slice(-3)];
|
||||
|
||||
let ctype = lookup(name.slice(0, enc && -3)) || '';
|
||||
if (ctype === 'text/html') ctype += ';charset=utf-8';
|
||||
|
||||
let headers = {
|
||||
'Content-Length': stats.size,
|
||||
'Content-Type': ctype,
|
||||
'Last-Modified': stats.mtime.toUTCString(),
|
||||
};
|
||||
|
||||
if (enc) headers['Content-Encoding'] = enc;
|
||||
if (isEtag) headers['ETag'] = `W/"${stats.size}-${stats.mtime.getTime()}"`;
|
||||
|
||||
return headers;
|
||||
}
|
||||
|
||||
module.exports = function (dir, opts={}) {
|
||||
dir = resolve(dir || '.');
|
||||
|
||||
let isNotFound = opts.onNoMatch || is404;
|
||||
let setHeaders = opts.setHeaders || noop;
|
||||
|
||||
let extensions = opts.extensions || ['html', 'htm'];
|
||||
let gzips = opts.gzip && extensions.map(x => `${x}.gz`).concat('gz');
|
||||
let brots = opts.brotli && extensions.map(x => `${x}.br`).concat('br');
|
||||
|
||||
const FILES = {};
|
||||
|
||||
let fallback = '/';
|
||||
let isEtag = !!opts.etag;
|
||||
let isSPA = !!opts.single;
|
||||
if (typeof opts.single === 'string') {
|
||||
let idx = opts.single.lastIndexOf('.');
|
||||
fallback += !!~idx ? opts.single.substring(0, idx) : opts.single;
|
||||
}
|
||||
|
||||
let ignores = [];
|
||||
if (opts.ignores !== false) {
|
||||
ignores.push(/[/]([A-Za-z\s\d~$._-]+\.\w+){1,}$/); // any extn
|
||||
if (opts.dotfiles) ignores.push(/\/\.\w/);
|
||||
else ignores.push(/\/\.well-known/);
|
||||
[].concat(opts.ignores || []).forEach(x => {
|
||||
ignores.push(new RegExp(x, 'i'));
|
||||
});
|
||||
}
|
||||
|
||||
let cc = opts.maxAge != null && `public,max-age=${opts.maxAge}`;
|
||||
if (cc && opts.immutable) cc += ',immutable';
|
||||
else if (cc && opts.maxAge === 0) cc += ',must-revalidate';
|
||||
|
||||
if (!opts.dev) {
|
||||
totalist(dir, (name, abs, stats) => {
|
||||
if (/\.well-known[\\+\/]/.test(name)) {} // keep
|
||||
else if (!opts.dotfiles && /(^\.|[\\+|\/+]\.)/.test(name)) return;
|
||||
|
||||
let headers = toHeaders(name, stats, isEtag);
|
||||
if (cc) headers['Cache-Control'] = cc;
|
||||
|
||||
FILES['/' + name.normalize().replace(/\\+/g, '/')] = { abs, stats, headers };
|
||||
});
|
||||
}
|
||||
|
||||
let lookup = opts.dev ? viaLocal.bind(0, dir, isEtag) : viaCache.bind(0, FILES);
|
||||
|
||||
return function (req, res, next) {
|
||||
let extns = [''];
|
||||
let pathname = parse(req).pathname;
|
||||
let val = req.headers['accept-encoding'] || '';
|
||||
if (gzips && val.includes('gzip')) extns.unshift(...gzips);
|
||||
if (brots && /(br|brotli)/i.test(val)) extns.unshift(...brots);
|
||||
extns.push(...extensions); // [...br, ...gz, orig, ...exts]
|
||||
|
||||
if (pathname.indexOf('%') !== -1) {
|
||||
try { pathname = decodeURI(pathname) }
|
||||
catch (err) { /* malform uri */ }
|
||||
}
|
||||
|
||||
let data = lookup(pathname, extns) || isSPA && !isMatch(pathname, ignores) && lookup(fallback, extns);
|
||||
if (!data) return next ? next() : isNotFound(req, res);
|
||||
|
||||
if (isEtag && req.headers['if-none-match'] === data.headers['ETag']) {
|
||||
res.writeHead(304);
|
||||
return res.end();
|
||||
}
|
||||
|
||||
if (gzips || brots) {
|
||||
res.setHeader('Vary', 'Accept-Encoding');
|
||||
}
|
||||
|
||||
setHeaders(res, pathname, data.stats);
|
||||
send(req, res, data.abs, data.stats, data.headers);
|
||||
};
|
||||
}
|
||||
194
node_modules/vite-plugin-inspect/node_modules/sirv/build.mjs
generated
vendored
Normal file
194
node_modules/vite-plugin-inspect/node_modules/sirv/build.mjs
generated
vendored
Normal file
@@ -0,0 +1,194 @@
|
||||
import * as fs from 'fs';
|
||||
import { join, normalize, resolve } from 'path';
|
||||
import { totalist } from 'totalist/sync';
|
||||
import { parse } from '@polka/url';
|
||||
import { lookup } from 'mrmime';
|
||||
|
||||
const noop = () => {};
|
||||
|
||||
function isMatch(uri, arr) {
|
||||
for (let i=0; i < arr.length; i++) {
|
||||
if (arr[i].test(uri)) return true;
|
||||
}
|
||||
}
|
||||
|
||||
function toAssume(uri, extns) {
|
||||
let i=0, x, len=uri.length - 1;
|
||||
if (uri.charCodeAt(len) === 47) {
|
||||
uri = uri.substring(0, len);
|
||||
}
|
||||
|
||||
let arr=[], tmp=`${uri}/index`;
|
||||
for (; i < extns.length; i++) {
|
||||
x = extns[i] ? `.${extns[i]}` : '';
|
||||
if (uri) arr.push(uri + x);
|
||||
arr.push(tmp + x);
|
||||
}
|
||||
|
||||
return arr;
|
||||
}
|
||||
|
||||
function viaCache(cache, uri, extns) {
|
||||
let i=0, data, arr=toAssume(uri, extns);
|
||||
for (; i < arr.length; i++) {
|
||||
if (data = cache[arr[i]]) return data;
|
||||
}
|
||||
}
|
||||
|
||||
function viaLocal(dir, isEtag, uri, extns) {
|
||||
let i=0, arr=toAssume(uri, extns);
|
||||
let abs, stats, name, headers;
|
||||
for (; i < arr.length; i++) {
|
||||
abs = normalize(join(dir, name=arr[i]));
|
||||
if (abs.startsWith(dir) && fs.existsSync(abs)) {
|
||||
stats = fs.statSync(abs);
|
||||
if (stats.isDirectory()) continue;
|
||||
headers = toHeaders(name, stats, isEtag);
|
||||
headers['Cache-Control'] = isEtag ? 'no-cache' : 'no-store';
|
||||
return { abs, stats, headers };
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
function is404(req, res) {
|
||||
return (res.statusCode=404,res.end());
|
||||
}
|
||||
|
||||
function send(req, res, file, stats, headers) {
|
||||
let code=200, tmp, opts={};
|
||||
headers = { ...headers };
|
||||
|
||||
for (let key in headers) {
|
||||
tmp = res.getHeader(key);
|
||||
if (tmp) headers[key] = tmp;
|
||||
}
|
||||
|
||||
if (tmp = res.getHeader('content-type')) {
|
||||
headers['Content-Type'] = tmp;
|
||||
}
|
||||
|
||||
if (req.headers.range) {
|
||||
code = 206;
|
||||
let [x, y] = req.headers.range.replace('bytes=', '').split('-');
|
||||
let end = opts.end = parseInt(y, 10) || stats.size - 1;
|
||||
let start = opts.start = parseInt(x, 10) || 0;
|
||||
|
||||
if (end >= stats.size) {
|
||||
end = stats.size - 1;
|
||||
}
|
||||
|
||||
if (start >= stats.size) {
|
||||
res.setHeader('Content-Range', `bytes */${stats.size}`);
|
||||
res.statusCode = 416;
|
||||
return res.end();
|
||||
}
|
||||
|
||||
headers['Content-Range'] = `bytes ${start}-${end}/${stats.size}`;
|
||||
headers['Content-Length'] = (end - start + 1);
|
||||
headers['Accept-Ranges'] = 'bytes';
|
||||
}
|
||||
|
||||
res.writeHead(code, headers);
|
||||
fs.createReadStream(file, opts).pipe(res);
|
||||
}
|
||||
|
||||
const ENCODING = {
|
||||
'.br': 'br',
|
||||
'.gz': 'gzip',
|
||||
};
|
||||
|
||||
function toHeaders(name, stats, isEtag) {
|
||||
let enc = ENCODING[name.slice(-3)];
|
||||
|
||||
let ctype = lookup(name.slice(0, enc && -3)) || '';
|
||||
if (ctype === 'text/html') ctype += ';charset=utf-8';
|
||||
|
||||
let headers = {
|
||||
'Content-Length': stats.size,
|
||||
'Content-Type': ctype,
|
||||
'Last-Modified': stats.mtime.toUTCString(),
|
||||
};
|
||||
|
||||
if (enc) headers['Content-Encoding'] = enc;
|
||||
if (isEtag) headers['ETag'] = `W/"${stats.size}-${stats.mtime.getTime()}"`;
|
||||
|
||||
return headers;
|
||||
}
|
||||
|
||||
export default function (dir, opts={}) {
|
||||
dir = resolve(dir || '.');
|
||||
|
||||
let isNotFound = opts.onNoMatch || is404;
|
||||
let setHeaders = opts.setHeaders || noop;
|
||||
|
||||
let extensions = opts.extensions || ['html', 'htm'];
|
||||
let gzips = opts.gzip && extensions.map(x => `${x}.gz`).concat('gz');
|
||||
let brots = opts.brotli && extensions.map(x => `${x}.br`).concat('br');
|
||||
|
||||
const FILES = {};
|
||||
|
||||
let fallback = '/';
|
||||
let isEtag = !!opts.etag;
|
||||
let isSPA = !!opts.single;
|
||||
if (typeof opts.single === 'string') {
|
||||
let idx = opts.single.lastIndexOf('.');
|
||||
fallback += !!~idx ? opts.single.substring(0, idx) : opts.single;
|
||||
}
|
||||
|
||||
let ignores = [];
|
||||
if (opts.ignores !== false) {
|
||||
ignores.push(/[/]([A-Za-z\s\d~$._-]+\.\w+){1,}$/); // any extn
|
||||
if (opts.dotfiles) ignores.push(/\/\.\w/);
|
||||
else ignores.push(/\/\.well-known/);
|
||||
[].concat(opts.ignores || []).forEach(x => {
|
||||
ignores.push(new RegExp(x, 'i'));
|
||||
});
|
||||
}
|
||||
|
||||
let cc = opts.maxAge != null && `public,max-age=${opts.maxAge}`;
|
||||
if (cc && opts.immutable) cc += ',immutable';
|
||||
else if (cc && opts.maxAge === 0) cc += ',must-revalidate';
|
||||
|
||||
if (!opts.dev) {
|
||||
totalist(dir, (name, abs, stats) => {
|
||||
if (/\.well-known[\\+\/]/.test(name)) {} // keep
|
||||
else if (!opts.dotfiles && /(^\.|[\\+|\/+]\.)/.test(name)) return;
|
||||
|
||||
let headers = toHeaders(name, stats, isEtag);
|
||||
if (cc) headers['Cache-Control'] = cc;
|
||||
|
||||
FILES['/' + name.normalize().replace(/\\+/g, '/')] = { abs, stats, headers };
|
||||
});
|
||||
}
|
||||
|
||||
let lookup = opts.dev ? viaLocal.bind(0, dir, isEtag) : viaCache.bind(0, FILES);
|
||||
|
||||
return function (req, res, next) {
|
||||
let extns = [''];
|
||||
let pathname = parse(req).pathname;
|
||||
let val = req.headers['accept-encoding'] || '';
|
||||
if (gzips && val.includes('gzip')) extns.unshift(...gzips);
|
||||
if (brots && /(br|brotli)/i.test(val)) extns.unshift(...brots);
|
||||
extns.push(...extensions); // [...br, ...gz, orig, ...exts]
|
||||
|
||||
if (pathname.indexOf('%') !== -1) {
|
||||
try { pathname = decodeURI(pathname) }
|
||||
catch (err) { /* malform uri */ }
|
||||
}
|
||||
|
||||
let data = lookup(pathname, extns) || isSPA && !isMatch(pathname, ignores) && lookup(fallback, extns);
|
||||
if (!data) return next ? next() : isNotFound(req, res);
|
||||
|
||||
if (isEtag && req.headers['if-none-match'] === data.headers['ETag']) {
|
||||
res.writeHead(304);
|
||||
return res.end();
|
||||
}
|
||||
|
||||
if (gzips || brots) {
|
||||
res.setHeader('Vary', 'Accept-Encoding');
|
||||
}
|
||||
|
||||
setHeaders(res, pathname, data.stats);
|
||||
send(req, res, data.abs, data.stats, data.headers);
|
||||
};
|
||||
}
|
||||
27
node_modules/vite-plugin-inspect/node_modules/sirv/package.json
generated
vendored
Normal file
27
node_modules/vite-plugin-inspect/node_modules/sirv/package.json
generated
vendored
Normal file
@@ -0,0 +1,27 @@
|
||||
{
|
||||
"name": "sirv",
|
||||
"version": "2.0.4",
|
||||
"description": "The optimized & lightweight middleware for serving requests to static assets",
|
||||
"repository": "lukeed/sirv",
|
||||
"module": "build.mjs",
|
||||
"types": "sirv.d.ts",
|
||||
"main": "build.js",
|
||||
"license": "MIT",
|
||||
"files": [
|
||||
"build.*",
|
||||
"sirv.d.ts"
|
||||
],
|
||||
"author": {
|
||||
"name": "Luke Edwards",
|
||||
"email": "luke@lukeed.com",
|
||||
"url": "https://lukeed.com"
|
||||
},
|
||||
"engines": {
|
||||
"node": ">= 10"
|
||||
},
|
||||
"dependencies": {
|
||||
"@polka/url": "^1.0.0-next.24",
|
||||
"mrmime": "^2.0.0",
|
||||
"totalist": "^3.0.0"
|
||||
}
|
||||
}
|
||||
238
node_modules/vite-plugin-inspect/node_modules/sirv/readme.md
generated
vendored
Normal file
238
node_modules/vite-plugin-inspect/node_modules/sirv/readme.md
generated
vendored
Normal file
@@ -0,0 +1,238 @@
|
||||
# sirv 
|
||||
|
||||
> The optimized and lightweight middleware for serving requests to static assets
|
||||
|
||||
You may use `sirv` as a *very* fast and lightweight alternative to [`serve-static`](https://www.npmjs.com/package/serve-static).
|
||||
|
||||
The massive performance advantage over `serve-static` is explained by **not** relying on the file system for existence checks on every request. These are expensive interactions and must be avoided whenever possible! Instead, when not in "dev" mode, `sirv` performs all its file-system operations upfront and then relies on its cache for future operations.
|
||||
|
||||
This middleware will work out of the box for [Polka](https://github.com/lukeed/polka), Express, and other Express-like frameworks. It will also work with the native `http`, `https` and `http2` modules. It requires _very_ little effort to modify/wrap it for servers that don't accept the `(req, res, next)` signature.
|
||||
|
||||
:bulb: For a feature-complete CLI application, check out the sibling [`sirv-cli`](https://github.com/lukeed/sirv/tree/master/packages/sirv-cli) package as an alternative to [`zeit/serve`](https://github.com/zeit/serve)~!
|
||||
|
||||
## Install
|
||||
|
||||
```
|
||||
$ npm install --save sirv
|
||||
```
|
||||
|
||||
|
||||
## Usage
|
||||
|
||||
```js
|
||||
const sirv = require('sirv');
|
||||
const polka = require('polka');
|
||||
const compress = require('compression')();
|
||||
|
||||
// Init `sirv` handler
|
||||
const assets = sirv('public', {
|
||||
maxAge: 31536000, // 1Y
|
||||
immutable: true
|
||||
});
|
||||
|
||||
polka()
|
||||
.use(compress, assets)
|
||||
.use('/api', require('./api'))
|
||||
.listen(3000, err => {
|
||||
if (err) throw err;
|
||||
console.log('> Ready on localhost:3000~!');
|
||||
});
|
||||
```
|
||||
|
||||
|
||||
## API
|
||||
|
||||
### sirv(dir, opts={})
|
||||
|
||||
Returns: `Function`
|
||||
|
||||
The returned function is a middleware in the standard Express-like signature: `(req, res, next)`, where `req` is the [`http.IncomingMessage`](https://nodejs.org/api/http.html#http_class_http_incomingmessage), `res` is the [`http.ServerResponse`](https://nodejs.org/dist/latest-v9.x/docs/api/http.html#http_class_http_serverresponse), and `next` (in this case) is the function to call if no file was found for the given path.
|
||||
|
||||
When defined, a `next()` callback is always called _instead of_ the [`opts.onNoMatch`](#optsonnomatch) callback. However, unlike `onNoMatch`, your `next()` is given no arguments.
|
||||
|
||||
#### dir
|
||||
Type: `String`<br>
|
||||
Default: `.`
|
||||
|
||||
The directory from which to read and serve assets. It is resolved to an absolute path — you must provide an absolute path yourself if `process.cwd()` is not the correct assumption.
|
||||
|
||||
#### opts.dev
|
||||
Type: `Boolean`<br>
|
||||
Default: `false`
|
||||
|
||||
Enable "dev" mode, which disables/skips caching. Instead, `sirv` will traverse the file system ***on every request***.
|
||||
|
||||
Additionally, `dev` mode will ignore `maxAge` and `immutable` as these options generate a production-oriented `Cache-Control` header value.
|
||||
|
||||
> **Important:** Do not use `dev` mode in production!
|
||||
|
||||
#### opts.etag
|
||||
Type: `Boolean`<br>
|
||||
Default: `false`
|
||||
|
||||
Generate and attach an `ETag` header to responses.
|
||||
|
||||
> **Note:** If an incoming request's [`If-None-Match` header](https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/If-None-Match) matches the `ETag` value, a `304` response is given.
|
||||
|
||||
#### opts.dotfiles
|
||||
Type: `Boolean`<br>
|
||||
Default: `false`
|
||||
|
||||
Allow requests to dotfiles (files or directories beginning with a `.`).
|
||||
|
||||
> **Note:** Requests to [`/.well-known/*`](https://tools.ietf.org/html/rfc8615) are always allowed.
|
||||
|
||||
#### opts.extensions
|
||||
Type: `Array<String>`<br>
|
||||
Default: `['html', 'htm']`
|
||||
|
||||
The file extension fallbacks to check for if a pathame is not initially found. For example, if a `/login` request cannot find a `login` filename, it will then look for `login.html` and `login.htm` before giving up~!
|
||||
|
||||
> **Important:** Actually, `sirv` will **also** look for `login/index.html` and `login/index.htm` before giving up.
|
||||
|
||||
#### opts.gzip
|
||||
Type: `Boolean`<br>
|
||||
Default: `false`
|
||||
|
||||
Determine if `sirv` look for **precompiled** `*.gz` files.<br>
|
||||
Must be enabled _and_ the incoming request's [`Accept Encoding`](https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Accept-Encoding) must include "gzip" in order for `sirv` to search for the gzip'd alternative.
|
||||
|
||||
> **Note:** The `.gz` assumption also applies to the `opts.extensions` list.
|
||||
|
||||
```js
|
||||
// NOTE: PSEUDO CODE
|
||||
// Showing lookup logic
|
||||
|
||||
// Request: [Accept-Encoding: gzip] "/foobar.jpg"
|
||||
lookup([
|
||||
'/foobar.jpg.gz', '/foobar.jpg',
|
||||
'/foobar.jpg.html.gz', '/foobar.jpg/index.html.gz',
|
||||
'/foobar.jpg.htm.gz', '/foobar.jpg/index.htm.gz',
|
||||
'/foobar.jpg.html', '/foobar.jpg/index.html',
|
||||
'/foobar.jpg.htm', '/foobar.jpg/index.htm',
|
||||
]);
|
||||
|
||||
// Request: [Accept-Encoding: gzip] "/"
|
||||
lookup([
|
||||
'/index.html.gz',
|
||||
'/index.htm.gz',
|
||||
'/index.html',
|
||||
'/index.htm',
|
||||
]);
|
||||
```
|
||||
|
||||
|
||||
#### opts.brotli
|
||||
Type: `Boolean`<br>
|
||||
Default: `false`
|
||||
|
||||
Determine if `sirv` look for **precompiled** `*.br` files.<br>
|
||||
Must be enabled _and_ the incoming request's [`Accept Encoding`](https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Accept-Encoding) must include either "br" or "brotli" in order for `sirv` to search for the brotli-compressed alternative.
|
||||
|
||||
> **Note:** The `.br` assumption also applies to the `opts.extensions` list.
|
||||
|
||||
When both `opts.broli` and `opts.gzip` are enabled — and all conditions are equal — then the brotli variant always takes priority.
|
||||
|
||||
```js
|
||||
// NOTE: PSEUDO CODE
|
||||
// Showing lookup logic
|
||||
|
||||
// Request: [Accept-Encoding: br] "/foobar.jpg"
|
||||
lookup([
|
||||
'/foobar.jpg.br', '/foobar.jpg',
|
||||
'/foobar.jpg.html.br', '/foobar.jpg/index.html.br',
|
||||
'/foobar.jpg.htm.br', '/foobar.jpg/index.htm.br',
|
||||
'/foobar.jpg.html', '/foobar.jpg/index.html',
|
||||
'/foobar.jpg.htm', '/foobar.jpg/index.htm',
|
||||
]);
|
||||
|
||||
// Request: [Accept-Encoding: br,gz] "/"
|
||||
lookup([
|
||||
'/index.html.br'
|
||||
'/index.htm.br'
|
||||
'/index.html.gz'
|
||||
'/index.htm.gz'
|
||||
'/index.html'
|
||||
'/index.htm'
|
||||
]);
|
||||
```
|
||||
|
||||
#### opts.maxAge
|
||||
Type: `Number`<br>
|
||||
Default: `undefined`
|
||||
|
||||
Enables the `Cache-Control` header on responses and sets the `max-age` value (in seconds).<br>
|
||||
For example, `maxAge: 31536000` is equivalent to one year.
|
||||
|
||||
#### opts.immutable
|
||||
Type: `Boolean`<br>
|
||||
Default: `false`
|
||||
|
||||
Appends the [`immutable` directive](https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Cache-Control#Revalidation_and_reloading) on your `Cache-Control` header, used for uniquely-named assets that will not change!
|
||||
|
||||
> **Important:** Will only work if `opts.maxAge` has a value defined!
|
||||
|
||||
#### opts.single
|
||||
Type: `Boolean` or `String`<br>
|
||||
Default: `false`
|
||||
|
||||
Treat the directory as a single-page application.
|
||||
|
||||
When `true`, the directory's index page (default `index.html`) will be sent if the request asset does not exist.<br>
|
||||
You may pass a `string` value to use a file _instead of_ `index.html` as your fallback.
|
||||
|
||||
For example, if "/about" is requested but no variants of that file exist, then the response for "/" is sent instead:
|
||||
|
||||
```js
|
||||
// Note: This is psuedo code to illustrate what's happening
|
||||
|
||||
// Request: "/about"
|
||||
let file = find(['/about', '/about.html', '/about.htm', '/about/index.html', '/about.htm']);
|
||||
if (file) {
|
||||
send(file);
|
||||
} else if (opts.single === true) {
|
||||
file = find(['/', '/index.html', '/index.htm']);
|
||||
send(file);
|
||||
} else if (typeof opts.single === 'string') {
|
||||
file = find([opts.single]);
|
||||
send(file);
|
||||
} else {
|
||||
// next() or 404
|
||||
}
|
||||
```
|
||||
|
||||
#### opts.ignores
|
||||
Type: `false` or `Array<String | RegExp>`
|
||||
|
||||
Specify paths/patterns that should ignore the fallback behavior that `opts.single` provides.
|
||||
|
||||
By default, any asset-like path (URLs that end with an extension) will be ignored. This means that, for example, if `/foobar.jpg` is not found, a `404` response is sent instead of the `index.html` fallback.
|
||||
|
||||
Additionally, any `/.well-known/*` pathname ignores the fallback – as do all other dotfile requests when `opts.dotfiles` is enabled.
|
||||
|
||||
Any string value(s) will be passed through `new RegExp(value, 'i')` directly.
|
||||
|
||||
Finally, you may set `ignores: false` to disable ***all*** ignores, including the defaults. Put differently, this will fallback ***all*** unknown pathnames to your `index.html` (or custom `opts.single` value).
|
||||
|
||||
> **Important:** Only has an effect if `opts.single` is enabled.
|
||||
|
||||
#### opts.onNoMatch
|
||||
Type: `Function`
|
||||
|
||||
A custom function to run if a file cannot be found for a given request. <br>By default, `sirv` will send a basic `(404) Not found` response.
|
||||
|
||||
The function receives the current `req <IncomingMessage>, res <ServerResponse>` pair for as its two arguments.
|
||||
|
||||
> **Note:** This won't run if a `next` callback has been provided to the middleware; see [`sirv`](#sirvdir-opts) description.
|
||||
|
||||
#### opts.setHeaders
|
||||
Type: `Function`
|
||||
|
||||
A custom function to append or change any headers on the outgoing response. There is no default.
|
||||
|
||||
Its signature is `(res, pathname, stats)`, where `res` is the `ServerResponse`, `pathname` is incoming request path (stripped of queries), and `stats` is the file's result from [`fs.statSync`](https://nodejs.org/api/fs.html#fs_fs_statsync_path).
|
||||
|
||||
|
||||
## License
|
||||
|
||||
MIT © [Luke Edwards](https://lukeed.com)
|
||||
25
node_modules/vite-plugin-inspect/node_modules/sirv/sirv.d.ts
generated
vendored
Normal file
25
node_modules/vite-plugin-inspect/node_modules/sirv/sirv.d.ts
generated
vendored
Normal file
@@ -0,0 +1,25 @@
|
||||
declare module 'sirv' {
|
||||
import type { Stats } from 'fs';
|
||||
import type { IncomingMessage, ServerResponse } from 'http';
|
||||
|
||||
type Arrayable<T> = T | T[];
|
||||
export type NextHandler = () => void | Promise<void>;
|
||||
export type RequestHandler = (req: IncomingMessage, res: ServerResponse, next?: NextHandler) => void;
|
||||
|
||||
export interface Options {
|
||||
dev?: boolean;
|
||||
etag?: boolean;
|
||||
maxAge?: number;
|
||||
immutable?: boolean;
|
||||
single?: string | boolean;
|
||||
ignores?: false | Arrayable<string | RegExp>;
|
||||
extensions?: string[];
|
||||
dotfiles?: boolean;
|
||||
brotli?: boolean;
|
||||
gzip?: boolean;
|
||||
onNoMatch?: (req: IncomingMessage, res: ServerResponse) => void;
|
||||
setHeaders?: (res: ServerResponse, pathname: string, stats: Stats) => void;
|
||||
}
|
||||
|
||||
export default function(dir?: string, opts?: Options): RequestHandler;
|
||||
}
|
||||
153
node_modules/vite-plugin-inspect/package.json
generated
vendored
Normal file
153
node_modules/vite-plugin-inspect/package.json
generated
vendored
Normal file
@@ -0,0 +1,153 @@
|
||||
{
|
||||
"name": "vite-plugin-inspect",
|
||||
"type": "module",
|
||||
"version": "0.8.7",
|
||||
"packageManager": "pnpm@9.7.1",
|
||||
"description": "Inspect the intermediate state of Vite plugins",
|
||||
"author": "Anthony Fu <anthonyfu117@hotmail.com>",
|
||||
"license": "MIT",
|
||||
"funding": "https://github.com/sponsors/antfu",
|
||||
"homepage": "https://github.com/antfu/vite-plugin-inspect#readme",
|
||||
"repository": {
|
||||
"type": "git",
|
||||
"url": "git+https://github.com/antfu/vite-plugin-inspect.git"
|
||||
},
|
||||
"bugs": {
|
||||
"url": "https://github.com/antfu/vite-plugin-inspect/issues"
|
||||
},
|
||||
"keywords": [
|
||||
"vite-plugin"
|
||||
],
|
||||
"exports": {
|
||||
".": {
|
||||
"import": {
|
||||
"types": "./dist/index.d.mts",
|
||||
"default": "./dist/index.mjs"
|
||||
},
|
||||
"require": {
|
||||
"types": "./dist/index.d.cts",
|
||||
"default": "./dist/index.cjs"
|
||||
}
|
||||
},
|
||||
"./nuxt": {
|
||||
"import": {
|
||||
"types": "./dist/nuxt.d.mts",
|
||||
"default": "./dist/nuxt.mjs"
|
||||
},
|
||||
"require": {
|
||||
"types": "./dist/nuxt.d.cts",
|
||||
"default": "./dist/nuxt.cjs"
|
||||
}
|
||||
},
|
||||
"./*": "./*"
|
||||
},
|
||||
"main": "dist/index.cjs",
|
||||
"module": "dist/index.mjs",
|
||||
"types": "dist/index.d.ts",
|
||||
"typesVersions": {
|
||||
"*": {
|
||||
"*": [
|
||||
"./dist/*",
|
||||
"./*"
|
||||
]
|
||||
}
|
||||
},
|
||||
"files": [
|
||||
"*.d.ts",
|
||||
"dist"
|
||||
],
|
||||
"engines": {
|
||||
"node": ">=14"
|
||||
},
|
||||
"scripts": {
|
||||
"build": "rimraf dist && run-s build:* && esno ./scripts/postbuild.ts",
|
||||
"build:client": "vite build src/client",
|
||||
"build:js": "unbuild",
|
||||
"dev": "nr stub && cross-env INSPECT_DEV=true vite src/client",
|
||||
"dev:client": "vite build src/client --watch",
|
||||
"stub": "unbuild --stub",
|
||||
"lint": "eslint .",
|
||||
"typecheck": "vue-tsc --noEmit",
|
||||
"prepublishOnly": "npm run build",
|
||||
"release": "bumpp && npm publish"
|
||||
},
|
||||
"peerDependencies": {
|
||||
"vite": "^3.1.0 || ^4.0.0 || ^5.0.0-0"
|
||||
},
|
||||
"peerDependenciesMeta": {
|
||||
"@nuxt/kit": {
|
||||
"optional": true
|
||||
}
|
||||
},
|
||||
"dependencies": {
|
||||
"@antfu/utils": "^0.7.10",
|
||||
"@rollup/pluginutils": "^5.1.0",
|
||||
"debug": "^4.3.6",
|
||||
"error-stack-parser-es": "^0.1.5",
|
||||
"fs-extra": "^11.2.0",
|
||||
"open": "^10.1.0",
|
||||
"perfect-debounce": "^1.0.0",
|
||||
"picocolors": "^1.0.1",
|
||||
"sirv": "^2.0.4"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@antfu/eslint-config": "^2.26.0",
|
||||
"@antfu/ni": "^0.22.4",
|
||||
"@iconify-json/catppuccin": "^1.1.4",
|
||||
"@iconify/json": "^2.2.239",
|
||||
"@nuxt/kit": "^3.12.4",
|
||||
"@types/codemirror": "^5.60.15",
|
||||
"@types/debug": "^4.1.12",
|
||||
"@types/fs-extra": "^11.0.4",
|
||||
"@types/node": "^22.4.1",
|
||||
"@unocss/eslint-config": "^0.62.2",
|
||||
"@unocss/eslint-plugin": "^0.62.2",
|
||||
"@vitejs/plugin-vue": "^5.1.2",
|
||||
"@vue/compiler-sfc": "^3.4.38",
|
||||
"@vueuse/core": "^11.0.1",
|
||||
"@vueuse/router": "^11.0.1",
|
||||
"bumpp": "^9.5.1",
|
||||
"codemirror": "^5.65.16",
|
||||
"codemirror-theme-vars": "^0.1.2",
|
||||
"comlink": "^4.4.1",
|
||||
"cross-env": "^7.0.3",
|
||||
"diff-match-patch-es": "^0.1.0",
|
||||
"echarts": "^5.5.1",
|
||||
"eslint": "^9.9.0",
|
||||
"esno": "^4.7.0",
|
||||
"floating-vue": "^5.2.2",
|
||||
"fuse.js": "^7.0.0",
|
||||
"lint-staged": "^15.2.9",
|
||||
"npm-run-all": "^4.1.5",
|
||||
"ohash": "^1.1.3",
|
||||
"pathe": "^1.1.2",
|
||||
"pinia": "^2.2.2",
|
||||
"prism-theme-vars": "^0.2.5",
|
||||
"rimraf": "^6.0.1",
|
||||
"simple-git-hooks": "^2.11.1",
|
||||
"splitpanes": "^3.1.5",
|
||||
"typescript": "^5.5.4",
|
||||
"unbuild": "^2.0.0",
|
||||
"unocss": "^0.62.2",
|
||||
"unplugin-auto-import": "^0.18.2",
|
||||
"unplugin-vue-components": "^0.27.4",
|
||||
"vis-data": "7.1.7",
|
||||
"vis-network": "9.1.6",
|
||||
"vite": "^5.4.1",
|
||||
"vite-dev-rpc": "^0.1.4",
|
||||
"vite-hot-client": "^0.2.3",
|
||||
"vite-plugin-pages": "^0.32.3",
|
||||
"vue": "^3.4.38",
|
||||
"vue-echarts": "^7.0.3",
|
||||
"vue-router": "^4.4.3",
|
||||
"vue-tsc": "^2.0.29"
|
||||
},
|
||||
"simple-git-hooks": {
|
||||
"pre-commit": "npx lint-staged"
|
||||
},
|
||||
"lint-staged": {
|
||||
"*.{js,ts,vue,md}": [
|
||||
"eslint --cache --fix"
|
||||
]
|
||||
}
|
||||
}
|
||||
21
node_modules/vite-plugin-inspect/splitpanes.d.ts
generated
vendored
Normal file
21
node_modules/vite-plugin-inspect/splitpanes.d.ts
generated
vendored
Normal file
@@ -0,0 +1,21 @@
|
||||
// TODO install @types/splitpanes once updated
|
||||
declare module 'splitpanes' {
|
||||
import type { Component } from 'vue'
|
||||
|
||||
export interface SplitpaneProps {
|
||||
horizontal: boolean
|
||||
pushOtherPanes: boolean
|
||||
dblClickSplitter: boolean
|
||||
firstSplitter: boolean
|
||||
}
|
||||
|
||||
export interface PaneProps {
|
||||
size: number | string
|
||||
minSize: number | string
|
||||
maxSize: number | string
|
||||
}
|
||||
|
||||
export type Pane = Component<PaneProps>
|
||||
export const Pane: Pane
|
||||
export const Splitpanes: Component<SplitpaneProps>
|
||||
}
|
||||
Reference in New Issue
Block a user