@wyw-in-js/transform 1.1.0 → 2.0.0-alpha.0

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 (603) hide show
  1. package/esm/cache.js +426 -289
  2. package/esm/cache.js.map +1 -1
  3. package/esm/debug/fileReporter.js +137 -134
  4. package/esm/debug/fileReporter.js.map +1 -1
  5. package/esm/eval/broker.js +2134 -0
  6. package/esm/eval/broker.js.map +1 -0
  7. package/esm/eval/lru.js +36 -0
  8. package/esm/eval/lru.js.map +1 -0
  9. package/esm/eval/prepareModuleOnDemand.js +21 -0
  10. package/esm/eval/prepareModuleOnDemand.js.map +1 -0
  11. package/esm/eval/protocol.js +2 -0
  12. package/esm/eval/protocol.js.map +1 -0
  13. package/esm/eval/resolverStrategy.js +51 -0
  14. package/esm/eval/resolverStrategy.js.map +1 -0
  15. package/esm/eval/runner.js +1759 -0
  16. package/esm/eval/runner.js.map +1 -0
  17. package/esm/eval/serialize.js +333 -0
  18. package/esm/eval/serialize.js.map +1 -0
  19. package/esm/eval/writeQueue.js +81 -0
  20. package/esm/eval/writeQueue.js.map +1 -0
  21. package/esm/evaluators/index.js +11 -12
  22. package/esm/evaluators/index.js.map +1 -1
  23. package/esm/index.js +25 -29
  24. package/esm/index.js.map +1 -1
  25. package/esm/module.js +896 -520
  26. package/esm/module.js.map +1 -1
  27. package/esm/shaker.js +14 -80
  28. package/esm/shaker.js.map +1 -1
  29. package/esm/transform/BaseEntrypoint.js +162 -164
  30. package/esm/transform/BaseEntrypoint.js.map +1 -1
  31. package/esm/transform/Entrypoint.helpers.js +96 -253
  32. package/esm/transform/Entrypoint.helpers.js.map +1 -1
  33. package/esm/transform/Entrypoint.js +336 -270
  34. package/esm/transform/Entrypoint.js.map +1 -1
  35. package/esm/transform/Entrypoint.types.js +1 -1
  36. package/esm/transform/Entrypoint.types.js.map +1 -1
  37. package/esm/transform/EvaluatedEntrypoint.js +10 -4
  38. package/esm/transform/EvaluatedEntrypoint.js.map +1 -1
  39. package/esm/transform/actions/AbortError.js +6 -6
  40. package/esm/transform/actions/AbortError.js.map +1 -1
  41. package/esm/transform/actions/BaseAction.js +140 -136
  42. package/esm/transform/actions/BaseAction.js.map +1 -1
  43. package/esm/transform/actions/UnprocessedEntrypointError.js +6 -6
  44. package/esm/transform/actions/UnprocessedEntrypointError.js.map +1 -1
  45. package/esm/transform/actions/actionRunner.js +63 -66
  46. package/esm/transform/actions/actionRunner.js.map +1 -1
  47. package/esm/transform/actions/types.js +1 -1
  48. package/esm/transform/actions/types.js.map +1 -1
  49. package/esm/transform/barrelManifest.types.js +2 -0
  50. package/esm/transform/barrelManifest.types.js.map +1 -0
  51. package/esm/transform/generators/baseProcessingHandlers.js +15 -17
  52. package/esm/transform/generators/baseProcessingHandlers.js.map +1 -1
  53. package/esm/transform/generators/collect.js +27 -55
  54. package/esm/transform/generators/collect.js.map +1 -1
  55. package/esm/transform/generators/createStylisPreprocessor.js +353 -321
  56. package/esm/transform/generators/createStylisPreprocessor.js.map +1 -1
  57. package/esm/transform/generators/evalFile.js +48 -47
  58. package/esm/transform/generators/evalFile.js.map +1 -1
  59. package/esm/transform/generators/extract.js +78 -90
  60. package/esm/transform/generators/extract.js.map +1 -1
  61. package/esm/transform/generators/getExports.js +57 -74
  62. package/esm/transform/generators/getExports.js.map +1 -1
  63. package/esm/transform/generators/index.js +11 -11
  64. package/esm/transform/generators/index.js.map +1 -1
  65. package/esm/transform/generators/processEntrypoint.js +78 -67
  66. package/esm/transform/generators/processEntrypoint.js.map +1 -1
  67. package/esm/transform/generators/processImports.js +102 -67
  68. package/esm/transform/generators/processImports.js.map +1 -1
  69. package/esm/transform/generators/resolveImports.js +165 -196
  70. package/esm/transform/generators/resolveImports.js.map +1 -1
  71. package/esm/transform/generators/resolveStaticOxcValues.js +2911 -0
  72. package/esm/transform/generators/resolveStaticOxcValues.js.map +1 -0
  73. package/esm/transform/generators/rewriteOxcBarrelImports.js +822 -0
  74. package/esm/transform/generators/rewriteOxcBarrelImports.js.map +1 -0
  75. package/esm/transform/generators/transform.js +239 -248
  76. package/esm/transform/generators/transform.js.map +1 -1
  77. package/esm/transform/generators/workflow.js +87 -90
  78. package/esm/transform/generators/workflow.js.map +1 -1
  79. package/esm/transform/helpers/loadWywOptions.js +154 -74
  80. package/esm/transform/helpers/loadWywOptions.js.map +1 -1
  81. package/esm/transform/helpers/withDefaultServices.js +13 -22
  82. package/esm/transform/helpers/withDefaultServices.js.map +1 -1
  83. package/esm/transform/isStaticallyEvaluatableModule.js +140 -152
  84. package/esm/transform/isStaticallyEvaluatableModule.js.map +1 -1
  85. package/esm/transform/oxcBarrelManifest.js +349 -0
  86. package/esm/transform/oxcBarrelManifest.js.map +1 -0
  87. package/esm/transform/rootLog.js +3 -3
  88. package/esm/transform/rootLog.js.map +1 -1
  89. package/esm/transform/syntax.js +2 -0
  90. package/esm/transform/syntax.js.map +1 -0
  91. package/esm/transform/types.js +2 -2
  92. package/esm/transform/types.js.map +1 -1
  93. package/esm/transform.js +123 -147
  94. package/esm/transform.js.map +1 -1
  95. package/esm/types.js +4 -1
  96. package/esm/types.js.map +1 -1
  97. package/esm/utils/EventEmitter.js +46 -48
  98. package/esm/utils/EventEmitter.js.map +1 -1
  99. package/esm/utils/ShakerMetadata.js +2 -2
  100. package/esm/utils/ShakerMetadata.js.map +1 -1
  101. package/esm/utils/TransformDiagnostics.js +9 -9
  102. package/esm/utils/TransformDiagnostics.js.map +1 -1
  103. package/esm/utils/TransformMetadata.js +24 -26
  104. package/esm/utils/TransformMetadata.js.map +1 -1
  105. package/esm/utils/applyOxcProcessors.js +1217 -0
  106. package/esm/utils/applyOxcProcessors.js.map +1 -0
  107. package/esm/utils/collectOxcExportsAndImports.js +934 -0
  108. package/esm/utils/collectOxcExportsAndImports.js.map +1 -0
  109. package/esm/utils/collectOxcRuntime.js +220 -0
  110. package/esm/utils/collectOxcRuntime.js.map +1 -0
  111. package/esm/utils/collectOxcTemplateDependencies.js +1398 -0
  112. package/esm/utils/collectOxcTemplateDependencies.js.map +1 -0
  113. package/esm/utils/dispose-polyfill.js +3 -4
  114. package/esm/utils/dispose-polyfill.js.map +1 -1
  115. package/esm/utils/getFileIdx.js +6 -6
  116. package/esm/utils/getFileIdx.js.map +1 -1
  117. package/esm/utils/getPluginKey.js +12 -12
  118. package/esm/utils/getPluginKey.js.map +1 -1
  119. package/esm/utils/getVisitorKeys.js +9 -3
  120. package/esm/utils/getVisitorKeys.js.map +1 -1
  121. package/esm/utils/hasCachedWywPrevalExport.js +23 -0
  122. package/esm/utils/hasCachedWywPrevalExport.js.map +1 -0
  123. package/esm/utils/hasWywPreval.js +5 -5
  124. package/esm/utils/hasWywPreval.js.map +1 -1
  125. package/esm/utils/importOverrides.js +75 -90
  126. package/esm/utils/importOverrides.js.map +1 -1
  127. package/esm/utils/isNode.js +2 -2
  128. package/esm/utils/isNode.js.map +1 -1
  129. package/esm/utils/isNotNull.js +2 -2
  130. package/esm/utils/isNotNull.js.map +1 -1
  131. package/esm/utils/isSerializable.js +11 -11
  132. package/esm/utils/isSerializable.js.map +1 -1
  133. package/esm/utils/oxcAstService.js +121 -0
  134. package/esm/utils/oxcAstService.js.map +1 -0
  135. package/esm/utils/oxcEmit.js +447 -0
  136. package/esm/utils/oxcEmit.js.map +1 -0
  137. package/esm/utils/oxcPreevalStage.js +97 -0
  138. package/esm/utils/oxcPreevalStage.js.map +1 -0
  139. package/esm/utils/oxcPreevalTransforms.js +1054 -0
  140. package/esm/utils/oxcPreevalTransforms.js.map +1 -0
  141. package/esm/utils/oxcShaker.js +662 -0
  142. package/esm/utils/oxcShaker.js.map +1 -0
  143. package/esm/utils/parseOxc.js +37 -0
  144. package/esm/utils/parseOxc.js.map +1 -0
  145. package/esm/utils/parseRequest.js +27 -27
  146. package/esm/utils/parseRequest.js.map +1 -1
  147. package/esm/utils/peek.js +1 -1
  148. package/esm/utils/peek.js.map +1 -1
  149. package/esm/utils/processorLookup.js +125 -0
  150. package/esm/utils/processorLookup.js.map +1 -0
  151. package/esm/utils/resolveWithConditions.js +99 -0
  152. package/esm/utils/resolveWithConditions.js.map +1 -0
  153. package/esm/vm/createVmContext.js +140 -141
  154. package/esm/vm/createVmContext.js.map +1 -1
  155. package/esm/vm/process.js +11 -13
  156. package/esm/vm/process.js.map +1 -1
  157. package/package.json +18 -26
  158. package/types/cache.d.ts +17 -8
  159. package/types/cache.js +237 -95
  160. package/types/debug/fileReporter.js +22 -22
  161. package/types/eval/broker.d.ts +88 -0
  162. package/types/eval/broker.js +2262 -0
  163. package/types/eval/lru.d.ts +10 -0
  164. package/types/eval/lru.js +36 -0
  165. package/types/eval/prepareModuleOnDemand.d.ts +7 -0
  166. package/types/eval/prepareModuleOnDemand.js +24 -0
  167. package/types/eval/protocol.d.ts +97 -0
  168. package/types/eval/protocol.js +1 -0
  169. package/types/eval/resolverStrategy.d.ts +13 -0
  170. package/types/eval/resolverStrategy.js +46 -0
  171. package/types/eval/serialize.d.ts +78 -0
  172. package/types/eval/serialize.js +357 -0
  173. package/types/eval/writeQueue.d.ts +13 -0
  174. package/types/eval/writeQueue.js +80 -0
  175. package/types/evaluators/index.d.ts +2 -2
  176. package/types/evaluators/index.js +6 -9
  177. package/types/index.d.ts +3 -6
  178. package/types/index.js +24 -82
  179. package/types/module.d.ts +35 -7
  180. package/types/module.js +535 -163
  181. package/types/shaker.d.ts +2 -10
  182. package/types/shaker.js +10 -100
  183. package/types/transform/BaseEntrypoint.js +6 -11
  184. package/types/transform/Entrypoint.d.ts +15 -15
  185. package/types/transform/Entrypoint.helpers.d.ts +2 -5
  186. package/types/transform/Entrypoint.helpers.js +43 -203
  187. package/types/transform/Entrypoint.js +130 -53
  188. package/types/transform/Entrypoint.types.d.ts +28 -6
  189. package/types/transform/Entrypoint.types.js +1 -2
  190. package/types/transform/EvaluatedEntrypoint.d.ts +13 -2
  191. package/types/transform/EvaluatedEntrypoint.js +7 -6
  192. package/types/transform/actions/AbortError.js +2 -7
  193. package/types/transform/actions/BaseAction.js +4 -8
  194. package/types/transform/actions/UnprocessedEntrypointError.js +2 -7
  195. package/types/transform/actions/actionRunner.js +8 -12
  196. package/types/transform/actions/types.d.ts +2 -2
  197. package/types/transform/actions/types.js +1 -2
  198. package/types/transform/{barrelManifest.d.ts → barrelManifest.types.d.ts} +0 -2
  199. package/types/transform/barrelManifest.types.js +1 -0
  200. package/types/transform/generators/baseProcessingHandlers.d.ts +4 -5
  201. package/types/transform/generators/baseProcessingHandlers.js +10 -14
  202. package/types/transform/generators/collect.js +13 -39
  203. package/types/transform/generators/createStylisPreprocessor.js +19 -60
  204. package/types/transform/generators/evalFile.d.ts +2 -2
  205. package/types/transform/generators/evalFile.js +26 -28
  206. package/types/transform/generators/extract.js +5 -8
  207. package/types/transform/generators/getExports.js +23 -30
  208. package/types/transform/generators/index.d.ts +2 -2
  209. package/types/transform/generators/index.js +11 -14
  210. package/types/transform/generators/processEntrypoint.d.ts +2 -2
  211. package/types/transform/generators/processEntrypoint.js +60 -26
  212. package/types/transform/generators/processImports.d.ts +0 -3
  213. package/types/transform/generators/processImports.js +60 -20
  214. package/types/transform/generators/resolveImports.js +18 -22
  215. package/types/transform/generators/resolveStaticOxcValues.d.ts +2 -0
  216. package/types/transform/generators/resolveStaticOxcValues.js +3235 -0
  217. package/types/transform/generators/{rewriteBarrelImports.d.ts → rewriteOxcBarrelImports.d.ts} +2 -3
  218. package/types/transform/generators/{rewriteBarrelImports.js → rewriteOxcBarrelImports.js} +282 -225
  219. package/types/transform/generators/transform.d.ts +3 -7
  220. package/types/transform/generators/transform.js +203 -199
  221. package/types/transform/generators/workflow.js +62 -45
  222. package/types/transform/helpers/loadWywOptions.js +94 -20
  223. package/types/transform/helpers/withDefaultServices.d.ts +1 -1
  224. package/types/transform/helpers/withDefaultServices.js +6 -44
  225. package/types/transform/isStaticallyEvaluatableModule.d.ts +1 -2
  226. package/types/transform/isStaticallyEvaluatableModule.js +125 -126
  227. package/types/transform/oxcBarrelManifest.d.ts +2 -0
  228. package/types/transform/{barrelManifest.js → oxcBarrelManifest.js} +156 -97
  229. package/types/transform/rootLog.js +2 -5
  230. package/types/transform/syntax.d.ts +38 -0
  231. package/types/transform/syntax.js +1 -0
  232. package/types/transform/types.d.ts +9 -6
  233. package/types/transform/types.js +1 -4
  234. package/types/transform.d.ts +2 -2
  235. package/types/transform.js +88 -101
  236. package/types/types.d.ts +0 -23
  237. package/types/types.js +1 -2
  238. package/types/utils/EventEmitter.js +3 -9
  239. package/types/utils/ShakerMetadata.js +1 -5
  240. package/types/utils/TransformDiagnostics.js +3 -7
  241. package/types/utils/TransformMetadata.js +8 -16
  242. package/types/utils/applyOxcProcessors.d.ts +16 -0
  243. package/types/utils/applyOxcProcessors.js +1391 -0
  244. package/types/utils/collectOxcExportsAndImports.d.ts +35 -0
  245. package/types/utils/collectOxcExportsAndImports.js +957 -0
  246. package/types/utils/collectOxcRuntime.d.ts +14 -0
  247. package/types/utils/collectOxcRuntime.js +250 -0
  248. package/types/utils/collectOxcTemplateDependencies.d.ts +38 -0
  249. package/types/utils/collectOxcTemplateDependencies.js +1580 -0
  250. package/types/utils/getFileIdx.js +1 -4
  251. package/types/utils/getPluginKey.d.ts +5 -2
  252. package/types/utils/getPluginKey.js +2 -6
  253. package/types/utils/getVisitorKeys.d.ts +4 -4
  254. package/types/utils/getVisitorKeys.js +9 -6
  255. package/types/utils/hasCachedWywPrevalExport.d.ts +14 -0
  256. package/types/utils/hasCachedWywPrevalExport.js +30 -0
  257. package/types/utils/hasWywPreval.js +1 -4
  258. package/types/utils/importOverrides.js +17 -27
  259. package/types/utils/isNode.d.ts +2 -2
  260. package/types/utils/isNode.js +2 -6
  261. package/types/utils/isNotNull.js +1 -4
  262. package/types/utils/isSerializable.js +3 -6
  263. package/types/utils/oxcAstService.d.ts +11 -0
  264. package/types/utils/oxcAstService.js +79 -0
  265. package/types/utils/oxcEmit.d.ts +19 -0
  266. package/types/utils/oxcEmit.js +506 -0
  267. package/types/utils/oxcPreevalStage.d.ts +20 -0
  268. package/types/utils/oxcPreevalStage.js +102 -0
  269. package/types/utils/oxcPreevalTransforms.d.ts +13 -0
  270. package/types/utils/oxcPreevalTransforms.js +1179 -0
  271. package/types/utils/oxcShaker.d.ts +13 -0
  272. package/types/utils/oxcShaker.js +751 -0
  273. package/types/utils/parseOxc.d.ts +11 -0
  274. package/types/utils/parseOxc.js +38 -0
  275. package/types/utils/parseRequest.js +2 -7
  276. package/types/utils/peek.js +1 -5
  277. package/types/utils/processorLookup.d.ts +8 -0
  278. package/types/utils/processorLookup.js +135 -0
  279. package/types/utils/resolveWithConditions.d.ts +12 -0
  280. package/types/utils/resolveWithConditions.js +103 -0
  281. package/types/vm/createVmContext.d.ts +2 -2
  282. package/types/vm/createVmContext.js +25 -62
  283. package/types/vm/process.js +20 -26
  284. package/esm/babel.js +0 -2
  285. package/esm/babel.js.map +0 -1
  286. package/esm/options/buildOptions.js +0 -168
  287. package/esm/options/buildOptions.js.map +0 -1
  288. package/esm/options/buildOptions.test.js +0 -138
  289. package/esm/options/buildOptions.test.js.map +0 -1
  290. package/esm/options/loadBabelOptions.js +0 -24
  291. package/esm/options/loadBabelOptions.js.map +0 -1
  292. package/esm/plugins/babel-transform.js +0 -53
  293. package/esm/plugins/babel-transform.js.map +0 -1
  294. package/esm/plugins/collector.js +0 -60
  295. package/esm/plugins/collector.js.map +0 -1
  296. package/esm/plugins/dynamic-import.js +0 -56
  297. package/esm/plugins/dynamic-import.js.map +0 -1
  298. package/esm/plugins/preeval.js +0 -73
  299. package/esm/plugins/preeval.js.map +0 -1
  300. package/esm/plugins/shaker.js +0 -680
  301. package/esm/plugins/shaker.js.map +0 -1
  302. package/esm/transform/barrelManifest.js +0 -291
  303. package/esm/transform/barrelManifest.js.map +0 -1
  304. package/esm/transform/generators/explodeReexports.js +0 -64
  305. package/esm/transform/generators/explodeReexports.js.map +0 -1
  306. package/esm/transform/generators/rewriteBarrelImports.js +0 -733
  307. package/esm/transform/generators/rewriteBarrelImports.js.map +0 -1
  308. package/esm/utils/addIdentifierToWywPreval.js +0 -68
  309. package/esm/utils/addIdentifierToWywPreval.js.map +0 -1
  310. package/esm/utils/collectExportsAndImports.js +0 -1157
  311. package/esm/utils/collectExportsAndImports.js.map +0 -1
  312. package/esm/utils/collectTemplateDependencies.js +0 -228
  313. package/esm/utils/collectTemplateDependencies.js.map +0 -1
  314. package/esm/utils/createId.js +0 -6
  315. package/esm/utils/createId.js.map +0 -1
  316. package/esm/utils/findIdentifiers.js +0 -62
  317. package/esm/utils/findIdentifiers.js.map +0 -1
  318. package/esm/utils/getConstantStringValue.js +0 -58
  319. package/esm/utils/getConstantStringValue.js.map +0 -1
  320. package/esm/utils/getMemberExpressionPropertyName.js +0 -11
  321. package/esm/utils/getMemberExpressionPropertyName.js.map +0 -1
  322. package/esm/utils/getScope.js +0 -6
  323. package/esm/utils/getScope.js.map +0 -1
  324. package/esm/utils/getSource.js +0 -15
  325. package/esm/utils/getSource.js.map +0 -1
  326. package/esm/utils/getTagProcessor.js +0 -404
  327. package/esm/utils/getTagProcessor.js.map +0 -1
  328. package/esm/utils/isExports.js +0 -22
  329. package/esm/utils/isExports.js.map +0 -1
  330. package/esm/utils/isGlobal.js +0 -6
  331. package/esm/utils/isGlobal.js.map +0 -1
  332. package/esm/utils/isNodePath.js +0 -4
  333. package/esm/utils/isNodePath.js.map +0 -1
  334. package/esm/utils/isRemoved.js +0 -46
  335. package/esm/utils/isRemoved.js.map +0 -1
  336. package/esm/utils/isRequire.js +0 -13
  337. package/esm/utils/isRequire.js.map +0 -1
  338. package/esm/utils/isTypedNode.js +0 -6
  339. package/esm/utils/isTypedNode.js.map +0 -1
  340. package/esm/utils/isUnnecessaryReactCall.js +0 -72
  341. package/esm/utils/isUnnecessaryReactCall.js.map +0 -1
  342. package/esm/utils/removeDangerousCode.js +0 -276
  343. package/esm/utils/removeDangerousCode.js.map +0 -1
  344. package/esm/utils/replaceImportMetaEnv.js +0 -44
  345. package/esm/utils/replaceImportMetaEnv.js.map +0 -1
  346. package/esm/utils/scopeHelpers.js +0 -527
  347. package/esm/utils/scopeHelpers.js.map +0 -1
  348. package/esm/utils/traversalCache.js +0 -23
  349. package/esm/utils/traversalCache.js.map +0 -1
  350. package/esm/utils/unwrapExpression.js +0 -18
  351. package/esm/utils/unwrapExpression.js.map +0 -1
  352. package/esm/utils/unwrapSequence.js +0 -14
  353. package/esm/utils/unwrapSequence.js.map +0 -1
  354. package/esm/utils/valueToLiteral.js +0 -59
  355. package/esm/utils/valueToLiteral.js.map +0 -1
  356. package/esm/utils/visitors/JSXElementsRemover.js +0 -51
  357. package/esm/utils/visitors/JSXElementsRemover.js.map +0 -1
  358. package/lib/babel.js +0 -2
  359. package/lib/babel.js.map +0 -1
  360. package/lib/cache.js +0 -308
  361. package/lib/cache.js.map +0 -1
  362. package/lib/debug/fileReporter.js +0 -153
  363. package/lib/debug/fileReporter.js.map +0 -1
  364. package/lib/evaluators/index.js +0 -20
  365. package/lib/evaluators/index.js.map +0 -1
  366. package/lib/index.js +0 -286
  367. package/lib/index.js.map +0 -1
  368. package/lib/module.js +0 -552
  369. package/lib/module.js.map +0 -1
  370. package/lib/options/buildOptions.js +0 -176
  371. package/lib/options/buildOptions.js.map +0 -1
  372. package/lib/options/buildOptions.test.js +0 -141
  373. package/lib/options/buildOptions.test.js.map +0 -1
  374. package/lib/options/loadBabelOptions.js +0 -31
  375. package/lib/options/loadBabelOptions.js.map +0 -1
  376. package/lib/plugins/babel-transform.js +0 -60
  377. package/lib/plugins/babel-transform.js.map +0 -1
  378. package/lib/plugins/collector.js +0 -70
  379. package/lib/plugins/collector.js.map +0 -1
  380. package/lib/plugins/dynamic-import.js +0 -61
  381. package/lib/plugins/dynamic-import.js.map +0 -1
  382. package/lib/plugins/preeval.js +0 -81
  383. package/lib/plugins/preeval.js.map +0 -1
  384. package/lib/plugins/shaker.js +0 -691
  385. package/lib/plugins/shaker.js.map +0 -1
  386. package/lib/shaker.js +0 -95
  387. package/lib/shaker.js.map +0 -1
  388. package/lib/transform/BaseEntrypoint.js +0 -179
  389. package/lib/transform/BaseEntrypoint.js.map +0 -1
  390. package/lib/transform/Entrypoint.helpers.js +0 -279
  391. package/lib/transform/Entrypoint.helpers.js.map +0 -1
  392. package/lib/transform/Entrypoint.js +0 -289
  393. package/lib/transform/Entrypoint.js.map +0 -1
  394. package/lib/transform/Entrypoint.types.js +0 -2
  395. package/lib/transform/Entrypoint.types.js.map +0 -1
  396. package/lib/transform/EvaluatedEntrypoint.js +0 -13
  397. package/lib/transform/EvaluatedEntrypoint.js.map +0 -1
  398. package/lib/transform/actions/AbortError.js +0 -16
  399. package/lib/transform/actions/AbortError.js.map +0 -1
  400. package/lib/transform/actions/BaseAction.js +0 -150
  401. package/lib/transform/actions/BaseAction.js.map +0 -1
  402. package/lib/transform/actions/UnprocessedEntrypointError.js +0 -16
  403. package/lib/transform/actions/UnprocessedEntrypointError.js.map +0 -1
  404. package/lib/transform/actions/actionRunner.js +0 -82
  405. package/lib/transform/actions/actionRunner.js.map +0 -1
  406. package/lib/transform/actions/types.js +0 -2
  407. package/lib/transform/actions/types.js.map +0 -1
  408. package/lib/transform/barrelManifest.js +0 -300
  409. package/lib/transform/barrelManifest.js.map +0 -1
  410. package/lib/transform/generators/baseProcessingHandlers.js +0 -27
  411. package/lib/transform/generators/baseProcessingHandlers.js.map +0 -1
  412. package/lib/transform/generators/collect.js +0 -66
  413. package/lib/transform/generators/collect.js.map +0 -1
  414. package/lib/transform/generators/createStylisPreprocessor.js +0 -372
  415. package/lib/transform/generators/createStylisPreprocessor.js.map +0 -1
  416. package/lib/transform/generators/evalFile.js +0 -57
  417. package/lib/transform/generators/evalFile.js.map +0 -1
  418. package/lib/transform/generators/explodeReexports.js +0 -71
  419. package/lib/transform/generators/explodeReexports.js.map +0 -1
  420. package/lib/transform/generators/extract.js +0 -102
  421. package/lib/transform/generators/extract.js.map +0 -1
  422. package/lib/transform/generators/getExports.js +0 -85
  423. package/lib/transform/generators/getExports.js.map +0 -1
  424. package/lib/transform/generators/index.js +0 -19
  425. package/lib/transform/generators/index.js.map +0 -1
  426. package/lib/transform/generators/processEntrypoint.js +0 -76
  427. package/lib/transform/generators/processEntrypoint.js.map +0 -1
  428. package/lib/transform/generators/processImports.js +0 -82
  429. package/lib/transform/generators/processImports.js.map +0 -1
  430. package/lib/transform/generators/resolveImports.js +0 -221
  431. package/lib/transform/generators/resolveImports.js.map +0 -1
  432. package/lib/transform/generators/rewriteBarrelImports.js +0 -743
  433. package/lib/transform/generators/rewriteBarrelImports.js.map +0 -1
  434. package/lib/transform/generators/transform.js +0 -272
  435. package/lib/transform/generators/transform.js.map +0 -1
  436. package/lib/transform/generators/workflow.js +0 -100
  437. package/lib/transform/generators/workflow.js.map +0 -1
  438. package/lib/transform/helpers/loadWywOptions.js +0 -88
  439. package/lib/transform/helpers/loadWywOptions.js.map +0 -1
  440. package/lib/transform/helpers/withDefaultServices.js +0 -31
  441. package/lib/transform/helpers/withDefaultServices.js.map +0 -1
  442. package/lib/transform/isStaticallyEvaluatableModule.js +0 -159
  443. package/lib/transform/isStaticallyEvaluatableModule.js.map +0 -1
  444. package/lib/transform/rootLog.js +0 -9
  445. package/lib/transform/rootLog.js.map +0 -1
  446. package/lib/transform/types.js +0 -8
  447. package/lib/transform/types.js.map +0 -1
  448. package/lib/transform.js +0 -160
  449. package/lib/transform.js.map +0 -1
  450. package/lib/types.js +0 -2
  451. package/lib/types.js.map +0 -1
  452. package/lib/utils/EventEmitter.js +0 -61
  453. package/lib/utils/EventEmitter.js.map +0 -1
  454. package/lib/utils/ShakerMetadata.js +0 -9
  455. package/lib/utils/ShakerMetadata.js.map +0 -1
  456. package/lib/utils/TransformDiagnostics.js +0 -20
  457. package/lib/utils/TransformDiagnostics.js.map +0 -1
  458. package/lib/utils/TransformMetadata.js +0 -45
  459. package/lib/utils/TransformMetadata.js.map +0 -1
  460. package/lib/utils/addIdentifierToWywPreval.js +0 -75
  461. package/lib/utils/addIdentifierToWywPreval.js.map +0 -1
  462. package/lib/utils/collectExportsAndImports.js +0 -1173
  463. package/lib/utils/collectExportsAndImports.js.map +0 -1
  464. package/lib/utils/collectTemplateDependencies.js +0 -242
  465. package/lib/utils/collectTemplateDependencies.js.map +0 -1
  466. package/lib/utils/createId.js +0 -13
  467. package/lib/utils/createId.js.map +0 -1
  468. package/lib/utils/dispose-polyfill.js +0 -9
  469. package/lib/utils/dispose-polyfill.js.map +0 -1
  470. package/lib/utils/findIdentifiers.js +0 -73
  471. package/lib/utils/findIdentifiers.js.map +0 -1
  472. package/lib/utils/getConstantStringValue.js +0 -66
  473. package/lib/utils/getConstantStringValue.js.map +0 -1
  474. package/lib/utils/getFileIdx.js +0 -16
  475. package/lib/utils/getFileIdx.js.map +0 -1
  476. package/lib/utils/getMemberExpressionPropertyName.js +0 -18
  477. package/lib/utils/getMemberExpressionPropertyName.js.map +0 -1
  478. package/lib/utils/getPluginKey.js +0 -21
  479. package/lib/utils/getPluginKey.js.map +0 -1
  480. package/lib/utils/getScope.js +0 -12
  481. package/lib/utils/getScope.js.map +0 -1
  482. package/lib/utils/getSource.js +0 -24
  483. package/lib/utils/getSource.js.map +0 -1
  484. package/lib/utils/getTagProcessor.js +0 -424
  485. package/lib/utils/getTagProcessor.js.map +0 -1
  486. package/lib/utils/getVisitorKeys.js +0 -11
  487. package/lib/utils/getVisitorKeys.js.map +0 -1
  488. package/lib/utils/hasWywPreval.js +0 -13
  489. package/lib/utils/hasWywPreval.js.map +0 -1
  490. package/lib/utils/importOverrides.js +0 -119
  491. package/lib/utils/importOverrides.js.map +0 -1
  492. package/lib/utils/isExports.js +0 -27
  493. package/lib/utils/isExports.js.map +0 -1
  494. package/lib/utils/isGlobal.js +0 -13
  495. package/lib/utils/isGlobal.js.map +0 -1
  496. package/lib/utils/isNode.js +0 -9
  497. package/lib/utils/isNode.js.map +0 -1
  498. package/lib/utils/isNodePath.js +0 -10
  499. package/lib/utils/isNodePath.js.map +0 -1
  500. package/lib/utils/isNotNull.js +0 -10
  501. package/lib/utils/isNotNull.js.map +0 -1
  502. package/lib/utils/isRemoved.js +0 -52
  503. package/lib/utils/isRemoved.js.map +0 -1
  504. package/lib/utils/isRequire.js +0 -18
  505. package/lib/utils/isRequire.js.map +0 -1
  506. package/lib/utils/isSerializable.js +0 -19
  507. package/lib/utils/isSerializable.js.map +0 -1
  508. package/lib/utils/isTypedNode.js +0 -13
  509. package/lib/utils/isTypedNode.js.map +0 -1
  510. package/lib/utils/isUnnecessaryReactCall.js +0 -81
  511. package/lib/utils/isUnnecessaryReactCall.js.map +0 -1
  512. package/lib/utils/parseRequest.js +0 -37
  513. package/lib/utils/parseRequest.js.map +0 -1
  514. package/lib/utils/peek.js +0 -9
  515. package/lib/utils/peek.js.map +0 -1
  516. package/lib/utils/removeDangerousCode.js +0 -284
  517. package/lib/utils/removeDangerousCode.js.map +0 -1
  518. package/lib/utils/replaceImportMetaEnv.js +0 -50
  519. package/lib/utils/replaceImportMetaEnv.js.map +0 -1
  520. package/lib/utils/scopeHelpers.js +0 -557
  521. package/lib/utils/scopeHelpers.js.map +0 -1
  522. package/lib/utils/traversalCache.js +0 -31
  523. package/lib/utils/traversalCache.js.map +0 -1
  524. package/lib/utils/unwrapExpression.js +0 -25
  525. package/lib/utils/unwrapExpression.js.map +0 -1
  526. package/lib/utils/unwrapSequence.js +0 -20
  527. package/lib/utils/unwrapSequence.js.map +0 -1
  528. package/lib/utils/valueToLiteral.js +0 -65
  529. package/lib/utils/valueToLiteral.js.map +0 -1
  530. package/lib/utils/visitors/JSXElementsRemover.js +0 -57
  531. package/lib/utils/visitors/JSXElementsRemover.js.map +0 -1
  532. package/lib/vm/createVmContext.js +0 -166
  533. package/lib/vm/createVmContext.js.map +0 -1
  534. package/lib/vm/process.js +0 -38
  535. package/lib/vm/process.js.map +0 -1
  536. package/types/babel.d.ts +0 -2
  537. package/types/babel.js +0 -2
  538. package/types/options/buildOptions.d.ts +0 -6
  539. package/types/options/buildOptions.js +0 -178
  540. package/types/options/loadBabelOptions.d.ts +0 -3
  541. package/types/options/loadBabelOptions.js +0 -26
  542. package/types/plugins/babel-transform.d.ts +0 -4
  543. package/types/plugins/babel-transform.js +0 -49
  544. package/types/plugins/collector.d.ts +0 -23
  545. package/types/plugins/collector.js +0 -62
  546. package/types/plugins/dynamic-import.d.ts +0 -6
  547. package/types/plugins/dynamic-import.js +0 -60
  548. package/types/plugins/preeval.d.ts +0 -16
  549. package/types/plugins/preeval.js +0 -69
  550. package/types/plugins/shaker.d.ts +0 -14
  551. package/types/plugins/shaker.js +0 -724
  552. package/types/transform/generators/explodeReexports.d.ts +0 -7
  553. package/types/transform/generators/explodeReexports.js +0 -65
  554. package/types/utils/addIdentifierToWywPreval.d.ts +0 -4
  555. package/types/utils/addIdentifierToWywPreval.js +0 -74
  556. package/types/utils/collectExportsAndImports.d.ts +0 -31
  557. package/types/utils/collectExportsAndImports.js +0 -1147
  558. package/types/utils/collectTemplateDependencies.d.ts +0 -17
  559. package/types/utils/collectTemplateDependencies.js +0 -220
  560. package/types/utils/createId.d.ts +0 -2
  561. package/types/utils/createId.js +0 -9
  562. package/types/utils/findIdentifiers.d.ts +0 -6
  563. package/types/utils/findIdentifiers.js +0 -67
  564. package/types/utils/getConstantStringValue.d.ts +0 -2
  565. package/types/utils/getConstantStringValue.js +0 -94
  566. package/types/utils/getMemberExpressionPropertyName.d.ts +0 -2
  567. package/types/utils/getMemberExpressionPropertyName.js +0 -46
  568. package/types/utils/getScope.d.ts +0 -2
  569. package/types/utils/getScope.js +0 -10
  570. package/types/utils/getSource.d.ts +0 -2
  571. package/types/utils/getSource.js +0 -22
  572. package/types/utils/getTagProcessor.d.ts +0 -13
  573. package/types/utils/getTagProcessor.js +0 -411
  574. package/types/utils/isExports.d.ts +0 -6
  575. package/types/utils/isExports.js +0 -19
  576. package/types/utils/isGlobal.d.ts +0 -2
  577. package/types/utils/isGlobal.js +0 -9
  578. package/types/utils/isNodePath.d.ts +0 -3
  579. package/types/utils/isNodePath.js +0 -6
  580. package/types/utils/isRemoved.d.ts +0 -5
  581. package/types/utils/isRemoved.js +0 -41
  582. package/types/utils/isRequire.d.ts +0 -6
  583. package/types/utils/isRequire.js +0 -14
  584. package/types/utils/isTypedNode.d.ts +0 -5
  585. package/types/utils/isTypedNode.js +0 -9
  586. package/types/utils/isUnnecessaryReactCall.d.ts +0 -3
  587. package/types/utils/isUnnecessaryReactCall.js +0 -75
  588. package/types/utils/removeDangerousCode.d.ts +0 -4
  589. package/types/utils/removeDangerousCode.js +0 -326
  590. package/types/utils/replaceImportMetaEnv.d.ts +0 -3
  591. package/types/utils/replaceImportMetaEnv.js +0 -39
  592. package/types/utils/scopeHelpers.d.ts +0 -12
  593. package/types/utils/scopeHelpers.js +0 -580
  594. package/types/utils/traversalCache.d.ts +0 -4
  595. package/types/utils/traversalCache.js +0 -27
  596. package/types/utils/unwrapExpression.d.ts +0 -2
  597. package/types/utils/unwrapExpression.js +0 -57
  598. package/types/utils/unwrapSequence.d.ts +0 -8
  599. package/types/utils/unwrapSequence.js +0 -16
  600. package/types/utils/valueToLiteral.d.ts +0 -3
  601. package/types/utils/valueToLiteral.js +0 -63
  602. package/types/utils/visitors/JSXElementsRemover.d.ts +0 -3
  603. package/types/utils/visitors/JSXElementsRemover.js +0 -51
package/esm/module.js CHANGED
@@ -1,539 +1,915 @@
1
1
  /**
2
- * This is a custom implementation for the module system for evaluating code,
3
- * used for resolving values for dependencies interpolated in `css` or `styled`.
4
- *
5
- * This serves 2 purposes:
6
- * - Avoid leakage from evaluated code to module cache in current context, e.g. `babel-register`
7
- * - Allow us to invalidate the module cache without affecting other stuff, necessary for rebuilds
8
- *
9
- * We also use it to transpile the code with Babel by default.
10
- * We also store source maps for it to provide correct error stacktraces.
11
- *
12
- */
13
-
14
- import fs from 'fs';
15
- import NativeModule from 'module';
16
- import path from 'path';
17
- import vm from 'vm';
18
- import { invariant } from 'ts-invariant';
19
- import { isFeatureEnabled } from '@wyw-in-js/shared';
20
- import './utils/dispose-polyfill';
21
- import { Entrypoint } from './transform/Entrypoint';
22
- import { getStack, isSuperSet, mergeOnly } from './transform/Entrypoint.helpers';
23
- import { isUnprocessedEntrypointError } from './transform/actions/UnprocessedEntrypointError';
24
- import { applyImportOverrideToOnly, getImportOverride, resolveMockSpecifier, toImportKey } from './utils/importOverrides';
25
- import { parseRequest, stripQueryAndHash } from './utils/parseRequest';
26
- import { createVmContext } from './vm/createVmContext';
27
- const CJS_DEFAULT_CONDITIONS = ['require', 'node', 'default'];
28
- function expandConditions(conditionNames) {
29
- const result = new Set();
30
- for (const name of conditionNames) {
31
- if (name === '...') {
32
- for (const d of CJS_DEFAULT_CONDITIONS) result.add(d);
33
- } else {
34
- result.add(name);
35
- }
36
- }
37
- return result;
38
- }
39
- function isBarePackageSubpath(id) {
40
- if (id.startsWith('.') || path.isAbsolute(id)) {
41
- return false;
42
- }
43
- if (id.startsWith('@')) {
44
- return id.split('/').length > 2;
45
- }
46
- return id.includes('/');
47
- }
2
+ * This is a custom implementation for the module system for evaluating code,
3
+ * used for resolving values for dependencies interpolated in `css` or `styled`.
4
+ *
5
+ * This serves 2 purposes:
6
+ * - Avoid leakage from evaluated code to module cache in current context
7
+ * - Allow us to invalidate the module cache without affecting other stuff, necessary for rebuilds
8
+ *
9
+ * We also store prepared evaluator code in it.
10
+ * We also store source maps for it to provide correct error stacktraces.
11
+ *
12
+ */
13
+ import fs from "fs";
14
+ import NativeModule, { createRequire } from "module";
15
+ import path from "path";
16
+ import * as vm from "vm";
17
+ import { pathToFileURL } from "url";
18
+ import { invariant } from "ts-invariant";
19
+ import { isFeatureEnabled } from "@wyw-in-js/shared";
20
+ import "./utils/dispose-polyfill.js";
21
+ import { Entrypoint } from "./transform/Entrypoint.js";
22
+ import { getStack, isSuperSet, mergeOnly } from "./transform/Entrypoint.helpers.js";
23
+ import { isUnprocessedEntrypointError } from "./transform/actions/UnprocessedEntrypointError.js";
24
+ import { applyImportOverrideToOnly, getImportOverride, resolveMockSpecifier, toImportKey } from "./utils/importOverrides.js";
25
+ import { parseRequest, stripQueryAndHash } from "./utils/parseRequest.js";
26
+ import { resolveFilenameWithConditions } from "./utils/resolveWithConditions.js";
27
+ import { createVmContext } from "./vm/createVmContext.js";
28
+ const CJS_DEFAULT_CONDITIONS = [
29
+ "require",
30
+ "node",
31
+ "default"
32
+ ];
33
+ const expandConditions = (conditionNames) => {
34
+ const result = new Set();
35
+ conditionNames.forEach((name) => {
36
+ if (name === "...") {
37
+ CJS_DEFAULT_CONDITIONS.forEach((condition) => result.add(condition));
38
+ return;
39
+ }
40
+ result.add(name);
41
+ });
42
+ return result;
43
+ };
44
+ const isBarePackageSubpath = (id) => {
45
+ if (id.startsWith(".") || path.isAbsolute(id)) {
46
+ return false;
47
+ }
48
+ if (id.startsWith("@")) {
49
+ return id.split("/").length > 2;
50
+ }
51
+ return id.includes("/");
52
+ };
48
53
  export const DefaultModuleImplementation = NativeModule;
49
-
50
54
  // Supported node builtins based on the modules polyfilled by webpack
51
55
  // `true` means module is polyfilled, `false` means module is empty
52
56
  const builtins = {
53
- assert: true,
54
- buffer: true,
55
- child_process: false,
56
- cluster: false,
57
- console: true,
58
- constants: true,
59
- crypto: true,
60
- dgram: false,
61
- dns: false,
62
- domain: true,
63
- events: true,
64
- fs: false,
65
- http: true,
66
- https: true,
67
- module: false,
68
- net: false,
69
- os: true,
70
- path: true,
71
- punycode: true,
72
- process: true,
73
- querystring: true,
74
- readline: false,
75
- repl: false,
76
- stream: true,
77
- string_decoder: true,
78
- sys: true,
79
- timers: true,
80
- tls: false,
81
- tty: true,
82
- url: true,
83
- util: true,
84
- vm: true,
85
- zlib: true
86
- };
87
- const VITE_VIRTUAL_PREFIX = '/@';
88
- const REACT_REFRESH_VIRTUAL_ID = '/@react-refresh';
89
- const reactRefreshRuntime = {
90
- createSignatureFunctionForTransform: () => () => {}
57
+ assert: true,
58
+ buffer: true,
59
+ child_process: false,
60
+ cluster: false,
61
+ console: true,
62
+ constants: true,
63
+ crypto: true,
64
+ dgram: false,
65
+ dns: false,
66
+ domain: true,
67
+ events: true,
68
+ fs: false,
69
+ http: true,
70
+ https: true,
71
+ module: false,
72
+ net: false,
73
+ os: true,
74
+ path: true,
75
+ punycode: true,
76
+ process: true,
77
+ querystring: true,
78
+ readline: false,
79
+ repl: false,
80
+ stream: true,
81
+ string_decoder: true,
82
+ sys: true,
83
+ timers: true,
84
+ tls: false,
85
+ tty: true,
86
+ url: true,
87
+ util: true,
88
+ vm: true,
89
+ zlib: true
91
90
  };
91
+ const VITE_VIRTUAL_PREFIX = "/@";
92
+ const REACT_REFRESH_VIRTUAL_ID = "/@react-refresh";
93
+ const reactRefreshRuntime = { createSignatureFunctionForTransform: () => () => {} };
94
+ const nodeRequire = createRequire(import.meta.url);
92
95
  const NOOP = () => {};
93
- const browserOnlyEvalHintTriggers = ['window is not defined', "evaluating 'window", 'document is not defined', "evaluating 'document", 'navigator is not defined', "evaluating 'navigator", 'self is not defined', "evaluating 'self"];
94
- const getBrowserOnlyEvalHint = error => {
95
- const message = error instanceof Error ? error.message : String(error);
96
- const looksLikeBrowserOnly = browserOnlyEvalHintTriggers.some(trigger => message.includes(trigger));
97
- if (!looksLikeBrowserOnly) return null;
98
- return ['', '[wyw-in-js] Evaluation hint:', 'This usually means browser-only code ran during build-time evaluation.', 'Move browser-only initialization out of evaluated modules, or mock the import via `importOverrides`.', "Example: importOverrides: { 'msw/browser': { mock: './src/__mocks__/msw-browser.js' } }"].join('\n');
96
+ const TROUBLESHOOTING_URL = "https://wyw-in-js.dev/troubleshooting";
97
+ const defaultEvalOptions = {
98
+ mode: "strict",
99
+ require: "warn-and-run",
100
+ resolver: "bundler"
101
+ };
102
+ const browserOnlyEvalHintTriggers = [
103
+ "window is not defined",
104
+ "evaluating 'window",
105
+ "document is not defined",
106
+ "evaluating 'document",
107
+ "navigator is not defined",
108
+ "evaluating 'navigator",
109
+ "self is not defined",
110
+ "evaluating 'self"
111
+ ];
112
+ const getBrowserOnlyEvalHint = (error) => {
113
+ const message = error instanceof Error ? error.message : String(error);
114
+ const looksLikeBrowserOnly = browserOnlyEvalHintTriggers.some((trigger) => message.includes(trigger));
115
+ if (!looksLikeBrowserOnly) return null;
116
+ return [
117
+ "",
118
+ "[wyw-in-js] Evaluation hint:",
119
+ "This usually means browser-only code ran during build-time evaluation.",
120
+ "Move browser-only initialization out of evaluated modules, or mock the import via `importOverrides`.",
121
+ "Example: importOverrides: { 'msw/browser': { mock: './src/__mocks__/msw-browser.js' } }",
122
+ `Docs: ${TROUBLESHOOTING_URL}`
123
+ ].join("\n");
99
124
  };
100
125
  const warnedUnknownImportsByServices = new WeakMap();
126
+ const getEvalOptions = (services) => ({
127
+ ...defaultEvalOptions,
128
+ ...services.options.pluginOptions.eval ?? {}
129
+ });
101
130
  function emitWarning(services, message) {
102
- if (services.emitWarning) {
103
- services.emitWarning(message);
104
- return;
105
- }
106
-
107
- // eslint-disable-next-line no-console
108
- console.warn(message);
131
+ if (services.emitWarning) {
132
+ services.emitWarning(message);
133
+ return;
134
+ }
135
+ // eslint-disable-next-line no-console
136
+ console.warn(message);
137
+ }
138
+ function emitEvalWarning(services, warning) {
139
+ const { onWarn } = getEvalOptions(services);
140
+ onWarn?.(warning);
141
+ emitWarning(services, warning.message);
109
142
  }
110
143
  function getWarnedUnknownImports(services) {
111
- const cached = warnedUnknownImportsByServices.get(services);
112
- if (cached) {
113
- return cached;
114
- }
115
- const created = new Set();
116
- warnedUnknownImportsByServices.set(services, created);
117
- return created;
144
+ const cached = warnedUnknownImportsByServices.get(services);
145
+ if (cached) {
146
+ return cached;
147
+ }
148
+ const created = new Set();
149
+ warnedUnknownImportsByServices.set(services, created);
150
+ return created;
118
151
  }
119
152
  function getUncached(cached, test) {
120
- const cachedSet = new Set(typeof cached === 'string' ? cached.split(',') : cached);
121
- if (cachedSet.has('*')) {
122
- return [];
123
- }
124
- return test.filter(t => !cachedSet.has(t));
125
- }
126
- function resolve(id) {
127
- const {
128
- resolved
129
- } = this.resolveDependency(id);
130
- invariant(resolved, `Unable to resolve "${id}"`);
131
- return resolved;
153
+ const cachedSet = new Set(typeof cached === "string" ? cached.split(",") : cached);
154
+ if (cachedSet.has("*")) {
155
+ return [];
156
+ }
157
+ return test.filter((t) => !cachedSet.has(t));
132
158
  }
133
159
  const defaultImportLoaders = {
134
- raw: 'raw',
135
- url: 'url'
160
+ raw: "raw",
161
+ url: "url"
162
+ };
163
+ const buildModulePreamble = (id) => {
164
+ const payload = JSON.stringify(id);
165
+ return [
166
+ `const __wyw_module = __wyw_getModule(${payload});`,
167
+ `let exports = __wyw_module.exports;`,
168
+ `const module = __wyw_module.module;`,
169
+ `const require = __wyw_module.require;`,
170
+ `const __filename = __wyw_module.filename;`,
171
+ `const __dirname = __wyw_module.dirname;`,
172
+ `const __wyw_dynamic_import = __wyw_module.dynamicImport;`,
173
+ ``
174
+ ].join("\n");
175
+ };
176
+ const applyModuleNamespace = (entrypointExports, module, moduleData) => {
177
+ const { namespace } = module;
178
+ const keys = Object.keys(namespace);
179
+ if (keys.length === 0 && moduleData.module.exports !== moduleData.exports) {
180
+ return moduleData.module.exports;
181
+ }
182
+ const nextExports = entrypointExports;
183
+ keys.forEach((key) => {
184
+ nextExports[key] = namespace[key];
185
+ });
186
+ return nextExports;
187
+ };
188
+ const ensureVmModules = () => {
189
+ if (!vm.SourceTextModule || !vm.SyntheticModule) {
190
+ throw new EvalError("[wyw-in-js] vm.SourceTextModule is not available in this runtime. " + "WyW v2 uses a separate eval runner process for ESM evaluation.");
191
+ }
192
+ };
193
+ const getImporterDependency = (importer, specifier) => {
194
+ if (importer instanceof Entrypoint) {
195
+ return importer.getDependency(specifier);
196
+ }
197
+ return importer.dependencies.get(specifier);
136
198
  };
137
199
  export class Module {
138
- callstack = [];
139
- isEvaluated = false;
140
- require = Object.assign(id => {
141
- if (id === REACT_REFRESH_VIRTUAL_ID) {
142
- this.dependencies.push(id);
143
- this.debug('require', `vite virtual '${id}'`);
144
- return reactRefreshRuntime;
145
- }
146
- if (id.startsWith(VITE_VIRTUAL_PREFIX)) {
147
- this.dependencies.push(id);
148
- this.debug('require', `vite virtual '${id}'`);
149
- return {};
150
- }
151
- if (id in builtins) {
152
- // The module is in the allowed list of builtin node modules
153
- // Ideally we should prevent importing them, but webpack polyfills some
154
- // So we check for the list of polyfills to determine which ones to support
155
- if (builtins[id]) {
156
- this.debug('require', `builtin '${id}'`);
157
- return require(id);
158
- }
159
- return null;
160
- }
161
-
162
- // Resolve module id (and filename) relatively to parent module
163
- const dependency = this.resolveDependency(id);
164
- if (dependency.resolved === id && !path.isAbsolute(id)) {
165
- // The module is a builtin node modules, but not in the allowed list
166
- throw new Error(`Unable to import "${id}". Importing Node builtins is not supported in the sandbox.`);
167
- }
168
- invariant(dependency.resolved, `Dependency ${dependency.source} cannot be resolved`);
169
- const loaded = this.loadByImportLoaders(id, dependency.resolved);
170
- if (loaded.handled) {
171
- this.dependencies.push(id);
172
- this.debug('require', `${id} -> ${dependency.resolved} (loader)`);
173
- return loaded.value;
174
- }
175
- this.dependencies.push(id);
176
- this.debug('require', `${id} -> ${dependency.resolved}`);
177
- const entrypoint = this.getEntrypoint(dependency.resolved, dependency.only, this.debug);
178
- if (entrypoint === null) {
179
- return dependency.resolved;
180
- }
181
- if (entrypoint.evaluated || isSuperSet(entrypoint.evaluatedOnly, dependency.only)) {
182
- return entrypoint.exports;
183
- }
184
- const m = this.createChild(entrypoint);
185
- m.evaluate();
186
- return entrypoint.exports;
187
- }, {
188
- ensure: NOOP,
189
- resolve: resolve.bind(this)
190
- });
191
- resolve = resolve.bind(this);
192
- #entrypointRef;
193
- constructor(services, entrypoint, parentModule, moduleImpl = DefaultModuleImplementation) {
194
- this.services = services;
195
- this.moduleImpl = moduleImpl;
196
- this.cache = services.cache;
197
- this.#entrypointRef = isFeatureEnabled(services.options.pluginOptions.features, 'useWeakRefInEval', entrypoint.name) ? new WeakRef(entrypoint) : entrypoint;
198
- this.idx = entrypoint.idx;
199
- this.id = entrypoint.name;
200
- this.filename = entrypoint.name;
201
- this.dependencies = [];
202
- this.debug = entrypoint.log.extend('module');
203
- this.parentIsIgnored = parentModule?.ignored ?? false;
204
- this.ignored = entrypoint.ignored ?? this.parentIsIgnored;
205
- if (parentModule) {
206
- this.callstack = [entrypoint.name, ...parentModule.callstack];
207
- } else {
208
- this.callstack = [entrypoint.name];
209
- }
210
- this.extensions = services.options.pluginOptions.extensions;
211
- this.debug('init', entrypoint.name);
212
- }
213
- get exports() {
214
- return this.entrypoint.exports;
215
- }
216
- set exports(value) {
217
- this.entrypoint.exports = value;
218
- this.debug('the whole exports was overridden with %O', value);
219
- }
220
- get entrypoint() {
221
- const entrypoint = this.#entrypointRef instanceof WeakRef ? this.#entrypointRef.deref() : this.#entrypointRef;
222
- invariant(entrypoint, `Module ${this.idx} is disposed`);
223
- return entrypoint;
224
- }
225
- evaluate() {
226
- const {
227
- entrypoint
228
- } = this;
229
- entrypoint.assertTransformed();
230
- const cached = this.cache.get('entrypoints', entrypoint.name);
231
- let evaluatedCreated = false;
232
- if (!entrypoint.supersededWith) {
233
- this.cache.add('entrypoints', entrypoint.name, entrypoint.createEvaluated());
234
- evaluatedCreated = true;
235
- }
236
- const {
237
- transformedCode: source
238
- } = entrypoint;
239
- const {
240
- pluginOptions
241
- } = this.services.options;
242
- if (!source) {
243
- this.debug(`evaluate`, 'there is nothing to evaluate');
244
- return;
245
- }
246
- if (this.isEvaluated) {
247
- this.debug('evaluate', `is already evaluated`);
248
- return;
249
- }
250
- this.debug('evaluate');
251
- this.debug.extend('source')('%s', source);
252
- this.isEvaluated = true;
253
- const filename = stripQueryAndHash(this.filename);
254
- if (/\.json$/.test(filename)) {
255
- // For JSON files, parse it to a JS object similar to Node
256
- this.exports = JSON.parse(source);
257
- return;
258
- }
259
- const {
260
- context,
261
- teardown
262
- } = createVmContext(filename, pluginOptions.features, {
263
- module: this,
264
- exports: entrypoint.exports,
265
- require: this.require,
266
- __wyw_dynamic_import: async id => this.require(String(id)),
267
- __dirname: path.dirname(filename)
268
- }, pluginOptions.overrideContext);
269
- try {
270
- const script = new vm.Script(`(function (exports) { ${source}\n})(exports);`, {
271
- filename
272
- });
273
- script.runInContext(context);
274
- } catch (e) {
275
- this.isEvaluated = false;
276
- if (evaluatedCreated) {
277
- this.cache.add('entrypoints', entrypoint.name, cached);
278
- }
279
- if (isUnprocessedEntrypointError(e)) {
280
- // It will be handled by evalFile scenario
281
- throw e;
282
- }
283
- if (e instanceof EvalError) {
284
- this.debug('%O', e);
285
- throw e;
286
- }
287
- this.debug('%O\n%O', e, this.callstack);
288
- const baseMessage = `${e.message} in${this.callstack.join('\n| ')}\n`;
289
- const hint = getBrowserOnlyEvalHint(e);
290
- throw new EvalError(hint ? `${baseMessage}${hint}\n` : baseMessage);
291
- } finally {
292
- teardown();
293
- }
294
- }
295
- getEntrypoint(filename, only, log) {
296
- const strippedFilename = stripQueryAndHash(filename);
297
- const extension = path.extname(strippedFilename);
298
- if (extension !== '.json' && !this.extensions.includes(extension)) {
299
- return null;
300
- }
301
- let entrypoint = this.cache.get('entrypoints', filename);
302
- if (entrypoint && isSuperSet(entrypoint.evaluatedOnly ?? [], only)) {
303
- if (this.cache.checkFreshness(filename, strippedFilename)) {
304
- entrypoint = undefined;
305
- }
306
- if (entrypoint) {
307
- log(' file has been already evaluated');
308
- return entrypoint;
309
- }
310
- }
311
- if (entrypoint?.ignored) {
312
- log('✅ file has been ignored during prepare stage. Original code will be used');
313
- return entrypoint;
314
- }
315
- if (this.ignored) {
316
- log('one of the parent files has been ignored during prepare stage. Original code will be used');
317
- const newEntrypoint = this.entrypoint.createChild(filename, ['*'], fs.readFileSync(strippedFilename, 'utf-8'));
318
- if (newEntrypoint === 'loop') {
319
- const stack = getStack(this.entrypoint);
320
- throw new Error(`Circular dependency detected: ${stack.join(' -> ')} -> ${filename}`);
321
- }
322
- return newEntrypoint;
323
- }
324
- let uncachedExports = null;
325
- let reprocessOnly = only;
326
- // Requested file can be already prepared for evaluation on the stage 1
327
- if (only && entrypoint) {
328
- const evaluatedExports = entrypoint.evaluatedOnly?.length !== 0 ? entrypoint.evaluatedOnly : entrypoint.only ?? [];
329
- uncachedExports = getUncached(evaluatedExports, only);
330
- if (uncachedExports.length === 0) {
331
- log('✅ ready for evaluation');
332
- return entrypoint;
333
- }
334
- if (entrypoint.evaluatedOnly?.length) {
335
- reprocessOnly = mergeOnly(evaluatedExports, only);
336
- }
337
- log('❌ file has been processed during prepare stage but %o is not evaluated yet (evaluated: %o)', uncachedExports, evaluatedExports);
338
- } else {
339
- log('❌ file has not been processed during prepare stage');
340
- }
341
-
342
- // If code wasn't extracted from cache, it indicates that we were unable
343
- // to process some of the imports on stage1. Let's try to reprocess.
344
- const code = fs.readFileSync(strippedFilename, 'utf-8');
345
- const newEntrypoint = Entrypoint.createRoot(this.services, filename, reprocessOnly, code);
346
- if (newEntrypoint.evaluated) {
347
- log('✅ file has been already evaluated');
348
- return newEntrypoint;
349
- }
350
- if (newEntrypoint.ignored) {
351
- log('✅ file has been ignored during prepare stage. Original code will be used');
352
- return newEntrypoint;
353
- }
354
- return newEntrypoint;
355
- }
356
- resolveWithConditions(id, parent, conditions) {
357
- const resolveOptions = conditions ? {
358
- conditions
359
- } : undefined;
360
- const shouldRetryWithExtensions = conditions && path.extname(id) === '' && (id.startsWith('.') || path.isAbsolute(id) || isBarePackageSubpath(id));
361
- try {
362
- return this.moduleImpl._resolveFilename(id, parent, false, resolveOptions);
363
- } catch (e) {
364
- if (shouldRetryWithExtensions && e instanceof Error && e.code === 'MODULE_NOT_FOUND') {
365
- // Extensionless subpath requests (e.g. "pkg/src/*" or "./src/*") may
366
- // resolve to extensionless targets via conditional exports. Retry with
367
- // each known extension, but never rewrite already explicit specifiers.
368
- for (const ext of this.extensions) {
369
- try {
370
- return this.moduleImpl._resolveFilename(id + ext, parent, false, resolveOptions);
371
- } catch {
372
- // try next extension
373
- }
374
- }
375
- }
376
- throw e;
377
- }
378
- }
379
- resolveDependency = id => {
380
- const cached = this.entrypoint.getDependency(id);
381
- invariant(!(cached instanceof Promise), 'Dependency is not resolved yet');
382
- if (cached) {
383
- return cached;
384
- }
385
- if (!this.ignored) {
386
- this.debug('❌ import has not been resolved during prepare stage. Fallback to Node.js resolver');
387
- }
388
- const extensions = this.moduleImpl._extensions;
389
- const added = [];
390
- try {
391
- // Check for supported extensions
392
- this.extensions.forEach(ext => {
393
- if (ext in extensions) {
394
- return;
395
- }
396
-
397
- // When an extension is not supported, add it
398
- // And keep track of it to clean it up after resolving
399
- // Use noop for the transform function since we handle it
400
- extensions[ext] = NOOP;
401
- added.push(ext);
402
- });
403
- const {
404
- filename
405
- } = this;
406
- const strippedId = stripQueryAndHash(id);
407
- const parent = {
408
- id: filename,
409
- filename,
410
- paths: this.moduleImpl._nodeModulePaths(path.dirname(filename))
411
- };
412
- const {
413
- conditionNames
414
- } = this.services.options.pluginOptions;
415
- const conditions = conditionNames?.length ? expandConditions(conditionNames) : undefined;
416
- let resolved = this.resolveWithConditions(strippedId, parent, conditions);
417
- const isFileSpecifier = strippedId.startsWith('.') || path.isAbsolute(strippedId);
418
- if (isFileSpecifier && path.extname(strippedId) === '' && resolved.endsWith('.cjs') && fs.existsSync(`${resolved.slice(0, -4)}.js`)) {
419
- // When both `.cjs` and `.js` exist for an extensionless specifier, the
420
- // resolver may pick `.cjs` depending on the environment/extensions.
421
- // Prefer `.js` to keep resolved paths stable (e.g. importOverrides keys).
422
- resolved = `${resolved.slice(0, -4)}.js`;
423
- }
424
- const {
425
- root
426
- } = this.services.options;
427
- const keyInfo = toImportKey({
428
- source: id,
429
- resolved,
430
- root
431
- });
432
- const override = getImportOverride(this.services.options.pluginOptions.importOverrides, keyInfo.key);
433
- const policy = override?.unknown ?? (override?.mock ? 'allow' : 'warn');
434
- const shouldWarn = !this.ignored && policy === 'warn';
435
- let finalResolved = resolved;
436
- if (override?.mock) {
437
- try {
438
- finalResolved = resolveMockSpecifier({
439
- mock: override.mock,
440
- importer: filename,
441
- root,
442
- stack: this.callstack
443
- });
444
- } catch (e) {
445
- const errorMessage = String(e?.message ?? e);
446
- throw new Error(`[wyw-in-js] Failed to resolve import mock for "${keyInfo.key}" (${id} from ${filename}): ${errorMessage}`);
447
- }
448
- }
449
- if (policy === 'error') {
450
- throw new Error([`[wyw-in-js] Unknown import reached during eval (Node resolver fallback)`, ``, `importer: ${filename}`, `source: ${id}`, `resolved: ${resolved}`, override?.mock ? `mock: ${override.mock} -> ${finalResolved}` : ``, ``, `callstack:`, ...this.callstack.map(item => ` ${item}`), ``, `config key: ${keyInfo.key}`].filter(Boolean).join('\n'));
451
- }
452
- const warnedUnknownImports = getWarnedUnknownImports(this.services);
453
- if (shouldWarn && !warnedUnknownImports.has(keyInfo.key)) {
454
- warnedUnknownImports.add(keyInfo.key);
455
- emitWarning(this.services, [`[wyw-in-js] Unknown import reached during eval (Node resolver fallback)`, ``, `importer: ${filename}`, `source: ${id}`, `resolved: ${resolved}`, override?.mock ? `mock: ${override.mock} -> ${finalResolved}` : ``, ``, `callstack:`, ...this.callstack.map(item => ` ${item}`), ``, `config key: ${keyInfo.key}`, `hint: add { importOverrides: { ${JSON.stringify(keyInfo.key)}: { unknown: 'allow' } } } to silence warnings, or use { mock } / { noShake: true } overrides.`].filter(Boolean).join('\n'));
456
- }
457
- return {
458
- source: id,
459
- only: applyImportOverrideToOnly(['*'], override),
460
- resolved: finalResolved
461
- };
462
- } finally {
463
- // Cleanup the extensions we added to restore previous behaviour
464
- added.forEach(ext => delete extensions[ext]);
465
- }
466
- };
467
- createChild(entrypoint) {
468
- return new Module(this.services, entrypoint, this, this.moduleImpl);
469
- }
470
- loadByImportLoaders(request, resolved) {
471
- const {
472
- pluginOptions
473
- } = this.services.options;
474
- const importLoaders = pluginOptions.importLoaders === undefined ? defaultImportLoaders : {
475
- ...defaultImportLoaders,
476
- ...pluginOptions.importLoaders
477
- };
478
- const {
479
- query,
480
- hash
481
- } = parseRequest(request);
482
- if (!query) return {
483
- handled: false,
484
- value: undefined
485
- };
486
- const params = new URLSearchParams(query);
487
- const matchedKey = Array.from(params.keys()).find(key => importLoaders[key] !== undefined && importLoaders[key] !== false);
488
- if (!matchedKey) return {
489
- handled: false,
490
- value: undefined
491
- };
492
- const loader = importLoaders[matchedKey];
493
- const filename = stripQueryAndHash(resolved);
494
- const importer = stripQueryAndHash(this.filename);
495
- const importerDir = path.dirname(importer);
496
- const toUrl = () => {
497
- const relative = path.relative(importerDir, filename).replace(/\\/g, path.posix.sep);
498
- if (relative.startsWith('.') || path.isAbsolute(relative)) {
499
- return relative;
500
- }
501
- return `./${relative}`;
502
- };
503
- const readFile = () => fs.readFileSync(filename, 'utf-8');
504
- const context = {
505
- importer,
506
- request,
507
- resolved,
508
- filename,
509
- query,
510
- hash,
511
- emitWarning: message => emitWarning(this.services, message),
512
- readFile,
513
- toUrl
514
- };
515
- if (loader === 'raw') {
516
- return {
517
- handled: true,
518
- value: context.readFile()
519
- };
520
- }
521
- if (loader === 'url') {
522
- return {
523
- handled: true,
524
- value: context.toUrl()
525
- };
526
- }
527
- if (typeof loader === 'function') {
528
- return {
529
- handled: true,
530
- value: loader(context)
531
- };
532
- }
533
- return {
534
- handled: false,
535
- value: undefined
536
- };
537
- }
200
+ callstack = [];
201
+ debug;
202
+ dependencies;
203
+ extensions;
204
+ filename;
205
+ id;
206
+ idx;
207
+ ignored;
208
+ isEvaluated = false;
209
+ parentIsIgnored;
210
+ require = Object.assign((id, nonLiteral) => this.requireWithFallback(id, this.entrypoint, nonLiteral), {
211
+ ensure: NOOP,
212
+ resolve: (id) => this.resolveRequire(id, this.entrypoint).resolved
213
+ });
214
+ resolve = (id) => this.resolveRequire(id, this.entrypoint).resolved;
215
+ cache;
216
+ context = null;
217
+ teardown = null;
218
+ moduleCache = new Map();
219
+ moduleEntrypoints = new WeakMap();
220
+ moduleLinkPromises = new WeakMap();
221
+ moduleData = new Map();
222
+ #entrypointRef;
223
+ constructor(services, entrypoint, parentModule, moduleImpl = DefaultModuleImplementation) {
224
+ this.services = services;
225
+ this.moduleImpl = moduleImpl;
226
+ this.cache = services.cache;
227
+ this.#entrypointRef = isFeatureEnabled(services.options.pluginOptions.features, "useWeakRefInEval", entrypoint.name) ? new WeakRef(entrypoint) : entrypoint;
228
+ this.idx = entrypoint.idx;
229
+ this.id = entrypoint.name;
230
+ this.filename = entrypoint.name;
231
+ this.dependencies = [];
232
+ this.debug = entrypoint.log.extend("module");
233
+ this.parentIsIgnored = parentModule?.ignored ?? false;
234
+ this.ignored = entrypoint.ignored ?? this.parentIsIgnored;
235
+ if (parentModule) {
236
+ this.callstack = [entrypoint.name, ...parentModule.callstack];
237
+ } else {
238
+ this.callstack = [entrypoint.name];
239
+ }
240
+ this.extensions = services.options.pluginOptions.extensions;
241
+ this.debug("init", entrypoint.name);
242
+ }
243
+ get exports() {
244
+ return this.entrypoint.exports;
245
+ }
246
+ set exports(value) {
247
+ this.entrypoint.exports = value;
248
+ this.debug("the whole exports was overridden with %O", value);
249
+ }
250
+ get entrypoint() {
251
+ const entrypoint = this.#entrypointRef instanceof WeakRef ? this.#entrypointRef.deref() : this.#entrypointRef;
252
+ invariant(entrypoint, `Module ${this.idx} is disposed`);
253
+ return entrypoint;
254
+ }
255
+ async evaluate() {
256
+ const { entrypoint } = this;
257
+ entrypoint.assertTransformed();
258
+ const cached = this.cache.get("entrypoints", entrypoint.name);
259
+ let evaluatedCreated = false;
260
+ if (!entrypoint.supersededWith) {
261
+ this.cache.add("entrypoints", entrypoint.name, entrypoint.createEvaluated());
262
+ evaluatedCreated = true;
263
+ }
264
+ const { transformedCode: source } = entrypoint;
265
+ if (!source) {
266
+ this.debug(`evaluate`, "there is nothing to evaluate");
267
+ return;
268
+ }
269
+ if (this.isEvaluated) {
270
+ this.debug("evaluate", `is already evaluated`);
271
+ return;
272
+ }
273
+ this.debug("evaluate");
274
+ this.debug.extend("source")("%s", source);
275
+ this.isEvaluated = true;
276
+ const filename = stripQueryAndHash(this.filename);
277
+ if (/\.json$/.test(filename)) {
278
+ // For JSON files, parse it to a JS object similar to Node
279
+ this.exports = JSON.parse(source);
280
+ return;
281
+ }
282
+ const { teardown } = await this.ensureContext(filename);
283
+ try {
284
+ const module = await this.getModuleForEntrypoint(entrypoint);
285
+ await this.linkModule(module);
286
+ await module.evaluate();
287
+ const exports = applyModuleNamespace(entrypoint.exports, module, this.getModuleData(entrypoint.name));
288
+ if (exports !== entrypoint.exports) {
289
+ entrypoint.exports = exports;
290
+ }
291
+ } catch (e) {
292
+ this.isEvaluated = false;
293
+ if (evaluatedCreated) {
294
+ this.cache.add("entrypoints", entrypoint.name, cached);
295
+ }
296
+ if (isUnprocessedEntrypointError(e)) {
297
+ // It will be handled by evalFile scenario
298
+ throw e;
299
+ }
300
+ if (e instanceof EvalError) {
301
+ this.debug("%O", e);
302
+ throw e;
303
+ }
304
+ this.debug("%O\n%O", e, this.callstack);
305
+ const baseMessage = `${e.message} in${this.callstack.join("\n| ")}\n`;
306
+ const hint = getBrowserOnlyEvalHint(e);
307
+ throw new EvalError(hint ? `${baseMessage}${hint}\n` : baseMessage);
308
+ } finally {
309
+ teardown();
310
+ }
311
+ }
312
+ getEntrypoint(filename, only, log) {
313
+ const strippedFilename = stripQueryAndHash(filename);
314
+ const extension = path.extname(strippedFilename);
315
+ if (extension !== ".json" && !this.extensions.includes(extension)) {
316
+ return null;
317
+ }
318
+ let entrypoint = this.cache.get("entrypoints", filename);
319
+ if (entrypoint && isSuperSet(entrypoint.evaluatedOnly ?? [], only)) {
320
+ if (this.cache.checkFreshness(filename, strippedFilename)) {
321
+ entrypoint = undefined;
322
+ }
323
+ if (entrypoint) {
324
+ log("✅ file has been already evaluated");
325
+ return entrypoint;
326
+ }
327
+ }
328
+ if (entrypoint?.ignored) {
329
+ log("✅ file has been ignored during prepare stage. Original code will be used");
330
+ return entrypoint;
331
+ }
332
+ if (this.ignored) {
333
+ log("✅ one of the parent files has been ignored during prepare stage. Original code will be used");
334
+ const newEntrypoint = this.entrypoint.createChild(filename, ["*"], fs.readFileSync(strippedFilename, "utf-8"));
335
+ if (newEntrypoint === "loop") {
336
+ const stack = getStack(this.entrypoint);
337
+ throw new Error(`Circular dependency detected: ${stack.join(" -> ")} -> ${filename}`);
338
+ }
339
+ return newEntrypoint;
340
+ }
341
+ let uncachedExports = null;
342
+ let reprocessOnly = only;
343
+ let cachedSource;
344
+ // Requested file can be already prepared for evaluation on the stage 1
345
+ if (only && entrypoint) {
346
+ const evaluatedExports = entrypoint.evaluatedOnly?.length !== 0 ? entrypoint.evaluatedOnly : entrypoint.only ?? [];
347
+ uncachedExports = getUncached(evaluatedExports, only);
348
+ if (uncachedExports.length === 0) {
349
+ log("✅ ready for evaluation");
350
+ return entrypoint;
351
+ }
352
+ if (entrypoint.evaluatedOnly?.length) {
353
+ if (this.cache.checkFreshness(filename, strippedFilename)) {
354
+ entrypoint = undefined;
355
+ uncachedExports = null;
356
+ } else {
357
+ reprocessOnly = mergeOnly(evaluatedExports, only);
358
+ cachedSource = entrypoint.loadedAndParsed?.code ?? entrypoint.initialCode;
359
+ }
360
+ }
361
+ if (entrypoint) {
362
+ log("❌ file has been processed during prepare stage but %o is not evaluated yet (evaluated: %o)", uncachedExports, evaluatedExports);
363
+ } else {
364
+ log("❌ file has not been processed during prepare stage");
365
+ }
366
+ } else {
367
+ log("❌ file has not been processed during prepare stage");
368
+ }
369
+ // If code wasn't extracted from cache, it indicates that we were unable
370
+ // to process some of the imports on stage1. Let's try to reprocess.
371
+ const code = cachedSource ?? fs.readFileSync(strippedFilename, "utf-8");
372
+ const newEntrypoint = Entrypoint.createRoot(this.services, filename, reprocessOnly, code);
373
+ if (newEntrypoint.evaluated) {
374
+ log("✅ file has been already evaluated");
375
+ return newEntrypoint;
376
+ }
377
+ if (newEntrypoint.ignored) {
378
+ log("file has been ignored during prepare stage. Original code will be used");
379
+ return newEntrypoint;
380
+ }
381
+ return newEntrypoint;
382
+ }
383
+ async ensureContext(filename) {
384
+ if (this.context && this.teardown) {
385
+ return {
386
+ context: this.context,
387
+ teardown: this.teardown
388
+ };
389
+ }
390
+ const evalOptions = getEvalOptions(this.services);
391
+ const { context, teardown } = await createVmContext(filename, this.services.options.pluginOptions.features, {
392
+ ...evalOptions.globals ?? {},
393
+ __wyw_getModule: (id) => this.getModuleData(id)
394
+ }, this.services.options.pluginOptions.overrideContext);
395
+ this.context = context;
396
+ this.teardown = () => {
397
+ teardown();
398
+ this.context = null;
399
+ this.teardown = null;
400
+ };
401
+ return {
402
+ context: this.context,
403
+ teardown: this.teardown
404
+ };
405
+ }
406
+ getModuleData(id) {
407
+ const data = this.moduleData.get(id);
408
+ invariant(data, `Missing module data for ${id}`);
409
+ return data;
410
+ }
411
+ createModuleData(id, entrypoint) {
412
+ const cached = this.moduleData.get(id);
413
+ if (cached) return cached;
414
+ const exporter = entrypoint ?? this.entrypoint;
415
+ const exportsProxy = entrypoint && "exports" in entrypoint ? entrypoint.exports : {};
416
+ const moduleObj = { exports: exportsProxy };
417
+ const requireFn = Object.assign((request) => this.requireWithFallback(request, exporter), {
418
+ ensure: NOOP,
419
+ resolve: (request) => this.resolveRequire(request, exporter).resolved
420
+ });
421
+ const filename = stripQueryAndHash(id);
422
+ const data = {
423
+ exports: exportsProxy,
424
+ module: moduleObj,
425
+ require: requireFn,
426
+ filename,
427
+ dirname: path.dirname(filename),
428
+ dynamicImport: (request) => this.dynamicImportFrom(exporter, request)
429
+ };
430
+ this.moduleData.set(id, data);
431
+ return data;
432
+ }
433
+ async createSourceTextModule(id, code, entrypoint) {
434
+ ensureVmModules();
435
+ const { context } = await this.ensureContext(stripQueryAndHash(id));
436
+ this.createModuleData(id, entrypoint);
437
+ const module = new vm.SourceTextModule(`${buildModulePreamble(id)}${code}`, {
438
+ context,
439
+ identifier: id,
440
+ initializeImportMeta: (meta, targetModule) => {
441
+ const identifier = typeof targetModule.identifier === "string" ? targetModule.identifier : id;
442
+ const fileId = stripQueryAndHash(identifier);
443
+ Object.assign(meta, { url: path.isAbsolute(fileId) ? pathToFileURL(fileId).href : fileId });
444
+ },
445
+ importModuleDynamically: (specifier, referencingModule) => this.importModuleDynamically(specifier, referencingModule)
446
+ });
447
+ this.moduleCache.set(id, module);
448
+ if (entrypoint) {
449
+ this.moduleEntrypoints.set(module, entrypoint);
450
+ }
451
+ return module;
452
+ }
453
+ async createSyntheticModule(id, exportsValue) {
454
+ ensureVmModules();
455
+ const { context } = await this.ensureContext(stripQueryAndHash(id));
456
+ const exportNames = new Set(Object.keys(exportsValue));
457
+ const hasDefault = Object.prototype.hasOwnProperty.call(exportsValue, "default");
458
+ if (!exportNames.has("default")) {
459
+ exportNames.add("default");
460
+ }
461
+ const module = new vm.SyntheticModule([...exportNames], function init() {
462
+ exportNames.forEach((key) => {
463
+ const value = key === "default" && !hasDefault ? exportsValue : exportsValue[key];
464
+ this.setExport(key, value);
465
+ });
466
+ }, {
467
+ context,
468
+ identifier: id
469
+ });
470
+ this.moduleCache.set(id, module);
471
+ return module;
472
+ }
473
+ async getVirtualModule(specifier) {
474
+ if (specifier === REACT_REFRESH_VIRTUAL_ID) {
475
+ return this.createSyntheticModule(specifier, { createSignatureFunctionForTransform: reactRefreshRuntime.createSignatureFunctionForTransform });
476
+ }
477
+ if (specifier.startsWith(VITE_VIRTUAL_PREFIX)) {
478
+ return this.createSyntheticModule(specifier, { default: {} });
479
+ }
480
+ if (specifier.startsWith("virtual:")) {
481
+ return this.createSyntheticModule(specifier, { default: {} });
482
+ }
483
+ return null;
484
+ }
485
+ async getModuleForEntrypoint(entrypoint) {
486
+ const cached = this.moduleCache.get(entrypoint.name);
487
+ if (cached) return cached;
488
+ if (!(entrypoint instanceof Entrypoint)) {
489
+ return this.createSyntheticModule(entrypoint.name, entrypoint.exports);
490
+ }
491
+ entrypoint.assertTransformed();
492
+ const source = entrypoint.transformedCode ?? "";
493
+ return this.createSourceTextModule(entrypoint.name, source, entrypoint);
494
+ }
495
+ async linkModule(module) {
496
+ const cached = this.moduleLinkPromises.get(module);
497
+ if (cached) {
498
+ await cached;
499
+ return;
500
+ }
501
+ if (module.status !== "unlinked") {
502
+ return;
503
+ }
504
+ const linking = module.link((specifier, referencingModule) => this.getModuleForSpecifier(specifier, referencingModule, "import"));
505
+ this.moduleLinkPromises.set(module, linking);
506
+ await linking;
507
+ }
508
+ async importModuleDynamically(specifier, referencingModule) {
509
+ const module = await this.getModuleForSpecifier(specifier, referencingModule, "dynamic-import");
510
+ await this.linkModule(module);
511
+ if (module.status === "linked") {
512
+ await module.evaluate();
513
+ }
514
+ return module;
515
+ }
516
+ async dynamicImportFrom(importer, id) {
517
+ const specifier = String(id);
518
+ const module = await this.getModuleForSpecifierFromEntrypoint(specifier, importer, "dynamic-import");
519
+ await this.linkModule(module);
520
+ if (module.status === "linked") {
521
+ await module.evaluate();
522
+ }
523
+ return module.namespace;
524
+ }
525
+ async getModuleForSpecifier(specifier, referencingModule, kind) {
526
+ const importer = this.moduleEntrypoints.get(referencingModule) ?? this.entrypoint;
527
+ return this.getModuleForSpecifierFromEntrypoint(specifier, importer, kind);
528
+ }
529
+ async getModuleForSpecifierFromEntrypoint(specifier, importer, kind) {
530
+ const virtualModule = await this.getVirtualModule(specifier);
531
+ if (virtualModule) {
532
+ return virtualModule;
533
+ }
534
+ this.dependencies.push(specifier);
535
+ const resolved = await this.resolveImport(specifier, importer, kind);
536
+ const evalOptions = getEvalOptions(this.services);
537
+ if (!resolved) {
538
+ if (evalOptions.mode === "loose") {
539
+ return this.createSyntheticModule(specifier, { default: undefined });
540
+ }
541
+ throw new Error([
542
+ `[wyw-in-js] Unable to resolve "${specifier}" during evaluation.`,
543
+ ``,
544
+ `importer: ${importer.name}`,
545
+ `hint: check eval.resolver/customResolver or add importOverrides for this specifier.`,
546
+ `docs: ${TROUBLESHOOTING_URL}`
547
+ ].join("\n"));
548
+ }
549
+ if (resolved.external) {
550
+ return this.createSyntheticModule(resolved.resolved, { default: undefined });
551
+ }
552
+ return this.getModuleForResolved(resolved, importer);
553
+ }
554
+ async resolveImport(specifier, importer, kind) {
555
+ const evalOptions = getEvalOptions(this.services);
556
+ if (evalOptions.customResolver) {
557
+ const customResolved = await evalOptions.customResolver(specifier, importer.name, kind);
558
+ if (customResolved) {
559
+ return this.applyImportOverrides({
560
+ source: specifier,
561
+ resolved: customResolved.id,
562
+ only: ["*"],
563
+ external: customResolved.external
564
+ }, importer);
565
+ }
566
+ if (evalOptions.resolver === "custom") {
567
+ return null;
568
+ }
569
+ }
570
+ if (evalOptions.resolver !== "node") {
571
+ const dependency = getImporterDependency(importer, specifier);
572
+ if (dependency?.resolved) {
573
+ return {
574
+ source: specifier,
575
+ resolved: dependency.resolved,
576
+ only: dependency.only
577
+ };
578
+ }
579
+ }
580
+ if (evalOptions.resolver === "node" || evalOptions.require !== "off") {
581
+ return this.resolveWithNodeFallback(specifier, importer, kind);
582
+ }
583
+ return null;
584
+ }
585
+ resolveRequire(specifier, importer) {
586
+ const dependency = getImporterDependency(importer, specifier);
587
+ if (dependency?.resolved) {
588
+ return this.applyImportOverrides({
589
+ source: specifier,
590
+ resolved: dependency.resolved,
591
+ only: dependency.only
592
+ }, importer);
593
+ }
594
+ return this.resolveWithNodeFallback(specifier, importer, "require");
595
+ }
596
+ applyImportOverrides(resolved, importer) {
597
+ const { root } = this.services.options;
598
+ const keyInfo = toImportKey({
599
+ source: resolved.source,
600
+ resolved: resolved.resolved,
601
+ root
602
+ });
603
+ const override = getImportOverride(this.services.options.pluginOptions.importOverrides, keyInfo.key);
604
+ if (!override) {
605
+ return resolved;
606
+ }
607
+ let nextResolved = resolved.resolved;
608
+ if (override.mock) {
609
+ nextResolved = resolveMockSpecifier({
610
+ mock: override.mock,
611
+ importer: importer.name,
612
+ root,
613
+ stack: getStack(importer)
614
+ });
615
+ }
616
+ return {
617
+ ...resolved,
618
+ resolved: nextResolved,
619
+ only: applyImportOverrideToOnly(resolved.only, override)
620
+ };
621
+ }
622
+ async getModuleForResolved(resolved, importer) {
623
+ const cached = this.moduleCache.get(resolved.resolved);
624
+ if (cached) return cached;
625
+ const evalOptions = getEvalOptions(this.services);
626
+ if (evalOptions.customLoader) {
627
+ const loaded = await evalOptions.customLoader(resolved.resolved);
628
+ if (loaded) {
629
+ if (loaded.loader === "json") {
630
+ const jsonValue = JSON.parse(loaded.code);
631
+ return this.createSyntheticModule(resolved.resolved, { default: jsonValue });
632
+ }
633
+ if (loaded.loader === "raw" || loaded.loader === "text") {
634
+ return this.createSyntheticModule(resolved.resolved, { default: loaded.code });
635
+ }
636
+ return this.createSourceTextModule(resolved.resolved, loaded.code, importer);
637
+ }
638
+ }
639
+ const loaded = this.loadByImportLoaders(resolved.source, resolved.resolved, importer.name);
640
+ if (loaded.handled) {
641
+ return this.createSyntheticModule(resolved.resolved, { default: loaded.value });
642
+ }
643
+ const stripped = stripQueryAndHash(resolved.resolved);
644
+ if (stripped.endsWith(".json")) {
645
+ const jsonSource = fs.readFileSync(stripped, "utf-8");
646
+ return this.createSyntheticModule(resolved.resolved, { default: JSON.parse(jsonSource) });
647
+ }
648
+ const entrypoint = this.getEntrypoint(resolved.resolved, resolved.only, importer.log);
649
+ if (!entrypoint) {
650
+ return this.createSyntheticModule(resolved.resolved, { default: resolved.resolved });
651
+ }
652
+ if ("evaluated" in entrypoint && entrypoint.evaluated) {
653
+ return this.createSyntheticModule(entrypoint.name, entrypoint.exports);
654
+ }
655
+ return this.getModuleForEntrypoint(entrypoint);
656
+ }
657
+ resolveWithConditions(id, parent, conditions) {
658
+ const shouldRetryWithExtensions = conditions && path.extname(id) === "" && (id.startsWith(".") || path.isAbsolute(id) || isBarePackageSubpath(id));
659
+ try {
660
+ return resolveFilenameWithConditions(this.moduleImpl, id, parent, conditions);
661
+ } catch (error) {
662
+ if (shouldRetryWithExtensions && error instanceof Error && error.code === "MODULE_NOT_FOUND") {
663
+ for (const ext of this.extensions) {
664
+ try {
665
+ return resolveFilenameWithConditions(this.moduleImpl, `${id}${ext}`, parent, conditions);
666
+ } catch {}
667
+ }
668
+ }
669
+ throw error;
670
+ }
671
+ }
672
+ resolveWithNodeFallback = (id, importer, kind) => {
673
+ if (!this.ignored) {
674
+ this.debug("❌ import has not been resolved during prepare stage. Fallback to Node.js resolver");
675
+ }
676
+ const extensions = this.moduleImpl._extensions;
677
+ const added = [];
678
+ try {
679
+ // Check for supported extensions
680
+ this.extensions.forEach((ext) => {
681
+ if (ext === ".cjs" || ext === ".mjs") {
682
+ return;
683
+ }
684
+ if (ext in extensions) {
685
+ return;
686
+ }
687
+ // When an extension is not supported, add it
688
+ // And keep track of it to clean it up after resolving
689
+ // Use noop for the transform function since we handle it
690
+ extensions[ext] = NOOP;
691
+ added.push(ext);
692
+ });
693
+ const filename = importer.name;
694
+ const strippedId = stripQueryAndHash(id);
695
+ const parent = {
696
+ id: filename,
697
+ filename,
698
+ paths: this.moduleImpl._nodeModulePaths(path.dirname(filename))
699
+ };
700
+ const { conditionNames } = this.services.options.pluginOptions;
701
+ const conditions = conditionNames?.length ? expandConditions(conditionNames) : undefined;
702
+ let resolved = this.resolveWithConditions(strippedId, parent, conditions);
703
+ const isFileSpecifier = strippedId.startsWith(".") || path.isAbsolute(strippedId);
704
+ if (isFileSpecifier && path.extname(strippedId) === "" && resolved.endsWith(".cjs") && fs.existsSync(`${resolved.slice(0, -4)}.js`)) {
705
+ // When both `.cjs` and `.js` exist for an extensionless specifier, the
706
+ // resolver may pick `.cjs` depending on the environment/extensions.
707
+ // Prefer `.js` to keep resolved paths stable (e.g. importOverrides keys).
708
+ resolved = `${resolved.slice(0, -4)}.js`;
709
+ }
710
+ const { root } = this.services.options;
711
+ const keyInfo = toImportKey({
712
+ source: id,
713
+ resolved,
714
+ root
715
+ });
716
+ const override = getImportOverride(this.services.options.pluginOptions.importOverrides, keyInfo.key);
717
+ const evalOptions = getEvalOptions(this.services);
718
+ const basePolicy = evalOptions.require === "warn-and-run" ? "warn" : "error";
719
+ let policy = override?.unknown ?? (override?.mock ? "allow" : basePolicy);
720
+ if (evalOptions.require === "off" && policy !== "error") {
721
+ policy = "error";
722
+ }
723
+ const shouldWarn = !this.ignored && policy === "warn";
724
+ let finalResolved = resolved;
725
+ if (override?.mock) {
726
+ try {
727
+ finalResolved = resolveMockSpecifier({
728
+ mock: override.mock,
729
+ importer: filename,
730
+ root,
731
+ stack: getStack(importer)
732
+ });
733
+ } catch (e) {
734
+ const errorMessage = String(e?.message ?? e);
735
+ throw new Error(`[wyw-in-js] Failed to resolve import mock for "${keyInfo.key}" (${id} from ${filename}): ${errorMessage}`);
736
+ }
737
+ }
738
+ if (policy === "error") {
739
+ throw new Error([
740
+ `[wyw-in-js] Unknown import reached during eval (Node resolver fallback)`,
741
+ ``,
742
+ `importer: ${filename}`,
743
+ `source: ${id}`,
744
+ `resolved: ${resolved}`,
745
+ override?.mock ? `mock: ${override.mock} -> ${finalResolved}` : ``,
746
+ ``,
747
+ `callstack:`,
748
+ ...getStack(importer).map((item) => ` ${item}`),
749
+ ``,
750
+ `config key: ${keyInfo.key}`,
751
+ `docs: ${TROUBLESHOOTING_URL}`
752
+ ].filter(Boolean).join("\n"));
753
+ }
754
+ const warnedUnknownImports = getWarnedUnknownImports(this.services);
755
+ if (shouldWarn && !warnedUnknownImports.has(keyInfo.key)) {
756
+ warnedUnknownImports.add(keyInfo.key);
757
+ const warningMessage = [
758
+ `[wyw-in-js] Unknown import reached during eval (Node resolver fallback)`,
759
+ ``,
760
+ `importer: ${filename}`,
761
+ `source: ${id}`,
762
+ `resolved: ${resolved}`,
763
+ override?.mock ? `mock: ${override.mock} -> ${finalResolved}` : ``,
764
+ ``,
765
+ `callstack:`,
766
+ ...getStack(importer).map((item) => ` ${item}`),
767
+ ``,
768
+ `config key: ${keyInfo.key}`,
769
+ `hint: add { importOverrides: { ${JSON.stringify(keyInfo.key)}: { unknown: 'allow' } } } to silence warnings, or use { mock } / { noShake: true } overrides.`,
770
+ `docs: ${TROUBLESHOOTING_URL}`
771
+ ].filter(Boolean).join("\n");
772
+ emitEvalWarning(this.services, {
773
+ code: kind === "require" ? "require-fallback" : "resolve-fallback",
774
+ message: warningMessage,
775
+ importer: filename,
776
+ specifier: id,
777
+ resolved: resolved ?? null,
778
+ callstack: getStack(importer),
779
+ hint: `Use importOverrides or eval.require settings to avoid fallback.`
780
+ });
781
+ }
782
+ return {
783
+ source: id,
784
+ only: applyImportOverrideToOnly(["*"], override),
785
+ resolved: finalResolved
786
+ };
787
+ } finally {
788
+ // Cleanup the extensions we added to restore previous behaviour
789
+ added.forEach((ext) => delete extensions[ext]);
790
+ }
791
+ };
792
+ requireWithFallback(id, importer, nonLiteral = false) {
793
+ const evalOptions = getEvalOptions(this.services);
794
+ if (nonLiteral || typeof id !== "string") {
795
+ if (evalOptions.mode === "strict") {
796
+ throw new Error(`[wyw-in-js] Non-literal require() is not supported during eval.\n` + `importer: ${importer.name}\n` + `hint: make it a string literal or mock the import via importOverrides.`);
797
+ }
798
+ emitEvalWarning(this.services, {
799
+ code: "require-error",
800
+ message: "[wyw-in-js] Non-literal require() reached during eval (loose mode).",
801
+ importer: importer.name
802
+ });
803
+ return {};
804
+ }
805
+ const specifier = id;
806
+ if (id === REACT_REFRESH_VIRTUAL_ID) {
807
+ this.dependencies.push(id);
808
+ this.debug("require", `vite virtual '${id}'`);
809
+ return reactRefreshRuntime;
810
+ }
811
+ if (id.startsWith(VITE_VIRTUAL_PREFIX)) {
812
+ this.dependencies.push(id);
813
+ this.debug("require", `vite virtual '${id}'`);
814
+ return {};
815
+ }
816
+ const normalizedId = specifier.startsWith("node:") ? specifier.slice(5) : specifier;
817
+ if (NativeModule.builtinModules?.includes(normalizedId) || NativeModule.builtinModules?.includes(`node:${normalizedId}`)) {
818
+ if (normalizedId in builtins) {
819
+ if (builtins[normalizedId]) {
820
+ this.debug("require", `builtin '${normalizedId}'`);
821
+ return nodeRequire(normalizedId);
822
+ }
823
+ return null;
824
+ }
825
+ throw new Error(`Unable to import "${normalizedId}". Importing Node builtins is not supported in the sandbox.`);
826
+ }
827
+ const dependency = this.resolveRequire(specifier, importer);
828
+ const loaded = this.loadByImportLoaders(specifier, dependency.resolved, importer.name);
829
+ if (loaded.handled) {
830
+ this.dependencies.push(id);
831
+ this.debug("require", `${id} -> ${dependency.resolved} (loader)`);
832
+ return loaded.value;
833
+ }
834
+ const stripped = stripQueryAndHash(dependency.resolved);
835
+ const extension = path.extname(stripped);
836
+ if (extension && extension !== ".json" && !this.extensions.includes(extension)) {
837
+ this.dependencies.push(id);
838
+ this.debug("require", `${id} -> ${dependency.resolved} (asset)`);
839
+ return stripped;
840
+ }
841
+ if (this.services.cache.consumeInvalidation(dependency.resolved)) {
842
+ delete nodeRequire.cache[dependency.resolved];
843
+ }
844
+ this.dependencies.push(id);
845
+ this.debug("require", `${id} -> ${dependency.resolved}`);
846
+ return nodeRequire(dependency.resolved);
847
+ }
848
+ createChild(entrypoint) {
849
+ return new Module(this.services, entrypoint, this, this.moduleImpl);
850
+ }
851
+ loadByImportLoaders(request, resolved, importer) {
852
+ const { pluginOptions } = this.services.options;
853
+ const importLoaders = pluginOptions.importLoaders === undefined ? defaultImportLoaders : {
854
+ ...defaultImportLoaders,
855
+ ...pluginOptions.importLoaders
856
+ };
857
+ const { query, hash } = parseRequest(request);
858
+ if (!query) return {
859
+ handled: false,
860
+ value: undefined
861
+ };
862
+ const params = new URLSearchParams(query);
863
+ const matchedKey = Array.from(params.keys()).find((key) => importLoaders[key] !== undefined && importLoaders[key] !== false);
864
+ if (!matchedKey) return {
865
+ handled: false,
866
+ value: undefined
867
+ };
868
+ const loader = importLoaders[matchedKey];
869
+ const filename = stripQueryAndHash(resolved);
870
+ const importerFilename = stripQueryAndHash(importer);
871
+ const importerDir = path.dirname(importerFilename);
872
+ const toUrl = () => {
873
+ const relative = path.relative(importerDir, filename).replace(/\\/g, path.posix.sep);
874
+ if (relative.startsWith(".") || path.isAbsolute(relative)) {
875
+ return relative;
876
+ }
877
+ return `./${relative}`;
878
+ };
879
+ const readFile = () => fs.readFileSync(filename, "utf-8");
880
+ const context = {
881
+ importer: importerFilename,
882
+ request,
883
+ resolved,
884
+ filename,
885
+ query,
886
+ hash,
887
+ emitWarning: (message) => emitWarning(this.services, message),
888
+ readFile,
889
+ toUrl
890
+ };
891
+ if (loader === "raw") {
892
+ return {
893
+ handled: true,
894
+ value: context.readFile()
895
+ };
896
+ }
897
+ if (loader === "url") {
898
+ return {
899
+ handled: true,
900
+ value: context.toUrl()
901
+ };
902
+ }
903
+ if (typeof loader === "function") {
904
+ return {
905
+ handled: true,
906
+ value: loader(context)
907
+ };
908
+ }
909
+ return {
910
+ handled: false,
911
+ value: undefined
912
+ };
913
+ }
538
914
  }
539
- //# sourceMappingURL=module.js.map
915
+ //# sourceMappingURL=module.js.map