@wyw-in-js/transform 1.0.4 → 1.0.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (66) hide show
  1. package/esm/cache.js +47 -6
  2. package/esm/cache.js.map +1 -1
  3. package/esm/module.js +2 -2
  4. package/esm/module.js.map +1 -1
  5. package/esm/options/buildOptions.js +23 -2
  6. package/esm/options/buildOptions.js.map +1 -1
  7. package/esm/options/buildOptions.test.js +97 -0
  8. package/esm/options/buildOptions.test.js.map +1 -1
  9. package/esm/plugins/shaker.js +87 -9
  10. package/esm/plugins/shaker.js.map +1 -1
  11. package/esm/transform/Entrypoint.helpers.js +8 -1
  12. package/esm/transform/Entrypoint.helpers.js.map +1 -1
  13. package/esm/transform/Entrypoint.js +5 -3
  14. package/esm/transform/Entrypoint.js.map +1 -1
  15. package/esm/transform/EvaluatedEntrypoint.js.map +1 -1
  16. package/esm/transform/actions/BaseAction.js +1 -1
  17. package/esm/transform/actions/BaseAction.js.map +1 -1
  18. package/esm/transform/generators/processImports.js +53 -0
  19. package/esm/transform/generators/processImports.js.map +1 -1
  20. package/esm/transform/generators/resolveImports.js +2 -2
  21. package/esm/transform/generators/resolveImports.js.map +1 -1
  22. package/esm/utils/importOverrides.js +60 -0
  23. package/esm/utils/importOverrides.js.map +1 -1
  24. package/esm/vm/createVmContext.js +48 -16
  25. package/esm/vm/createVmContext.js.map +1 -1
  26. package/lib/cache.js +47 -7
  27. package/lib/cache.js.map +1 -1
  28. package/lib/module.js +2 -2
  29. package/lib/module.js.map +1 -1
  30. package/lib/options/buildOptions.js +23 -3
  31. package/lib/options/buildOptions.js.map +1 -1
  32. package/lib/options/buildOptions.test.js +97 -0
  33. package/lib/options/buildOptions.test.js.map +1 -1
  34. package/lib/plugins/shaker.js +88 -9
  35. package/lib/plugins/shaker.js.map +1 -1
  36. package/lib/transform/Entrypoint.helpers.js +8 -1
  37. package/lib/transform/Entrypoint.helpers.js.map +1 -1
  38. package/lib/transform/Entrypoint.js +5 -3
  39. package/lib/transform/Entrypoint.js.map +1 -1
  40. package/lib/transform/EvaluatedEntrypoint.js.map +1 -1
  41. package/lib/transform/actions/BaseAction.js +1 -1
  42. package/lib/transform/actions/BaseAction.js.map +1 -1
  43. package/lib/transform/generators/processImports.js +53 -0
  44. package/lib/transform/generators/processImports.js.map +1 -1
  45. package/lib/transform/generators/resolveImports.js +1 -1
  46. package/lib/transform/generators/resolveImports.js.map +1 -1
  47. package/lib/utils/importOverrides.js +62 -0
  48. package/lib/utils/importOverrides.js.map +1 -1
  49. package/lib/vm/createVmContext.js +48 -16
  50. package/lib/vm/createVmContext.js.map +1 -1
  51. package/package.json +5 -4
  52. package/types/cache.d.ts +2 -1
  53. package/types/cache.js +48 -6
  54. package/types/module.js +1 -1
  55. package/types/options/buildOptions.js +29 -2
  56. package/types/plugins/shaker.js +104 -9
  57. package/types/transform/Entrypoint.helpers.js +10 -1
  58. package/types/transform/Entrypoint.js +5 -3
  59. package/types/transform/EvaluatedEntrypoint.d.ts +2 -0
  60. package/types/transform/EvaluatedEntrypoint.js +1 -0
  61. package/types/transform/actions/BaseAction.js +1 -1
  62. package/types/transform/generators/processImports.js +70 -0
  63. package/types/transform/generators/resolveImports.js +1 -1
  64. package/types/utils/importOverrides.d.ts +2 -1
  65. package/types/utils/importOverrides.js +63 -0
  66. package/types/vm/createVmContext.js +61 -13
@@ -1 +1 @@
1
- {"version":3,"file":"Entrypoint.js","names":["invariant","BaseEntrypoint","isSuperSet","mergeOnly","isStaticallyEvaluatableModule","EvaluatedEntrypoint","AbortError","BaseAction","UnprocessedEntrypointError","EMPTY_FILE","hasLoop","name","parent","processed","includes","p","parents","found","Entrypoint","evaluated","onSupersedeHandlers","actionsCache","Map","hasWywMetadata","supersededWith","transformResultCode","constructor","services","initialCode","only","exports","evaluatedOnly","loadedAndParsed","resolveTasks","dependencies","generation","loadAndParseFn","log","code","undefined","cache","invalidateIfChanged","evaluator","originalCode","extend","ignored","transformedCode","createRoot","loadedCode","created","create","eventEmitter","perf","status","entrypoint","innerCreate","seqId","add","cached","get","changed","mergedOnly","isLoop","map","push","supersede","newEntrypoint","ast","length","addDependency","dependency","delete","source","set","addResolveTask","assertNotSuperseded","assertTransformed","createAction","actionType","data","abortSignal","has","aborted","newAction","entrypointEvent","type","actionIdx","idx","createChild","createEvaluated","exportsProxy","getDependency","getResolveTask","onSupersede","callback","index","indexOf","splice","setTransformResult","res","Boolean","metadata","isNull","newOnlyOrEntrypoint","with","forEach","handler"],"sources":["../../src/transform/Entrypoint.ts"],"sourcesContent":["import { invariant } from 'ts-invariant';\n\nimport type { ParentEntrypoint, ITransformFileResult } from '../types';\n\nimport { BaseEntrypoint } from './BaseEntrypoint';\nimport { isSuperSet, mergeOnly } from './Entrypoint.helpers';\nimport { isStaticallyEvaluatableModule } from './isStaticallyEvaluatableModule';\nimport type {\n IEntrypointCode,\n IEntrypointDependency,\n IIgnoredEntrypoint,\n} from './Entrypoint.types';\nimport { EvaluatedEntrypoint } from './EvaluatedEntrypoint';\nimport { AbortError } from './actions/AbortError';\nimport type { ActionByType } from './actions/BaseAction';\nimport { BaseAction } from './actions/BaseAction';\nimport { UnprocessedEntrypointError } from './actions/UnprocessedEntrypointError';\nimport type { Services, ActionTypes, ActionQueueItem } from './types';\n\nconst EMPTY_FILE = '=== empty file ===';\n\nfunction hasLoop(\n name: string,\n parent: ParentEntrypoint,\n processed: string[] = []\n): boolean {\n if (parent.name === name || processed.includes(parent.name)) {\n return true;\n }\n\n for (const p of parent.parents) {\n const found = hasLoop(name, p, [...processed, parent.name]);\n if (found) {\n return found;\n }\n }\n\n return false;\n}\n\nexport class Entrypoint extends BaseEntrypoint {\n public readonly evaluated = false;\n\n public readonly loadedAndParsed: IEntrypointCode | IIgnoredEntrypoint;\n\n protected onSupersedeHandlers: Array<(newEntrypoint: Entrypoint) => void> =\n [];\n\n private actionsCache: Map<\n ActionTypes,\n Map<unknown, BaseAction<ActionQueueItem>>\n > = new Map();\n\n #hasWywMetadata: boolean = false;\n\n #supersededWith: Entrypoint | null = null;\n\n #transformResultCode: string | null = null;\n\n private constructor(\n services: Services,\n parents: ParentEntrypoint[],\n public readonly initialCode: string | undefined,\n name: string,\n only: string[],\n exports: Record<string | symbol, unknown> | undefined,\n evaluatedOnly: string[],\n loadedAndParsed?: IEntrypointCode | IIgnoredEntrypoint,\n protected readonly resolveTasks = new Map<\n string,\n Promise<IEntrypointDependency>\n >(),\n readonly dependencies = new Map<string, IEntrypointDependency>(),\n generation = 1\n ) {\n super(\n services,\n evaluatedOnly,\n exports,\n generation,\n name,\n only,\n parents,\n dependencies\n );\n\n this.loadedAndParsed =\n loadedAndParsed ??\n services.loadAndParseFn(\n services,\n name,\n initialCode,\n parents[0]?.log ?? services.log\n );\n\n if (this.loadedAndParsed.code !== undefined) {\n services.cache.invalidateIfChanged(name, this.loadedAndParsed.code);\n }\n\n const code =\n this.loadedAndParsed.evaluator === 'ignored'\n ? '[IGNORED]'\n : this.originalCode || EMPTY_FILE;\n\n this.log.extend('source')('created %s (%o)\\n%s', name, only, code);\n }\n\n public get ignored() {\n return this.loadedAndParsed.evaluator === 'ignored';\n }\n\n public get originalCode() {\n return this.loadedAndParsed.code;\n }\n\n public get supersededWith(): Entrypoint | null {\n return this.#supersededWith?.supersededWith ?? this.#supersededWith;\n }\n\n public get transformedCode(): string | null {\n return (\n this.#transformResultCode ?? this.supersededWith?.transformedCode ?? null\n );\n }\n\n public static createRoot(\n services: Services,\n name: string,\n only: string[],\n loadedCode: string | undefined\n ): Entrypoint {\n const created = Entrypoint.create(services, null, name, only, loadedCode);\n invariant(created !== 'loop', 'loop detected');\n\n return created;\n }\n\n /**\n * Creates an entrypoint for the specified file.\n * If there is already an entrypoint for this file, there will be four possible outcomes:\n * 1. If `loadedCode` is specified and is different from the one that was used to create the existing entrypoint,\n * the existing entrypoint will be superseded by a new one and all cached results for it will be invalidated.\n * It can happen if the file was changed and the watcher notified us about it, or we received a new version\n * of the file from a loader whereas the previous one was loaded from the filesystem.\n * The new entrypoint will be returned.\n * 2. If `only` is subset of the existing entrypoint's `only`, the existing entrypoint will be returned.\n * 3. If `only` is superset of the existing entrypoint's `only`, the existing entrypoint will be superseded and the new one will be returned.\n * 4. If a loop is detected, 'ignored' will be returned, the existing entrypoint will be superseded or not depending on the `only` value.\n */\n protected static create(\n services: Services,\n parent: ParentEntrypoint | null,\n name: string,\n only: string[],\n loadedCode: string | undefined\n ): Entrypoint | 'loop' {\n const { cache, eventEmitter } = services;\n return eventEmitter.perf('createEntrypoint', () => {\n const [status, entrypoint] = Entrypoint.innerCreate(\n services,\n parent\n ? {\n evaluated: parent.evaluated,\n log: parent.log,\n name: parent.name,\n parents: parent.parents,\n seqId: parent.seqId,\n }\n : null,\n name,\n only,\n loadedCode\n );\n\n if (status !== 'cached') {\n cache.add('entrypoints', name, entrypoint);\n }\n\n return status === 'loop' ? 'loop' : entrypoint;\n });\n }\n\n private static innerCreate(\n services: Services,\n parent: ParentEntrypoint | null,\n name: string,\n only: string[],\n loadedCode: string | undefined\n ): ['loop' | 'created' | 'cached', Entrypoint] {\n const { cache } = services;\n\n const cached = cache.get('entrypoints', name);\n const changed =\n loadedCode !== undefined\n ? cache.invalidateIfChanged(name, loadedCode)\n : false;\n\n if (!cached?.evaluated && cached?.ignored) {\n return ['cached', cached];\n }\n\n const exports = cached?.exports;\n const evaluatedOnly = changed ? [] : cached?.evaluatedOnly ?? [];\n\n const mergedOnly = cached?.only ? mergeOnly(cached.only, only) : [...only];\n\n if (cached?.evaluated) {\n cached.log('is already evaluated with', cached.evaluatedOnly);\n }\n\n if (!changed && cached && !cached.evaluated) {\n const isLoop = parent && hasLoop(name, parent);\n if (isLoop) {\n parent.log('[createEntrypoint] %s is a loop', name);\n }\n\n if (parent && !cached.parents.map((p) => p.name).includes(parent.name)) {\n cached.parents.push(parent);\n }\n\n if (isSuperSet(cached.only, mergedOnly)) {\n cached.log('is cached', name);\n return [isLoop ? 'loop' : 'cached', cached];\n }\n\n cached.log(\n 'is cached, but with different `only` %o (the cached one %o)',\n only,\n cached?.only\n );\n\n return [isLoop ? 'loop' : 'created', cached.supersede(mergedOnly)];\n }\n\n const newEntrypoint = new Entrypoint(\n services,\n parent ? [parent] : [],\n loadedCode,\n name,\n mergedOnly,\n exports,\n evaluatedOnly,\n undefined,\n cached && 'resolveTasks' in cached ? cached.resolveTasks : undefined,\n cached && 'dependencies' in cached ? cached.dependencies : undefined,\n cached ? cached.generation + 1 : 1\n );\n\n if (\n !newEntrypoint.ignored &&\n !newEntrypoint.only.includes('*') &&\n !newEntrypoint.only.includes('__wywPreval') &&\n !newEntrypoint.only.includes('side-effect')\n ) {\n const { ast } = newEntrypoint.loadedAndParsed;\n\n if (ast && isStaticallyEvaluatableModule(ast)) {\n newEntrypoint.log(\n '[entrypoint] promote `only` to \"*\" for statically evaluatable module'\n );\n newEntrypoint.only.length = 0;\n newEntrypoint.only.push('*');\n }\n }\n\n if (cached && !cached.evaluated) {\n cached.log('is cached, but with different code');\n cached.supersede(newEntrypoint);\n }\n\n return ['created', newEntrypoint];\n }\n\n public addDependency(dependency: IEntrypointDependency): void {\n this.resolveTasks.delete(dependency.source);\n this.dependencies.set(dependency.source, dependency);\n }\n\n public addResolveTask(\n name: string,\n dependency: Promise<IEntrypointDependency>\n ): void {\n this.resolveTasks.set(name, dependency);\n }\n\n public assertNotSuperseded() {\n if (this.supersededWith) {\n this.log('superseded');\n throw new AbortError('superseded');\n }\n }\n\n public assertTransformed() {\n if (this.transformedCode === null) {\n this.log('not transformed');\n throw new UnprocessedEntrypointError(this.supersededWith ?? this);\n }\n }\n\n public createAction<\n TType extends ActionTypes,\n TAction extends ActionByType<TType>,\n >(\n actionType: TType,\n data: TAction['data'],\n abortSignal: AbortSignal | null = null\n ): BaseAction<TAction> {\n if (!this.actionsCache.has(actionType)) {\n this.actionsCache.set(actionType, new Map());\n }\n\n const cache = this.actionsCache.get(actionType)!;\n const cached = cache.get(data);\n if (cached && !cached.abortSignal?.aborted) {\n return cached as BaseAction<TAction>;\n }\n\n const newAction = new BaseAction<TAction>(\n actionType as TAction['type'],\n this.services,\n this,\n data,\n abortSignal\n );\n\n cache.set(data, newAction);\n\n this.services.eventEmitter.entrypointEvent(this.seqId, {\n type: 'actionCreated',\n actionType,\n actionIdx: newAction.idx,\n });\n\n return newAction;\n }\n\n public createChild(\n name: string,\n only: string[],\n loadedCode?: string\n ): Entrypoint | 'loop' {\n return Entrypoint.create(this.services, this, name, only, loadedCode);\n }\n\n public createEvaluated() {\n const evaluatedOnly = mergeOnly(this.evaluatedOnly, this.only);\n this.log('create EvaluatedEntrypoint for %o', evaluatedOnly);\n\n return new EvaluatedEntrypoint(\n this.services,\n evaluatedOnly,\n this.exportsProxy,\n this.generation + 1,\n this.name,\n this.only,\n this.parents,\n this.dependencies\n );\n }\n\n public getDependency(name: string): IEntrypointDependency | undefined {\n return this.dependencies.get(name);\n }\n\n public getResolveTask(\n name: string\n ): Promise<IEntrypointDependency> | undefined {\n return this.resolveTasks.get(name);\n }\n\n public hasWywMetadata() {\n return this.#hasWywMetadata;\n }\n\n public onSupersede(callback: (newEntrypoint: Entrypoint) => void) {\n if (this.#supersededWith) {\n callback(this.#supersededWith);\n return () => {};\n }\n\n this.onSupersedeHandlers.push(callback);\n\n return () => {\n const index = this.onSupersedeHandlers.indexOf(callback);\n if (index >= 0) {\n this.onSupersedeHandlers.splice(index, 1);\n }\n };\n }\n\n public setTransformResult(res: ITransformFileResult | null) {\n this.#hasWywMetadata = Boolean(res?.metadata);\n this.#transformResultCode = res?.code ?? null;\n\n this.services.eventEmitter.entrypointEvent(this.seqId, {\n isNull: res === null,\n type: 'setTransformResult',\n });\n }\n\n private supersede(newOnlyOrEntrypoint: string[] | Entrypoint): Entrypoint {\n const newEntrypoint =\n newOnlyOrEntrypoint instanceof Entrypoint\n ? newOnlyOrEntrypoint\n : new Entrypoint(\n this.services,\n this.parents,\n this.initialCode,\n this.name,\n newOnlyOrEntrypoint,\n this.exports,\n this.evaluatedOnly,\n this.loadedAndParsed,\n this.resolveTasks,\n this.dependencies,\n this.generation + 1\n );\n\n this.services.eventEmitter.entrypointEvent(this.seqId, {\n type: 'superseded',\n with: newEntrypoint.seqId,\n });\n this.log(\n 'superseded by %s (%o -> %o)',\n newEntrypoint.name,\n this.only,\n newEntrypoint.only\n );\n this.#supersededWith = newEntrypoint;\n this.onSupersedeHandlers.forEach((handler) => handler(newEntrypoint));\n\n return newEntrypoint;\n }\n}\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"Entrypoint.js","names":["invariant","BaseEntrypoint","isSuperSet","mergeOnly","isStaticallyEvaluatableModule","EvaluatedEntrypoint","AbortError","BaseAction","UnprocessedEntrypointError","EMPTY_FILE","hasLoop","name","parent","processed","includes","p","parents","found","Entrypoint","evaluated","onSupersedeHandlers","actionsCache","Map","hasWywMetadata","supersededWith","transformResultCode","constructor","services","initialCode","only","exports","evaluatedOnly","loadedAndParsed","resolveTasks","dependencies","generation","loadAndParseFn","log","code","undefined","cache","invalidateIfChanged","evaluator","originalCode","extend","ignored","transformedCode","createRoot","loadedCode","created","create","eventEmitter","perf","status","entrypoint","innerCreate","seqId","add","cached","get","changed","mergedOnly","isLoop","map","push","supersede","newEntrypoint","ast","length","addDependency","dependency","delete","source","set","addResolveTask","assertNotSuperseded","assertTransformed","createAction","actionType","data","abortSignal","has","aborted","newAction","entrypointEvent","type","actionIdx","idx","createChild","createEvaluated","exportsProxy","getDependency","getResolveTask","onSupersede","callback","index","indexOf","splice","setTransformResult","res","Boolean","metadata","isNull","newOnlyOrEntrypoint","with","forEach","handler"],"sources":["../../src/transform/Entrypoint.ts"],"sourcesContent":["import { invariant } from 'ts-invariant';\n\nimport type { ParentEntrypoint, ITransformFileResult } from '../types';\n\nimport { BaseEntrypoint } from './BaseEntrypoint';\nimport { isSuperSet, mergeOnly } from './Entrypoint.helpers';\nimport { isStaticallyEvaluatableModule } from './isStaticallyEvaluatableModule';\nimport type {\n IEntrypointCode,\n IEntrypointDependency,\n IIgnoredEntrypoint,\n} from './Entrypoint.types';\nimport { EvaluatedEntrypoint } from './EvaluatedEntrypoint';\nimport { AbortError } from './actions/AbortError';\nimport type { ActionByType } from './actions/BaseAction';\nimport { BaseAction } from './actions/BaseAction';\nimport { UnprocessedEntrypointError } from './actions/UnprocessedEntrypointError';\nimport type { Services, ActionTypes, ActionQueueItem } from './types';\n\nconst EMPTY_FILE = '=== empty file ===';\n\nfunction hasLoop(\n name: string,\n parent: ParentEntrypoint,\n processed: string[] = []\n): boolean {\n if (parent.name === name || processed.includes(parent.name)) {\n return true;\n }\n\n for (const p of parent.parents) {\n const found = hasLoop(name, p, [...processed, parent.name]);\n if (found) {\n return found;\n }\n }\n\n return false;\n}\n\nexport class Entrypoint extends BaseEntrypoint {\n public readonly evaluated = false;\n\n public readonly loadedAndParsed: IEntrypointCode | IIgnoredEntrypoint;\n\n protected onSupersedeHandlers: Array<(newEntrypoint: Entrypoint) => void> =\n [];\n\n private actionsCache: Map<\n ActionTypes,\n Map<unknown, BaseAction<ActionQueueItem>>\n > = new Map();\n\n #hasWywMetadata: boolean = false;\n\n #supersededWith: Entrypoint | null = null;\n\n #transformResultCode: string | null = null;\n\n private constructor(\n services: Services,\n parents: ParentEntrypoint[],\n public readonly initialCode: string | undefined,\n name: string,\n only: string[],\n exports: Record<string | symbol, unknown> | undefined,\n evaluatedOnly: string[],\n loadedAndParsed?: IEntrypointCode | IIgnoredEntrypoint,\n protected readonly resolveTasks = new Map<\n string,\n Promise<IEntrypointDependency>\n >(),\n readonly dependencies = new Map<string, IEntrypointDependency>(),\n generation = 1\n ) {\n super(\n services,\n evaluatedOnly,\n exports,\n generation,\n name,\n only,\n parents,\n dependencies\n );\n\n this.loadedAndParsed =\n loadedAndParsed ??\n services.loadAndParseFn(\n services,\n name,\n initialCode,\n parents[0]?.log ?? services.log\n );\n\n if (this.loadedAndParsed.code !== undefined) {\n services.cache.invalidateIfChanged(\n name,\n this.loadedAndParsed.code,\n undefined,\n this.initialCode === undefined ? 'fs' : 'loaded'\n );\n }\n\n const code =\n this.loadedAndParsed.evaluator === 'ignored'\n ? '[IGNORED]'\n : this.originalCode || EMPTY_FILE;\n\n this.log.extend('source')('created %s (%o)\\n%s', name, only, code);\n }\n\n public get ignored() {\n return this.loadedAndParsed.evaluator === 'ignored';\n }\n\n public get originalCode() {\n return this.loadedAndParsed.code;\n }\n\n public get supersededWith(): Entrypoint | null {\n return this.#supersededWith?.supersededWith ?? this.#supersededWith;\n }\n\n public get transformedCode(): string | null {\n return (\n this.#transformResultCode ?? this.supersededWith?.transformedCode ?? null\n );\n }\n\n public static createRoot(\n services: Services,\n name: string,\n only: string[],\n loadedCode: string | undefined\n ): Entrypoint {\n const created = Entrypoint.create(services, null, name, only, loadedCode);\n invariant(created !== 'loop', 'loop detected');\n\n return created;\n }\n\n /**\n * Creates an entrypoint for the specified file.\n * If there is already an entrypoint for this file, there will be four possible outcomes:\n * 1. If `loadedCode` is specified and is different from the one that was used to create the existing entrypoint,\n * the existing entrypoint will be superseded by a new one and all cached results for it will be invalidated.\n * It can happen if the file was changed and the watcher notified us about it, or we received a new version\n * of the file from a loader whereas the previous one was loaded from the filesystem.\n * The new entrypoint will be returned.\n * 2. If `only` is subset of the existing entrypoint's `only`, the existing entrypoint will be returned.\n * 3. If `only` is superset of the existing entrypoint's `only`, the existing entrypoint will be superseded and the new one will be returned.\n * 4. If a loop is detected, 'ignored' will be returned, the existing entrypoint will be superseded or not depending on the `only` value.\n */\n protected static create(\n services: Services,\n parent: ParentEntrypoint | null,\n name: string,\n only: string[],\n loadedCode: string | undefined\n ): Entrypoint | 'loop' {\n const { cache, eventEmitter } = services;\n return eventEmitter.perf('createEntrypoint', () => {\n const [status, entrypoint] = Entrypoint.innerCreate(\n services,\n parent\n ? {\n evaluated: parent.evaluated,\n log: parent.log,\n name: parent.name,\n parents: parent.parents,\n seqId: parent.seqId,\n }\n : null,\n name,\n only,\n loadedCode\n );\n\n if (status !== 'cached') {\n cache.add('entrypoints', name, entrypoint);\n }\n\n return status === 'loop' ? 'loop' : entrypoint;\n });\n }\n\n private static innerCreate(\n services: Services,\n parent: ParentEntrypoint | null,\n name: string,\n only: string[],\n loadedCode: string | undefined\n ): ['loop' | 'created' | 'cached', Entrypoint] {\n const { cache } = services;\n\n const cached = cache.get('entrypoints', name);\n const changed =\n loadedCode !== undefined\n ? cache.invalidateIfChanged(name, loadedCode, undefined, 'loaded')\n : false;\n\n if (!cached?.evaluated && cached?.ignored) {\n return ['cached', cached];\n }\n\n const exports = cached?.exports;\n const evaluatedOnly = changed ? [] : cached?.evaluatedOnly ?? [];\n\n const mergedOnly = cached?.only ? mergeOnly(cached.only, only) : [...only];\n\n if (cached?.evaluated) {\n cached.log('is already evaluated with', cached.evaluatedOnly);\n }\n\n if (!changed && cached && !cached.evaluated) {\n const isLoop = parent && hasLoop(name, parent);\n if (isLoop) {\n parent.log('[createEntrypoint] %s is a loop', name);\n }\n\n if (parent && !cached.parents.map((p) => p.name).includes(parent.name)) {\n cached.parents.push(parent);\n }\n\n if (isSuperSet(cached.only, mergedOnly)) {\n cached.log('is cached', name);\n return [isLoop ? 'loop' : 'cached', cached];\n }\n\n cached.log(\n 'is cached, but with different `only` %o (the cached one %o)',\n only,\n cached?.only\n );\n\n return [isLoop ? 'loop' : 'created', cached.supersede(mergedOnly)];\n }\n\n const newEntrypoint = new Entrypoint(\n services,\n parent ? [parent] : [],\n loadedCode,\n name,\n mergedOnly,\n exports,\n evaluatedOnly,\n undefined,\n cached && 'resolveTasks' in cached ? cached.resolveTasks : undefined,\n cached && 'dependencies' in cached ? cached.dependencies : undefined,\n cached ? cached.generation + 1 : 1\n );\n\n if (\n !newEntrypoint.ignored &&\n !newEntrypoint.only.includes('*') &&\n !newEntrypoint.only.includes('__wywPreval') &&\n !newEntrypoint.only.includes('side-effect')\n ) {\n const { ast } = newEntrypoint.loadedAndParsed;\n\n if (ast && isStaticallyEvaluatableModule(ast)) {\n newEntrypoint.log(\n '[entrypoint] promote `only` to \"*\" for statically evaluatable module'\n );\n newEntrypoint.only.length = 0;\n newEntrypoint.only.push('*');\n }\n }\n\n if (cached && !cached.evaluated) {\n cached.log('is cached, but with different code');\n cached.supersede(newEntrypoint);\n }\n\n return ['created', newEntrypoint];\n }\n\n public addDependency(dependency: IEntrypointDependency): void {\n this.resolveTasks.delete(dependency.source);\n this.dependencies.set(dependency.source, dependency);\n }\n\n public addResolveTask(\n name: string,\n dependency: Promise<IEntrypointDependency>\n ): void {\n this.resolveTasks.set(name, dependency);\n }\n\n public assertNotSuperseded() {\n if (this.supersededWith) {\n this.log('superseded');\n throw new AbortError('superseded');\n }\n }\n\n public assertTransformed() {\n if (this.transformedCode === null) {\n this.log('not transformed');\n throw new UnprocessedEntrypointError(this.supersededWith ?? this);\n }\n }\n\n public createAction<\n TType extends ActionTypes,\n TAction extends ActionByType<TType>,\n >(\n actionType: TType,\n data: TAction['data'],\n abortSignal: AbortSignal | null = null\n ): BaseAction<TAction> {\n if (!this.actionsCache.has(actionType)) {\n this.actionsCache.set(actionType, new Map());\n }\n\n const cache = this.actionsCache.get(actionType)!;\n const cached = cache.get(data);\n if (cached && !cached.abortSignal?.aborted) {\n return cached as BaseAction<TAction>;\n }\n\n const newAction = new BaseAction<TAction>(\n actionType as TAction['type'],\n this.services,\n this,\n data,\n abortSignal\n );\n\n cache.set(data, newAction);\n\n this.services.eventEmitter.entrypointEvent(this.seqId, {\n type: 'actionCreated',\n actionType,\n actionIdx: newAction.idx,\n });\n\n return newAction;\n }\n\n public createChild(\n name: string,\n only: string[],\n loadedCode?: string\n ): Entrypoint | 'loop' {\n return Entrypoint.create(this.services, this, name, only, loadedCode);\n }\n\n public createEvaluated() {\n const evaluatedOnly = mergeOnly(this.evaluatedOnly, this.only);\n this.log('create EvaluatedEntrypoint for %o', evaluatedOnly);\n\n const evaluated = new EvaluatedEntrypoint(\n this.services,\n evaluatedOnly,\n this.exportsProxy,\n this.generation + 1,\n this.name,\n this.only,\n this.parents,\n this.dependencies\n );\n\n evaluated.initialCode = this.initialCode;\n\n return evaluated;\n }\n\n public getDependency(name: string): IEntrypointDependency | undefined {\n return this.dependencies.get(name);\n }\n\n public getResolveTask(\n name: string\n ): Promise<IEntrypointDependency> | undefined {\n return this.resolveTasks.get(name);\n }\n\n public hasWywMetadata() {\n return this.#hasWywMetadata;\n }\n\n public onSupersede(callback: (newEntrypoint: Entrypoint) => void) {\n if (this.#supersededWith) {\n callback(this.#supersededWith);\n return () => {};\n }\n\n this.onSupersedeHandlers.push(callback);\n\n return () => {\n const index = this.onSupersedeHandlers.indexOf(callback);\n if (index >= 0) {\n this.onSupersedeHandlers.splice(index, 1);\n }\n };\n }\n\n public setTransformResult(res: ITransformFileResult | null) {\n this.#hasWywMetadata = Boolean(res?.metadata);\n this.#transformResultCode = res?.code ?? null;\n\n this.services.eventEmitter.entrypointEvent(this.seqId, {\n isNull: res === null,\n type: 'setTransformResult',\n });\n }\n\n private supersede(newOnlyOrEntrypoint: string[] | Entrypoint): Entrypoint {\n const newEntrypoint =\n newOnlyOrEntrypoint instanceof Entrypoint\n ? newOnlyOrEntrypoint\n : new Entrypoint(\n this.services,\n this.parents,\n this.initialCode,\n this.name,\n newOnlyOrEntrypoint,\n this.exports,\n this.evaluatedOnly,\n this.loadedAndParsed,\n this.resolveTasks,\n this.dependencies,\n this.generation + 1\n );\n\n this.services.eventEmitter.entrypointEvent(this.seqId, {\n type: 'superseded',\n with: newEntrypoint.seqId,\n });\n this.log(\n 'superseded by %s (%o -> %o)',\n newEntrypoint.name,\n this.only,\n newEntrypoint.only\n );\n this.#supersededWith = newEntrypoint;\n this.onSupersedeHandlers.forEach((handler) => handler(newEntrypoint));\n\n return newEntrypoint;\n }\n}\n"],"mappings":"AAAA,SAASA,SAAS,QAAQ,cAAc;AAIxC,SAASC,cAAc,QAAQ,kBAAkB;AACjD,SAASC,UAAU,EAAEC,SAAS,QAAQ,sBAAsB;AAC5D,SAASC,6BAA6B,QAAQ,iCAAiC;AAM/E,SAASC,mBAAmB,QAAQ,uBAAuB;AAC3D,SAASC,UAAU,QAAQ,sBAAsB;AAEjD,SAASC,UAAU,QAAQ,sBAAsB;AACjD,SAASC,0BAA0B,QAAQ,sCAAsC;AAGjF,MAAMC,UAAU,GAAG,oBAAoB;AAEvC,SAASC,OAAOA,CACdC,IAAY,EACZC,MAAwB,EACxBC,SAAmB,GAAG,EAAE,EACf;EACT,IAAID,MAAM,CAACD,IAAI,KAAKA,IAAI,IAAIE,SAAS,CAACC,QAAQ,CAACF,MAAM,CAACD,IAAI,CAAC,EAAE;IAC3D,OAAO,IAAI;EACb;EAEA,KAAK,MAAMI,CAAC,IAAIH,MAAM,CAACI,OAAO,EAAE;IAC9B,MAAMC,KAAK,GAAGP,OAAO,CAACC,IAAI,EAAEI,CAAC,EAAE,CAAC,GAAGF,SAAS,EAAED,MAAM,CAACD,IAAI,CAAC,CAAC;IAC3D,IAAIM,KAAK,EAAE;MACT,OAAOA,KAAK;IACd;EACF;EAEA,OAAO,KAAK;AACd;AAEA,OAAO,MAAMC,UAAU,SAASjB,cAAc,CAAC;EAC7BkB,SAAS,GAAG,KAAK;EAIvBC,mBAAmB,GAC3B,EAAE;EAEIC,YAAY,GAGhB,IAAIC,GAAG,CAAC,CAAC;EAEb,CAACC,cAAc,GAAY,KAAK;EAEhC,CAACC,cAAc,GAAsB,IAAI;EAEzC,CAACC,mBAAmB,GAAkB,IAAI;EAElCC,WAAWA,CACjBC,QAAkB,EAClBX,OAA2B,EACXY,WAA+B,EAC/CjB,IAAY,EACZkB,IAAc,EACdC,OAAqD,EACrDC,aAAuB,EACvBC,eAAsD,EACnCC,YAAY,GAAG,IAAIX,GAAG,CAGvC,CAAC,EACMY,YAAY,GAAG,IAAIZ,GAAG,CAAgC,CAAC,EAChEa,UAAU,GAAG,CAAC,EACd;IACA,KAAK,CACHR,QAAQ,EACRI,aAAa,EACbD,OAAO,EACPK,UAAU,EACVxB,IAAI,EACJkB,IAAI,EACJb,OAAO,EACPkB,YACF,CAAC;IAAC,KAtBcN,WAA+B,GAA/BA,WAA+B;IAAA,KAM5BK,YAAY,GAAZA,YAAY;IAAA,KAItBC,YAAY,GAAZA,YAAY;IAcrB,IAAI,CAACF,eAAe,GAClBA,eAAe,IACfL,QAAQ,CAACS,cAAc,CACrBT,QAAQ,EACRhB,IAAI,EACJiB,WAAW,EACXZ,OAAO,CAAC,CAAC,CAAC,EAAEqB,GAAG,IAAIV,QAAQ,CAACU,GAC9B,CAAC;IAEH,IAAI,IAAI,CAACL,eAAe,CAACM,IAAI,KAAKC,SAAS,EAAE;MAC3CZ,QAAQ,CAACa,KAAK,CAACC,mBAAmB,CAChC9B,IAAI,EACJ,IAAI,CAACqB,eAAe,CAACM,IAAI,EACzBC,SAAS,EACT,IAAI,CAACX,WAAW,KAAKW,SAAS,GAAG,IAAI,GAAG,QAC1C,CAAC;IACH;IAEA,MAAMD,IAAI,GACR,IAAI,CAACN,eAAe,CAACU,SAAS,KAAK,SAAS,GACxC,WAAW,GACX,IAAI,CAACC,YAAY,IAAIlC,UAAU;IAErC,IAAI,CAAC4B,GAAG,CAACO,MAAM,CAAC,QAAQ,CAAC,CAAC,qBAAqB,EAAEjC,IAAI,EAAEkB,IAAI,EAAES,IAAI,CAAC;EACpE;EAEA,IAAWO,OAAOA,CAAA,EAAG;IACnB,OAAO,IAAI,CAACb,eAAe,CAACU,SAAS,KAAK,SAAS;EACrD;EAEA,IAAWC,YAAYA,CAAA,EAAG;IACxB,OAAO,IAAI,CAACX,eAAe,CAACM,IAAI;EAClC;EAEA,IAAWd,cAAcA,CAAA,EAAsB;IAC7C,OAAO,IAAI,CAAC,CAACA,cAAc,EAAEA,cAAc,IAAI,IAAI,CAAC,CAACA,cAAc;EACrE;EAEA,IAAWsB,eAAeA,CAAA,EAAkB;IAC1C,OACE,IAAI,CAAC,CAACrB,mBAAmB,IAAI,IAAI,CAACD,cAAc,EAAEsB,eAAe,IAAI,IAAI;EAE7E;EAEA,OAAcC,UAAUA,CACtBpB,QAAkB,EAClBhB,IAAY,EACZkB,IAAc,EACdmB,UAA8B,EAClB;IACZ,MAAMC,OAAO,GAAG/B,UAAU,CAACgC,MAAM,CAACvB,QAAQ,EAAE,IAAI,EAAEhB,IAAI,EAAEkB,IAAI,EAAEmB,UAAU,CAAC;IACzEhD,SAAS,CAACiD,OAAO,KAAK,MAAM,EAAE,eAAe,CAAC;IAE9C,OAAOA,OAAO;EAChB;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EACE,OAAiBC,MAAMA,CACrBvB,QAAkB,EAClBf,MAA+B,EAC/BD,IAAY,EACZkB,IAAc,EACdmB,UAA8B,EACT;IACrB,MAAM;MAAER,KAAK;MAAEW;IAAa,CAAC,GAAGxB,QAAQ;IACxC,OAAOwB,YAAY,CAACC,IAAI,CAAC,kBAAkB,EAAE,MAAM;MACjD,MAAM,CAACC,MAAM,EAAEC,UAAU,CAAC,GAAGpC,UAAU,CAACqC,WAAW,CACjD5B,QAAQ,EACRf,MAAM,GACF;QACEO,SAAS,EAAEP,MAAM,CAACO,SAAS;QAC3BkB,GAAG,EAAEzB,MAAM,CAACyB,GAAG;QACf1B,IAAI,EAAEC,MAAM,CAACD,IAAI;QACjBK,OAAO,EAAEJ,MAAM,CAACI,OAAO;QACvBwC,KAAK,EAAE5C,MAAM,CAAC4C;MAChB,CAAC,GACD,IAAI,EACR7C,IAAI,EACJkB,IAAI,EACJmB,UACF,CAAC;MAED,IAAIK,MAAM,KAAK,QAAQ,EAAE;QACvBb,KAAK,CAACiB,GAAG,CAAC,aAAa,EAAE9C,IAAI,EAAE2C,UAAU,CAAC;MAC5C;MAEA,OAAOD,MAAM,KAAK,MAAM,GAAG,MAAM,GAAGC,UAAU;IAChD,CAAC,CAAC;EACJ;EAEA,OAAeC,WAAWA,CACxB5B,QAAkB,EAClBf,MAA+B,EAC/BD,IAAY,EACZkB,IAAc,EACdmB,UAA8B,EACe;IAC7C,MAAM;MAAER;IAAM,CAAC,GAAGb,QAAQ;IAE1B,MAAM+B,MAAM,GAAGlB,KAAK,CAACmB,GAAG,CAAC,aAAa,EAAEhD,IAAI,CAAC;IAC7C,MAAMiD,OAAO,GACXZ,UAAU,KAAKT,SAAS,GACpBC,KAAK,CAACC,mBAAmB,CAAC9B,IAAI,EAAEqC,UAAU,EAAET,SAAS,EAAE,QAAQ,CAAC,GAChE,KAAK;IAEX,IAAI,CAACmB,MAAM,EAAEvC,SAAS,IAAIuC,MAAM,EAAEb,OAAO,EAAE;MACzC,OAAO,CAAC,QAAQ,EAAEa,MAAM,CAAC;IAC3B;IAEA,MAAM5B,OAAO,GAAG4B,MAAM,EAAE5B,OAAO;IAC/B,MAAMC,aAAa,GAAG6B,OAAO,GAAG,EAAE,GAAGF,MAAM,EAAE3B,aAAa,IAAI,EAAE;IAEhE,MAAM8B,UAAU,GAAGH,MAAM,EAAE7B,IAAI,GAAG1B,SAAS,CAACuD,MAAM,CAAC7B,IAAI,EAAEA,IAAI,CAAC,GAAG,CAAC,GAAGA,IAAI,CAAC;IAE1E,IAAI6B,MAAM,EAAEvC,SAAS,EAAE;MACrBuC,MAAM,CAACrB,GAAG,CAAC,2BAA2B,EAAEqB,MAAM,CAAC3B,aAAa,CAAC;IAC/D;IAEA,IAAI,CAAC6B,OAAO,IAAIF,MAAM,IAAI,CAACA,MAAM,CAACvC,SAAS,EAAE;MAC3C,MAAM2C,MAAM,GAAGlD,MAAM,IAAIF,OAAO,CAACC,IAAI,EAAEC,MAAM,CAAC;MAC9C,IAAIkD,MAAM,EAAE;QACVlD,MAAM,CAACyB,GAAG,CAAC,iCAAiC,EAAE1B,IAAI,CAAC;MACrD;MAEA,IAAIC,MAAM,IAAI,CAAC8C,MAAM,CAAC1C,OAAO,CAAC+C,GAAG,CAAEhD,CAAC,IAAKA,CAAC,CAACJ,IAAI,CAAC,CAACG,QAAQ,CAACF,MAAM,CAACD,IAAI,CAAC,EAAE;QACtE+C,MAAM,CAAC1C,OAAO,CAACgD,IAAI,CAACpD,MAAM,CAAC;MAC7B;MAEA,IAAIV,UAAU,CAACwD,MAAM,CAAC7B,IAAI,EAAEgC,UAAU,CAAC,EAAE;QACvCH,MAAM,CAACrB,GAAG,CAAC,WAAW,EAAE1B,IAAI,CAAC;QAC7B,OAAO,CAACmD,MAAM,GAAG,MAAM,GAAG,QAAQ,EAAEJ,MAAM,CAAC;MAC7C;MAEAA,MAAM,CAACrB,GAAG,CACR,6DAA6D,EAC7DR,IAAI,EACJ6B,MAAM,EAAE7B,IACV,CAAC;MAED,OAAO,CAACiC,MAAM,GAAG,MAAM,GAAG,SAAS,EAAEJ,MAAM,CAACO,SAAS,CAACJ,UAAU,CAAC,CAAC;IACpE;IAEA,MAAMK,aAAa,GAAG,IAAIhD,UAAU,CAClCS,QAAQ,EACRf,MAAM,GAAG,CAACA,MAAM,CAAC,GAAG,EAAE,EACtBoC,UAAU,EACVrC,IAAI,EACJkD,UAAU,EACV/B,OAAO,EACPC,aAAa,EACbQ,SAAS,EACTmB,MAAM,IAAI,cAAc,IAAIA,MAAM,GAAGA,MAAM,CAACzB,YAAY,GAAGM,SAAS,EACpEmB,MAAM,IAAI,cAAc,IAAIA,MAAM,GAAGA,MAAM,CAACxB,YAAY,GAAGK,SAAS,EACpEmB,MAAM,GAAGA,MAAM,CAACvB,UAAU,GAAG,CAAC,GAAG,CACnC,CAAC;IAED,IACE,CAAC+B,aAAa,CAACrB,OAAO,IACtB,CAACqB,aAAa,CAACrC,IAAI,CAACf,QAAQ,CAAC,GAAG,CAAC,IACjC,CAACoD,aAAa,CAACrC,IAAI,CAACf,QAAQ,CAAC,aAAa,CAAC,IAC3C,CAACoD,aAAa,CAACrC,IAAI,CAACf,QAAQ,CAAC,aAAa,CAAC,EAC3C;MACA,MAAM;QAAEqD;MAAI,CAAC,GAAGD,aAAa,CAAClC,eAAe;MAE7C,IAAImC,GAAG,IAAI/D,6BAA6B,CAAC+D,GAAG,CAAC,EAAE;QAC7CD,aAAa,CAAC7B,GAAG,CACf,sEACF,CAAC;QACD6B,aAAa,CAACrC,IAAI,CAACuC,MAAM,GAAG,CAAC;QAC7BF,aAAa,CAACrC,IAAI,CAACmC,IAAI,CAAC,GAAG,CAAC;MAC9B;IACF;IAEA,IAAIN,MAAM,IAAI,CAACA,MAAM,CAACvC,SAAS,EAAE;MAC/BuC,MAAM,CAACrB,GAAG,CAAC,oCAAoC,CAAC;MAChDqB,MAAM,CAACO,SAAS,CAACC,aAAa,CAAC;IACjC;IAEA,OAAO,CAAC,SAAS,EAAEA,aAAa,CAAC;EACnC;EAEOG,aAAaA,CAACC,UAAiC,EAAQ;IAC5D,IAAI,CAACrC,YAAY,CAACsC,MAAM,CAACD,UAAU,CAACE,MAAM,CAAC;IAC3C,IAAI,CAACtC,YAAY,CAACuC,GAAG,CAACH,UAAU,CAACE,MAAM,EAAEF,UAAU,CAAC;EACtD;EAEOI,cAAcA,CACnB/D,IAAY,EACZ2D,UAA0C,EACpC;IACN,IAAI,CAACrC,YAAY,CAACwC,GAAG,CAAC9D,IAAI,EAAE2D,UAAU,CAAC;EACzC;EAEOK,mBAAmBA,CAAA,EAAG;IAC3B,IAAI,IAAI,CAACnD,cAAc,EAAE;MACvB,IAAI,CAACa,GAAG,CAAC,YAAY,CAAC;MACtB,MAAM,IAAI/B,UAAU,CAAC,YAAY,CAAC;IACpC;EACF;EAEOsE,iBAAiBA,CAAA,EAAG;IACzB,IAAI,IAAI,CAAC9B,eAAe,KAAK,IAAI,EAAE;MACjC,IAAI,CAACT,GAAG,CAAC,iBAAiB,CAAC;MAC3B,MAAM,IAAI7B,0BAA0B,CAAC,IAAI,CAACgB,cAAc,IAAI,IAAI,CAAC;IACnE;EACF;EAEOqD,YAAYA,CAIjBC,UAAiB,EACjBC,IAAqB,EACrBC,WAA+B,GAAG,IAAI,EACjB;IACrB,IAAI,CAAC,IAAI,CAAC3D,YAAY,CAAC4D,GAAG,CAACH,UAAU,CAAC,EAAE;MACtC,IAAI,CAACzD,YAAY,CAACoD,GAAG,CAACK,UAAU,EAAE,IAAIxD,GAAG,CAAC,CAAC,CAAC;IAC9C;IAEA,MAAMkB,KAAK,GAAG,IAAI,CAACnB,YAAY,CAACsC,GAAG,CAACmB,UAAU,CAAE;IAChD,MAAMpB,MAAM,GAAGlB,KAAK,CAACmB,GAAG,CAACoB,IAAI,CAAC;IAC9B,IAAIrB,MAAM,IAAI,CAACA,MAAM,CAACsB,WAAW,EAAEE,OAAO,EAAE;MAC1C,OAAOxB,MAAM;IACf;IAEA,MAAMyB,SAAS,GAAG,IAAI5E,UAAU,CAC9BuE,UAAU,EACV,IAAI,CAACnD,QAAQ,EACb,IAAI,EACJoD,IAAI,EACJC,WACF,CAAC;IAEDxC,KAAK,CAACiC,GAAG,CAACM,IAAI,EAAEI,SAAS,CAAC;IAE1B,IAAI,CAACxD,QAAQ,CAACwB,YAAY,CAACiC,eAAe,CAAC,IAAI,CAAC5B,KAAK,EAAE;MACrD6B,IAAI,EAAE,eAAe;MACrBP,UAAU;MACVQ,SAAS,EAAEH,SAAS,CAACI;IACvB,CAAC,CAAC;IAEF,OAAOJ,SAAS;EAClB;EAEOK,WAAWA,CAChB7E,IAAY,EACZkB,IAAc,EACdmB,UAAmB,EACE;IACrB,OAAO9B,UAAU,CAACgC,MAAM,CAAC,IAAI,CAACvB,QAAQ,EAAE,IAAI,EAAEhB,IAAI,EAAEkB,IAAI,EAAEmB,UAAU,CAAC;EACvE;EAEOyC,eAAeA,CAAA,EAAG;IACvB,MAAM1D,aAAa,GAAG5B,SAAS,CAAC,IAAI,CAAC4B,aAAa,EAAE,IAAI,CAACF,IAAI,CAAC;IAC9D,IAAI,CAACQ,GAAG,CAAC,mCAAmC,EAAEN,aAAa,CAAC;IAE5D,MAAMZ,SAAS,GAAG,IAAId,mBAAmB,CACvC,IAAI,CAACsB,QAAQ,EACbI,aAAa,EACb,IAAI,CAAC2D,YAAY,EACjB,IAAI,CAACvD,UAAU,GAAG,CAAC,EACnB,IAAI,CAACxB,IAAI,EACT,IAAI,CAACkB,IAAI,EACT,IAAI,CAACb,OAAO,EACZ,IAAI,CAACkB,YACP,CAAC;IAEDf,SAAS,CAACS,WAAW,GAAG,IAAI,CAACA,WAAW;IAExC,OAAOT,SAAS;EAClB;EAEOwE,aAAaA,CAAChF,IAAY,EAAqC;IACpE,OAAO,IAAI,CAACuB,YAAY,CAACyB,GAAG,CAAChD,IAAI,CAAC;EACpC;EAEOiF,cAAcA,CACnBjF,IAAY,EACgC;IAC5C,OAAO,IAAI,CAACsB,YAAY,CAAC0B,GAAG,CAAChD,IAAI,CAAC;EACpC;EAEOY,cAAcA,CAAA,EAAG;IACtB,OAAO,IAAI,CAAC,CAACA,cAAc;EAC7B;EAEOsE,WAAWA,CAACC,QAA6C,EAAE;IAChE,IAAI,IAAI,CAAC,CAACtE,cAAc,EAAE;MACxBsE,QAAQ,CAAC,IAAI,CAAC,CAACtE,cAAc,CAAC;MAC9B,OAAO,MAAM,CAAC,CAAC;IACjB;IAEA,IAAI,CAACJ,mBAAmB,CAAC4C,IAAI,CAAC8B,QAAQ,CAAC;IAEvC,OAAO,MAAM;MACX,MAAMC,KAAK,GAAG,IAAI,CAAC3E,mBAAmB,CAAC4E,OAAO,CAACF,QAAQ,CAAC;MACxD,IAAIC,KAAK,IAAI,CAAC,EAAE;QACd,IAAI,CAAC3E,mBAAmB,CAAC6E,MAAM,CAACF,KAAK,EAAE,CAAC,CAAC;MAC3C;IACF,CAAC;EACH;EAEOG,kBAAkBA,CAACC,GAAgC,EAAE;IAC1D,IAAI,CAAC,CAAC5E,cAAc,GAAG6E,OAAO,CAACD,GAAG,EAAEE,QAAQ,CAAC;IAC7C,IAAI,CAAC,CAAC5E,mBAAmB,GAAG0E,GAAG,EAAE7D,IAAI,IAAI,IAAI;IAE7C,IAAI,CAACX,QAAQ,CAACwB,YAAY,CAACiC,eAAe,CAAC,IAAI,CAAC5B,KAAK,EAAE;MACrD8C,MAAM,EAAEH,GAAG,KAAK,IAAI;MACpBd,IAAI,EAAE;IACR,CAAC,CAAC;EACJ;EAEQpB,SAASA,CAACsC,mBAA0C,EAAc;IACxE,MAAMrC,aAAa,GACjBqC,mBAAmB,YAAYrF,UAAU,GACrCqF,mBAAmB,GACnB,IAAIrF,UAAU,CACZ,IAAI,CAACS,QAAQ,EACb,IAAI,CAACX,OAAO,EACZ,IAAI,CAACY,WAAW,EAChB,IAAI,CAACjB,IAAI,EACT4F,mBAAmB,EACnB,IAAI,CAACzE,OAAO,EACZ,IAAI,CAACC,aAAa,EAClB,IAAI,CAACC,eAAe,EACpB,IAAI,CAACC,YAAY,EACjB,IAAI,CAACC,YAAY,EACjB,IAAI,CAACC,UAAU,GAAG,CACpB,CAAC;IAEP,IAAI,CAACR,QAAQ,CAACwB,YAAY,CAACiC,eAAe,CAAC,IAAI,CAAC5B,KAAK,EAAE;MACrD6B,IAAI,EAAE,YAAY;MAClBmB,IAAI,EAAEtC,aAAa,CAACV;IACtB,CAAC,CAAC;IACF,IAAI,CAACnB,GAAG,CACN,6BAA6B,EAC7B6B,aAAa,CAACvD,IAAI,EAClB,IAAI,CAACkB,IAAI,EACTqC,aAAa,CAACrC,IAChB,CAAC;IACD,IAAI,CAAC,CAACL,cAAc,GAAG0C,aAAa;IACpC,IAAI,CAAC9C,mBAAmB,CAACqF,OAAO,CAAEC,OAAO,IAAKA,OAAO,CAACxC,aAAa,CAAC,CAAC;IAErE,OAAOA,aAAa;EACtB;AACF","ignoreList":[]}
@@ -1 +1 @@
1
- {"version":3,"file":"EvaluatedEntrypoint.js","names":["BaseEntrypoint","EvaluatedEntrypoint","evaluated","ignored"],"sources":["../../src/transform/EvaluatedEntrypoint.ts"],"sourcesContent":["import type { Debugger } from '@wyw-in-js/shared';\n\nimport { BaseEntrypoint } from './BaseEntrypoint';\nimport type { IEntrypointDependency } from './Entrypoint.types';\n\nexport interface IEvaluatedEntrypoint {\n dependencies: Map<string, IEntrypointDependency>;\n evaluated: true;\n evaluatedOnly: string[];\n exports: Record<string | symbol, unknown>;\n generation: number;\n ignored: false;\n log: Debugger;\n only: string[];\n}\n\nexport class EvaluatedEntrypoint\n extends BaseEntrypoint\n implements IEvaluatedEntrypoint\n{\n public readonly evaluated = true;\n\n public readonly ignored = false;\n}\n"],"mappings":"AAEA,SAASA,cAAc,QAAQ,kBAAkB;AAcjD,OAAO,MAAMC,mBAAmB,SACtBD,cAAc,CAExB;EACkBE,SAAS,GAAG,IAAI;EAEhBC,OAAO,GAAG,KAAK;AACjC","ignoreList":[]}
1
+ {"version":3,"file":"EvaluatedEntrypoint.js","names":["BaseEntrypoint","EvaluatedEntrypoint","evaluated","ignored"],"sources":["../../src/transform/EvaluatedEntrypoint.ts"],"sourcesContent":["import type { Debugger } from '@wyw-in-js/shared';\n\nimport { BaseEntrypoint } from './BaseEntrypoint';\nimport type { IEntrypointDependency } from './Entrypoint.types';\n\nexport interface IEvaluatedEntrypoint {\n dependencies: Map<string, IEntrypointDependency>;\n evaluated: true;\n evaluatedOnly: string[];\n exports: Record<string | symbol, unknown>;\n generation: number;\n ignored: false;\n initialCode?: string;\n log: Debugger;\n only: string[];\n}\n\nexport class EvaluatedEntrypoint\n extends BaseEntrypoint\n implements IEvaluatedEntrypoint\n{\n public readonly evaluated = true;\n\n public readonly ignored = false;\n\n public initialCode?: string;\n}\n"],"mappings":"AAEA,SAASA,cAAc,QAAQ,kBAAkB;AAejD,OAAO,MAAMC,mBAAmB,SACtBD,cAAc,CAExB;EACkBE,SAAS,GAAG,IAAI;EAEhBC,OAAO,GAAG,KAAK;AAGjC","ignoreList":[]}
@@ -50,7 +50,7 @@ export class BaseAction {
50
50
  }
51
51
  run(handler) {
52
52
  if (this.handler && this.handler !== handler) {
53
- throw new Error(`action handler is already set`);
53
+ throw new Error(`action handler is already set for ${this.ref} (${this.entrypoint.name})`);
54
54
  }
55
55
  this.handler = handler;
56
56
  if (!this.activeScenario) {
@@ -1 +1 @@
1
- {"version":3,"file":"BaseAction.js","names":["Pending","actionIdx","BaseAction","result","activeScenario","activeScenarioNextResults","handler","constructor","type","services","entrypoint","data","abortSignal","idx","toString","padStart","log","extend","ref","createAbortSignal","abortController","AbortController","unsubscribeFromParentAbort","onAbort","abort","unsubscribeFromSupersede","onSupersede","signal","Symbol","dispose","getNext","fn","addEventListener","removeEventListener","run","Error","call","nextIdx","throwFn","e","emitAction","throw","nextFn","arg","next","processNextResult","onError","then","r","done","value","push","processError","length","nextResult","errorInGenerator","recover","activeScenarioError","processNext","rethrowActiveScenarioError","yieldIdx","eventEmitter","action"],"sources":["../../../src/transform/actions/BaseAction.ts"],"sourcesContent":["/* eslint-disable no-plusplus */\nimport '../../utils/dispose-polyfill';\nimport type { Debugger } from '@wyw-in-js/shared';\n\nimport type { Entrypoint } from '../Entrypoint';\nimport type {\n ActionQueueItem,\n ActionTypes,\n AnyIteratorResult,\n AsyncScenarioForAction,\n Handler,\n IBaseAction,\n Services,\n SyncScenarioForAction,\n TypeOfResult,\n YieldResult,\n} from '../types';\nimport { Pending } from '../types';\n\nlet actionIdx = 0;\n\nexport type ActionByType<TType extends ActionTypes> = Extract<\n ActionQueueItem,\n {\n type: TType;\n }\n>;\n\ntype GetBase<TAction extends ActionQueueItem> = IBaseAction<\n TAction,\n TypeOfResult<TAction>,\n TAction['data']\n>;\n\nexport class BaseAction<TAction extends ActionQueueItem>\n implements GetBase<TAction>\n{\n public readonly idx: string;\n\n public result: TypeOfResult<TAction> | typeof Pending = Pending;\n\n private activeScenario:\n | SyncScenarioForAction<TAction>\n | AsyncScenarioForAction<TAction>\n | null = null;\n\n private activeScenarioError?: unknown;\n\n private activeScenarioNextResults: AnyIteratorResult<\n 'async' | 'sync',\n TypeOfResult<TAction>\n >[] = [];\n\n private handler: null | unknown = null;\n\n public constructor(\n public readonly type: TAction['type'],\n public readonly services: Services,\n public readonly entrypoint: Entrypoint,\n public readonly data: TAction['data'],\n public readonly abortSignal: AbortSignal | null\n ) {\n actionIdx += 1;\n this.idx = actionIdx.toString(16).padStart(6, '0');\n }\n\n public get log(): Debugger {\n return this.entrypoint.log.extend(this.ref);\n }\n\n public get ref() {\n return `${this.type}@${this.idx}`;\n }\n\n public createAbortSignal(): AbortSignal & Disposable {\n const abortController = new AbortController();\n\n const unsubscribeFromParentAbort = this.onAbort(() => {\n this.entrypoint.log('parent aborted');\n abortController.abort();\n });\n\n const unsubscribeFromSupersede = this.entrypoint.onSupersede(() => {\n this.entrypoint.log('entrypoint superseded, aborting processing');\n abortController.abort();\n });\n\n const abortSignal = abortController.signal as AbortSignal & Disposable;\n abortSignal[Symbol.dispose] = () => {\n unsubscribeFromParentAbort();\n unsubscribeFromSupersede();\n };\n\n return abortSignal;\n }\n\n public *getNext<\n TNextType extends ActionTypes,\n TNextAction extends ActionByType<TNextType> = ActionByType<TNextType>,\n >(\n type: TNextType,\n entrypoint: Entrypoint,\n data: TNextAction['data'],\n abortSignal: AbortSignal | null = this.abortSignal\n ): Generator<\n [TNextType, Entrypoint, TNextAction['data'], AbortSignal | null],\n TypeOfResult<TNextAction>,\n YieldResult\n > {\n return (yield [\n type,\n entrypoint,\n data,\n abortSignal,\n ]) as TypeOfResult<TNextAction>;\n }\n\n public onAbort(fn: () => void): () => void {\n this.abortSignal?.addEventListener('abort', fn);\n\n return () => {\n this.abortSignal?.removeEventListener('abort', fn);\n };\n }\n\n public run<\n TMode extends 'async' | 'sync',\n THandler extends Handler<TMode, TAction> = Handler<TMode, TAction>,\n >(handler: THandler) {\n type IterationResult = AnyIteratorResult<TMode, TypeOfResult<TAction>>;\n\n if (this.handler && this.handler !== handler) {\n throw new Error(`action handler is already set`);\n }\n\n this.handler = handler;\n\n if (!this.activeScenario) {\n this.activeScenario = handler.call(this);\n this.activeScenarioNextResults = [];\n }\n\n let nextIdx = 0;\n\n const throwFn = (e: unknown) =>\n this.emitAction(nextIdx, () => this.activeScenario!.throw(e));\n\n const nextFn = (arg: YieldResult) =>\n this.emitAction(nextIdx, () => this.activeScenario!.next(arg));\n\n const processNextResult = (\n result: IterationResult,\n onError?: (e: unknown) => void\n ) => {\n if ('then' in result) {\n result.then((r) => {\n if (r.done) {\n this.result = r.value;\n }\n }, onError);\n } else if (result.done) {\n this.result = result.value;\n }\n\n this.activeScenarioNextResults.push(result);\n };\n\n const processError = (e: unknown) => {\n if (this.activeScenarioNextResults.length > nextIdx) {\n this.log(\n 'error was already handled in another branch, result idx is %d',\n nextIdx\n );\n return;\n }\n\n this.log('error processing, result idx is %d', nextIdx);\n\n try {\n const nextResult = throwFn(e);\n processNextResult(nextResult as IterationResult, processError);\n } catch (errorInGenerator) {\n const { recover } = handler;\n if (recover) {\n const nextResult = {\n done: false,\n value: recover(errorInGenerator, this),\n };\n\n processNextResult(nextResult as IterationResult, processError);\n return;\n }\n\n this.activeScenarioError = errorInGenerator;\n throw errorInGenerator;\n }\n };\n\n const processNext = (arg: YieldResult) => {\n if (this.activeScenarioNextResults.length > nextIdx) {\n this.log(\n 'next was already handled in another branch, result idx is %d',\n nextIdx\n );\n return;\n }\n\n this.log('next processing, result idx is %d', nextIdx);\n\n try {\n const nextResult = nextFn(arg);\n processNextResult(nextResult as IterationResult, processError);\n } catch (e) {\n processError(e);\n }\n };\n\n return {\n next: (arg: YieldResult): IterationResult => {\n this.rethrowActiveScenarioError();\n processNext(arg);\n return this.activeScenarioNextResults[nextIdx++] as IterationResult;\n },\n throw: (e: unknown): IterationResult => {\n this.rethrowActiveScenarioError();\n processError(e);\n return this.activeScenarioNextResults[nextIdx++] as IterationResult;\n },\n };\n }\n\n protected emitAction<TRes>(yieldIdx: number, fn: () => TRes) {\n return this.services.eventEmitter.action(\n this.type,\n `${this.idx}:${yieldIdx + 1}`,\n this.entrypoint.ref,\n fn\n );\n }\n\n private rethrowActiveScenarioError() {\n if (!this.activeScenarioError) {\n return;\n }\n\n this.log(\n 'scenario has an unhandled error from another branch, rethrow %o',\n this.activeScenarioError\n );\n\n // eslint-disable-next-line @typescript-eslint/no-throw-literal\n throw this.activeScenarioError;\n }\n}\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"BaseAction.js","names":["Pending","actionIdx","BaseAction","result","activeScenario","activeScenarioNextResults","handler","constructor","type","services","entrypoint","data","abortSignal","idx","toString","padStart","log","extend","ref","createAbortSignal","abortController","AbortController","unsubscribeFromParentAbort","onAbort","abort","unsubscribeFromSupersede","onSupersede","signal","Symbol","dispose","getNext","fn","addEventListener","removeEventListener","run","Error","name","call","nextIdx","throwFn","e","emitAction","throw","nextFn","arg","next","processNextResult","onError","then","r","done","value","push","processError","length","nextResult","errorInGenerator","recover","activeScenarioError","processNext","rethrowActiveScenarioError","yieldIdx","eventEmitter","action"],"sources":["../../../src/transform/actions/BaseAction.ts"],"sourcesContent":["/* eslint-disable no-plusplus */\nimport '../../utils/dispose-polyfill';\nimport type { Debugger } from '@wyw-in-js/shared';\n\nimport type { Entrypoint } from '../Entrypoint';\nimport type {\n ActionQueueItem,\n ActionTypes,\n AnyIteratorResult,\n AsyncScenarioForAction,\n Handler,\n IBaseAction,\n Services,\n SyncScenarioForAction,\n TypeOfResult,\n YieldResult,\n} from '../types';\nimport { Pending } from '../types';\n\nlet actionIdx = 0;\n\nexport type ActionByType<TType extends ActionTypes> = Extract<\n ActionQueueItem,\n {\n type: TType;\n }\n>;\n\ntype GetBase<TAction extends ActionQueueItem> = IBaseAction<\n TAction,\n TypeOfResult<TAction>,\n TAction['data']\n>;\n\nexport class BaseAction<TAction extends ActionQueueItem>\n implements GetBase<TAction>\n{\n public readonly idx: string;\n\n public result: TypeOfResult<TAction> | typeof Pending = Pending;\n\n private activeScenario:\n | SyncScenarioForAction<TAction>\n | AsyncScenarioForAction<TAction>\n | null = null;\n\n private activeScenarioError?: unknown;\n\n private activeScenarioNextResults: AnyIteratorResult<\n 'async' | 'sync',\n TypeOfResult<TAction>\n >[] = [];\n\n private handler: null | unknown = null;\n\n public constructor(\n public readonly type: TAction['type'],\n public readonly services: Services,\n public readonly entrypoint: Entrypoint,\n public readonly data: TAction['data'],\n public readonly abortSignal: AbortSignal | null\n ) {\n actionIdx += 1;\n this.idx = actionIdx.toString(16).padStart(6, '0');\n }\n\n public get log(): Debugger {\n return this.entrypoint.log.extend(this.ref);\n }\n\n public get ref() {\n return `${this.type}@${this.idx}`;\n }\n\n public createAbortSignal(): AbortSignal & Disposable {\n const abortController = new AbortController();\n\n const unsubscribeFromParentAbort = this.onAbort(() => {\n this.entrypoint.log('parent aborted');\n abortController.abort();\n });\n\n const unsubscribeFromSupersede = this.entrypoint.onSupersede(() => {\n this.entrypoint.log('entrypoint superseded, aborting processing');\n abortController.abort();\n });\n\n const abortSignal = abortController.signal as AbortSignal & Disposable;\n abortSignal[Symbol.dispose] = () => {\n unsubscribeFromParentAbort();\n unsubscribeFromSupersede();\n };\n\n return abortSignal;\n }\n\n public *getNext<\n TNextType extends ActionTypes,\n TNextAction extends ActionByType<TNextType> = ActionByType<TNextType>,\n >(\n type: TNextType,\n entrypoint: Entrypoint,\n data: TNextAction['data'],\n abortSignal: AbortSignal | null = this.abortSignal\n ): Generator<\n [TNextType, Entrypoint, TNextAction['data'], AbortSignal | null],\n TypeOfResult<TNextAction>,\n YieldResult\n > {\n return (yield [\n type,\n entrypoint,\n data,\n abortSignal,\n ]) as TypeOfResult<TNextAction>;\n }\n\n public onAbort(fn: () => void): () => void {\n this.abortSignal?.addEventListener('abort', fn);\n\n return () => {\n this.abortSignal?.removeEventListener('abort', fn);\n };\n }\n\n public run<\n TMode extends 'async' | 'sync',\n THandler extends Handler<TMode, TAction> = Handler<TMode, TAction>,\n >(handler: THandler) {\n type IterationResult = AnyIteratorResult<TMode, TypeOfResult<TAction>>;\n\n if (this.handler && this.handler !== handler) {\n throw new Error(\n `action handler is already set for ${this.ref} (${this.entrypoint.name})`\n );\n }\n\n this.handler = handler;\n\n if (!this.activeScenario) {\n this.activeScenario = handler.call(this);\n this.activeScenarioNextResults = [];\n }\n\n let nextIdx = 0;\n\n const throwFn = (e: unknown) =>\n this.emitAction(nextIdx, () => this.activeScenario!.throw(e));\n\n const nextFn = (arg: YieldResult) =>\n this.emitAction(nextIdx, () => this.activeScenario!.next(arg));\n\n const processNextResult = (\n result: IterationResult,\n onError?: (e: unknown) => void\n ) => {\n if ('then' in result) {\n result.then((r) => {\n if (r.done) {\n this.result = r.value;\n }\n }, onError);\n } else if (result.done) {\n this.result = result.value;\n }\n\n this.activeScenarioNextResults.push(result);\n };\n\n const processError = (e: unknown) => {\n if (this.activeScenarioNextResults.length > nextIdx) {\n this.log(\n 'error was already handled in another branch, result idx is %d',\n nextIdx\n );\n return;\n }\n\n this.log('error processing, result idx is %d', nextIdx);\n\n try {\n const nextResult = throwFn(e);\n processNextResult(nextResult as IterationResult, processError);\n } catch (errorInGenerator) {\n const { recover } = handler;\n if (recover) {\n const nextResult = {\n done: false,\n value: recover(errorInGenerator, this),\n };\n\n processNextResult(nextResult as IterationResult, processError);\n return;\n }\n\n this.activeScenarioError = errorInGenerator;\n throw errorInGenerator;\n }\n };\n\n const processNext = (arg: YieldResult) => {\n if (this.activeScenarioNextResults.length > nextIdx) {\n this.log(\n 'next was already handled in another branch, result idx is %d',\n nextIdx\n );\n return;\n }\n\n this.log('next processing, result idx is %d', nextIdx);\n\n try {\n const nextResult = nextFn(arg);\n processNextResult(nextResult as IterationResult, processError);\n } catch (e) {\n processError(e);\n }\n };\n\n return {\n next: (arg: YieldResult): IterationResult => {\n this.rethrowActiveScenarioError();\n processNext(arg);\n return this.activeScenarioNextResults[nextIdx++] as IterationResult;\n },\n throw: (e: unknown): IterationResult => {\n this.rethrowActiveScenarioError();\n processError(e);\n return this.activeScenarioNextResults[nextIdx++] as IterationResult;\n },\n };\n }\n\n protected emitAction<TRes>(yieldIdx: number, fn: () => TRes) {\n return this.services.eventEmitter.action(\n this.type,\n `${this.idx}:${yieldIdx + 1}`,\n this.entrypoint.ref,\n fn\n );\n }\n\n private rethrowActiveScenarioError() {\n if (!this.activeScenarioError) {\n return;\n }\n\n this.log(\n 'scenario has an unhandled error from another branch, rethrow %o',\n this.activeScenarioError\n );\n\n // eslint-disable-next-line @typescript-eslint/no-throw-literal\n throw this.activeScenarioError;\n }\n}\n"],"mappings":"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","ignoreList":[]}
@@ -1,9 +1,43 @@
1
1
  /* eslint-disable no-continue */
2
2
 
3
+ import { toImportKey } from '../../utils/importOverrides';
4
+ const warnedSlowImportsByServices = new WeakMap();
5
+ function emitWarning(services, message) {
6
+ if (services.emitWarning) {
7
+ services.emitWarning(message);
8
+ return;
9
+ }
10
+
11
+ // eslint-disable-next-line no-console
12
+ console.warn(message);
13
+ }
14
+ function getWarnedSlowImports(services) {
15
+ const cached = warnedSlowImportsByServices.get(services);
16
+ if (cached) return cached;
17
+ const created = new Set();
18
+ warnedSlowImportsByServices.set(services, created);
19
+ return created;
20
+ }
21
+ function isWarningEnabled(value) {
22
+ return Boolean(value) && value !== '0' && value !== 'false';
23
+ }
24
+
3
25
  /**
4
26
  * Creates new entrypoints and emits processEntrypoint for each resolved import
5
27
  */
6
28
  export function* processImports() {
29
+ const slowImportWarningsEnabled = isWarningEnabled(process.env.WYW_WARN_SLOW_IMPORTS);
30
+ const slowImportThresholdMs = (() => {
31
+ const raw = process.env.WYW_WARN_SLOW_IMPORTS_MS;
32
+ if (!raw) return 50;
33
+ const parsed = Number(raw);
34
+ if (!Number.isFinite(parsed)) return 50;
35
+ return parsed;
36
+ })();
37
+ const warnedSlowImports = slowImportWarningsEnabled ? getWarnedSlowImports(this.services) : null;
38
+ const {
39
+ root
40
+ } = this.services.options;
7
41
  for (const dependency of this.data.resolved) {
8
42
  const {
9
43
  resolved,
@@ -17,7 +51,26 @@ export function* processImports() {
17
51
  if (nextEntrypoint === 'loop' || nextEntrypoint.ignored) {
18
52
  continue;
19
53
  }
54
+ const startedAt = slowImportWarningsEnabled ? performance.now() : 0;
20
55
  yield* this.getNext('processEntrypoint', nextEntrypoint, undefined, null);
56
+ if (slowImportWarningsEnabled && warnedSlowImports && slowImportThresholdMs > 0) {
57
+ const durationMs = performance.now() - startedAt;
58
+ if (durationMs >= slowImportThresholdMs) {
59
+ const {
60
+ key: importKey
61
+ } = toImportKey({
62
+ source: dependency.source,
63
+ resolved,
64
+ root
65
+ });
66
+ const dedupeKey = `${this.entrypoint.name}::${importKey}`;
67
+ if (!warnedSlowImports.has(dedupeKey)) {
68
+ warnedSlowImports.add(dedupeKey);
69
+ const warning = [`[wyw-in-js] Slow import during prepare stage`, ``, `file: ${this.entrypoint.name}`, `import: ${dependency.source}`, `resolved: ${resolved}`, `duration: ${durationMs.toFixed(1)}ms`, ``, `tip: if this import is runtime-only or heavy, mock it during evaluation via importOverrides:`, ` importOverrides: {`, ` '${importKey}': { mock: './path/to/mock' },`, ` }`, ``, `note: importOverrides affects only build-time evaluation (it does not change your bundler runtime behavior)`, ``, `note: configure threshold with WYW_WARN_SLOW_IMPORTS_MS (current: ${slowImportThresholdMs}ms)`].join('\n');
70
+ emitWarning(this.services, warning);
71
+ }
72
+ }
73
+ }
21
74
  }
22
75
  }
23
76
  //# sourceMappingURL=processImports.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"processImports.js","names":["processImports","dependency","data","resolved","only","entrypoint","addDependency","nextEntrypoint","createChild","ignored","getNext","undefined"],"sources":["../../../src/transform/generators/processImports.ts"],"sourcesContent":["/* eslint-disable no-continue */\nimport type { IProcessImportsAction, SyncScenarioForAction } from '../types';\n\n/**\n * Creates new entrypoints and emits processEntrypoint for each resolved import\n */\nexport function* processImports(\n this: IProcessImportsAction\n): SyncScenarioForAction<IProcessImportsAction> {\n for (const dependency of this.data.resolved) {\n const { resolved, only } = dependency;\n if (!resolved) {\n continue;\n }\n\n this.entrypoint.addDependency(dependency);\n\n const nextEntrypoint = this.entrypoint.createChild(resolved, only);\n if (nextEntrypoint === 'loop' || nextEntrypoint.ignored) {\n continue;\n }\n\n yield* this.getNext('processEntrypoint', nextEntrypoint, undefined, null);\n }\n}\n"],"mappings":"AAAA;;AAGA;AACA;AACA;AACA,OAAO,UAAUA,cAAcA,CAAA,EAEiB;EAC9C,KAAK,MAAMC,UAAU,IAAI,IAAI,CAACC,IAAI,CAACC,QAAQ,EAAE;IAC3C,MAAM;MAAEA,QAAQ;MAAEC;IAAK,CAAC,GAAGH,UAAU;IACrC,IAAI,CAACE,QAAQ,EAAE;MACb;IACF;IAEA,IAAI,CAACE,UAAU,CAACC,aAAa,CAACL,UAAU,CAAC;IAEzC,MAAMM,cAAc,GAAG,IAAI,CAACF,UAAU,CAACG,WAAW,CAACL,QAAQ,EAAEC,IAAI,CAAC;IAClE,IAAIG,cAAc,KAAK,MAAM,IAAIA,cAAc,CAACE,OAAO,EAAE;MACvD;IACF;IAEA,OAAO,IAAI,CAACC,OAAO,CAAC,mBAAmB,EAAEH,cAAc,EAAEI,SAAS,EAAE,IAAI,CAAC;EAC3E;AACF","ignoreList":[]}
1
+ {"version":3,"file":"processImports.js","names":["toImportKey","warnedSlowImportsByServices","WeakMap","emitWarning","services","message","console","warn","getWarnedSlowImports","cached","get","created","Set","set","isWarningEnabled","value","Boolean","processImports","slowImportWarningsEnabled","process","env","WYW_WARN_SLOW_IMPORTS","slowImportThresholdMs","raw","WYW_WARN_SLOW_IMPORTS_MS","parsed","Number","isFinite","warnedSlowImports","root","options","dependency","data","resolved","only","entrypoint","addDependency","nextEntrypoint","createChild","ignored","startedAt","performance","now","getNext","undefined","durationMs","key","importKey","source","dedupeKey","name","has","add","warning","toFixed","join"],"sources":["../../../src/transform/generators/processImports.ts"],"sourcesContent":["/* eslint-disable no-continue */\nimport type {\n IProcessImportsAction,\n Services,\n SyncScenarioForAction,\n} from '../types';\n\nimport { toImportKey } from '../../utils/importOverrides';\n\nconst warnedSlowImportsByServices = new WeakMap<Services, Set<string>>();\n\nfunction emitWarning(services: Services, message: string) {\n if (services.emitWarning) {\n services.emitWarning(message);\n return;\n }\n\n // eslint-disable-next-line no-console\n console.warn(message);\n}\n\nfunction getWarnedSlowImports(services: Services): Set<string> {\n const cached = warnedSlowImportsByServices.get(services);\n if (cached) return cached;\n\n const created = new Set<string>();\n warnedSlowImportsByServices.set(services, created);\n return created;\n}\n\nfunction isWarningEnabled(value: string | undefined): boolean {\n return Boolean(value) && value !== '0' && value !== 'false';\n}\n\n/**\n * Creates new entrypoints and emits processEntrypoint for each resolved import\n */\nexport function* processImports(\n this: IProcessImportsAction\n): SyncScenarioForAction<IProcessImportsAction> {\n const slowImportWarningsEnabled = isWarningEnabled(\n process.env.WYW_WARN_SLOW_IMPORTS\n );\n const slowImportThresholdMs = (() => {\n const raw = process.env.WYW_WARN_SLOW_IMPORTS_MS;\n if (!raw) return 50;\n\n const parsed = Number(raw);\n if (!Number.isFinite(parsed)) return 50;\n return parsed;\n })();\n\n const warnedSlowImports = slowImportWarningsEnabled\n ? getWarnedSlowImports(this.services)\n : null;\n\n const { root } = this.services.options;\n\n for (const dependency of this.data.resolved) {\n const { resolved, only } = dependency;\n if (!resolved) {\n continue;\n }\n\n this.entrypoint.addDependency(dependency);\n\n const nextEntrypoint = this.entrypoint.createChild(resolved, only);\n if (nextEntrypoint === 'loop' || nextEntrypoint.ignored) {\n continue;\n }\n\n const startedAt = slowImportWarningsEnabled ? performance.now() : 0;\n yield* this.getNext('processEntrypoint', nextEntrypoint, undefined, null);\n\n if (\n slowImportWarningsEnabled &&\n warnedSlowImports &&\n slowImportThresholdMs > 0\n ) {\n const durationMs = performance.now() - startedAt;\n if (durationMs >= slowImportThresholdMs) {\n const { key: importKey } = toImportKey({\n source: dependency.source,\n resolved,\n root,\n });\n const dedupeKey = `${this.entrypoint.name}::${importKey}`;\n\n if (!warnedSlowImports.has(dedupeKey)) {\n warnedSlowImports.add(dedupeKey);\n\n const warning = [\n `[wyw-in-js] Slow import during prepare stage`,\n ``,\n `file: ${this.entrypoint.name}`,\n `import: ${dependency.source}`,\n `resolved: ${resolved}`,\n `duration: ${durationMs.toFixed(1)}ms`,\n ``,\n `tip: if this import is runtime-only or heavy, mock it during evaluation via importOverrides:`,\n ` importOverrides: {`,\n ` '${importKey}': { mock: './path/to/mock' },`,\n ` }`,\n ``,\n `note: importOverrides affects only build-time evaluation (it does not change your bundler runtime behavior)`,\n ``,\n `note: configure threshold with WYW_WARN_SLOW_IMPORTS_MS (current: ${slowImportThresholdMs}ms)`,\n ].join('\\n');\n\n emitWarning(this.services, warning);\n }\n }\n }\n }\n}\n"],"mappings":"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","ignoreList":[]}
@@ -1,7 +1,7 @@
1
1
  /* eslint-disable no-continue,no-await-in-loop,require-yield */
2
2
  import { getFileIdx } from '../../utils/getFileIdx';
3
3
  import { getStack, isSuperSet, mergeOnly } from '../Entrypoint.helpers';
4
- import { applyImportOverrideToOnly, resolveMockSpecifier, toImportKey } from '../../utils/importOverrides';
4
+ import { applyImportOverrideToOnly, getImportOverride, resolveMockSpecifier, toImportKey } from '../../utils/importOverrides';
5
5
  function applyImportOverrides(services, entrypoint, resolvedImports) {
6
6
  const overrides = services.options.pluginOptions.importOverrides;
7
7
  if (!overrides || Object.keys(overrides).length === 0) {
@@ -20,7 +20,7 @@ function applyImportOverrides(services, entrypoint, resolvedImports) {
20
20
  resolved: dependency.resolved,
21
21
  root
22
22
  });
23
- const override = overrides[key];
23
+ const override = getImportOverride(overrides, key);
24
24
  if (!override) {
25
25
  return dependency;
26
26
  }
@@ -1 +1 @@
1
- {"version":3,"file":"resolveImports.js","names":["getFileIdx","getStack","isSuperSet","mergeOnly","applyImportOverrideToOnly","resolveMockSpecifier","toImportKey","applyImportOverrides","services","entrypoint","resolvedImports","overrides","options","pluginOptions","importOverrides","Object","keys","length","root","importer","name","stack","map","dependency","key","source","resolved","override","nextOnly","only","nextResolved","mock","emitDependency","emitter","imports","single","type","file","from","what","fileIdx","filterUnresolved","filter","i","log","syncResolveImports","resolve","data","eventEmitter","listOfImports","Array","entries","err","overriddenImports","filteredImports","asyncResolveImports","getResolveTask","Promise","all","importsOnly","cached","getDependency","task","newTask","then","res","merged","addResolveTask","resolveTask"],"sources":["../../../src/transform/generators/resolveImports.ts"],"sourcesContent":["/* eslint-disable no-continue,no-await-in-loop,require-yield */\nimport { getFileIdx } from '../../utils/getFileIdx';\nimport type { Entrypoint } from '../Entrypoint';\nimport { getStack, isSuperSet, mergeOnly } from '../Entrypoint.helpers';\nimport type { IEntrypointDependency } from '../Entrypoint.types';\nimport {\n applyImportOverrideToOnly,\n resolveMockSpecifier,\n toImportKey,\n} from '../../utils/importOverrides';\nimport type {\n AsyncScenarioForAction,\n IResolveImportsAction,\n Services,\n SyncScenarioForAction,\n} from '../types';\n\nfunction applyImportOverrides(\n services: Services,\n entrypoint: Entrypoint,\n resolvedImports: IEntrypointDependency[]\n): IEntrypointDependency[] {\n const overrides = services.options.pluginOptions.importOverrides;\n if (!overrides || Object.keys(overrides).length === 0) {\n return resolvedImports;\n }\n\n const { root } = services.options;\n const importer = entrypoint.name;\n const stack = getStack(entrypoint);\n\n return resolvedImports.map((dependency) => {\n const { key } = toImportKey({\n source: dependency.source,\n resolved: dependency.resolved,\n root,\n });\n const override = overrides[key];\n if (!override) {\n return dependency;\n }\n\n const nextOnly = applyImportOverrideToOnly(dependency.only, override);\n const nextResolved = override.mock\n ? resolveMockSpecifier({\n mock: override.mock,\n importer,\n root,\n stack,\n })\n : dependency.resolved;\n\n return {\n ...dependency,\n only: nextOnly,\n resolved: nextResolved,\n };\n });\n}\n\nfunction emitDependency(\n emitter: Services['eventEmitter'],\n entrypoint: IResolveImportsAction['entrypoint'],\n imports: IEntrypointDependency[]\n) {\n emitter.single({\n type: 'dependency',\n file: entrypoint.name,\n only: entrypoint.only,\n imports: imports.map(({ resolved, only }) => ({\n from: resolved,\n what: only,\n })),\n fileIdx: getFileIdx(entrypoint.name),\n });\n}\n\nfunction filterUnresolved(\n entrypoint: Entrypoint,\n resolvedImports: IEntrypointDependency[]\n): IEntrypointDependency[] {\n return resolvedImports.filter((i): i is IEntrypointDependency => {\n if (i.resolved === null) {\n entrypoint.log(\n `[resolve] ✅ %s in %s is ignored`,\n i.source,\n entrypoint.name\n );\n return false;\n }\n\n return true;\n });\n}\n\n/**\n * Synchronously resolves specified imports with a provided resolver.\n */\nexport function* syncResolveImports(\n this: IResolveImportsAction,\n resolve: (what: string, importer: string, stack: string[]) => string\n): SyncScenarioForAction<IResolveImportsAction> {\n const {\n data: { imports },\n entrypoint,\n services: { eventEmitter },\n } = this;\n const listOfImports = Array.from(imports?.entries() ?? []);\n const { log } = entrypoint;\n\n if (listOfImports.length === 0) {\n emitDependency(eventEmitter, entrypoint, []);\n\n log('%s has no imports', entrypoint.name);\n return [];\n }\n\n const resolvedImports = listOfImports.map(([source, only]) => {\n let resolved: string | null = null;\n try {\n resolved = resolve(source, entrypoint.name, getStack(entrypoint));\n log('[sync-resolve] ✅ %s -> %s (only: %o)', source, resolved, only);\n } catch (err) {\n log('[sync-resolve] ❌ cannot resolve %s: %O', source, err);\n }\n\n return {\n source,\n only,\n resolved,\n };\n });\n\n const overriddenImports = applyImportOverrides(\n this.services,\n entrypoint,\n resolvedImports\n );\n const filteredImports = filterUnresolved(entrypoint, overriddenImports);\n emitDependency(eventEmitter, entrypoint, filteredImports);\n\n return filteredImports;\n}\n\n/**\n * Asynchronously resolves specified imports with a provided resolver.\n */\nexport async function* asyncResolveImports(\n this: IResolveImportsAction,\n resolve: (\n what: string,\n importer: string,\n stack: string[]\n ) => Promise<string | null>\n): AsyncScenarioForAction<IResolveImportsAction> {\n const {\n data: { imports },\n entrypoint,\n services: { eventEmitter },\n } = this;\n const listOfImports = Array.from(imports?.entries() ?? []);\n const { log } = entrypoint;\n\n if (listOfImports.length === 0) {\n emitDependency(eventEmitter, entrypoint, []);\n\n log('%s has no imports', entrypoint.name);\n return [];\n }\n\n log('resolving %d imports', listOfImports.length);\n\n const getResolveTask = async (\n source: string,\n only: string[]\n ): Promise<IEntrypointDependency> => {\n let resolved: string | null = null;\n try {\n resolved = await resolve(source, entrypoint.name, getStack(entrypoint));\n } catch (err) {\n log(\n '[async-resolve] ❌ cannot resolve %s in %s: %O',\n source,\n entrypoint.name,\n err\n );\n }\n\n if (resolved !== null) {\n log(\n '[async-resolve] ✅ %s (%o) in %s -> %s',\n source,\n only,\n entrypoint.name,\n resolved\n );\n }\n\n return {\n source,\n only,\n resolved,\n };\n };\n\n const resolvedImports = await Promise.all<IEntrypointDependency>(\n listOfImports.map(([source, importsOnly]) => {\n const cached = entrypoint.getDependency(source);\n if (cached) {\n return {\n source,\n only: mergeOnly(cached.only, importsOnly),\n resolved: cached.resolved,\n };\n }\n\n const task = entrypoint.getResolveTask(source);\n if (task) {\n // If we have cached task, we need to merge only…\n const newTask = task.then((res) => {\n if (isSuperSet(res.only, importsOnly)) {\n return res;\n }\n\n // Is this branch even possible?\n const merged = mergeOnly(res.only, importsOnly);\n\n log('merging imports %o and %o: %o', importsOnly, res.only, merged);\n\n return { ...res, only: merged };\n });\n\n // … and update the cache\n entrypoint.addResolveTask(source, newTask);\n return newTask;\n }\n\n const resolveTask = getResolveTask(source, importsOnly);\n\n entrypoint.addResolveTask(source, resolveTask);\n\n return resolveTask;\n })\n );\n\n log('resolved %d imports', resolvedImports.length);\n\n const overriddenImports = applyImportOverrides(\n this.services,\n entrypoint,\n resolvedImports\n );\n const filteredImports = filterUnresolved(entrypoint, overriddenImports);\n emitDependency(eventEmitter, entrypoint, filteredImports);\n return filteredImports;\n}\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"resolveImports.js","names":["getFileIdx","getStack","isSuperSet","mergeOnly","applyImportOverrideToOnly","getImportOverride","resolveMockSpecifier","toImportKey","applyImportOverrides","services","entrypoint","resolvedImports","overrides","options","pluginOptions","importOverrides","Object","keys","length","root","importer","name","stack","map","dependency","key","source","resolved","override","nextOnly","only","nextResolved","mock","emitDependency","emitter","imports","single","type","file","from","what","fileIdx","filterUnresolved","filter","i","log","syncResolveImports","resolve","data","eventEmitter","listOfImports","Array","entries","err","overriddenImports","filteredImports","asyncResolveImports","getResolveTask","Promise","all","importsOnly","cached","getDependency","task","newTask","then","res","merged","addResolveTask","resolveTask"],"sources":["../../../src/transform/generators/resolveImports.ts"],"sourcesContent":["/* eslint-disable no-continue,no-await-in-loop,require-yield */\nimport { getFileIdx } from '../../utils/getFileIdx';\nimport type { Entrypoint } from '../Entrypoint';\nimport { getStack, isSuperSet, mergeOnly } from '../Entrypoint.helpers';\nimport type { IEntrypointDependency } from '../Entrypoint.types';\nimport {\n applyImportOverrideToOnly,\n getImportOverride,\n resolveMockSpecifier,\n toImportKey,\n} from '../../utils/importOverrides';\nimport type {\n AsyncScenarioForAction,\n IResolveImportsAction,\n Services,\n SyncScenarioForAction,\n} from '../types';\n\nfunction applyImportOverrides(\n services: Services,\n entrypoint: Entrypoint,\n resolvedImports: IEntrypointDependency[]\n): IEntrypointDependency[] {\n const overrides = services.options.pluginOptions.importOverrides;\n if (!overrides || Object.keys(overrides).length === 0) {\n return resolvedImports;\n }\n\n const { root } = services.options;\n const importer = entrypoint.name;\n const stack = getStack(entrypoint);\n\n return resolvedImports.map((dependency) => {\n const { key } = toImportKey({\n source: dependency.source,\n resolved: dependency.resolved,\n root,\n });\n const override = getImportOverride(overrides, key);\n if (!override) {\n return dependency;\n }\n\n const nextOnly = applyImportOverrideToOnly(dependency.only, override);\n const nextResolved = override.mock\n ? resolveMockSpecifier({\n mock: override.mock,\n importer,\n root,\n stack,\n })\n : dependency.resolved;\n\n return {\n ...dependency,\n only: nextOnly,\n resolved: nextResolved,\n };\n });\n}\n\nfunction emitDependency(\n emitter: Services['eventEmitter'],\n entrypoint: IResolveImportsAction['entrypoint'],\n imports: IEntrypointDependency[]\n) {\n emitter.single({\n type: 'dependency',\n file: entrypoint.name,\n only: entrypoint.only,\n imports: imports.map(({ resolved, only }) => ({\n from: resolved,\n what: only,\n })),\n fileIdx: getFileIdx(entrypoint.name),\n });\n}\n\nfunction filterUnresolved(\n entrypoint: Entrypoint,\n resolvedImports: IEntrypointDependency[]\n): IEntrypointDependency[] {\n return resolvedImports.filter((i): i is IEntrypointDependency => {\n if (i.resolved === null) {\n entrypoint.log(\n `[resolve] ✅ %s in %s is ignored`,\n i.source,\n entrypoint.name\n );\n return false;\n }\n\n return true;\n });\n}\n\n/**\n * Synchronously resolves specified imports with a provided resolver.\n */\nexport function* syncResolveImports(\n this: IResolveImportsAction,\n resolve: (what: string, importer: string, stack: string[]) => string\n): SyncScenarioForAction<IResolveImportsAction> {\n const {\n data: { imports },\n entrypoint,\n services: { eventEmitter },\n } = this;\n const listOfImports = Array.from(imports?.entries() ?? []);\n const { log } = entrypoint;\n\n if (listOfImports.length === 0) {\n emitDependency(eventEmitter, entrypoint, []);\n\n log('%s has no imports', entrypoint.name);\n return [];\n }\n\n const resolvedImports = listOfImports.map(([source, only]) => {\n let resolved: string | null = null;\n try {\n resolved = resolve(source, entrypoint.name, getStack(entrypoint));\n log('[sync-resolve] ✅ %s -> %s (only: %o)', source, resolved, only);\n } catch (err) {\n log('[sync-resolve] ❌ cannot resolve %s: %O', source, err);\n }\n\n return {\n source,\n only,\n resolved,\n };\n });\n\n const overriddenImports = applyImportOverrides(\n this.services,\n entrypoint,\n resolvedImports\n );\n const filteredImports = filterUnresolved(entrypoint, overriddenImports);\n emitDependency(eventEmitter, entrypoint, filteredImports);\n\n return filteredImports;\n}\n\n/**\n * Asynchronously resolves specified imports with a provided resolver.\n */\nexport async function* asyncResolveImports(\n this: IResolveImportsAction,\n resolve: (\n what: string,\n importer: string,\n stack: string[]\n ) => Promise<string | null>\n): AsyncScenarioForAction<IResolveImportsAction> {\n const {\n data: { imports },\n entrypoint,\n services: { eventEmitter },\n } = this;\n const listOfImports = Array.from(imports?.entries() ?? []);\n const { log } = entrypoint;\n\n if (listOfImports.length === 0) {\n emitDependency(eventEmitter, entrypoint, []);\n\n log('%s has no imports', entrypoint.name);\n return [];\n }\n\n log('resolving %d imports', listOfImports.length);\n\n const getResolveTask = async (\n source: string,\n only: string[]\n ): Promise<IEntrypointDependency> => {\n let resolved: string | null = null;\n try {\n resolved = await resolve(source, entrypoint.name, getStack(entrypoint));\n } catch (err) {\n log(\n '[async-resolve] ❌ cannot resolve %s in %s: %O',\n source,\n entrypoint.name,\n err\n );\n }\n\n if (resolved !== null) {\n log(\n '[async-resolve] ✅ %s (%o) in %s -> %s',\n source,\n only,\n entrypoint.name,\n resolved\n );\n }\n\n return {\n source,\n only,\n resolved,\n };\n };\n\n const resolvedImports = await Promise.all<IEntrypointDependency>(\n listOfImports.map(([source, importsOnly]) => {\n const cached = entrypoint.getDependency(source);\n if (cached) {\n return {\n source,\n only: mergeOnly(cached.only, importsOnly),\n resolved: cached.resolved,\n };\n }\n\n const task = entrypoint.getResolveTask(source);\n if (task) {\n // If we have cached task, we need to merge only…\n const newTask = task.then((res) => {\n if (isSuperSet(res.only, importsOnly)) {\n return res;\n }\n\n // Is this branch even possible?\n const merged = mergeOnly(res.only, importsOnly);\n\n log('merging imports %o and %o: %o', importsOnly, res.only, merged);\n\n return { ...res, only: merged };\n });\n\n // … and update the cache\n entrypoint.addResolveTask(source, newTask);\n return newTask;\n }\n\n const resolveTask = getResolveTask(source, importsOnly);\n\n entrypoint.addResolveTask(source, resolveTask);\n\n return resolveTask;\n })\n );\n\n log('resolved %d imports', resolvedImports.length);\n\n const overriddenImports = applyImportOverrides(\n this.services,\n entrypoint,\n resolvedImports\n );\n const filteredImports = filterUnresolved(entrypoint, overriddenImports);\n emitDependency(eventEmitter, entrypoint, filteredImports);\n return filteredImports;\n}\n"],"mappings":"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","ignoreList":[]}
@@ -1,5 +1,6 @@
1
1
  import path from 'path';
2
2
  import { syncResolve } from '@wyw-in-js/shared';
3
+ import { Minimatch } from 'minimatch';
3
4
  export function toCanonicalFileKey(resolved, root) {
4
5
  const rootDir = root ? path.resolve(root) : process.cwd();
5
6
  const normalizedResolved = path.resolve(resolved);
@@ -44,4 +45,63 @@ export function applyImportOverrideToOnly(only, override) {
44
45
  }
45
46
  return only;
46
47
  }
48
+ const compiledImportOverridesCache = new WeakMap();
49
+ const minimatchOptions = {
50
+ dot: true,
51
+ nocomment: true,
52
+ nonegate: true
53
+ };
54
+ function getPatternSpecificity(pattern) {
55
+ let wildcardCount = 0;
56
+ let escaped = false;
57
+ for (const char of pattern) {
58
+ if (escaped) {
59
+ escaped = false;
60
+ } else if (char === '\\') {
61
+ escaped = true;
62
+ } else if (char === '*' || char === '?') {
63
+ wildcardCount += 1;
64
+ }
65
+ }
66
+ return pattern.length - wildcardCount * 10;
67
+ }
68
+ function compileImportOverrides(importOverrides) {
69
+ const matchers = Object.entries(importOverrides).map(([pattern, override]) => {
70
+ return {
71
+ matcher: new Minimatch(pattern, minimatchOptions),
72
+ override,
73
+ pattern,
74
+ specificity: getPatternSpecificity(pattern)
75
+ };
76
+ }).sort((a, b) => {
77
+ const bySpecificity = b.specificity - a.specificity;
78
+ if (bySpecificity !== 0) return bySpecificity;
79
+ const byLength = b.pattern.length - a.pattern.length;
80
+ if (byLength !== 0) return byLength;
81
+ return a.pattern.localeCompare(b.pattern);
82
+ });
83
+ return {
84
+ matchers
85
+ };
86
+ }
87
+ function getCompiledImportOverrides(importOverrides) {
88
+ const cached = compiledImportOverridesCache.get(importOverrides);
89
+ if (cached) return cached;
90
+ const compiled = compileImportOverrides(importOverrides);
91
+ compiledImportOverridesCache.set(importOverrides, compiled);
92
+ return compiled;
93
+ }
94
+ export function getImportOverride(importOverrides, key) {
95
+ if (!importOverrides) {
96
+ return undefined;
97
+ }
98
+ const direct = importOverrides[key];
99
+ if (direct) return direct;
100
+ const {
101
+ matchers
102
+ } = getCompiledImportOverrides(importOverrides);
103
+ return matchers.find(({
104
+ matcher
105
+ }) => matcher.match(key))?.override;
106
+ }
47
107
  //# sourceMappingURL=importOverrides.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"importOverrides.js","names":["path","syncResolve","toCanonicalFileKey","resolved","root","rootDir","resolve","process","cwd","normalizedResolved","relative","sep","posix","split","join","startsWith","toImportKey","source","isFileImport","isAbsolute","key","kind","resolveMockSpecifier","importer","mock","stack","specifier","applyImportOverrideToOnly","only","override","noShake"],"sources":["../../src/utils/importOverrides.ts"],"sourcesContent":["import path from 'path';\n\nimport { syncResolve, type ImportOverride } from '@wyw-in-js/shared';\n\nexport type ImportKeyKind = 'file' | 'package';\n\nexport type ImportKey = {\n key: string;\n kind: ImportKeyKind;\n};\n\nexport function toCanonicalFileKey(\n resolved: string,\n root: string | undefined\n): string {\n const rootDir = root ? path.resolve(root) : process.cwd();\n const normalizedResolved = path.resolve(resolved);\n let relative = path.relative(rootDir, normalizedResolved);\n\n if (path.sep !== path.posix.sep) {\n relative = relative.split(path.sep).join(path.posix.sep);\n }\n\n if (!relative.startsWith('.')) {\n relative = `./${relative}`;\n }\n\n return relative;\n}\n\nexport function toImportKey({\n source,\n resolved,\n root,\n}: {\n resolved: string | null;\n root: string | undefined;\n source: string;\n}): ImportKey {\n const isFileImport = source.startsWith('.') || path.isAbsolute(source);\n\n if (isFileImport && resolved) {\n return { key: toCanonicalFileKey(resolved, root), kind: 'file' };\n }\n\n return { key: source, kind: 'package' };\n}\n\nexport function resolveMockSpecifier({\n importer,\n mock,\n root,\n stack,\n}: {\n importer: string;\n mock: string;\n root: string | undefined;\n stack: string[];\n}): string {\n const specifier =\n mock.startsWith('.') && root ? path.resolve(root, mock) : mock;\n\n return syncResolve(specifier, importer, stack);\n}\n\nexport function applyImportOverrideToOnly(\n only: string[],\n override: ImportOverride | undefined\n): string[] {\n if (override?.noShake) {\n return ['*'];\n }\n\n return only;\n}\n"],"mappings":"AAAA,OAAOA,IAAI,MAAM,MAAM;AAEvB,SAASC,WAAW,QAA6B,mBAAmB;AASpE,OAAO,SAASC,kBAAkBA,CAChCC,QAAgB,EAChBC,IAAwB,EAChB;EACR,MAAMC,OAAO,GAAGD,IAAI,GAAGJ,IAAI,CAACM,OAAO,CAACF,IAAI,CAAC,GAAGG,OAAO,CAACC,GAAG,CAAC,CAAC;EACzD,MAAMC,kBAAkB,GAAGT,IAAI,CAACM,OAAO,CAACH,QAAQ,CAAC;EACjD,IAAIO,QAAQ,GAAGV,IAAI,CAACU,QAAQ,CAACL,OAAO,EAAEI,kBAAkB,CAAC;EAEzD,IAAIT,IAAI,CAACW,GAAG,KAAKX,IAAI,CAACY,KAAK,CAACD,GAAG,EAAE;IAC/BD,QAAQ,GAAGA,QAAQ,CAACG,KAAK,CAACb,IAAI,CAACW,GAAG,CAAC,CAACG,IAAI,CAACd,IAAI,CAACY,KAAK,CAACD,GAAG,CAAC;EAC1D;EAEA,IAAI,CAACD,QAAQ,CAACK,UAAU,CAAC,GAAG,CAAC,EAAE;IAC7BL,QAAQ,GAAG,KAAKA,QAAQ,EAAE;EAC5B;EAEA,OAAOA,QAAQ;AACjB;AAEA,OAAO,SAASM,WAAWA,CAAC;EAC1BC,MAAM;EACNd,QAAQ;EACRC;AAKF,CAAC,EAAa;EACZ,MAAMc,YAAY,GAAGD,MAAM,CAACF,UAAU,CAAC,GAAG,CAAC,IAAIf,IAAI,CAACmB,UAAU,CAACF,MAAM,CAAC;EAEtE,IAAIC,YAAY,IAAIf,QAAQ,EAAE;IAC5B,OAAO;MAAEiB,GAAG,EAAElB,kBAAkB,CAACC,QAAQ,EAAEC,IAAI,CAAC;MAAEiB,IAAI,EAAE;IAAO,CAAC;EAClE;EAEA,OAAO;IAAED,GAAG,EAAEH,MAAM;IAAEI,IAAI,EAAE;EAAU,CAAC;AACzC;AAEA,OAAO,SAASC,oBAAoBA,CAAC;EACnCC,QAAQ;EACRC,IAAI;EACJpB,IAAI;EACJqB;AAMF,CAAC,EAAU;EACT,MAAMC,SAAS,GACbF,IAAI,CAACT,UAAU,CAAC,GAAG,CAAC,IAAIX,IAAI,GAAGJ,IAAI,CAACM,OAAO,CAACF,IAAI,EAAEoB,IAAI,CAAC,GAAGA,IAAI;EAEhE,OAAOvB,WAAW,CAACyB,SAAS,EAAEH,QAAQ,EAAEE,KAAK,CAAC;AAChD;AAEA,OAAO,SAASE,yBAAyBA,CACvCC,IAAc,EACdC,QAAoC,EAC1B;EACV,IAAIA,QAAQ,EAAEC,OAAO,EAAE;IACrB,OAAO,CAAC,GAAG,CAAC;EACd;EAEA,OAAOF,IAAI;AACb","ignoreList":[]}
1
+ {"version":3,"file":"importOverrides.js","names":["path","syncResolve","Minimatch","toCanonicalFileKey","resolved","root","rootDir","resolve","process","cwd","normalizedResolved","relative","sep","posix","split","join","startsWith","toImportKey","source","isFileImport","isAbsolute","key","kind","resolveMockSpecifier","importer","mock","stack","specifier","applyImportOverrideToOnly","only","override","noShake","compiledImportOverridesCache","WeakMap","minimatchOptions","dot","nocomment","nonegate","getPatternSpecificity","pattern","wildcardCount","escaped","char","length","compileImportOverrides","importOverrides","matchers","Object","entries","map","matcher","specificity","sort","a","b","bySpecificity","byLength","localeCompare","getCompiledImportOverrides","cached","get","compiled","set","getImportOverride","undefined","direct","find","match"],"sources":["../../src/utils/importOverrides.ts"],"sourcesContent":["import path from 'path';\n\nimport {\n syncResolve,\n type ImportOverride,\n type ImportOverrides,\n} from '@wyw-in-js/shared';\nimport { Minimatch } from 'minimatch';\n\nexport type ImportKeyKind = 'file' | 'package';\n\nexport type ImportKey = {\n key: string;\n kind: ImportKeyKind;\n};\n\nexport function toCanonicalFileKey(\n resolved: string,\n root: string | undefined\n): string {\n const rootDir = root ? path.resolve(root) : process.cwd();\n const normalizedResolved = path.resolve(resolved);\n let relative = path.relative(rootDir, normalizedResolved);\n\n if (path.sep !== path.posix.sep) {\n relative = relative.split(path.sep).join(path.posix.sep);\n }\n\n if (!relative.startsWith('.')) {\n relative = `./${relative}`;\n }\n\n return relative;\n}\n\nexport function toImportKey({\n source,\n resolved,\n root,\n}: {\n resolved: string | null;\n root: string | undefined;\n source: string;\n}): ImportKey {\n const isFileImport = source.startsWith('.') || path.isAbsolute(source);\n\n if (isFileImport && resolved) {\n return { key: toCanonicalFileKey(resolved, root), kind: 'file' };\n }\n\n return { key: source, kind: 'package' };\n}\n\nexport function resolveMockSpecifier({\n importer,\n mock,\n root,\n stack,\n}: {\n importer: string;\n mock: string;\n root: string | undefined;\n stack: string[];\n}): string {\n const specifier =\n mock.startsWith('.') && root ? path.resolve(root, mock) : mock;\n\n return syncResolve(specifier, importer, stack);\n}\n\nexport function applyImportOverrideToOnly(\n only: string[],\n override: ImportOverride | undefined\n): string[] {\n if (override?.noShake) {\n return ['*'];\n }\n\n return only;\n}\n\ntype CompiledImportOverrides = {\n matchers: Array<{\n matcher: Minimatch;\n override: ImportOverride;\n pattern: string;\n specificity: number;\n }>;\n};\n\nconst compiledImportOverridesCache = new WeakMap<\n ImportOverrides,\n CompiledImportOverrides\n>();\n\nconst minimatchOptions = {\n dot: true,\n nocomment: true,\n nonegate: true,\n} as const;\n\nfunction getPatternSpecificity(pattern: string): number {\n let wildcardCount = 0;\n let escaped = false;\n for (const char of pattern) {\n if (escaped) {\n escaped = false;\n } else if (char === '\\\\') {\n escaped = true;\n } else if (char === '*' || char === '?') {\n wildcardCount += 1;\n }\n }\n\n return pattern.length - wildcardCount * 10;\n}\n\nfunction compileImportOverrides(\n importOverrides: ImportOverrides\n): CompiledImportOverrides {\n const matchers = Object.entries(importOverrides)\n .map(([pattern, override]) => {\n return {\n matcher: new Minimatch(pattern, minimatchOptions),\n override,\n pattern,\n specificity: getPatternSpecificity(pattern),\n };\n })\n .sort((a, b) => {\n const bySpecificity = b.specificity - a.specificity;\n if (bySpecificity !== 0) return bySpecificity;\n\n const byLength = b.pattern.length - a.pattern.length;\n if (byLength !== 0) return byLength;\n\n return a.pattern.localeCompare(b.pattern);\n });\n\n return { matchers };\n}\n\nfunction getCompiledImportOverrides(\n importOverrides: ImportOverrides\n): CompiledImportOverrides {\n const cached = compiledImportOverridesCache.get(importOverrides);\n if (cached) return cached;\n\n const compiled = compileImportOverrides(importOverrides);\n compiledImportOverridesCache.set(importOverrides, compiled);\n return compiled;\n}\n\nexport function getImportOverride(\n importOverrides: ImportOverrides | undefined,\n key: string\n): ImportOverride | undefined {\n if (!importOverrides) {\n return undefined;\n }\n\n const direct = importOverrides[key];\n if (direct) return direct;\n\n const { matchers } = getCompiledImportOverrides(importOverrides);\n return matchers.find(({ matcher }) => matcher.match(key))?.override;\n}\n"],"mappings":"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","ignoreList":[]}
@@ -3,7 +3,13 @@ import { isFeatureEnabled } from '@wyw-in-js/shared';
3
3
  import * as process from './process';
4
4
  const NOOP = () => {};
5
5
  const IMPORT_META_ENV = '__wyw_import_meta_env';
6
+ const HAPPY_DOM_REQUIRE_HOOK = '__wyw_requireHappyDom';
6
7
  let importMetaEnvWarned = false;
8
+ let happyDomRequireEsmWarned = false;
9
+ let happyDomUnavailable = false;
10
+ function isErrRequireEsm(error) {
11
+ return typeof error === 'object' && error !== null && 'code' in error && error.code === 'ERR_REQUIRE_ESM';
12
+ }
7
13
  function createImportMetaEnvProxy() {
8
14
  const target = Object.create(null);
9
15
  const warnOnce = () => {
@@ -42,18 +48,43 @@ function createImportMetaEnvProxy() {
42
48
  }
43
49
  });
44
50
  }
51
+ function requireHappyDom() {
52
+ const hook = globalThis[HAPPY_DOM_REQUIRE_HOOK];
53
+ if (typeof hook === 'function') {
54
+ return hook();
55
+ }
56
+ // eslint-disable-next-line @typescript-eslint/no-var-requires
57
+ return require('happy-dom');
58
+ }
45
59
  function createWindow() {
46
- const {
47
- Window,
48
- GlobalWindow
49
- } = require('happy-dom');
50
- const HappyWindow = GlobalWindow || Window;
51
- const win = new HappyWindow();
60
+ if (happyDomUnavailable) return undefined;
61
+ try {
62
+ const {
63
+ Window,
64
+ GlobalWindow
65
+ } = requireHappyDom();
66
+ const HappyWindow = GlobalWindow || Window;
67
+ const win = new HappyWindow();
52
68
 
53
- // TODO: browser doesn't expose Buffer, but a lot of dependencies use it
54
- win.Buffer = Buffer;
55
- win.Uint8Array = Uint8Array;
56
- return win;
69
+ // TODO: browser doesn't expose Buffer, but a lot of dependencies use it
70
+ win.Buffer = Buffer;
71
+ win.Uint8Array = Uint8Array;
72
+ return win;
73
+ } catch (error) {
74
+ if (!isErrRequireEsm(error)) {
75
+ throw error;
76
+ }
77
+ const hasCustomRequireHook = typeof globalThis[HAPPY_DOM_REQUIRE_HOOK] === 'function';
78
+ if (!hasCustomRequireHook) {
79
+ happyDomUnavailable = true;
80
+ }
81
+ if (happyDomRequireEsmWarned) return undefined;
82
+ happyDomRequireEsmWarned = true;
83
+
84
+ // eslint-disable-next-line no-console
85
+ console.warn([`[wyw-in-js] DOM emulation is enabled (features.happyDOM), but "happy-dom" could not be loaded in this build-time runtime.`, `This usually happens because "happy-dom" is ESM-only and cannot be loaded via require() in a CJS build.`, ``, `WyW will continue without DOM emulation (as if features.happyDOM:false).`, ``, `To silence this warning: set features: { happyDOM: false }.`, `To get real DOM emulation in Node 20+, WyW needs an ESM-only eval architecture (planned for v2.0.0),`, `or a runtime that supports require(ESM) (Node 24+).`].join('\n'));
86
+ return undefined;
87
+ }
57
88
  }
58
89
 
59
90
  /**
@@ -89,8 +120,15 @@ function createBaseContext(win, additionalContext) {
89
120
  }
90
121
  return baseContext;
91
122
  }
123
+ function createNothing() {
124
+ return {
125
+ teardown: () => {},
126
+ window: undefined
127
+ };
128
+ }
92
129
  function createHappyDOMWindow() {
93
130
  const win = createWindow();
131
+ if (!win) return createNothing();
94
132
  return {
95
133
  teardown: () => {
96
134
  win.happyDOM.abort();
@@ -98,12 +136,6 @@ function createHappyDOMWindow() {
98
136
  window: win
99
137
  };
100
138
  }
101
- function createNothing() {
102
- return {
103
- teardown: () => {},
104
- window: undefined
105
- };
106
- }
107
139
  export function createVmContext(filename, features, additionalContext, overrideContext = i => i) {
108
140
  const isHappyDOMEnabled = isFeatureEnabled(features, 'happyDOM', filename);
109
141
  const {