Initial commit
This commit is contained in:
commit
78f8d225ee
21173 changed files with 2907774 additions and 0 deletions
66
node_modules/next/dist/esm/server/web/sandbox/resource-managers.js
generated
vendored
Normal file
66
node_modules/next/dist/esm/server/web/sandbox/resource-managers.js
generated
vendored
Normal file
|
|
@ -0,0 +1,66 @@
|
|||
class ResourceManager {
|
||||
add(resourceArgs) {
|
||||
const resource = this.create(resourceArgs);
|
||||
this.resources.push(resource);
|
||||
return resource;
|
||||
}
|
||||
remove(resource) {
|
||||
this.resources = this.resources.filter((r)=>r !== resource);
|
||||
this.destroy(resource);
|
||||
}
|
||||
removeAll() {
|
||||
this.resources.forEach(this.destroy);
|
||||
this.resources = [];
|
||||
}
|
||||
constructor(){
|
||||
this.resources = [];
|
||||
}
|
||||
}
|
||||
class IntervalsManager extends ResourceManager {
|
||||
create(args) {
|
||||
// TODO: use the edge runtime provided `setInterval` instead
|
||||
return webSetIntervalPolyfill(...args);
|
||||
}
|
||||
destroy(interval) {
|
||||
clearInterval(interval);
|
||||
}
|
||||
}
|
||||
class TimeoutsManager extends ResourceManager {
|
||||
create(args) {
|
||||
// TODO: use the edge runtime provided `setTimeout` instead
|
||||
return webSetTimeoutPolyfill(...args);
|
||||
}
|
||||
destroy(timeout) {
|
||||
clearTimeout(timeout);
|
||||
}
|
||||
}
|
||||
function webSetIntervalPolyfill(callback, ms, ...args) {
|
||||
return setInterval(()=>{
|
||||
// node's `setInterval` sets `this` to the `Timeout` instance it returned,
|
||||
// but web `setInterval` always sets `this` to `window`
|
||||
// see: https://developer.mozilla.org/en-US/docs/Web/API/Window/setInterval#the_this_problem
|
||||
return callback.apply(globalThis, args);
|
||||
}, ms)[Symbol.toPrimitive]();
|
||||
}
|
||||
function webSetTimeoutPolyfill(callback, ms, ...args) {
|
||||
const wrappedCallback = ()=>{
|
||||
try {
|
||||
// node's `setTimeout` sets `this` to the `Timeout` instance it returned,
|
||||
// but web `setTimeout` always sets `this` to `window`
|
||||
// see: https://developer.mozilla.org/en-US/docs/Web/API/Window/setTimeout#the_this_problem
|
||||
return callback.apply(globalThis, args);
|
||||
} finally{
|
||||
// On certain older node versions (<20.16.0, <22.4.0),
|
||||
// a `setTimeout` whose Timeout was converted to a primitive will leak.
|
||||
// See: https://github.com/nodejs/node/issues/53335
|
||||
// We can work around this by explicitly calling `clearTimeout` after the callback runs.
|
||||
clearTimeout(timeout);
|
||||
}
|
||||
};
|
||||
const timeout = setTimeout(wrappedCallback, ms);
|
||||
return timeout[Symbol.toPrimitive]();
|
||||
}
|
||||
export const intervalsManager = new IntervalsManager();
|
||||
export const timeoutsManager = new TimeoutsManager();
|
||||
|
||||
//# sourceMappingURL=resource-managers.js.map
|
||||
Loading…
Add table
Add a link
Reference in a new issue