Spaces:
Sleeping
Sleeping
| ; | |
| var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { | |
| if (k2 === undefined) k2 = k; | |
| var desc = Object.getOwnPropertyDescriptor(m, k); | |
| if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { | |
| desc = { enumerable: true, get: function() { return m[k]; } }; | |
| } | |
| Object.defineProperty(o, k2, desc); | |
| }) : (function(o, m, k, k2) { | |
| if (k2 === undefined) k2 = k; | |
| o[k2] = m[k]; | |
| })); | |
| var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { | |
| Object.defineProperty(o, "default", { enumerable: true, value: v }); | |
| }) : function(o, v) { | |
| o["default"] = v; | |
| }); | |
| var __exportStar = (this && this.__exportStar) || function(m, exports) { | |
| for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p); | |
| }; | |
| var __importStar = (this && this.__importStar) || function (mod) { | |
| if (mod && mod.__esModule) return mod; | |
| var result = {}; | |
| if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); | |
| __setModuleDefault(result, mod); | |
| return result; | |
| }; | |
| Object.defineProperty(exports, "__esModule", { value: true }); | |
| exports.shouldInterruptAfterDeadline = exports.newAsyncContext = exports.newAsyncRuntime = exports.getQuickJSSync = exports.getQuickJS = exports.errors = exports.RELEASE_SYNC = exports.RELEASE_ASYNC = exports.DEBUG_SYNC = exports.DEBUG_ASYNC = exports.newQuickJSAsyncWASMModule = exports.newQuickJSWASMModule = void 0; | |
| // Build variants | |
| const variants_1 = require("./variants"); | |
| Object.defineProperty(exports, "newQuickJSWASMModule", { enumerable: true, get: function () { return variants_1.newQuickJSWASMModule; } }); | |
| Object.defineProperty(exports, "newQuickJSAsyncWASMModule", { enumerable: true, get: function () { return variants_1.newQuickJSAsyncWASMModule; } }); | |
| Object.defineProperty(exports, "DEBUG_ASYNC", { enumerable: true, get: function () { return variants_1.DEBUG_ASYNC; } }); | |
| Object.defineProperty(exports, "DEBUG_SYNC", { enumerable: true, get: function () { return variants_1.DEBUG_SYNC; } }); | |
| Object.defineProperty(exports, "RELEASE_ASYNC", { enumerable: true, get: function () { return variants_1.RELEASE_ASYNC; } }); | |
| Object.defineProperty(exports, "RELEASE_SYNC", { enumerable: true, get: function () { return variants_1.RELEASE_SYNC; } }); | |
| // Export helpers | |
| __exportStar(require("./vm-interface"), exports); | |
| __exportStar(require("./lifetime"), exports); | |
| /** Collects the informative errors this library may throw. */ | |
| exports.errors = __importStar(require("./errors")); | |
| __exportStar(require("./deferred-promise"), exports); | |
| __exportStar(require("./module-test"), exports); | |
| let singleton = undefined; | |
| let singletonPromise = undefined; | |
| /** | |
| * Get a shared singleton {@link QuickJSWASMModule}. Use this to evaluate code | |
| * or create Javascript environments. | |
| * | |
| * This is the top-level entrypoint for the quickjs-emscripten library. | |
| * | |
| * If you need strictest possible isolation guarantees, you may create a | |
| * separate {@link QuickJSWASMModule} via {@link newQuickJSWASMModule}. | |
| * | |
| * To work with the asyncified version of this library, see these functions: | |
| * | |
| * - {@link newAsyncRuntime}. | |
| * - {@link newAsyncContext}. | |
| * - {@link newQuickJSAsyncWASMModule}. | |
| */ | |
| async function getQuickJS() { | |
| singletonPromise ?? (singletonPromise = (0, variants_1.newQuickJSWASMModule)().then((instance) => { | |
| singleton = instance; | |
| return instance; | |
| })); | |
| return await singletonPromise; | |
| } | |
| exports.getQuickJS = getQuickJS; | |
| /** | |
| * Provides synchronous access to the shared {@link QuickJSWASMModule} instance returned by {@link getQuickJS}, as long as | |
| * least once. | |
| * @throws If called before `getQuickJS` resolves. | |
| */ | |
| function getQuickJSSync() { | |
| if (!singleton) { | |
| throw new Error("QuickJS not initialized. Await getQuickJS() at least once."); | |
| } | |
| return singleton; | |
| } | |
| exports.getQuickJSSync = getQuickJSSync; | |
| /** | |
| * Create a new [[QuickJSAsyncRuntime]] in a separate WebAssembly module. | |
| * | |
| * Each runtime is isolated in a separate WebAssembly module, so that errors in | |
| * one runtime cannot contaminate another runtime, and each runtime can execute | |
| * an asynchronous action without conflicts. | |
| * | |
| * Note that there is a hard limit on the number of WebAssembly modules in older | |
| * versions of v8: | |
| * https://bugs.chromium.org/p/v8/issues/detail?id=12076 | |
| */ | |
| async function newAsyncRuntime(options) { | |
| const module = await (0, variants_1.newQuickJSAsyncWASMModule)(); | |
| return module.newRuntime(options); | |
| } | |
| exports.newAsyncRuntime = newAsyncRuntime; | |
| /** | |
| * Create a new [[QuickJSAsyncContext]] (with an associated runtime) in an | |
| * separate WebAssembly module. | |
| * | |
| * Each context is isolated in a separate WebAssembly module, so that errors in | |
| * one runtime cannot contaminate another runtime, and each runtime can execute | |
| * an asynchronous action without conflicts. | |
| * | |
| * Note that there is a hard limit on the number of WebAssembly modules in older | |
| * versions of v8: | |
| * https://bugs.chromium.org/p/v8/issues/detail?id=12076 | |
| */ | |
| async function newAsyncContext(options) { | |
| const module = await (0, variants_1.newQuickJSAsyncWASMModule)(); | |
| return module.newContext(options); | |
| } | |
| exports.newAsyncContext = newAsyncContext; | |
| /** | |
| * Returns an interrupt handler that interrupts Javascript execution after a deadline time. | |
| * | |
| * @param deadline - Interrupt execution if it's still running after this time. | |
| * Number values are compared against `Date.now()` | |
| */ | |
| function shouldInterruptAfterDeadline(deadline) { | |
| const deadlineAsNumber = typeof deadline === "number" ? deadline : deadline.getTime(); | |
| return function () { | |
| return Date.now() > deadlineAsNumber; | |
| }; | |
| } | |
| exports.shouldInterruptAfterDeadline = shouldInterruptAfterDeadline; | |
| //# sourceMappingURL=index.js.map |