@ecopages/core 0.2.0-alpha.3 → 0.2.0-alpha.31

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 (436) hide show
  1. package/CHANGELOG.md +66 -66
  2. package/README.md +268 -14
  3. package/package.json +72 -108
  4. package/src/adapters/README.md +39 -0
  5. package/src/adapters/abstract/application-adapter.d.ts +28 -2
  6. package/src/adapters/abstract/application-adapter.js +14 -2
  7. package/src/adapters/abstract/router-adapter.d.ts +1 -1
  8. package/src/adapters/abstract/server-adapter.d.ts +2 -2
  9. package/src/adapters/bun/client-bridge.d.ts +1 -1
  10. package/src/adapters/bun/create-app.d.ts +5 -12
  11. package/src/adapters/bun/create-app.js +43 -7
  12. package/src/adapters/bun/hmr-manager.d.ts +72 -26
  13. package/src/adapters/bun/hmr-manager.js +153 -81
  14. package/src/adapters/bun/index.d.ts +2 -3
  15. package/src/adapters/bun/index.js +3 -3
  16. package/src/adapters/bun/server-adapter.d.ts +5 -5
  17. package/src/adapters/bun/server-adapter.js +63 -38
  18. package/src/adapters/bun/server-lifecycle.d.ts +28 -17
  19. package/src/adapters/bun/server-lifecycle.js +34 -62
  20. package/src/{create-app.d.ts → adapters/create-app.d.ts} +9 -6
  21. package/src/{create-app.js → adapters/create-app.js} +4 -4
  22. package/src/adapters/index.d.ts +2 -6
  23. package/src/adapters/index.js +2 -8
  24. package/src/adapters/node/create-app.d.ts +6 -9
  25. package/src/adapters/node/create-app.js +12 -6
  26. package/src/adapters/node/node-client-bridge.d.ts +1 -1
  27. package/src/adapters/node/node-hmr-manager.d.ts +79 -21
  28. package/src/adapters/node/node-hmr-manager.js +167 -114
  29. package/src/adapters/node/server-adapter.d.ts +7 -35
  30. package/src/adapters/node/server-adapter.js +55 -107
  31. package/src/adapters/node/static-content-server.d.ts +37 -1
  32. package/src/adapters/node/static-content-server.js +29 -1
  33. package/src/adapters/shared/application-adapter.d.ts +1 -1
  34. package/src/{define-api-handler.d.ts → adapters/shared/define-api-handler.d.ts} +1 -1
  35. package/src/adapters/shared/explicit-static-render-preparation.d.ts +25 -0
  36. package/src/adapters/shared/explicit-static-render-preparation.js +26 -0
  37. package/src/adapters/shared/explicit-static-route-matcher.d.ts +7 -4
  38. package/src/adapters/shared/explicit-static-route-matcher.js +14 -13
  39. package/src/adapters/shared/file-route-middleware-pipeline.d.ts +7 -10
  40. package/src/adapters/shared/file-route-middleware-pipeline.js +3 -11
  41. package/src/adapters/shared/fs-server-response-factory.d.ts +14 -10
  42. package/src/adapters/shared/fs-server-response-factory.js +11 -27
  43. package/src/adapters/shared/fs-server-response-matcher.d.ts +20 -16
  44. package/src/adapters/shared/fs-server-response-matcher.js +76 -45
  45. package/src/adapters/shared/hmr-entrypoint-registrar.d.ts +55 -0
  46. package/src/adapters/shared/hmr-entrypoint-registrar.js +87 -0
  47. package/src/adapters/shared/hmr-html-response.d.ts +22 -0
  48. package/src/adapters/shared/hmr-html-response.js +32 -0
  49. package/src/adapters/shared/render-context.d.ts +4 -3
  50. package/src/adapters/shared/render-context.js +6 -3
  51. package/src/adapters/shared/runtime-bootstrap.d.ts +38 -0
  52. package/src/adapters/shared/runtime-bootstrap.js +43 -0
  53. package/src/adapters/shared/server-adapter.d.ts +33 -12
  54. package/src/adapters/shared/server-adapter.js +208 -132
  55. package/src/adapters/shared/server-route-handler.d.ts +5 -5
  56. package/src/adapters/shared/server-route-handler.js +7 -16
  57. package/src/adapters/shared/server-static-builder.d.ts +41 -8
  58. package/src/adapters/shared/server-static-builder.js +65 -11
  59. package/src/build/README.md +107 -0
  60. package/src/build/build-adapter.d.ts +168 -3
  61. package/src/build/build-adapter.js +604 -16
  62. package/src/build/build-manifest.d.ts +27 -0
  63. package/src/build/build-manifest.js +30 -0
  64. package/src/build/dev-build-coordinator.d.ts +72 -0
  65. package/src/build/dev-build-coordinator.js +154 -0
  66. package/src/build/esbuild-build-adapter.d.ts +15 -6
  67. package/src/build/esbuild-build-adapter.js +189 -74
  68. package/src/build/runtime-build-executor.d.ts +14 -0
  69. package/src/build/runtime-build-executor.js +22 -0
  70. package/src/build/runtime-specifier-alias-plugin.d.ts +15 -0
  71. package/src/build/runtime-specifier-alias-plugin.js +35 -0
  72. package/src/build/runtime-specifier-aliases.d.ts +5 -0
  73. package/src/build/runtime-specifier-aliases.js +95 -0
  74. package/src/config/README.md +36 -0
  75. package/src/config/config-builder.d.ts +54 -29
  76. package/src/config/config-builder.js +255 -49
  77. package/src/{constants.d.ts → config/constants.d.ts} +13 -0
  78. package/src/{constants.js → config/constants.js} +4 -0
  79. package/src/declarations.d.ts +19 -14
  80. package/src/dev/host-runtime.d.ts +10 -0
  81. package/src/dev/host-runtime.js +24 -0
  82. package/src/dev/sc-server.d.ts +1 -1
  83. package/src/dev/sc-server.js +1 -1
  84. package/src/eco/README.md +70 -16
  85. package/src/eco/eco.browser.d.ts +2 -0
  86. package/src/eco/eco.browser.js +83 -0
  87. package/src/eco/eco.js +32 -57
  88. package/src/eco/eco.types.d.ts +14 -6
  89. package/src/eco/eco.utils.d.ts +1 -40
  90. package/src/eco/eco.utils.js +5 -35
  91. package/src/eco/global-injector-map.d.ts +3 -3
  92. package/src/eco/global-injector-map.js +2 -2
  93. package/src/eco/lazy-injector-map.d.ts +2 -2
  94. package/src/errors/index.d.ts +1 -0
  95. package/src/errors/index.js +3 -1
  96. package/src/hmr/README.md +26 -0
  97. package/src/hmr/client/hmr-runtime.d.ts +1 -6
  98. package/src/hmr/client/hmr-runtime.js +38 -7
  99. package/src/hmr/hmr-strategy.d.ts +16 -13
  100. package/src/hmr/hmr-strategy.js +22 -7
  101. package/src/hmr/hmr.postcss.test.e2e.d.ts +1 -0
  102. package/src/hmr/hmr.postcss.test.e2e.js +31 -0
  103. package/src/hmr/hmr.test.e2e.js +26 -33
  104. package/src/hmr/strategies/default-hmr-strategy.d.ts +2 -2
  105. package/src/hmr/strategies/default-hmr-strategy.js +1 -1
  106. package/src/hmr/strategies/js-hmr-strategy.d.ts +46 -48
  107. package/src/hmr/strategies/js-hmr-strategy.js +64 -74
  108. package/src/index.browser.d.ts +2 -2
  109. package/src/index.browser.js +1 -1
  110. package/src/index.d.ts +4 -3
  111. package/src/index.js +16 -5
  112. package/src/integrations/ghtml/ghtml-renderer.d.ts +3 -2
  113. package/src/integrations/ghtml/ghtml-renderer.js +27 -30
  114. package/src/integrations/ghtml/ghtml.constants.d.ts +1 -0
  115. package/src/integrations/ghtml/ghtml.constants.js +4 -0
  116. package/src/integrations/ghtml/ghtml.plugin.d.ts +2 -6
  117. package/src/integrations/ghtml/ghtml.plugin.js +3 -4
  118. package/src/plugins/README.md +35 -0
  119. package/src/plugins/alias-resolver-plugin.js +17 -3
  120. package/src/plugins/eco-component-meta-plugin.d.ts +14 -1
  121. package/src/plugins/eco-component-meta-plugin.js +27 -22
  122. package/src/plugins/foreign-jsx-override-plugin.d.ts +31 -0
  123. package/src/plugins/foreign-jsx-override-plugin.js +35 -0
  124. package/src/plugins/integration-plugin.d.ts +142 -29
  125. package/src/plugins/integration-plugin.js +103 -14
  126. package/src/plugins/processor.d.ts +17 -2
  127. package/src/plugins/processor.js +22 -3
  128. package/src/plugins/runtime-capability.d.ts +9 -0
  129. package/src/plugins/source-transform.d.ts +46 -0
  130. package/src/plugins/source-transform.js +71 -0
  131. package/src/route-renderer/GRAPH.md +83 -325
  132. package/src/route-renderer/README.md +73 -90
  133. package/src/route-renderer/orchestration/component-render-context.d.ts +89 -0
  134. package/src/route-renderer/orchestration/component-render-context.js +147 -0
  135. package/src/route-renderer/orchestration/declared-ownership-graph.d.ts +18 -0
  136. package/src/route-renderer/orchestration/declared-ownership-graph.js +34 -0
  137. package/src/route-renderer/orchestration/foreign-subtree-execution.service.d.ts +108 -0
  138. package/src/route-renderer/orchestration/foreign-subtree-execution.service.js +206 -0
  139. package/src/route-renderer/orchestration/integration-renderer.d.ts +516 -0
  140. package/src/route-renderer/orchestration/integration-renderer.js +909 -0
  141. package/src/route-renderer/orchestration/ownership-planning.service.d.ts +24 -0
  142. package/src/route-renderer/orchestration/ownership-planning.service.js +63 -0
  143. package/src/route-renderer/orchestration/ownership-validation.service.d.ts +29 -0
  144. package/src/route-renderer/orchestration/ownership-validation.service.js +53 -0
  145. package/src/route-renderer/orchestration/processed-asset-dedupe.d.ts +2 -0
  146. package/src/route-renderer/orchestration/processed-asset-dedupe.js +23 -0
  147. package/src/route-renderer/orchestration/queued-foreign-subtree-resolution.service.d.ts +90 -0
  148. package/src/route-renderer/orchestration/queued-foreign-subtree-resolution.service.js +158 -0
  149. package/src/route-renderer/orchestration/render-output.utils.d.ts +66 -0
  150. package/src/route-renderer/orchestration/render-output.utils.js +171 -0
  151. package/src/route-renderer/orchestration/route-render-orchestrator.d.ts +120 -0
  152. package/src/route-renderer/orchestration/route-render-orchestrator.js +388 -0
  153. package/src/route-renderer/orchestration/template-serialization.d.ts +38 -0
  154. package/src/route-renderer/orchestration/template-serialization.js +45 -0
  155. package/src/route-renderer/page-loading/component-dependency-collection.d.ts +37 -0
  156. package/src/route-renderer/page-loading/component-dependency-collection.js +132 -0
  157. package/src/route-renderer/page-loading/declared-asset-collection.d.ts +24 -0
  158. package/src/route-renderer/page-loading/declared-asset-collection.js +106 -0
  159. package/src/route-renderer/{dependency-resolver.d.ts → page-loading/dependency-resolver.d.ts} +15 -4
  160. package/src/route-renderer/page-loading/dependency-resolver.js +115 -0
  161. package/src/route-renderer/page-loading/ecopages-virtual-imports.d.ts +11 -0
  162. package/src/route-renderer/page-loading/ecopages-virtual-imports.js +57 -0
  163. package/src/route-renderer/page-loading/lazy-entry-collection.d.ts +45 -0
  164. package/src/route-renderer/page-loading/lazy-entry-collection.js +105 -0
  165. package/src/route-renderer/page-loading/lazy-trigger-planning.d.ts +19 -0
  166. package/src/route-renderer/page-loading/lazy-trigger-planning.js +40 -0
  167. package/src/route-renderer/page-loading/module-declaration-aggregation.d.ts +5 -0
  168. package/src/route-renderer/page-loading/module-declaration-aggregation.js +33 -0
  169. package/src/route-renderer/page-loading/module-declaration-scripts.d.ts +3 -0
  170. package/src/route-renderer/page-loading/module-declaration-scripts.js +18 -0
  171. package/src/route-renderer/page-loading/page-dependency-bundling.d.ts +13 -0
  172. package/src/route-renderer/page-loading/page-dependency-bundling.js +137 -0
  173. package/src/route-renderer/page-loading/page-module-loader.d.ts +90 -0
  174. package/src/route-renderer/{page-module-loader.js → page-loading/page-module-loader.js} +39 -14
  175. package/src/route-renderer/route-renderer.d.ts +57 -14
  176. package/src/route-renderer/route-renderer.js +30 -18
  177. package/src/router/README.md +94 -0
  178. package/src/router/client/link-intent.d.ts +53 -0
  179. package/src/router/client/link-intent.js +34 -0
  180. package/src/router/client/link-intent.test.browser.d.ts +1 -0
  181. package/src/router/client/link-intent.test.browser.js +43 -0
  182. package/src/router/client/navigation-coordinator.d.ts +169 -0
  183. package/src/router/client/navigation-coordinator.js +215 -0
  184. package/src/router/server/route-registry.d.ts +78 -0
  185. package/src/router/server/route-registry.js +262 -0
  186. package/src/services/README.md +28 -0
  187. package/src/services/assets/asset-processing-service/asset-dependency-keys.d.ts +3 -0
  188. package/src/services/assets/asset-processing-service/asset-dependency-keys.js +56 -0
  189. package/src/services/assets/asset-processing-service/asset-processing.service.d.ts +103 -0
  190. package/src/services/{asset-processing-service → assets/asset-processing-service}/asset-processing.service.js +124 -89
  191. package/src/services/{asset-processing-service → assets/asset-processing-service}/asset.factory.d.ts +1 -1
  192. package/src/services/{asset-processing-service → assets/asset-processing-service}/asset.factory.js +2 -2
  193. package/src/services/{asset-processing-service → assets/asset-processing-service}/assets.types.d.ts +16 -1
  194. package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.d.ts +55 -0
  195. package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.js +49 -0
  196. package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.d.ts +20 -0
  197. package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.js +41 -0
  198. package/src/services/assets/asset-processing-service/grouped-content-bundles.d.ts +30 -0
  199. package/src/services/assets/asset-processing-service/grouped-content-bundles.js +65 -0
  200. package/src/services/assets/asset-processing-service/index.d.ts +6 -0
  201. package/src/services/assets/asset-processing-service/index.js +6 -0
  202. package/src/services/assets/asset-processing-service/page-package.d.ts +3 -0
  203. package/src/services/assets/asset-processing-service/page-package.js +74 -0
  204. package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.interface.d.ts +2 -2
  205. package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.registry.d.ts +2 -2
  206. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/base/base-processor.d.ts +1 -1
  207. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/base/base-processor.js +11 -5
  208. package/src/services/assets/asset-processing-service/processors/base/base-script-processor.d.ts +22 -0
  209. package/src/services/assets/asset-processing-service/processors/base/base-script-processor.js +136 -0
  210. package/src/services/assets/asset-processing-service/processors/index.d.ts +5 -0
  211. package/src/services/assets/asset-processing-service/processors/index.js +5 -0
  212. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/content-script.processor.d.ts +3 -2
  213. package/src/services/assets/asset-processing-service/processors/script/content-script.processor.js +119 -0
  214. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/file-script.processor.d.ts +4 -3
  215. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/file-script.processor.js +28 -7
  216. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/node-module-script.processor.d.ts +3 -3
  217. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/node-module-script.processor.js +12 -7
  218. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/content-stylesheet.processor.d.ts +5 -2
  219. package/src/services/assets/asset-processing-service/processors/stylesheet/content-stylesheet.processor.js +59 -0
  220. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/file-stylesheet.processor.d.ts +2 -2
  221. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/file-stylesheet.processor.js +9 -3
  222. package/src/services/assets/asset-processing-service/ungrouped-dependency-processing.d.ts +18 -0
  223. package/src/services/assets/asset-processing-service/ungrouped-dependency-processing.js +45 -0
  224. package/src/services/assets/browser-bundle.service.d.ts +73 -0
  225. package/src/services/assets/browser-bundle.service.js +41 -0
  226. package/src/services/{page-request-cache-coordinator.service.d.ts → cache/page-request-cache-coordinator.service.d.ts} +2 -2
  227. package/src/services/{page-request-cache-coordinator.service.js → cache/page-request-cache-coordinator.service.js} +3 -1
  228. package/src/services/html/html-rewriter-provider.service.d.ts +37 -0
  229. package/src/services/html/html-rewriter-provider.service.js +68 -0
  230. package/src/services/html/html-transformer.service.d.ts +87 -0
  231. package/src/services/html/html-transformer.service.js +216 -0
  232. package/src/services/invalidation/development-invalidation.service.d.ts +74 -0
  233. package/src/services/invalidation/development-invalidation.service.js +190 -0
  234. package/src/services/module-loading/app-module-loader.service.d.ts +7 -0
  235. package/src/services/module-loading/app-server-module-transpiler.service.d.ts +24 -0
  236. package/src/services/module-loading/app-server-module-transpiler.service.js +115 -0
  237. package/src/services/module-loading/host-module-loader-registry.d.ts +4 -0
  238. package/src/services/module-loading/host-module-loader-registry.js +15 -0
  239. package/src/services/module-loading/module-loading-types.d.ts +2 -0
  240. package/src/services/module-loading/module-loading-types.js +0 -0
  241. package/src/services/module-loading/node-bootstrap-plugin.d.ts +42 -0
  242. package/src/services/module-loading/node-bootstrap-plugin.js +216 -0
  243. package/src/services/module-loading/page-module-import.service.d.ts +76 -0
  244. package/src/services/module-loading/page-module-import.service.js +170 -0
  245. package/src/services/module-loading/server-module-transpiler.service.d.ts +63 -0
  246. package/src/services/module-loading/server-module-transpiler.service.js +64 -0
  247. package/src/services/module-loading/source-module-support.d.ts +5 -0
  248. package/src/services/module-loading/source-module-support.js +8 -0
  249. package/src/services/runtime-state/dev-graph.service.d.ts +118 -0
  250. package/src/services/runtime-state/dev-graph.service.js +162 -0
  251. package/src/services/runtime-state/entrypoint-dependency-graph.service.d.ts +41 -0
  252. package/src/services/runtime-state/entrypoint-dependency-graph.service.js +85 -0
  253. package/src/services/runtime-state/server-invalidation-state.service.d.ts +26 -0
  254. package/src/services/runtime-state/server-invalidation-state.service.js +35 -0
  255. package/src/services/{schema-validation-service.d.ts → validation/schema-validation-service.d.ts} +1 -1
  256. package/src/static-site-generator/README.md +26 -0
  257. package/src/static-site-generator/static-site-generator.d.ts +67 -20
  258. package/src/static-site-generator/static-site-generator.js +182 -138
  259. package/src/{internal-types.d.ts → types/internal-types.d.ts} +62 -30
  260. package/src/types/internal-types.js +0 -0
  261. package/src/{public-types.d.ts → types/public-types.d.ts} +201 -32
  262. package/src/types/public-types.js +0 -0
  263. package/src/utils/html-escaping.d.ts +7 -0
  264. package/src/utils/html-escaping.js +6 -0
  265. package/src/utils/locals-utils.d.ts +1 -1
  266. package/src/utils/parse-cli-args.d.ts +4 -1
  267. package/src/utils/parse-cli-args.js +16 -1
  268. package/src/utils/resolve-work-dir.d.ts +11 -0
  269. package/src/utils/resolve-work-dir.js +31 -0
  270. package/src/watchers/project-watcher.d.ts +40 -29
  271. package/src/watchers/project-watcher.js +126 -116
  272. package/src/watchers/project-watcher.test-helpers.d.ts +2 -2
  273. package/src/watchers/project-watcher.test-helpers.js +6 -6
  274. package/src/adapters/abstract/application-adapter.ts +0 -337
  275. package/src/adapters/abstract/router-adapter.ts +0 -30
  276. package/src/adapters/abstract/server-adapter.ts +0 -79
  277. package/src/adapters/bun/client-bridge.ts +0 -62
  278. package/src/adapters/bun/create-app.ts +0 -189
  279. package/src/adapters/bun/define-api-handler.d.ts +0 -61
  280. package/src/adapters/bun/define-api-handler.ts +0 -114
  281. package/src/adapters/bun/hmr-manager.ts +0 -296
  282. package/src/adapters/bun/index.ts +0 -3
  283. package/src/adapters/bun/server-adapter.ts +0 -492
  284. package/src/adapters/bun/server-lifecycle.ts +0 -154
  285. package/src/adapters/index.ts +0 -6
  286. package/src/adapters/node/create-app.ts +0 -179
  287. package/src/adapters/node/index.d.ts +0 -4
  288. package/src/adapters/node/index.js +0 -8
  289. package/src/adapters/node/index.ts +0 -9
  290. package/src/adapters/node/node-client-bridge.ts +0 -79
  291. package/src/adapters/node/node-hmr-manager.ts +0 -289
  292. package/src/adapters/node/server-adapter.ts +0 -561
  293. package/src/adapters/node/static-content-server.ts +0 -203
  294. package/src/adapters/shared/api-response.ts +0 -104
  295. package/src/adapters/shared/application-adapter.ts +0 -199
  296. package/src/adapters/shared/explicit-static-route-matcher.ts +0 -134
  297. package/src/adapters/shared/file-route-middleware-pipeline.ts +0 -123
  298. package/src/adapters/shared/fs-server-response-factory.ts +0 -118
  299. package/src/adapters/shared/fs-server-response-matcher.ts +0 -198
  300. package/src/adapters/shared/render-context.ts +0 -105
  301. package/src/adapters/shared/server-adapter.ts +0 -442
  302. package/src/adapters/shared/server-route-handler.ts +0 -166
  303. package/src/adapters/shared/server-static-builder.ts +0 -82
  304. package/src/build/build-adapter.ts +0 -132
  305. package/src/build/build-types.ts +0 -83
  306. package/src/build/esbuild-build-adapter.ts +0 -510
  307. package/src/config/config-builder.ts +0 -474
  308. package/src/constants.ts +0 -39
  309. package/src/create-app.ts +0 -87
  310. package/src/define-api-handler.js +0 -15
  311. package/src/define-api-handler.ts +0 -66
  312. package/src/dev/sc-server.ts +0 -143
  313. package/src/eco/component-render-context.d.ts +0 -105
  314. package/src/eco/component-render-context.js +0 -77
  315. package/src/eco/component-render-context.ts +0 -202
  316. package/src/eco/eco.ts +0 -221
  317. package/src/eco/eco.types.ts +0 -202
  318. package/src/eco/eco.utils.ts +0 -89
  319. package/src/eco/global-injector-map.ts +0 -112
  320. package/src/eco/lazy-injector-map.ts +0 -120
  321. package/src/eco/module-dependencies.ts +0 -75
  322. package/src/errors/http-error.ts +0 -72
  323. package/src/errors/index.ts +0 -2
  324. package/src/errors/locals-access-error.ts +0 -7
  325. package/src/global/app-logger.ts +0 -4
  326. package/src/hmr/client/__screenshots__/hmr-runtime.test.browser.ts/HMR-Runtime-HMR-Server-Integration-should-have-HMR-script-injected-in-page-1.png +0 -0
  327. package/src/hmr/client/__screenshots__/hmr-runtime.test.browser.ts/HMR-Runtime-HMR-Server-Integration-should-load-fixture-app-page-1.png +0 -0
  328. package/src/hmr/client/__screenshots__/hmr-runtime.test.browser.ts/HMR-Runtime-WebSocket-Connection-should-connect-to-correct-HMR-endpoint-1.png +0 -0
  329. package/src/hmr/client/hmr-runtime.ts +0 -121
  330. package/src/hmr/hmr-strategy.ts +0 -172
  331. package/src/hmr/hmr.test.e2e.ts +0 -75
  332. package/src/hmr/strategies/default-hmr-strategy.ts +0 -60
  333. package/src/hmr/strategies/js-hmr-strategy.ts +0 -320
  334. package/src/index.browser.ts +0 -3
  335. package/src/index.ts +0 -5
  336. package/src/integrations/ghtml/ghtml-renderer.ts +0 -93
  337. package/src/integrations/ghtml/ghtml.plugin.ts +0 -32
  338. package/src/internal-types.ts +0 -212
  339. package/src/plugins/alias-resolver-plugin.ts +0 -45
  340. package/src/plugins/eco-component-meta-plugin.ts +0 -474
  341. package/src/plugins/integration-plugin.ts +0 -184
  342. package/src/plugins/processor.ts +0 -220
  343. package/src/public-types.ts +0 -1260
  344. package/src/route-renderer/component-graph-executor.d.ts +0 -32
  345. package/src/route-renderer/component-graph-executor.js +0 -31
  346. package/src/route-renderer/component-graph-executor.ts +0 -84
  347. package/src/route-renderer/component-graph.d.ts +0 -42
  348. package/src/route-renderer/component-graph.js +0 -72
  349. package/src/route-renderer/component-graph.ts +0 -159
  350. package/src/route-renderer/component-marker.d.ts +0 -52
  351. package/src/route-renderer/component-marker.js +0 -46
  352. package/src/route-renderer/component-marker.ts +0 -117
  353. package/src/route-renderer/dependency-resolver.js +0 -428
  354. package/src/route-renderer/dependency-resolver.ts +0 -596
  355. package/src/route-renderer/html-post-processing.service.d.ts +0 -40
  356. package/src/route-renderer/html-post-processing.service.js +0 -86
  357. package/src/route-renderer/html-post-processing.service.ts +0 -103
  358. package/src/route-renderer/integration-renderer.d.ts +0 -339
  359. package/src/route-renderer/integration-renderer.js +0 -526
  360. package/src/route-renderer/integration-renderer.ts +0 -696
  361. package/src/route-renderer/marker-graph-resolver.d.ts +0 -76
  362. package/src/route-renderer/marker-graph-resolver.js +0 -93
  363. package/src/route-renderer/marker-graph-resolver.ts +0 -153
  364. package/src/route-renderer/page-module-loader.d.ts +0 -61
  365. package/src/route-renderer/page-module-loader.ts +0 -153
  366. package/src/route-renderer/render-execution.service.d.ts +0 -69
  367. package/src/route-renderer/render-execution.service.js +0 -91
  368. package/src/route-renderer/render-execution.service.ts +0 -158
  369. package/src/route-renderer/render-preparation.service.d.ts +0 -112
  370. package/src/route-renderer/render-preparation.service.js +0 -243
  371. package/src/route-renderer/render-preparation.service.ts +0 -358
  372. package/src/route-renderer/route-renderer.ts +0 -80
  373. package/src/router/fs-router-scanner.d.ts +0 -41
  374. package/src/router/fs-router-scanner.js +0 -155
  375. package/src/router/fs-router-scanner.ts +0 -217
  376. package/src/router/fs-router.d.ts +0 -26
  377. package/src/router/fs-router.js +0 -100
  378. package/src/router/fs-router.ts +0 -122
  379. package/src/services/asset-processing-service/asset-processing.service.d.ts +0 -41
  380. package/src/services/asset-processing-service/asset-processing.service.ts +0 -306
  381. package/src/services/asset-processing-service/asset.factory.ts +0 -105
  382. package/src/services/asset-processing-service/assets.types.ts +0 -112
  383. package/src/services/asset-processing-service/index.d.ts +0 -3
  384. package/src/services/asset-processing-service/index.js +0 -3
  385. package/src/services/asset-processing-service/index.ts +0 -3
  386. package/src/services/asset-processing-service/processor.interface.ts +0 -27
  387. package/src/services/asset-processing-service/processor.registry.ts +0 -18
  388. package/src/services/asset-processing-service/processors/base/base-processor.ts +0 -76
  389. package/src/services/asset-processing-service/processors/base/base-script-processor.d.ts +0 -16
  390. package/src/services/asset-processing-service/processors/base/base-script-processor.js +0 -80
  391. package/src/services/asset-processing-service/processors/base/base-script-processor.ts +0 -105
  392. package/src/services/asset-processing-service/processors/index.d.ts +0 -5
  393. package/src/services/asset-processing-service/processors/index.js +0 -5
  394. package/src/services/asset-processing-service/processors/index.ts +0 -5
  395. package/src/services/asset-processing-service/processors/script/content-script.processor.js +0 -57
  396. package/src/services/asset-processing-service/processors/script/content-script.processor.ts +0 -66
  397. package/src/services/asset-processing-service/processors/script/file-script.processor.ts +0 -88
  398. package/src/services/asset-processing-service/processors/script/node-module-script.processor.ts +0 -84
  399. package/src/services/asset-processing-service/processors/stylesheet/content-stylesheet.processor.js +0 -25
  400. package/src/services/asset-processing-service/processors/stylesheet/content-stylesheet.processor.ts +0 -27
  401. package/src/services/asset-processing-service/processors/stylesheet/file-stylesheet.processor.ts +0 -77
  402. package/src/services/cache/cache.types.ts +0 -126
  403. package/src/services/cache/index.ts +0 -18
  404. package/src/services/cache/memory-cache-store.ts +0 -130
  405. package/src/services/cache/page-cache-service.ts +0 -202
  406. package/src/services/html-transformer.service.d.ts +0 -50
  407. package/src/services/html-transformer.service.js +0 -163
  408. package/src/services/html-transformer.service.ts +0 -217
  409. package/src/services/page-module-import.service.d.ts +0 -37
  410. package/src/services/page-module-import.service.js +0 -88
  411. package/src/services/page-module-import.service.ts +0 -129
  412. package/src/services/page-request-cache-coordinator.service.ts +0 -128
  413. package/src/services/schema-validation-service.ts +0 -204
  414. package/src/services/validation/standard-schema.types.ts +0 -68
  415. package/src/static-site-generator/static-site-generator.ts +0 -359
  416. package/src/utils/css.d.ts +0 -1
  417. package/src/utils/css.js +0 -7
  418. package/src/utils/css.ts +0 -5
  419. package/src/utils/deep-merge.ts +0 -47
  420. package/src/utils/hash.ts +0 -5
  421. package/src/utils/html.ts +0 -1
  422. package/src/utils/invariant.ts +0 -15
  423. package/src/utils/locals-utils.ts +0 -37
  424. package/src/utils/parse-cli-args.ts +0 -83
  425. package/src/utils/path-utils.module.ts +0 -14
  426. package/src/utils/runtime.ts +0 -44
  427. package/src/utils/server-utils.module.ts +0 -67
  428. package/src/watchers/project-watcher.test-helpers.ts +0 -41
  429. package/src/watchers/project-watcher.ts +0 -344
  430. /package/src/adapters/{bun → shared}/define-api-handler.js +0 -0
  431. /package/src/{internal-types.js → plugins/runtime-capability.js} +0 -0
  432. /package/src/services/{asset-processing-service → assets/asset-processing-service}/assets.types.js +0 -0
  433. /package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.interface.js +0 -0
  434. /package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.registry.js +0 -0
  435. /package/src/{public-types.js → services/module-loading/app-module-loader.service.js} +0 -0
  436. /package/src/services/{schema-validation-service.js → validation/schema-validation-service.js} +0 -0
@@ -0,0 +1,42 @@
1
+ import type { EcoBuildOnResolveArgs, EcoBuildOnResolveResult, EcoBuildPlugin } from '../../build/build-types.js';
2
+ import type { EcoPagesAppConfig } from '../../types/internal-types.js';
3
+ /**
4
+ * Returns the app-local node_modules directory used by framework-owned Node
5
+ * bootstrap loads outside the thin-host manifest path.
6
+ */
7
+ export declare function getAppRuntimeNodeModulesDir(appConfig: Pick<EcoPagesAppConfig, 'rootDir' | 'workDir' | 'absolutePaths'>): string;
8
+ export interface NodeBootstrapResolutionOptions {
9
+ /**
10
+ * App root used as the fallback package boundary when an importer does not
11
+ * live under a more specific package.json.
12
+ */
13
+ projectDir: string;
14
+ /**
15
+ * Runtime-local node_modules directory that receives symlinks to resolved
16
+ * package roots so transpiled Node imports share one package graph.
17
+ */
18
+ runtimeNodeModulesDir: string;
19
+ }
20
+ /**
21
+ * Builds the user-facing error for Bun-native imports that cannot run on the
22
+ * Node bootstrap transpile path.
23
+ */
24
+ export declare function getNodeUnsupportedBuiltinError(specifier: string, importer?: string): string;
25
+ export declare function resolveNodeBootstrapDependency(args: Pick<EcoBuildOnResolveArgs, 'path' | 'importer'>, options: NodeBootstrapResolutionOptions): EcoBuildOnResolveResult | undefined;
26
+ /**
27
+ * Creates the Node bootstrap plugin used by app-owned server module loads.
28
+ *
29
+ * The resolver anchors third-party imports to the nearest package boundary for
30
+ * the importing file, then mirrors the resolved package root into the runtime
31
+ * node_modules directory. That keeps transpiled Node execution aligned with the
32
+ * package graph each source file was authored against.
33
+ */
34
+ export declare function createNodeBootstrapPlugin(options: NodeBootstrapResolutionOptions): EcoBuildPlugin;
35
+ /**
36
+ * Creates the default Node bootstrap plugin for one Ecopages app runtime.
37
+ *
38
+ * This binds the shared resolution policy to the app's internal execution
39
+ * directory so transpiled server modules can externalize packages into one
40
+ * stable runtime node_modules graph.
41
+ */
42
+ export declare function createAppNodeBootstrapPlugin(appConfig: Pick<EcoPagesAppConfig, 'rootDir' | 'workDir' | 'absolutePaths'>): EcoBuildPlugin;
@@ -0,0 +1,216 @@
1
+ import path from "node:path";
2
+ import { existsSync, lstatSync, mkdirSync, readFileSync, realpathSync, rmSync, symlinkSync, unlinkSync } from "node:fs";
3
+ import { createRequire } from "node:module";
4
+ import { fileURLToPath, pathToFileURL } from "node:url";
5
+ import { resolveInternalExecutionDir } from "../../utils/resolve-work-dir.js";
6
+ function getAppRuntimeNodeModulesDir(appConfig) {
7
+ return path.join(resolveInternalExecutionDir(appConfig), "node_modules");
8
+ }
9
+ function getPackageNameFromSpecifier(specifier) {
10
+ if (specifier.startsWith("@")) {
11
+ const [scope, name] = specifier.split("/");
12
+ return `${scope}/${name}`;
13
+ }
14
+ return specifier.split("/")[0] ?? specifier;
15
+ }
16
+ function findPackageRoot(resolvedPath) {
17
+ let currentPath = path.dirname(resolvedPath);
18
+ while (true) {
19
+ const packageJsonPath = path.join(currentPath, "package.json");
20
+ if (existsSync(packageJsonPath)) {
21
+ return currentPath;
22
+ }
23
+ const parentPath = path.dirname(currentPath);
24
+ if (parentPath === currentPath) {
25
+ throw new Error(`Could not find package root for resolved dependency path: ${resolvedPath}`);
26
+ }
27
+ currentPath = parentPath;
28
+ }
29
+ }
30
+ function pathEntryExists(filePath) {
31
+ try {
32
+ lstatSync(filePath);
33
+ return true;
34
+ } catch {
35
+ return false;
36
+ }
37
+ }
38
+ function linkPointsToPackage(linkPath, packageRoot) {
39
+ try {
40
+ return realpathSync(linkPath) === realpathSync(packageRoot);
41
+ } catch {
42
+ return false;
43
+ }
44
+ }
45
+ function ensureRuntimePackageLink(nodeModulesDir, specifier, resolvedPath) {
46
+ const packageName = getPackageNameFromSpecifier(specifier);
47
+ const packageRoot = findPackageRoot(resolvedPath);
48
+ const linkPath = path.join(nodeModulesDir, packageName);
49
+ mkdirSync(path.dirname(linkPath), { recursive: true });
50
+ if (pathEntryExists(linkPath)) {
51
+ if (linkPointsToPackage(linkPath, packageRoot)) {
52
+ return;
53
+ }
54
+ removeRuntimePackageLink(linkPath);
55
+ }
56
+ try {
57
+ symlinkSync(packageRoot, linkPath, "dir");
58
+ } catch (error) {
59
+ if (error.code !== "EEXIST") {
60
+ throw error;
61
+ }
62
+ if (linkPointsToPackage(linkPath, packageRoot)) {
63
+ return;
64
+ }
65
+ removeRuntimePackageLink(linkPath);
66
+ symlinkSync(packageRoot, linkPath, "dir");
67
+ }
68
+ }
69
+ function removeRuntimePackageLink(linkPath) {
70
+ try {
71
+ const stats = lstatSync(linkPath);
72
+ if (stats.isSymbolicLink()) {
73
+ unlinkSync(linkPath);
74
+ return;
75
+ }
76
+ } catch {
77
+ return;
78
+ }
79
+ rmSync(linkPath, { recursive: true, force: true });
80
+ }
81
+ function getNodeUnsupportedBuiltinError(specifier, importer) {
82
+ return `Node bootstrap transpilation does not support Bun builtin specifier ${JSON.stringify(specifier)}${importer ? ` imported from ${importer}` : ""}.`;
83
+ }
84
+ function resolveSpecifier(specifier, parentPath) {
85
+ try {
86
+ return createRequire(parentPath).resolve(specifier);
87
+ } catch {
88
+ return fileURLToPath(import.meta.resolve(specifier, pathToFileURL(parentPath).href));
89
+ }
90
+ }
91
+ function resolveFromCore(specifier) {
92
+ return createRequire(import.meta.url).resolve(specifier);
93
+ }
94
+ function findResolutionParent(importer, projectDir) {
95
+ if (!importer || !path.isAbsolute(importer)) {
96
+ return path.join(projectDir, "package.json");
97
+ }
98
+ let currentPath = path.dirname(importer);
99
+ while (true) {
100
+ const packageJsonPath = path.join(currentPath, "package.json");
101
+ if (existsSync(packageJsonPath)) {
102
+ return packageJsonPath;
103
+ }
104
+ const parentPath = path.dirname(currentPath);
105
+ if (parentPath === currentPath) {
106
+ return path.join(projectDir, "package.json");
107
+ }
108
+ currentPath = parentPath;
109
+ }
110
+ }
111
+ function getBootstrapBuildLoaderForPath(filePath) {
112
+ switch (path.extname(filePath).toLowerCase()) {
113
+ case ".ts":
114
+ case ".mts":
115
+ case ".cts":
116
+ return "ts";
117
+ case ".tsx":
118
+ return "tsx";
119
+ case ".jsx":
120
+ return "jsx";
121
+ case ".json":
122
+ return "json";
123
+ default:
124
+ return "js";
125
+ }
126
+ }
127
+ function shouldRewriteBootstrapSource(filePath, projectDir) {
128
+ const normalizedPath = path.resolve(filePath);
129
+ const normalizedProjectDir = path.resolve(projectDir);
130
+ return normalizedPath.startsWith(`${normalizedProjectDir}${path.sep}`) && !normalizedPath.includes(`${path.sep}node_modules${path.sep}`);
131
+ }
132
+ function resolveNodeBootstrapDependency(args, options) {
133
+ if (args.path.startsWith("./") || args.path.startsWith("../") || args.path.startsWith("@/") || args.path.startsWith("/") || args.path.startsWith("node:")) {
134
+ return void 0;
135
+ }
136
+ const resolveParent = findResolutionParent(args.importer, options.projectDir);
137
+ if (args.path.startsWith("@ecopages/")) {
138
+ let resolvedPath2;
139
+ try {
140
+ resolvedPath2 = resolveFromCore(args.path);
141
+ } catch {
142
+ try {
143
+ resolvedPath2 = resolveSpecifier(args.path, resolveParent);
144
+ } catch {
145
+ const packageName = getPackageNameFromSpecifier(args.path);
146
+ const candidatePath = path.join(options.projectDir, "node_modules", packageName);
147
+ const candidatePackageJson = path.join(candidatePath, "package.json");
148
+ if (existsSync(candidatePackageJson)) {
149
+ ensureRuntimePackageLink(options.runtimeNodeModulesDir, args.path, candidatePackageJson);
150
+ return { path: args.path, external: true };
151
+ }
152
+ }
153
+ }
154
+ if (!resolvedPath2) {
155
+ return void 0;
156
+ }
157
+ if (resolvedPath2.includes(`${path.sep}node_modules${path.sep}`)) {
158
+ ensureRuntimePackageLink(options.runtimeNodeModulesDir, args.path, resolvedPath2);
159
+ return {
160
+ path: args.path,
161
+ external: true
162
+ };
163
+ }
164
+ return { path: resolvedPath2 };
165
+ }
166
+ const resolvedPath = resolveSpecifier(args.path, resolveParent);
167
+ ensureRuntimePackageLink(options.runtimeNodeModulesDir, args.path, resolvedPath);
168
+ return {
169
+ path: args.path,
170
+ external: true
171
+ };
172
+ }
173
+ function createNodeBootstrapPlugin(options) {
174
+ const projectDir = path.resolve(options.projectDir);
175
+ return {
176
+ name: "node-bootstrap-plugin",
177
+ setup(build) {
178
+ build.onResolve({ filter: /^bun:/ }, (args) => {
179
+ throw new Error(getNodeUnsupportedBuiltinError(args.path, args.importer));
180
+ });
181
+ build.onLoad({ filter: /\.[cm]?[jt]sx?$/ }, async (args) => {
182
+ const absolutePath = path.resolve(args.path);
183
+ const shouldRewriteImportMeta = shouldRewriteBootstrapSource(absolutePath, projectDir);
184
+ if (!shouldRewriteImportMeta) {
185
+ return void 0;
186
+ }
187
+ const originalContents = readFileSync(args.path, "utf8");
188
+ const contents = originalContents.replaceAll("import.meta.dirname", JSON.stringify(path.dirname(args.path))).replaceAll("import.meta.filename", JSON.stringify(args.path));
189
+ if (contents === originalContents) {
190
+ return void 0;
191
+ }
192
+ return {
193
+ contents,
194
+ loader: getBootstrapBuildLoaderForPath(args.path),
195
+ resolveDir: path.dirname(args.path)
196
+ };
197
+ });
198
+ build.onResolve({ filter: /^[@A-Za-z0-9][^:]*$/ }, (args) => {
199
+ return resolveNodeBootstrapDependency(args, options);
200
+ });
201
+ }
202
+ };
203
+ }
204
+ function createAppNodeBootstrapPlugin(appConfig) {
205
+ return createNodeBootstrapPlugin({
206
+ projectDir: appConfig.rootDir,
207
+ runtimeNodeModulesDir: getAppRuntimeNodeModulesDir(appConfig)
208
+ });
209
+ }
210
+ export {
211
+ createAppNodeBootstrapPlugin,
212
+ createNodeBootstrapPlugin,
213
+ getAppRuntimeNodeModulesDir,
214
+ getNodeUnsupportedBuiltinError,
215
+ resolveNodeBootstrapDependency
216
+ };
@@ -0,0 +1,76 @@
1
+ import { build, type BuildExecutor, type BuildResult } from '../../build/build-adapter.js';
2
+ import type { EcoBuildPlugin } from '../../build/build-types.js';
3
+ import type { SourceModuleLoaderFactory } from './module-loading-types.js';
4
+ export interface PageModuleImportOptions {
5
+ filePath: string;
6
+ rootDir: string;
7
+ outdir: string;
8
+ bypassCache?: boolean;
9
+ cacheScope?: string;
10
+ buildExecutor?: BuildExecutor;
11
+ invalidationVersion?: number;
12
+ splitting?: boolean;
13
+ externalPackages?: boolean;
14
+ plugins?: EcoBuildPlugin[];
15
+ transpileErrorMessage?: (details: string) => string;
16
+ noOutputMessage?: (filePath: string) => string;
17
+ }
18
+ /**
19
+ * Minimal runtime dependencies required to load page modules.
20
+ *
21
+ * @remarks
22
+ * This service owns cache and runtime import policy. Hashing and build
23
+ * execution are injected so tests can provide explicit fakes without module
24
+ * interception.
25
+ */
26
+ export interface PageModuleImportDependencies {
27
+ hashFile(filePath: string): string;
28
+ buildModule(options: Parameters<typeof build>[0], buildExecutor?: BuildExecutor): Promise<BuildResult>;
29
+ canLoadSourceModuleFromHost(filePath: string): boolean;
30
+ getHostModuleLoader: SourceModuleLoaderFactory;
31
+ }
32
+ /**
33
+ * Loads source page modules in a runtime-agnostic way.
34
+ *
35
+ * This service centralizes the Bun-vs-Node import strategy used by route
36
+ * scanning, page data loading, and request-time page inspection. In Bun it can
37
+ * import source files directly; in Node it transpiles the file into a dedicated
38
+ * output directory first and then imports the generated module.
39
+ *
40
+ * Keeping this logic in one place prevents subtle drift in cache-busting,
41
+ * transpilation settings, and error semantics across the different callers.
42
+ */
43
+ export declare class PageModuleImportService {
44
+ private readonly dependencies;
45
+ private readonly importCache;
46
+ private developmentInvalidationVersion;
47
+ constructor(dependencies?: Partial<PageModuleImportDependencies>);
48
+ /**
49
+ * Clears the shared import cache used by framework-owned page-module loads.
50
+ */
51
+ clearImportCache(): void;
52
+ /**
53
+ * Invalidates all previously imported modules in development by clearing the
54
+ * import cache and incrementing the invalidation version included in cache keys.
55
+ *
56
+ * This forces all modules to be reloaded on the next import, even if their
57
+ * source content hasn't changed. This is necessary to ensure that changes to
58
+ * non-content aspects of modules (e.g. dependencies, transpilation output)
59
+ * are picked up during development.
60
+ */
61
+ invalidateDevelopmentGraph(): void;
62
+ /**
63
+ * Imports a page-like module from source.
64
+ *
65
+ * The caller controls the output directory and error wording so different
66
+ * subsystems can reuse the same loading mechanism while preserving their
67
+ * current diagnostics. Module identities stay stable for unchanged files and
68
+ * roll forward automatically when the source hash changes during watch mode.
69
+ *
70
+ * @typeParam T Expected module shape.
71
+ * @param options Runtime-specific import settings.
72
+ * @returns The loaded module.
73
+ */
74
+ importModule<T = unknown>(options: PageModuleImportOptions): Promise<T>;
75
+ private loadModule;
76
+ }
@@ -0,0 +1,170 @@
1
+ import path from "node:path";
2
+ import { pathToFileURL } from "node:url";
3
+ import { fileSystem } from "@ecopages/file-system";
4
+ import { build } from "../../build/build-adapter.js";
5
+ import { supportsSourceModuleLoading } from "./source-module-support.js";
6
+ class PageModuleImportService {
7
+ dependencies;
8
+ importCache = /* @__PURE__ */ new Map();
9
+ developmentInvalidationVersion = 0;
10
+ constructor(dependencies) {
11
+ this.dependencies = {
12
+ hashFile: dependencies?.hashFile ?? ((filePath) => fileSystem.hash(filePath)),
13
+ buildModule: dependencies?.buildModule ?? ((options, buildExecutor) => build(options, buildExecutor)),
14
+ canLoadSourceModuleFromHost: dependencies?.canLoadSourceModuleFromHost ?? supportsSourceModuleLoading,
15
+ getHostModuleLoader: dependencies?.getHostModuleLoader ?? (() => void 0)
16
+ };
17
+ }
18
+ /**
19
+ * Clears the shared import cache used by framework-owned page-module loads.
20
+ */
21
+ clearImportCache() {
22
+ this.importCache.clear();
23
+ }
24
+ /**
25
+ * Invalidates all previously imported modules in development by clearing the
26
+ * import cache and incrementing the invalidation version included in cache keys.
27
+ *
28
+ * This forces all modules to be reloaded on the next import, even if their
29
+ * source content hasn't changed. This is necessary to ensure that changes to
30
+ * non-content aspects of modules (e.g. dependencies, transpilation output)
31
+ * are picked up during development.
32
+ */
33
+ invalidateDevelopmentGraph() {
34
+ this.clearImportCache();
35
+ this.developmentInvalidationVersion += 1;
36
+ }
37
+ /**
38
+ * Imports a page-like module from source.
39
+ *
40
+ * The caller controls the output directory and error wording so different
41
+ * subsystems can reuse the same loading mechanism while preserving their
42
+ * current diagnostics. Module identities stay stable for unchanged files and
43
+ * roll forward automatically when the source hash changes during watch mode.
44
+ *
45
+ * @typeParam T Expected module shape.
46
+ * @param options Runtime-specific import settings.
47
+ * @returns The loaded module.
48
+ */
49
+ async importModule(options) {
50
+ const { filePath, rootDir, externalPackages, splitting } = options;
51
+ const invalidationVersion = options.invalidationVersion ?? this.developmentInvalidationVersion;
52
+ const fileHash = this.dependencies.hashFile(filePath);
53
+ const hostModuleLoader = typeof Bun === "undefined" && process.env.NODE_ENV === "development" && this.dependencies.canLoadSourceModuleFromHost(filePath) ? this.dependencies.getHostModuleLoader() : void 0;
54
+ if (hostModuleLoader) {
55
+ const sourceModuleUrl = createRuntimeModuleUrl(filePath, fileHash, invalidationVersion, options.cacheScope);
56
+ return await hostModuleLoader(sourceModuleUrl.href);
57
+ }
58
+ if (options.bypassCache) {
59
+ this.developmentInvalidationVersion += 1;
60
+ return await this.loadModule({
61
+ ...options,
62
+ invalidationVersion: this.developmentInvalidationVersion,
63
+ fileHash
64
+ });
65
+ }
66
+ const runtime = typeof Bun !== "undefined" ? "bun" : "node-build";
67
+ const cacheKey = [
68
+ runtime,
69
+ filePath,
70
+ rootDir,
71
+ splitting ?? "default",
72
+ externalPackages ?? "default",
73
+ options.cacheScope ?? "default",
74
+ fileHash,
75
+ invalidationVersion
76
+ ].join("::");
77
+ const cachedModule = this.importCache.get(cacheKey);
78
+ if (cachedModule) {
79
+ return await cachedModule;
80
+ }
81
+ const importPromise = this.loadModule({
82
+ ...options,
83
+ fileHash
84
+ });
85
+ this.importCache.set(cacheKey, importPromise);
86
+ try {
87
+ return await importPromise;
88
+ } catch (error) {
89
+ this.importCache.delete(cacheKey);
90
+ throw error;
91
+ }
92
+ }
93
+ async loadModule(options) {
94
+ const {
95
+ filePath,
96
+ rootDir,
97
+ outdir,
98
+ invalidationVersion = this.developmentInvalidationVersion,
99
+ splitting,
100
+ externalPackages,
101
+ cacheScope,
102
+ transpileErrorMessage = (details) => `Error transpiling page module: ${details}`,
103
+ noOutputMessage = (targetFilePath) => `No transpiled output generated for page module: ${targetFilePath}`,
104
+ fileHash
105
+ } = options;
106
+ const sourceModuleUrl = createRuntimeModuleUrl(filePath, fileHash, invalidationVersion, cacheScope);
107
+ if (typeof Bun !== "undefined") {
108
+ return await import(
109
+ /* @vite-ignore */
110
+ sourceModuleUrl.href
111
+ );
112
+ }
113
+ const fileBaseName = path.basename(filePath, path.extname(filePath));
114
+ const cacheScopeSuffix = cacheScope ? `-${sanitizeCacheScope(cacheScope)}` : "";
115
+ const outputFileName = `${fileBaseName}-${fileHash}${cacheScopeSuffix}.js`;
116
+ const buildResult = await this.dependencies.buildModule(
117
+ {
118
+ entrypoints: [filePath],
119
+ root: rootDir,
120
+ outdir,
121
+ target: "es2022",
122
+ format: "esm",
123
+ sourcemap: "none",
124
+ splitting: splitting ?? true,
125
+ minify: false,
126
+ naming: outputFileName,
127
+ externalPackages: true,
128
+ plugins: options.plugins,
129
+ ...externalPackages !== void 0 ? { externalPackages } : {}
130
+ },
131
+ options.buildExecutor
132
+ );
133
+ if (!buildResult.success) {
134
+ const details = buildResult.logs.map((log) => log.message).join(" | ");
135
+ throw new Error(transpileErrorMessage(details));
136
+ }
137
+ const preferredOutputPath = path.join(outdir, outputFileName);
138
+ const compiledOutput = buildResult.outputs.find((output) => output.path === preferredOutputPath)?.path ?? buildResult.outputs.find((output) => output.path.endsWith(".js"))?.path;
139
+ if (!compiledOutput) {
140
+ throw new Error(noOutputMessage(filePath));
141
+ }
142
+ const compiledOutputUrl = pathToFileURL(compiledOutput);
143
+ if (process.env.NODE_ENV === "development" || cacheScope) {
144
+ compiledOutputUrl.searchParams.set(
145
+ "update",
146
+ [fileHash, invalidationVersion, cacheScope ? sanitizeCacheScope(cacheScope) : void 0].filter((value) => value !== void 0).join("-")
147
+ );
148
+ }
149
+ return await import(
150
+ /* @vite-ignore */
151
+ compiledOutputUrl.href
152
+ );
153
+ }
154
+ }
155
+ function createRuntimeModuleUrl(filePath, fileHash, invalidationVersion, cacheScope) {
156
+ const moduleUrl = pathToFileURL(filePath);
157
+ if (process.env.NODE_ENV === "development" || cacheScope) {
158
+ moduleUrl.searchParams.set(
159
+ "update",
160
+ [fileHash, invalidationVersion, cacheScope ? sanitizeCacheScope(cacheScope) : void 0].filter((value) => value !== void 0).join("-")
161
+ );
162
+ }
163
+ return moduleUrl;
164
+ }
165
+ function sanitizeCacheScope(cacheScope) {
166
+ return cacheScope.replace(/[^a-zA-Z0-9_-]+/g, "-");
167
+ }
168
+ export {
169
+ PageModuleImportService
170
+ };
@@ -0,0 +1,63 @@
1
+ import type { BuildExecutor } from '../../build/build-adapter.js';
2
+ import type { EcoBuildPlugin } from '../../build/build-types.js';
3
+ import type { AppModuleLoader } from './app-module-loader.service.js';
4
+ import { type PageModuleImportOptions } from './page-module-import.service.js';
5
+ import type { SourceModuleLoaderFactory } from './module-loading-types.js';
6
+ export type ServerModuleTranspilerOptions = Omit<PageModuleImportOptions, 'rootDir' | 'buildExecutor'>;
7
+ export type ServerModuleImportDependency = Pick<AppModuleLoader, 'importModule' | 'invalidateDevelopmentGraph'>;
8
+ /**
9
+ * Immutable execution context for one server-transpiler instance.
10
+ *
11
+ * @remarks
12
+ * Callers own when and why a new transpiler is created. This service only owns
13
+ * applying the supplied root/build-executor pair consistently to every module
14
+ * load that passes through it.
15
+ */
16
+ export type ServerModuleTranspilerBootstrapArgs = {
17
+ rootDir: string;
18
+ getBuildExecutor?: () => BuildExecutor | undefined;
19
+ canLoadSourceModuleFromHost?: (filePath: string) => boolean;
20
+ getHostModuleLoader?: SourceModuleLoaderFactory;
21
+ getInvalidationVersion?: () => number;
22
+ invalidateModules?: (changedFiles?: string[]) => void;
23
+ pageModuleImportService?: ServerModuleImportDependency;
24
+ /** Factory evaluated on each importModule call to produce plugins applied to every load. */
25
+ getDefaultPlugins?: () => EcoBuildPlugin[];
26
+ };
27
+ /**
28
+ * App-owned boundary for server-side source module loading.
29
+ *
30
+ * @remarks
31
+ * This service centralizes server-side module transpilation and import behind
32
+ * an explicit caller-owned root and build executor.
33
+ */
34
+ export declare class ServerModuleTranspiler {
35
+ private readonly pageModuleImportService;
36
+ private readonly getRootDir;
37
+ private readonly getBuildExecutor;
38
+ private readonly getInvalidationVersion;
39
+ private readonly invalidateModules;
40
+ private readonly getDefaultPlugins;
41
+ /**
42
+ * Creates one explicit server-transpiler boundary for a given execution
43
+ * context.
44
+ */
45
+ constructor(args: ServerModuleTranspilerBootstrapArgs);
46
+ /**
47
+ * Loads a server-side source module through the caller-owned transpile
48
+ * context.
49
+ */
50
+ importModule<T = unknown>(options: ServerModuleTranspilerOptions): Promise<T>;
51
+ /**
52
+ * Invalidates cached module state for development reloads.
53
+ */
54
+ invalidate(changedFiles?: string[]): void;
55
+ /**
56
+ * Releases transpiler-owned resources.
57
+ *
58
+ * @remarks
59
+ * The current implementation delegates cache ownership to lower-level module
60
+ * loading services, so disposal is intentionally a no-op for now.
61
+ */
62
+ dispose(): Promise<void>;
63
+ }
@@ -0,0 +1,64 @@
1
+ import { PageModuleImportService } from "./page-module-import.service.js";
2
+ class ServerModuleTranspiler {
3
+ pageModuleImportService;
4
+ getRootDir;
5
+ getBuildExecutor;
6
+ getInvalidationVersion;
7
+ invalidateModules;
8
+ getDefaultPlugins;
9
+ /**
10
+ * Creates one explicit server-transpiler boundary for a given execution
11
+ * context.
12
+ */
13
+ constructor(args) {
14
+ this.pageModuleImportService = args.pageModuleImportService ?? new PageModuleImportService({
15
+ canLoadSourceModuleFromHost: args.canLoadSourceModuleFromHost,
16
+ getHostModuleLoader: args.getHostModuleLoader
17
+ });
18
+ this.getRootDir = () => args.rootDir;
19
+ this.getBuildExecutor = args.getBuildExecutor ?? (() => void 0);
20
+ this.getInvalidationVersion = () => args.getInvalidationVersion?.();
21
+ this.getDefaultPlugins = args.getDefaultPlugins ?? (() => []);
22
+ this.invalidateModules = (changedFiles) => {
23
+ if (args.invalidateModules) {
24
+ args.invalidateModules(changedFiles);
25
+ return;
26
+ }
27
+ this.pageModuleImportService.invalidateDevelopmentGraph();
28
+ };
29
+ }
30
+ /**
31
+ * Loads a server-side source module through the caller-owned transpile
32
+ * context.
33
+ */
34
+ async importModule(options) {
35
+ const mergedPlugins = [...this.getDefaultPlugins(), ...options.plugins ?? []];
36
+ const { plugins: _plugins, ...baseOptions } = options;
37
+ return await this.pageModuleImportService.importModule({
38
+ ...baseOptions,
39
+ ...mergedPlugins.length > 0 ? { plugins: mergedPlugins } : {},
40
+ rootDir: this.getRootDir(),
41
+ buildExecutor: this.getBuildExecutor(),
42
+ invalidationVersion: this.getInvalidationVersion()
43
+ });
44
+ }
45
+ /**
46
+ * Invalidates cached module state for development reloads.
47
+ */
48
+ invalidate(changedFiles) {
49
+ this.invalidateModules(changedFiles);
50
+ }
51
+ /**
52
+ * Releases transpiler-owned resources.
53
+ *
54
+ * @remarks
55
+ * The current implementation delegates cache ownership to lower-level module
56
+ * loading services, so disposal is intentionally a no-op for now.
57
+ */
58
+ async dispose() {
59
+ return;
60
+ }
61
+ }
62
+ export {
63
+ ServerModuleTranspiler
64
+ };
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Returns whether a source module can be loaded directly by the host runtime without
3
+ * first going through the transpile/import pipeline.
4
+ */
5
+ export declare function supportsSourceModuleLoading(filePath: string): boolean;
@@ -0,0 +1,8 @@
1
+ import path from "node:path";
2
+ function supportsSourceModuleLoading(filePath) {
3
+ const extension = path.extname(filePath);
4
+ return extension === ".js" || extension === ".jsx" || extension === ".ts" || extension === ".tsx" || extension === ".mjs" || extension === ".mts" || extension === ".cjs" || extension === ".cts";
5
+ }
6
+ export {
7
+ supportsSourceModuleLoading
8
+ };