@ecopages/core 0.2.0-alpha.1 → 0.2.0-alpha.10
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.
- package/CHANGELOG.md +13 -70
- package/README.md +213 -12
- package/package.json +50 -18
- package/src/adapters/README.md +39 -0
- package/src/adapters/bun/hmr-manager.d.ts +77 -18
- package/src/adapters/bun/hmr-manager.js +159 -52
- package/src/adapters/bun/index.d.ts +1 -2
- package/src/adapters/bun/index.js +1 -1
- package/src/adapters/bun/server-adapter.js +35 -30
- package/src/adapters/bun/server-lifecycle.d.ts +24 -13
- package/src/adapters/bun/server-lifecycle.js +32 -60
- package/src/adapters/index.d.ts +1 -1
- package/src/adapters/index.js +1 -1
- package/src/adapters/node/bootstrap-dependency-resolver.d.ts +44 -0
- package/src/adapters/node/bootstrap-dependency-resolver.js +172 -0
- package/src/adapters/node/index.d.ts +2 -0
- package/src/adapters/node/index.js +3 -0
- package/src/adapters/node/node-hmr-manager.d.ts +87 -16
- package/src/adapters/node/node-hmr-manager.js +179 -88
- package/src/adapters/node/runtime-adapter.d.ts +46 -0
- package/src/adapters/node/runtime-adapter.js +306 -0
- package/src/adapters/node/server-adapter.d.ts +2 -31
- package/src/adapters/node/server-adapter.js +31 -93
- package/src/adapters/node/static-content-server.d.ts +36 -0
- package/src/adapters/node/static-content-server.js +28 -0
- package/src/adapters/node/write-runtime-manifest.d.ts +26 -0
- package/src/adapters/node/write-runtime-manifest.js +12 -0
- package/src/{define-api-handler.d.ts → adapters/shared/define-api-handler.d.ts} +1 -1
- package/src/adapters/shared/explicit-static-route-matcher.js +4 -1
- package/src/adapters/shared/file-route-middleware-pipeline.js +1 -0
- package/src/adapters/shared/fs-server-response-matcher.d.ts +9 -5
- package/src/adapters/shared/fs-server-response-matcher.js +13 -8
- package/src/adapters/shared/hmr-entrypoint-registrar.d.ts +55 -0
- package/src/adapters/shared/hmr-entrypoint-registrar.js +87 -0
- package/src/adapters/shared/hmr-html-response.d.ts +22 -0
- package/src/adapters/shared/hmr-html-response.js +32 -0
- package/src/adapters/shared/render-context.js +3 -2
- package/src/adapters/shared/runtime-bootstrap.d.ts +38 -0
- package/src/adapters/shared/runtime-bootstrap.js +43 -0
- package/src/adapters/shared/server-adapter.d.ts +12 -2
- package/src/adapters/shared/server-adapter.js +37 -4
- package/src/adapters/shared/server-route-handler.d.ts +1 -1
- package/src/adapters/shared/server-route-handler.js +4 -13
- package/src/adapters/shared/server-static-builder.d.ts +35 -3
- package/src/adapters/shared/server-static-builder.js +59 -6
- package/src/build/README.md +101 -0
- package/src/build/build-adapter.d.ts +114 -2
- package/src/build/build-adapter.js +119 -5
- package/src/build/build-manifest.d.ts +27 -0
- package/src/build/build-manifest.js +30 -0
- package/src/build/dev-build-coordinator.d.ts +74 -0
- package/src/build/dev-build-coordinator.js +161 -0
- package/src/build/esbuild-build-adapter.d.ts +9 -6
- package/src/build/esbuild-build-adapter.js +103 -71
- package/src/build/runtime-build-executor.d.ts +13 -0
- package/src/build/runtime-build-executor.js +20 -0
- package/src/build/runtime-specifier-alias-plugin.d.ts +15 -0
- package/src/build/runtime-specifier-alias-plugin.js +31 -0
- package/src/config/README.md +33 -0
- package/src/config/config-builder.d.ts +28 -17
- package/src/config/config-builder.js +221 -48
- package/src/constants.d.ts +13 -0
- package/src/constants.js +4 -0
- package/src/declarations.d.ts +18 -13
- package/src/eco/README.md +70 -16
- package/src/eco/component-render-context.d.ts +1 -1
- package/src/eco/component-render-context.js +26 -16
- package/src/eco/eco.js +16 -12
- package/src/eco/eco.types.d.ts +12 -4
- package/src/hmr/README.md +26 -0
- package/src/hmr/client/hmr-runtime.d.ts +1 -6
- package/src/hmr/client/hmr-runtime.js +30 -7
- package/src/hmr/hmr.postcss.test.e2e.d.ts +1 -0
- package/src/hmr/hmr.postcss.test.e2e.js +31 -0
- package/src/hmr/hmr.test.e2e.js +26 -33
- package/src/hmr/strategies/js-hmr-strategy.d.ts +45 -42
- package/src/hmr/strategies/js-hmr-strategy.js +70 -71
- package/src/index.d.ts +1 -1
- package/src/index.js +1 -1
- package/src/integrations/ghtml/ghtml-renderer.d.ts +1 -1
- package/src/integrations/ghtml/ghtml-renderer.js +3 -1
- package/src/internal-types.d.ts +39 -18
- package/src/plugins/README.md +34 -0
- package/src/plugins/alias-resolver-plugin.js +17 -3
- package/src/plugins/eco-component-meta-plugin.d.ts +2 -0
- package/src/plugins/eco-component-meta-plugin.js +1 -1
- package/src/plugins/integration-plugin.d.ts +38 -4
- package/src/plugins/integration-plugin.js +34 -1
- package/src/plugins/processor.d.ts +14 -1
- package/src/plugins/processor.js +15 -1
- package/src/plugins/runtime-capability.d.ts +9 -0
- package/src/public-types.d.ts +65 -10
- package/src/route-renderer/GRAPH.md +16 -20
- package/src/route-renderer/README.md +8 -21
- package/src/route-renderer/component-graph/component-reference.d.ts +10 -0
- package/src/route-renderer/component-graph/component-reference.js +19 -0
- package/src/route-renderer/{marker-graph-resolver.d.ts → component-graph/marker-graph-resolver.d.ts} +6 -5
- package/src/route-renderer/{marker-graph-resolver.js → component-graph/marker-graph-resolver.js} +10 -8
- package/src/route-renderer/{integration-renderer.d.ts → orchestration/integration-renderer.d.ts} +45 -12
- package/src/route-renderer/{integration-renderer.js → orchestration/integration-renderer.js} +79 -16
- package/src/route-renderer/{render-execution.service.d.ts → orchestration/render-execution.service.d.ts} +39 -5
- package/src/route-renderer/{render-execution.service.js → orchestration/render-execution.service.js} +58 -28
- package/src/route-renderer/{render-preparation.service.d.ts → orchestration/render-preparation.service.d.ts} +13 -4
- package/src/route-renderer/{render-preparation.service.js → orchestration/render-preparation.service.js} +92 -3
- package/src/route-renderer/{dependency-resolver.d.ts → page-loading/dependency-resolver.d.ts} +15 -4
- package/src/route-renderer/{dependency-resolver.js → page-loading/dependency-resolver.js} +18 -4
- package/src/route-renderer/page-loading/page-module-loader.d.ts +87 -0
- package/src/route-renderer/{page-module-loader.js → page-loading/page-module-loader.js} +36 -14
- package/src/route-renderer/route-renderer.d.ts +36 -1
- package/src/route-renderer/route-renderer.js +19 -0
- package/src/router/README.md +26 -0
- package/src/router/client/link-intent.d.ts +53 -0
- package/src/router/client/link-intent.js +34 -0
- package/src/router/client/link-intent.test.browser.d.ts +1 -0
- package/src/router/client/link-intent.test.browser.js +43 -0
- package/src/router/client/navigation-coordinator.d.ts +149 -0
- package/src/router/client/navigation-coordinator.js +215 -0
- package/src/router/{fs-router-scanner.d.ts → server/fs-router-scanner.d.ts} +3 -3
- package/src/router/{fs-router-scanner.js → server/fs-router-scanner.js} +8 -7
- package/src/router/{fs-router.d.ts → server/fs-router.d.ts} +1 -1
- package/src/router/{fs-router.js → server/fs-router.js} +1 -1
- package/src/services/README.md +29 -0
- package/src/services/assets/asset-processing-service/asset-processing.service.d.ts +120 -0
- package/src/services/{asset-processing-service → assets/asset-processing-service}/asset-processing.service.js +88 -7
- package/src/services/{asset-processing-service → assets/asset-processing-service}/asset.factory.js +2 -2
- package/src/services/{asset-processing-service → assets/asset-processing-service}/assets.types.d.ts +2 -1
- package/src/services/assets/asset-processing-service/assets.types.js +0 -0
- package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.d.ts +55 -0
- package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.js +48 -0
- package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.d.ts +20 -0
- package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.js +41 -0
- package/src/services/{asset-processing-service → assets/asset-processing-service}/index.d.ts +2 -0
- package/src/services/{asset-processing-service → assets/asset-processing-service}/index.js +2 -0
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.interface.d.ts +1 -1
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/base/base-processor.d.ts +1 -1
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/base/base-processor.js +9 -4
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/base/base-script-processor.d.ts +3 -2
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/base/base-script-processor.js +14 -22
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/file-script.processor.d.ts +1 -1
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/file-script.processor.js +2 -2
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/node-module-script.processor.js +5 -4
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/file-stylesheet.processor.js +4 -1
- package/src/services/assets/browser-bundle.service.d.ts +32 -0
- package/src/services/assets/browser-bundle.service.js +33 -0
- package/src/services/{page-request-cache-coordinator.service.d.ts → cache/page-request-cache-coordinator.service.d.ts} +2 -2
- package/src/services/{page-request-cache-coordinator.service.js → cache/page-request-cache-coordinator.service.js} +3 -1
- package/src/services/html/html-rewriter-provider.service.d.ts +37 -0
- package/src/services/html/html-rewriter-provider.service.js +65 -0
- package/src/services/html/html-transformer.service.d.ts +77 -0
- package/src/services/html/html-transformer.service.js +221 -0
- package/src/services/invalidation/development-invalidation.service.d.ts +74 -0
- package/src/services/invalidation/development-invalidation.service.js +189 -0
- package/src/services/module-loading/app-server-module-transpiler.service.d.ts +16 -0
- package/src/services/module-loading/app-server-module-transpiler.service.js +34 -0
- package/src/services/module-loading/page-module-import.service.d.ts +71 -0
- package/src/services/module-loading/page-module-import.service.js +132 -0
- package/src/services/module-loading/server-loader.service.d.ts +96 -0
- package/src/services/module-loading/server-loader.service.js +32 -0
- package/src/services/module-loading/server-module-transpiler.service.d.ts +69 -0
- package/src/services/module-loading/server-module-transpiler.service.js +61 -0
- package/src/services/runtime-manifest/node-runtime-manifest.service.d.ts +35 -0
- package/src/services/runtime-manifest/node-runtime-manifest.service.js +60 -0
- package/src/services/runtime-state/dev-graph.service.d.ts +118 -0
- package/src/services/runtime-state/dev-graph.service.js +162 -0
- package/src/services/runtime-state/entrypoint-dependency-graph.service.d.ts +41 -0
- package/src/services/runtime-state/entrypoint-dependency-graph.service.js +85 -0
- package/src/services/runtime-state/runtime-specifier-registry.service.d.ts +69 -0
- package/src/services/runtime-state/runtime-specifier-registry.service.js +37 -0
- package/src/services/runtime-state/server-invalidation-state.service.d.ts +26 -0
- package/src/services/runtime-state/server-invalidation-state.service.js +35 -0
- package/src/services/{schema-validation-service.d.ts → validation/schema-validation-service.d.ts} +1 -1
- package/src/static-site-generator/README.md +26 -0
- package/src/static-site-generator/static-site-generator.d.ts +53 -1
- package/src/static-site-generator/static-site-generator.js +86 -5
- package/src/utils/resolve-work-dir.d.ts +11 -0
- package/src/utils/resolve-work-dir.js +31 -0
- package/src/watchers/project-watcher.d.ts +37 -21
- package/src/watchers/project-watcher.js +109 -66
- package/src/watchers/project-watcher.test-helpers.js +1 -0
- package/src/adapters/abstract/application-adapter.ts +0 -337
- package/src/adapters/abstract/router-adapter.ts +0 -30
- package/src/adapters/abstract/server-adapter.ts +0 -79
- package/src/adapters/bun/client-bridge.ts +0 -62
- package/src/adapters/bun/create-app.ts +0 -189
- package/src/adapters/bun/define-api-handler.d.ts +0 -61
- package/src/adapters/bun/define-api-handler.ts +0 -114
- package/src/adapters/bun/hmr-manager.ts +0 -281
- package/src/adapters/bun/index.ts +0 -3
- package/src/adapters/bun/server-adapter.ts +0 -492
- package/src/adapters/bun/server-lifecycle.ts +0 -154
- package/src/adapters/index.ts +0 -6
- package/src/adapters/node/create-app.ts +0 -179
- package/src/adapters/node/index.ts +0 -9
- package/src/adapters/node/node-client-bridge.ts +0 -79
- package/src/adapters/node/node-hmr-manager.ts +0 -271
- package/src/adapters/node/server-adapter.ts +0 -561
- package/src/adapters/node/static-content-server.ts +0 -203
- package/src/adapters/shared/api-response.ts +0 -104
- package/src/adapters/shared/application-adapter.ts +0 -199
- package/src/adapters/shared/explicit-static-route-matcher.ts +0 -134
- package/src/adapters/shared/file-route-middleware-pipeline.ts +0 -123
- package/src/adapters/shared/fs-server-response-factory.ts +0 -118
- package/src/adapters/shared/fs-server-response-matcher.ts +0 -198
- package/src/adapters/shared/render-context.ts +0 -105
- package/src/adapters/shared/server-adapter.ts +0 -442
- package/src/adapters/shared/server-route-handler.ts +0 -166
- package/src/adapters/shared/server-static-builder.ts +0 -82
- package/src/build/build-adapter.ts +0 -132
- package/src/build/build-types.ts +0 -83
- package/src/build/esbuild-build-adapter.ts +0 -510
- package/src/config/config-builder.ts +0 -474
- package/src/constants.ts +0 -39
- package/src/create-app.ts +0 -87
- package/src/define-api-handler.js +0 -15
- package/src/define-api-handler.ts +0 -66
- package/src/dev/sc-server.ts +0 -143
- package/src/eco/component-render-context.ts +0 -202
- package/src/eco/eco.ts +0 -221
- package/src/eco/eco.types.ts +0 -202
- package/src/eco/eco.utils.ts +0 -89
- package/src/eco/global-injector-map.ts +0 -112
- package/src/eco/lazy-injector-map.ts +0 -120
- package/src/eco/module-dependencies.ts +0 -75
- package/src/errors/http-error.ts +0 -72
- package/src/errors/index.ts +0 -2
- package/src/errors/locals-access-error.ts +0 -7
- package/src/global/app-logger.ts +0 -4
- 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
- package/src/hmr/client/__screenshots__/hmr-runtime.test.browser.ts/HMR-Runtime-HMR-Server-Integration-should-load-fixture-app-page-1.png +0 -0
- package/src/hmr/client/__screenshots__/hmr-runtime.test.browser.ts/HMR-Runtime-WebSocket-Connection-should-connect-to-correct-HMR-endpoint-1.png +0 -0
- package/src/hmr/client/hmr-runtime.ts +0 -121
- package/src/hmr/hmr-strategy.ts +0 -172
- package/src/hmr/hmr.test.e2e.ts +0 -75
- package/src/hmr/strategies/default-hmr-strategy.ts +0 -60
- package/src/hmr/strategies/js-hmr-strategy.ts +0 -308
- package/src/index.browser.ts +0 -3
- package/src/index.ts +0 -5
- package/src/integrations/ghtml/ghtml-renderer.ts +0 -93
- package/src/integrations/ghtml/ghtml.plugin.ts +0 -32
- package/src/internal-types.ts +0 -212
- package/src/plugins/alias-resolver-plugin.ts +0 -45
- package/src/plugins/eco-component-meta-plugin.ts +0 -474
- package/src/plugins/integration-plugin.ts +0 -184
- package/src/plugins/processor.ts +0 -220
- package/src/public-types.ts +0 -1255
- package/src/route-renderer/component-graph-executor.ts +0 -84
- package/src/route-renderer/component-graph.ts +0 -159
- package/src/route-renderer/component-marker.ts +0 -117
- package/src/route-renderer/dependency-resolver.ts +0 -596
- package/src/route-renderer/html-post-processing.service.d.ts +0 -40
- package/src/route-renderer/html-post-processing.service.js +0 -86
- package/src/route-renderer/html-post-processing.service.ts +0 -103
- package/src/route-renderer/integration-renderer.ts +0 -696
- package/src/route-renderer/marker-graph-resolver.ts +0 -153
- package/src/route-renderer/page-module-loader.d.ts +0 -61
- package/src/route-renderer/page-module-loader.ts +0 -153
- package/src/route-renderer/render-execution.service.ts +0 -158
- package/src/route-renderer/render-preparation.service.ts +0 -358
- package/src/route-renderer/route-renderer.ts +0 -80
- package/src/router/fs-router-scanner.ts +0 -217
- package/src/router/fs-router.ts +0 -122
- package/src/services/asset-processing-service/asset-processing.service.d.ts +0 -41
- package/src/services/asset-processing-service/asset-processing.service.ts +0 -306
- package/src/services/asset-processing-service/asset.factory.ts +0 -105
- package/src/services/asset-processing-service/assets.types.ts +0 -112
- package/src/services/asset-processing-service/index.ts +0 -3
- package/src/services/asset-processing-service/processor.interface.ts +0 -27
- package/src/services/asset-processing-service/processor.registry.ts +0 -18
- package/src/services/asset-processing-service/processors/base/base-processor.ts +0 -76
- package/src/services/asset-processing-service/processors/base/base-script-processor.ts +0 -105
- package/src/services/asset-processing-service/processors/index.ts +0 -5
- package/src/services/asset-processing-service/processors/script/content-script.processor.ts +0 -66
- package/src/services/asset-processing-service/processors/script/file-script.processor.ts +0 -88
- package/src/services/asset-processing-service/processors/script/node-module-script.processor.ts +0 -84
- package/src/services/asset-processing-service/processors/stylesheet/content-stylesheet.processor.ts +0 -27
- package/src/services/asset-processing-service/processors/stylesheet/file-stylesheet.processor.ts +0 -77
- package/src/services/cache/cache.types.ts +0 -126
- package/src/services/cache/index.ts +0 -18
- package/src/services/cache/memory-cache-store.ts +0 -130
- package/src/services/cache/page-cache-service.ts +0 -202
- package/src/services/html-transformer.service.d.ts +0 -50
- package/src/services/html-transformer.service.js +0 -163
- package/src/services/html-transformer.service.ts +0 -217
- package/src/services/page-module-import.service.d.ts +0 -37
- package/src/services/page-module-import.service.js +0 -88
- package/src/services/page-module-import.service.ts +0 -129
- package/src/services/page-request-cache-coordinator.service.ts +0 -128
- package/src/services/schema-validation-service.ts +0 -204
- package/src/services/validation/standard-schema.types.ts +0 -68
- package/src/static-site-generator/static-site-generator.ts +0 -359
- package/src/utils/css.ts +0 -5
- package/src/utils/deep-merge.ts +0 -47
- package/src/utils/hash.ts +0 -5
- package/src/utils/html.ts +0 -1
- package/src/utils/invariant.ts +0 -15
- package/src/utils/locals-utils.ts +0 -37
- package/src/utils/parse-cli-args.ts +0 -83
- package/src/utils/path-utils.module.ts +0 -14
- package/src/utils/runtime.ts +0 -44
- package/src/utils/server-utils.module.ts +0 -67
- package/src/watchers/project-watcher.test-helpers.ts +0 -40
- package/src/watchers/project-watcher.ts +0 -306
- /package/src/adapters/{bun → shared}/define-api-handler.js +0 -0
- /package/src/{services/asset-processing-service/assets.types.js → plugins/runtime-capability.js} +0 -0
- /package/src/route-renderer/{component-graph-executor.d.ts → component-graph/component-graph-executor.d.ts} +0 -0
- /package/src/route-renderer/{component-graph-executor.js → component-graph/component-graph-executor.js} +0 -0
- /package/src/route-renderer/{component-graph.d.ts → component-graph/component-graph.d.ts} +0 -0
- /package/src/route-renderer/{component-graph.js → component-graph/component-graph.js} +0 -0
- /package/src/route-renderer/{component-marker.d.ts → component-graph/component-marker.d.ts} +0 -0
- /package/src/route-renderer/{component-marker.js → component-graph/component-marker.js} +0 -0
- /package/src/services/{asset-processing-service → assets/asset-processing-service}/asset.factory.d.ts +0 -0
- /package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.interface.js +0 -0
- /package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.registry.d.ts +0 -0
- /package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.registry.js +0 -0
- /package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/index.d.ts +0 -0
- /package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/index.js +0 -0
- /package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/content-script.processor.d.ts +0 -0
- /package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/content-script.processor.js +0 -0
- /package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/node-module-script.processor.d.ts +0 -0
- /package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/content-stylesheet.processor.d.ts +0 -0
- /package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/content-stylesheet.processor.js +0 -0
- /package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/file-stylesheet.processor.d.ts +0 -0
- /package/src/services/{schema-validation-service.js → validation/schema-validation-service.js} +0 -0
|
@@ -0,0 +1,132 @@
|
|
|
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
|
+
class PageModuleImportService {
|
|
6
|
+
dependencies;
|
|
7
|
+
importCache = /* @__PURE__ */ new Map();
|
|
8
|
+
developmentInvalidationVersion = 0;
|
|
9
|
+
constructor(dependencies) {
|
|
10
|
+
this.dependencies = {
|
|
11
|
+
hashFile: dependencies?.hashFile ?? ((filePath) => fileSystem.hash(filePath)),
|
|
12
|
+
buildModule: dependencies?.buildModule ?? ((options, buildExecutor) => build(options, buildExecutor))
|
|
13
|
+
};
|
|
14
|
+
}
|
|
15
|
+
/**
|
|
16
|
+
* Clears the shared import cache used by framework-owned page-module loads.
|
|
17
|
+
*/
|
|
18
|
+
clearImportCache() {
|
|
19
|
+
this.importCache.clear();
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* Invalidates all previously imported modules in development by clearing the
|
|
23
|
+
* import cache and incrementing the invalidation version included in cache keys.
|
|
24
|
+
*
|
|
25
|
+
* This forces all modules to be reloaded on the next import, even if their
|
|
26
|
+
* source content hasn't changed. This is necessary to ensure that changes to
|
|
27
|
+
* non-content aspects of modules (e.g. dependencies, transpilation output)
|
|
28
|
+
* are picked up during development.
|
|
29
|
+
*/
|
|
30
|
+
invalidateDevelopmentGraph() {
|
|
31
|
+
this.clearImportCache();
|
|
32
|
+
this.developmentInvalidationVersion += 1;
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* Imports a page-like module from source.
|
|
36
|
+
*
|
|
37
|
+
* The caller controls the output directory and error wording so different
|
|
38
|
+
* subsystems can reuse the same loading mechanism while preserving their
|
|
39
|
+
* current diagnostics. Module identities stay stable for unchanged files and
|
|
40
|
+
* roll forward automatically when the source hash changes during watch mode.
|
|
41
|
+
*
|
|
42
|
+
* @typeParam T Expected module shape.
|
|
43
|
+
* @param options Runtime-specific import settings.
|
|
44
|
+
* @returns The loaded module.
|
|
45
|
+
*/
|
|
46
|
+
async importModule(options) {
|
|
47
|
+
const { filePath, rootDir, externalPackages, splitting } = options;
|
|
48
|
+
const invalidationVersion = options.invalidationVersion ?? this.developmentInvalidationVersion;
|
|
49
|
+
const fileHash = this.dependencies.hashFile(filePath);
|
|
50
|
+
const runtime = typeof Bun !== "undefined" ? "bun" : "node";
|
|
51
|
+
const cacheKey = [
|
|
52
|
+
runtime,
|
|
53
|
+
filePath,
|
|
54
|
+
rootDir,
|
|
55
|
+
splitting ?? "default",
|
|
56
|
+
externalPackages ?? "default",
|
|
57
|
+
fileHash,
|
|
58
|
+
invalidationVersion
|
|
59
|
+
].join("::");
|
|
60
|
+
const cachedModule = this.importCache.get(cacheKey);
|
|
61
|
+
if (cachedModule) {
|
|
62
|
+
return await cachedModule;
|
|
63
|
+
}
|
|
64
|
+
const importPromise = this.loadModule({
|
|
65
|
+
...options,
|
|
66
|
+
fileHash
|
|
67
|
+
});
|
|
68
|
+
this.importCache.set(cacheKey, importPromise);
|
|
69
|
+
try {
|
|
70
|
+
return await importPromise;
|
|
71
|
+
} catch (error) {
|
|
72
|
+
this.importCache.delete(cacheKey);
|
|
73
|
+
throw error;
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
async loadModule(options) {
|
|
77
|
+
const {
|
|
78
|
+
filePath,
|
|
79
|
+
rootDir,
|
|
80
|
+
outdir,
|
|
81
|
+
invalidationVersion = this.developmentInvalidationVersion,
|
|
82
|
+
splitting,
|
|
83
|
+
externalPackages,
|
|
84
|
+
transpileErrorMessage = (details) => `Error transpiling page module: ${details}`,
|
|
85
|
+
noOutputMessage = (targetFilePath) => `No transpiled output generated for page module: ${targetFilePath}`,
|
|
86
|
+
fileHash
|
|
87
|
+
} = options;
|
|
88
|
+
if (typeof Bun !== "undefined") {
|
|
89
|
+
const moduleUrl = pathToFileURL(filePath);
|
|
90
|
+
if (process.env.NODE_ENV === "development") {
|
|
91
|
+
moduleUrl.searchParams.set("update", `${fileHash}-${invalidationVersion}`);
|
|
92
|
+
}
|
|
93
|
+
return await import(moduleUrl.href);
|
|
94
|
+
}
|
|
95
|
+
const fileBaseName = path.basename(filePath, path.extname(filePath));
|
|
96
|
+
const outputFileName = `${fileBaseName}-${fileHash}.js`;
|
|
97
|
+
const buildResult = await this.dependencies.buildModule(
|
|
98
|
+
{
|
|
99
|
+
entrypoints: [filePath],
|
|
100
|
+
root: rootDir,
|
|
101
|
+
outdir,
|
|
102
|
+
target: "node",
|
|
103
|
+
format: "esm",
|
|
104
|
+
sourcemap: "none",
|
|
105
|
+
splitting: splitting ?? true,
|
|
106
|
+
minify: false,
|
|
107
|
+
naming: outputFileName,
|
|
108
|
+
externalPackages: true,
|
|
109
|
+
plugins: options.plugins,
|
|
110
|
+
...externalPackages !== void 0 ? { externalPackages } : {}
|
|
111
|
+
},
|
|
112
|
+
options.buildExecutor
|
|
113
|
+
);
|
|
114
|
+
if (!buildResult.success) {
|
|
115
|
+
const details = buildResult.logs.map((log) => log.message).join(" | ");
|
|
116
|
+
throw new Error(transpileErrorMessage(details));
|
|
117
|
+
}
|
|
118
|
+
const preferredOutputPath = path.join(outdir, outputFileName);
|
|
119
|
+
const compiledOutput = buildResult.outputs.find((output) => output.path === preferredOutputPath)?.path ?? buildResult.outputs.find((output) => output.path.endsWith(".js"))?.path;
|
|
120
|
+
if (!compiledOutput) {
|
|
121
|
+
throw new Error(noOutputMessage(filePath));
|
|
122
|
+
}
|
|
123
|
+
const compiledOutputUrl = pathToFileURL(compiledOutput);
|
|
124
|
+
if (process.env.NODE_ENV === "development") {
|
|
125
|
+
compiledOutputUrl.searchParams.set("update", `${fileHash}-${invalidationVersion}`);
|
|
126
|
+
}
|
|
127
|
+
return await import(compiledOutputUrl.href);
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
export {
|
|
131
|
+
PageModuleImportService
|
|
132
|
+
};
|
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
import type { EcoBuildPlugin } from '../../build/build-types.js';
|
|
2
|
+
import { type ServerModuleTranspilerBootstrapArgs, type ServerModuleTranspilerOptions } from './server-module-transpiler.service.js';
|
|
3
|
+
/**
|
|
4
|
+
* High-level module-loading options owned by the framework loader boundary.
|
|
5
|
+
*
|
|
6
|
+
* @remarks
|
|
7
|
+
* These are the same shape the lower-level transpiler needs, minus the
|
|
8
|
+
* root/build-executor ownership that the loader keeps internally.
|
|
9
|
+
*/
|
|
10
|
+
export interface ServerLoaderModuleOptions extends ServerModuleTranspilerOptions {
|
|
11
|
+
plugins?: EcoBuildPlugin[];
|
|
12
|
+
}
|
|
13
|
+
/**
|
|
14
|
+
* Mutable app-phase server-loading context.
|
|
15
|
+
*
|
|
16
|
+
* @remarks
|
|
17
|
+
* The loader starts with bootstrap config-loading context. Once a real built
|
|
18
|
+
* app config is available, the runtime adapter rebinds the loader so app-entry
|
|
19
|
+
* and downstream server modules load through the app-owned executor.
|
|
20
|
+
*/
|
|
21
|
+
export interface ServerLoaderAppContext extends ServerModuleTranspilerBootstrapArgs {
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* Minimal transpiler dependency required by the server loader.
|
|
25
|
+
*
|
|
26
|
+
* @remarks
|
|
27
|
+
* The loader owns orchestration between bootstrap and app phases, so tests only
|
|
28
|
+
* need this narrow import/invalidate/dispose surface rather than the concrete
|
|
29
|
+
* transpiler class.
|
|
30
|
+
*/
|
|
31
|
+
export interface ServerLoaderTranspilerDependency {
|
|
32
|
+
importModule<T = unknown>(options: ServerLoaderModuleOptions): Promise<T>;
|
|
33
|
+
invalidate(changedFiles?: string[]): void;
|
|
34
|
+
dispose(): Promise<void>;
|
|
35
|
+
}
|
|
36
|
+
/**
|
|
37
|
+
* Factory dependency used by the loader to create phase-specific transpilers.
|
|
38
|
+
*/
|
|
39
|
+
export interface ServerLoaderDependencyFactory {
|
|
40
|
+
createTranspiler(context: ServerModuleTranspilerBootstrapArgs): ServerLoaderTranspilerDependency;
|
|
41
|
+
}
|
|
42
|
+
/**
|
|
43
|
+
* Framework-owned server loading boundary.
|
|
44
|
+
*
|
|
45
|
+
* @remarks
|
|
46
|
+
* This abstraction owns config loading, app-entry loading, and cache lifecycle
|
|
47
|
+
* for the Node thin-host runtime path. Hosts and runtime adapters should depend
|
|
48
|
+
* on this boundary rather than coordinating raw transpiler instances directly.
|
|
49
|
+
*/
|
|
50
|
+
export interface ServerLoader {
|
|
51
|
+
/**
|
|
52
|
+
* Loads the bootstrap config module through the bootstrap server-loading
|
|
53
|
+
* context.
|
|
54
|
+
*/
|
|
55
|
+
loadConfig<T = unknown>(options: ServerLoaderModuleOptions): Promise<T>;
|
|
56
|
+
/**
|
|
57
|
+
* Loads the app entry module through the currently active app context.
|
|
58
|
+
*
|
|
59
|
+
* @remarks
|
|
60
|
+
* Until app context is rebound, this falls back to the bootstrap context so a
|
|
61
|
+
* caller can still load through one boundary during early bootstrap.
|
|
62
|
+
*/
|
|
63
|
+
loadApp<T = unknown>(options: ServerLoaderModuleOptions): Promise<T>;
|
|
64
|
+
/**
|
|
65
|
+
* Rebinds the app-phase loading context after a real app config has been
|
|
66
|
+
* loaded and app-owned build services are available.
|
|
67
|
+
*/
|
|
68
|
+
rebindAppContext(context: ServerLoaderAppContext): void;
|
|
69
|
+
/**
|
|
70
|
+
* Invalidates cached server module state for development reloads.
|
|
71
|
+
*/
|
|
72
|
+
invalidate(changedFiles?: string[]): void;
|
|
73
|
+
/**
|
|
74
|
+
* Releases loader-owned resources.
|
|
75
|
+
*/
|
|
76
|
+
dispose(): Promise<void>;
|
|
77
|
+
}
|
|
78
|
+
/**
|
|
79
|
+
* `ServerLoader` implementation backed by `ServerModuleTranspiler` instances.
|
|
80
|
+
*
|
|
81
|
+
* @remarks
|
|
82
|
+
* This is the first named loader abstraction for Workstream 3. It keeps the
|
|
83
|
+
* lower-level transpiler as the implementation detail while moving ownership of
|
|
84
|
+
* config/app entry orchestration into one service boundary.
|
|
85
|
+
*/
|
|
86
|
+
export declare class TranspilerServerLoader implements ServerLoader {
|
|
87
|
+
private readonly createTranspiler;
|
|
88
|
+
private readonly configTranspiler;
|
|
89
|
+
private appTranspiler;
|
|
90
|
+
constructor(configContext: ServerModuleTranspilerBootstrapArgs, dependencies?: ServerLoaderDependencyFactory);
|
|
91
|
+
loadConfig<T = unknown>(options: ServerLoaderModuleOptions): Promise<T>;
|
|
92
|
+
loadApp<T = unknown>(options: ServerLoaderModuleOptions): Promise<T>;
|
|
93
|
+
rebindAppContext(context: ServerLoaderAppContext): void;
|
|
94
|
+
invalidate(changedFiles?: string[]): void;
|
|
95
|
+
dispose(): Promise<void>;
|
|
96
|
+
}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import {
|
|
2
|
+
ServerModuleTranspiler
|
|
3
|
+
} from "./server-module-transpiler.service.js";
|
|
4
|
+
class TranspilerServerLoader {
|
|
5
|
+
createTranspiler;
|
|
6
|
+
configTranspiler;
|
|
7
|
+
appTranspiler = null;
|
|
8
|
+
constructor(configContext, dependencies) {
|
|
9
|
+
this.createTranspiler = dependencies?.createTranspiler ?? ((context) => new ServerModuleTranspiler(context));
|
|
10
|
+
this.configTranspiler = this.createTranspiler(configContext);
|
|
11
|
+
}
|
|
12
|
+
async loadConfig(options) {
|
|
13
|
+
return await this.configTranspiler.importModule(options);
|
|
14
|
+
}
|
|
15
|
+
async loadApp(options) {
|
|
16
|
+
return await (this.appTranspiler ?? this.configTranspiler).importModule(options);
|
|
17
|
+
}
|
|
18
|
+
rebindAppContext(context) {
|
|
19
|
+
this.appTranspiler = this.createTranspiler(context);
|
|
20
|
+
}
|
|
21
|
+
invalidate(changedFiles) {
|
|
22
|
+
this.configTranspiler.invalidate(changedFiles);
|
|
23
|
+
this.appTranspiler?.invalidate(changedFiles);
|
|
24
|
+
}
|
|
25
|
+
async dispose() {
|
|
26
|
+
await this.appTranspiler?.dispose();
|
|
27
|
+
await this.configTranspiler.dispose();
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
export {
|
|
31
|
+
TranspilerServerLoader
|
|
32
|
+
};
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
import type { BuildExecutor } from '../../build/build-adapter.js';
|
|
2
|
+
import type { EcoBuildPlugin } from '../../build/build-types.js';
|
|
3
|
+
import { type PageModuleImportOptions } from './page-module-import.service.js';
|
|
4
|
+
export type ServerModuleTranspilerOptions = Omit<PageModuleImportOptions, 'rootDir' | 'buildExecutor'>;
|
|
5
|
+
/**
|
|
6
|
+
* Minimal import-service dependency required by the server module transpiler.
|
|
7
|
+
*
|
|
8
|
+
* @remarks
|
|
9
|
+
* This keeps the transpiler boundary testable without module-level mocking and
|
|
10
|
+
* lets callers provide an app-owned import implementation when needed.
|
|
11
|
+
*/
|
|
12
|
+
export interface ServerModuleImportDependency {
|
|
13
|
+
importModule<T = unknown>(options: PageModuleImportOptions): Promise<T>;
|
|
14
|
+
invalidateDevelopmentGraph(): void;
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* Immutable execution context for one server-transpiler instance.
|
|
18
|
+
*
|
|
19
|
+
* @remarks
|
|
20
|
+
* Callers own when and why a new transpiler is created. This service only owns
|
|
21
|
+
* applying the supplied root/build-executor pair consistently to every module
|
|
22
|
+
* load that passes through it.
|
|
23
|
+
*/
|
|
24
|
+
export type ServerModuleTranspilerBootstrapArgs = {
|
|
25
|
+
rootDir: string;
|
|
26
|
+
getBuildExecutor: () => BuildExecutor | undefined;
|
|
27
|
+
getInvalidationVersion?: () => number;
|
|
28
|
+
invalidateModules?: (changedFiles?: string[]) => void;
|
|
29
|
+
pageModuleImportService?: ServerModuleImportDependency;
|
|
30
|
+
/** Factory evaluated on each importModule call to produce plugins applied to every load. */
|
|
31
|
+
getDefaultPlugins?: () => EcoBuildPlugin[];
|
|
32
|
+
};
|
|
33
|
+
/**
|
|
34
|
+
* App-owned boundary for server-side source module loading.
|
|
35
|
+
*
|
|
36
|
+
* @remarks
|
|
37
|
+
* This service centralizes server-side module transpilation and import behind
|
|
38
|
+
* an explicit caller-owned root and build executor.
|
|
39
|
+
*/
|
|
40
|
+
export declare class ServerModuleTranspiler {
|
|
41
|
+
private readonly pageModuleImportService;
|
|
42
|
+
private readonly getRootDir;
|
|
43
|
+
private readonly getBuildExecutor;
|
|
44
|
+
private readonly getInvalidationVersion;
|
|
45
|
+
private readonly invalidateModules;
|
|
46
|
+
private readonly getDefaultPlugins;
|
|
47
|
+
/**
|
|
48
|
+
* Creates one explicit server-transpiler boundary for a given execution
|
|
49
|
+
* context.
|
|
50
|
+
*/
|
|
51
|
+
constructor(args: ServerModuleTranspilerBootstrapArgs);
|
|
52
|
+
/**
|
|
53
|
+
* Loads a server-side source module through the caller-owned transpile
|
|
54
|
+
* context.
|
|
55
|
+
*/
|
|
56
|
+
importModule<T = unknown>(options: ServerModuleTranspilerOptions): Promise<T>;
|
|
57
|
+
/**
|
|
58
|
+
* Invalidates cached module state for development reloads.
|
|
59
|
+
*/
|
|
60
|
+
invalidate(changedFiles?: string[]): void;
|
|
61
|
+
/**
|
|
62
|
+
* Releases transpiler-owned resources.
|
|
63
|
+
*
|
|
64
|
+
* @remarks
|
|
65
|
+
* The current implementation delegates cache ownership to lower-level module
|
|
66
|
+
* loading services, so disposal is intentionally a no-op for now.
|
|
67
|
+
*/
|
|
68
|
+
dispose(): Promise<void>;
|
|
69
|
+
}
|
|
@@ -0,0 +1,61 @@
|
|
|
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
|
+
this.getRootDir = () => args.rootDir;
|
|
16
|
+
this.getBuildExecutor = args.getBuildExecutor;
|
|
17
|
+
this.getInvalidationVersion = () => args.getInvalidationVersion?.();
|
|
18
|
+
this.getDefaultPlugins = args.getDefaultPlugins ?? (() => []);
|
|
19
|
+
this.invalidateModules = (changedFiles) => {
|
|
20
|
+
if (args.invalidateModules) {
|
|
21
|
+
args.invalidateModules(changedFiles);
|
|
22
|
+
return;
|
|
23
|
+
}
|
|
24
|
+
this.pageModuleImportService.invalidateDevelopmentGraph();
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
/**
|
|
28
|
+
* Loads a server-side source module through the caller-owned transpile
|
|
29
|
+
* context.
|
|
30
|
+
*/
|
|
31
|
+
async importModule(options) {
|
|
32
|
+
const mergedPlugins = [...this.getDefaultPlugins(), ...options.plugins ?? []];
|
|
33
|
+
const { plugins: _plugins, ...baseOptions } = options;
|
|
34
|
+
return await this.pageModuleImportService.importModule({
|
|
35
|
+
...baseOptions,
|
|
36
|
+
...mergedPlugins.length > 0 ? { plugins: mergedPlugins } : {},
|
|
37
|
+
rootDir: this.getRootDir(),
|
|
38
|
+
buildExecutor: this.getBuildExecutor(),
|
|
39
|
+
invalidationVersion: this.getInvalidationVersion()
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
/**
|
|
43
|
+
* Invalidates cached module state for development reloads.
|
|
44
|
+
*/
|
|
45
|
+
invalidate(changedFiles) {
|
|
46
|
+
this.invalidateModules(changedFiles);
|
|
47
|
+
}
|
|
48
|
+
/**
|
|
49
|
+
* Releases transpiler-owned resources.
|
|
50
|
+
*
|
|
51
|
+
* @remarks
|
|
52
|
+
* The current implementation delegates cache ownership to lower-level module
|
|
53
|
+
* loading services, so disposal is intentionally a no-op for now.
|
|
54
|
+
*/
|
|
55
|
+
async dispose() {
|
|
56
|
+
return;
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
export {
|
|
60
|
+
ServerModuleTranspiler
|
|
61
|
+
};
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import type { EcoPagesAppConfig } from '../../internal-types.js';
|
|
2
|
+
export interface NodeRuntimeManifest {
|
|
3
|
+
runtime: 'node';
|
|
4
|
+
appRootDir: string;
|
|
5
|
+
sourceRootDir: string;
|
|
6
|
+
distDir: string;
|
|
7
|
+
workDir?: string;
|
|
8
|
+
modulePaths: {
|
|
9
|
+
config: string;
|
|
10
|
+
entry?: string;
|
|
11
|
+
};
|
|
12
|
+
}
|
|
13
|
+
/**
|
|
14
|
+
* Returns the default file handoff location for the Node runtime manifest.
|
|
15
|
+
*/
|
|
16
|
+
export declare function getNodeRuntimeManifestPath(appConfig: EcoPagesAppConfig): string;
|
|
17
|
+
export declare function createNodeRuntimeManifest(appConfig: EcoPagesAppConfig, options?: {
|
|
18
|
+
entryModulePath?: string;
|
|
19
|
+
}): NodeRuntimeManifest;
|
|
20
|
+
/**
|
|
21
|
+
* Serializes a Node runtime manifest to the file boundary used by the thin host.
|
|
22
|
+
*/
|
|
23
|
+
export declare function writeNodeRuntimeManifestFile(manifest: NodeRuntimeManifest, manifestFilePath: string): string;
|
|
24
|
+
/**
|
|
25
|
+
* Derives the app-owned Node manifest and writes it to the runtime handoff path.
|
|
26
|
+
*/
|
|
27
|
+
export declare function writeAppNodeRuntimeManifest(appConfig: EcoPagesAppConfig, options?: {
|
|
28
|
+
entryModulePath?: string;
|
|
29
|
+
manifestFilePath?: string;
|
|
30
|
+
}): {
|
|
31
|
+
manifest: NodeRuntimeManifest;
|
|
32
|
+
manifestFilePath: string;
|
|
33
|
+
};
|
|
34
|
+
export declare function getAppNodeRuntimeManifest(appConfig: EcoPagesAppConfig): NodeRuntimeManifest;
|
|
35
|
+
export declare function setAppNodeRuntimeManifest(appConfig: EcoPagesAppConfig, nodeRuntimeManifest: NodeRuntimeManifest): void;
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
import { mkdirSync, writeFileSync } from "node:fs";
|
|
2
|
+
import path from "node:path";
|
|
3
|
+
import { DEFAULT_ECOPAGES_WORK_DIR } from "../../constants.js";
|
|
4
|
+
const NODE_RUNTIME_MANIFEST_DIRNAME = "runtime";
|
|
5
|
+
const NODE_RUNTIME_MANIFEST_FILENAME = "node-runtime-manifest.json";
|
|
6
|
+
function getNodeRuntimeManifestPath(appConfig) {
|
|
7
|
+
return path.join(resolveWorkDir(appConfig), NODE_RUNTIME_MANIFEST_DIRNAME, NODE_RUNTIME_MANIFEST_FILENAME);
|
|
8
|
+
}
|
|
9
|
+
function resolveWorkDir(appConfig) {
|
|
10
|
+
return appConfig.absolutePaths?.workDir ?? path.join(appConfig.rootDir, appConfig.workDir ?? DEFAULT_ECOPAGES_WORK_DIR);
|
|
11
|
+
}
|
|
12
|
+
function createNodeRuntimeManifest(appConfig, options) {
|
|
13
|
+
return {
|
|
14
|
+
runtime: "node",
|
|
15
|
+
appRootDir: appConfig.rootDir,
|
|
16
|
+
sourceRootDir: appConfig.absolutePaths.srcDir,
|
|
17
|
+
distDir: appConfig.absolutePaths.distDir,
|
|
18
|
+
workDir: resolveWorkDir(appConfig),
|
|
19
|
+
modulePaths: {
|
|
20
|
+
config: appConfig.absolutePaths.config,
|
|
21
|
+
...options?.entryModulePath ? { entry: options.entryModulePath } : {}
|
|
22
|
+
}
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
function writeNodeRuntimeManifestFile(manifest, manifestFilePath) {
|
|
26
|
+
mkdirSync(path.dirname(manifestFilePath), { recursive: true });
|
|
27
|
+
writeFileSync(manifestFilePath, `${JSON.stringify(manifest, null, 2)}
|
|
28
|
+
`, "utf8");
|
|
29
|
+
return manifestFilePath;
|
|
30
|
+
}
|
|
31
|
+
function writeAppNodeRuntimeManifest(appConfig, options) {
|
|
32
|
+
const manifest = createNodeRuntimeManifest(appConfig, {
|
|
33
|
+
entryModulePath: options?.entryModulePath
|
|
34
|
+
});
|
|
35
|
+
const manifestFilePath = writeNodeRuntimeManifestFile(
|
|
36
|
+
manifest,
|
|
37
|
+
options?.manifestFilePath ?? getNodeRuntimeManifestPath(appConfig)
|
|
38
|
+
);
|
|
39
|
+
return {
|
|
40
|
+
manifest,
|
|
41
|
+
manifestFilePath
|
|
42
|
+
};
|
|
43
|
+
}
|
|
44
|
+
function getAppNodeRuntimeManifest(appConfig) {
|
|
45
|
+
return appConfig.runtime?.nodeRuntimeManifest ?? createNodeRuntimeManifest(appConfig);
|
|
46
|
+
}
|
|
47
|
+
function setAppNodeRuntimeManifest(appConfig, nodeRuntimeManifest) {
|
|
48
|
+
appConfig.runtime = {
|
|
49
|
+
...appConfig.runtime ?? {},
|
|
50
|
+
nodeRuntimeManifest
|
|
51
|
+
};
|
|
52
|
+
}
|
|
53
|
+
export {
|
|
54
|
+
createNodeRuntimeManifest,
|
|
55
|
+
getAppNodeRuntimeManifest,
|
|
56
|
+
getNodeRuntimeManifestPath,
|
|
57
|
+
setAppNodeRuntimeManifest,
|
|
58
|
+
writeAppNodeRuntimeManifest,
|
|
59
|
+
writeNodeRuntimeManifestFile
|
|
60
|
+
};
|
|
@@ -0,0 +1,118 @@
|
|
|
1
|
+
import type { EcoPagesAppConfig } from '../../internal-types.js';
|
|
2
|
+
import { type ServerInvalidationState } from './server-invalidation-state.service.js';
|
|
3
|
+
import { type EntrypointDependencyGraph } from './entrypoint-dependency-graph.service.js';
|
|
4
|
+
/**
|
|
5
|
+
* Tracks development-time dependency relationships and invalidation state for
|
|
6
|
+
* one Ecopages app instance.
|
|
7
|
+
*
|
|
8
|
+
* @remarks
|
|
9
|
+
* The current contract stays intentionally small. It supports today's needs for
|
|
10
|
+
* server-module cache invalidation and entrypoint-to-dependency lookups without
|
|
11
|
+
* forcing the rest of the runtime to know about one specific graph
|
|
12
|
+
* implementation.
|
|
13
|
+
*/
|
|
14
|
+
export interface DevGraphService extends ServerInvalidationState, EntrypointDependencyGraph {
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* Minimal dev-graph implementation used when an app has no selective graph
|
|
18
|
+
* metadata available.
|
|
19
|
+
*
|
|
20
|
+
* @remarks
|
|
21
|
+
* This preserves correct behavior by using coarse invalidation version bumps.
|
|
22
|
+
* Callers still pass changed-file information through the interface now so a
|
|
23
|
+
* richer graph can become more selective later without changing call sites.
|
|
24
|
+
*/
|
|
25
|
+
export declare class NoopDevGraphService implements DevGraphService {
|
|
26
|
+
private readonly invalidationState;
|
|
27
|
+
private readonly dependencyGraph;
|
|
28
|
+
/**
|
|
29
|
+
* Returns the current coarse invalidation version.
|
|
30
|
+
*/
|
|
31
|
+
getServerInvalidationVersion(): number;
|
|
32
|
+
/**
|
|
33
|
+
* Invalidates all server-side module state by incrementing the shared version.
|
|
34
|
+
*/
|
|
35
|
+
invalidateServerModules(_changedFiles?: string[]): void;
|
|
36
|
+
/**
|
|
37
|
+
* Indicates that this graph cannot target invalidation to one entrypoint set.
|
|
38
|
+
*/
|
|
39
|
+
supportsSelectiveInvalidation(): boolean;
|
|
40
|
+
/**
|
|
41
|
+
* Returns an empty entrypoint set because this implementation stores no
|
|
42
|
+
* dependency graph metadata.
|
|
43
|
+
*/
|
|
44
|
+
getDependencyEntrypoints(_filePath: string): Set<string>;
|
|
45
|
+
/**
|
|
46
|
+
* Accepts dependency updates to preserve interface compatibility, but stores no
|
|
47
|
+
* graph state in the noop implementation.
|
|
48
|
+
*/
|
|
49
|
+
setEntrypointDependencies(_entrypointPath: string, _dependencies: string[]): void;
|
|
50
|
+
/**
|
|
51
|
+
* Clears one entrypoint from the graph.
|
|
52
|
+
*
|
|
53
|
+
* @remarks
|
|
54
|
+
* There is no stored graph state in this implementation, so this is a no-op.
|
|
55
|
+
*/
|
|
56
|
+
clearEntrypointDependencies(_entrypointPath: string): void;
|
|
57
|
+
/**
|
|
58
|
+
* Resets graph-owned state for a fresh runtime cycle.
|
|
59
|
+
*/
|
|
60
|
+
reset(): void;
|
|
61
|
+
}
|
|
62
|
+
/**
|
|
63
|
+
* In-memory development graph with entrypoint-to-dependency reverse lookups.
|
|
64
|
+
*
|
|
65
|
+
* @remarks
|
|
66
|
+
* This is the current selective graph implementation used by development flows
|
|
67
|
+
* that need to answer which entrypoints depend on a changed file while still
|
|
68
|
+
* keeping invalidation state app-local.
|
|
69
|
+
*/
|
|
70
|
+
export declare class InMemoryDevGraphService implements DevGraphService {
|
|
71
|
+
private readonly invalidationState;
|
|
72
|
+
private readonly dependencyGraph;
|
|
73
|
+
/**
|
|
74
|
+
* Returns the current app-local server invalidation version.
|
|
75
|
+
*/
|
|
76
|
+
getServerInvalidationVersion(): number;
|
|
77
|
+
/**
|
|
78
|
+
* Invalidates the current server-module cache generation.
|
|
79
|
+
*
|
|
80
|
+
* @remarks
|
|
81
|
+
* The current implementation still uses a coarse generation bump for server
|
|
82
|
+
* modules. Selective dependency lookups are used by callers that need to limit
|
|
83
|
+
* browser rebuild work.
|
|
84
|
+
*/
|
|
85
|
+
invalidateServerModules(_changedFiles?: string[]): void;
|
|
86
|
+
/**
|
|
87
|
+
* Indicates that this graph can answer dependency-to-entrypoint lookups.
|
|
88
|
+
*/
|
|
89
|
+
supportsSelectiveInvalidation(): boolean;
|
|
90
|
+
/**
|
|
91
|
+
* Returns all known entrypoints that currently depend on the given file.
|
|
92
|
+
*/
|
|
93
|
+
getDependencyEntrypoints(filePath: string): Set<string>;
|
|
94
|
+
/**
|
|
95
|
+
* Replaces the stored dependency set for one entrypoint.
|
|
96
|
+
*
|
|
97
|
+
* @remarks
|
|
98
|
+
* The entrypoint itself is always included in its own dependency set so reverse
|
|
99
|
+
* lookups can map a changed entry file back to that same entrypoint.
|
|
100
|
+
*/
|
|
101
|
+
setEntrypointDependencies(entrypointPath: string, dependencies: string[]): void;
|
|
102
|
+
/**
|
|
103
|
+
* Removes one entrypoint and all of its reverse dependency edges.
|
|
104
|
+
*/
|
|
105
|
+
clearEntrypointDependencies(entrypointPath: string): void;
|
|
106
|
+
/**
|
|
107
|
+
* Clears all graph state and starts a fresh invalidation generation.
|
|
108
|
+
*/
|
|
109
|
+
reset(): void;
|
|
110
|
+
}
|
|
111
|
+
/**
|
|
112
|
+
* Returns the dev-graph service owned by one app instance.
|
|
113
|
+
*/
|
|
114
|
+
export declare function getAppDevGraphService(appConfig: EcoPagesAppConfig): DevGraphService;
|
|
115
|
+
/**
|
|
116
|
+
* Installs the dev-graph service that should back one app/runtime instance.
|
|
117
|
+
*/
|
|
118
|
+
export declare function setAppDevGraphService(appConfig: EcoPagesAppConfig, devGraphService: DevGraphService): void;
|