@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
|
@@ -1,179 +0,0 @@
|
|
|
1
|
-
import { createServer, type IncomingMessage, type Server as NodeServerInstance, type ServerResponse } from 'node:http';
|
|
2
|
-
import { Readable } from 'node:stream';
|
|
3
|
-
import { DEFAULT_ECOPAGES_HOSTNAME, DEFAULT_ECOPAGES_PORT } from '../../constants.ts';
|
|
4
|
-
import { appLogger } from '../../global/app-logger.ts';
|
|
5
|
-
import type { EcoPagesAppConfig } from '../../internal-types.ts';
|
|
6
|
-
import type { StaticRoute } from '../../public-types.ts';
|
|
7
|
-
import { type ApplicationAdapterOptions } from '../abstract/application-adapter.ts';
|
|
8
|
-
import { SharedApplicationAdapter } from '../shared/application-adapter.ts';
|
|
9
|
-
import { type NodeServerAdapterResult, createNodeServerAdapter } from './server-adapter.ts';
|
|
10
|
-
|
|
11
|
-
export interface EcopagesAppOptions extends ApplicationAdapterOptions {
|
|
12
|
-
appConfig: EcoPagesAppConfig;
|
|
13
|
-
serverOptions?: Record<string, any>;
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
export class EcopagesApp extends SharedApplicationAdapter<EcopagesAppOptions, NodeServerInstance, Request> {
|
|
17
|
-
serverAdapter: NodeServerAdapterResult | undefined;
|
|
18
|
-
private server: NodeServerInstance | null = null;
|
|
19
|
-
private runtimeOrigin = '';
|
|
20
|
-
|
|
21
|
-
public async stop(force = true): Promise<void> {
|
|
22
|
-
if (!this.server) {
|
|
23
|
-
return;
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
const activeServer = this.server;
|
|
27
|
-
this.server = null;
|
|
28
|
-
|
|
29
|
-
await new Promise<void>((resolve, reject) => {
|
|
30
|
-
activeServer.close((error) => {
|
|
31
|
-
if (error) {
|
|
32
|
-
reject(error);
|
|
33
|
-
return;
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
resolve();
|
|
37
|
-
});
|
|
38
|
-
|
|
39
|
-
if (force) {
|
|
40
|
-
activeServer.closeAllConnections();
|
|
41
|
-
}
|
|
42
|
-
});
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
protected async initializeServerAdapter(): Promise<NodeServerAdapterResult> {
|
|
46
|
-
const { dev } = this.cliArgs;
|
|
47
|
-
const { port: cliPort, hostname: cliHostname } = this.cliArgs;
|
|
48
|
-
|
|
49
|
-
const envPort = process.env.ECOPAGES_PORT;
|
|
50
|
-
const envHostname = process.env.ECOPAGES_HOSTNAME;
|
|
51
|
-
|
|
52
|
-
const preferredPort = cliPort ?? (envPort ? Number(envPort) : undefined) ?? DEFAULT_ECOPAGES_PORT;
|
|
53
|
-
const preferredHostname = cliHostname ?? envHostname ?? DEFAULT_ECOPAGES_HOSTNAME;
|
|
54
|
-
this.runtimeOrigin = `http://${preferredHostname}:${preferredPort}`;
|
|
55
|
-
|
|
56
|
-
return createNodeServerAdapter({
|
|
57
|
-
runtimeOrigin: this.runtimeOrigin,
|
|
58
|
-
appConfig: this.appConfig,
|
|
59
|
-
apiHandlers: this.apiHandlers,
|
|
60
|
-
staticRoutes: this.staticRoutes as StaticRoute[],
|
|
61
|
-
errorHandler: this.errorHandler,
|
|
62
|
-
options: { watch: dev },
|
|
63
|
-
serveOptions: {
|
|
64
|
-
port: preferredPort,
|
|
65
|
-
hostname: preferredHostname,
|
|
66
|
-
...this.serverOptions,
|
|
67
|
-
},
|
|
68
|
-
});
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
public async start(): Promise<NodeServerInstance | void> {
|
|
72
|
-
if (!this.serverAdapter) {
|
|
73
|
-
this.serverAdapter = await this.initializeServerAdapter();
|
|
74
|
-
}
|
|
75
|
-
|
|
76
|
-
if (this.server) {
|
|
77
|
-
return this.server;
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
const { build, preview } = this.cliArgs;
|
|
81
|
-
|
|
82
|
-
if (build || preview) {
|
|
83
|
-
appLogger.debugTime('Building static pages');
|
|
84
|
-
await this.serverAdapter.buildStatic({ preview });
|
|
85
|
-
await this.stop(true);
|
|
86
|
-
appLogger.debugTimeEnd('Building static pages');
|
|
87
|
-
|
|
88
|
-
if (build) {
|
|
89
|
-
process.exit(0);
|
|
90
|
-
}
|
|
91
|
-
return;
|
|
92
|
-
}
|
|
93
|
-
|
|
94
|
-
const serveOptions = this.serverAdapter.getServerOptions();
|
|
95
|
-
const hostname = String(serveOptions.hostname ?? DEFAULT_ECOPAGES_HOSTNAME);
|
|
96
|
-
const port = Number(serveOptions.port ?? DEFAULT_ECOPAGES_PORT);
|
|
97
|
-
this.runtimeOrigin = `http://${hostname}:${port}`;
|
|
98
|
-
|
|
99
|
-
this.server = createServer(async (req, res) => {
|
|
100
|
-
try {
|
|
101
|
-
const webRequest = this.createWebRequest(req);
|
|
102
|
-
const response = await this.serverAdapter!.handleRequest(webRequest);
|
|
103
|
-
await this.sendNodeResponse(res, response);
|
|
104
|
-
} catch (error) {
|
|
105
|
-
appLogger.error('Node server adapter request failed', error as Error);
|
|
106
|
-
res.statusCode = 500;
|
|
107
|
-
res.end('Internal Server Error');
|
|
108
|
-
}
|
|
109
|
-
});
|
|
110
|
-
|
|
111
|
-
await new Promise<void>((resolve) => {
|
|
112
|
-
this.server!.listen(port, hostname, () => resolve());
|
|
113
|
-
});
|
|
114
|
-
|
|
115
|
-
await this.serverAdapter.completeInitialization(this.server);
|
|
116
|
-
appLogger.info(`Node server running at ${this.runtimeOrigin}`);
|
|
117
|
-
|
|
118
|
-
return this.server;
|
|
119
|
-
}
|
|
120
|
-
|
|
121
|
-
private createWebRequest(req: IncomingMessage): Request {
|
|
122
|
-
const url = new URL(req.url ?? '/', this.runtimeOrigin);
|
|
123
|
-
const headers = new Headers();
|
|
124
|
-
|
|
125
|
-
for (const [key, value] of Object.entries(req.headers)) {
|
|
126
|
-
if (Array.isArray(value)) {
|
|
127
|
-
for (const item of value) {
|
|
128
|
-
headers.append(key, item);
|
|
129
|
-
}
|
|
130
|
-
continue;
|
|
131
|
-
}
|
|
132
|
-
|
|
133
|
-
if (value !== undefined) {
|
|
134
|
-
headers.set(key, value);
|
|
135
|
-
}
|
|
136
|
-
}
|
|
137
|
-
|
|
138
|
-
const method = (req.method ?? 'GET').toUpperCase();
|
|
139
|
-
const requestInit: RequestInit & { duplex?: 'half' } = {
|
|
140
|
-
method,
|
|
141
|
-
headers,
|
|
142
|
-
};
|
|
143
|
-
|
|
144
|
-
if (method !== 'GET' && method !== 'HEAD') {
|
|
145
|
-
requestInit.body = Readable.toWeb(req) as unknown as BodyInit;
|
|
146
|
-
requestInit.duplex = 'half';
|
|
147
|
-
}
|
|
148
|
-
|
|
149
|
-
return new Request(url, requestInit);
|
|
150
|
-
}
|
|
151
|
-
|
|
152
|
-
private async sendNodeResponse(res: ServerResponse, response: Response): Promise<void> {
|
|
153
|
-
res.statusCode = response.status;
|
|
154
|
-
|
|
155
|
-
response.headers.forEach((value, key) => {
|
|
156
|
-
res.setHeader(key, value);
|
|
157
|
-
});
|
|
158
|
-
|
|
159
|
-
if (!response.body) {
|
|
160
|
-
res.end();
|
|
161
|
-
return;
|
|
162
|
-
}
|
|
163
|
-
|
|
164
|
-
const body = Buffer.from(await response.arrayBuffer());
|
|
165
|
-
res.end(body);
|
|
166
|
-
}
|
|
167
|
-
|
|
168
|
-
public async fetch(request: Request): Promise<Response> {
|
|
169
|
-
if (!this.serverAdapter) {
|
|
170
|
-
this.serverAdapter = await this.initializeServerAdapter();
|
|
171
|
-
}
|
|
172
|
-
|
|
173
|
-
return this.serverAdapter.handleRequest(request);
|
|
174
|
-
}
|
|
175
|
-
}
|
|
176
|
-
|
|
177
|
-
export async function createNodeApp(options: EcopagesAppOptions): Promise<EcopagesApp> {
|
|
178
|
-
return new EcopagesApp(options);
|
|
179
|
-
}
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
export { NodeServerAdapter, createNodeServerAdapter } from './server-adapter.ts';
|
|
2
|
-
export { EcopagesApp, createNodeApp } from './create-app.ts';
|
|
3
|
-
export type { EcopagesAppOptions } from './create-app.ts';
|
|
4
|
-
export type {
|
|
5
|
-
NodeServerAdapterParams,
|
|
6
|
-
NodeServerAdapterResult,
|
|
7
|
-
NodeServerInstance,
|
|
8
|
-
NodeServeAdapterServerOptions,
|
|
9
|
-
} from './server-adapter.ts';
|
|
@@ -1,79 +0,0 @@
|
|
|
1
|
-
import type { WebSocket } from 'ws';
|
|
2
|
-
import type { ClientBridgeEvent, IClientBridge } from '../../public-types.ts';
|
|
3
|
-
|
|
4
|
-
const HEARTBEAT_INTERVAL_MS = 30_000;
|
|
5
|
-
|
|
6
|
-
export class NodeClientBridge implements IClientBridge {
|
|
7
|
-
private subscribers = new Set<WebSocket>();
|
|
8
|
-
private heartbeatTimer: ReturnType<typeof setInterval> | null = null;
|
|
9
|
-
|
|
10
|
-
constructor() {
|
|
11
|
-
this.heartbeatTimer = setInterval(() => this.sweep(), HEARTBEAT_INTERVAL_MS);
|
|
12
|
-
/* Allow the process to exit even if the timer is still active */
|
|
13
|
-
this.heartbeatTimer.unref?.();
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
/**
|
|
17
|
-
* Pings all open subscribers and removes any that are no longer in OPEN state.
|
|
18
|
-
* This prevents a slow memory leak caused by zombie connections that never
|
|
19
|
-
* send a close event (e.g. abruptly killed browsers, orphaned tabs, network drops).
|
|
20
|
-
*/
|
|
21
|
-
private sweep(): void {
|
|
22
|
-
for (const ws of this.subscribers) {
|
|
23
|
-
if (ws.readyState !== 1 /* OPEN */) {
|
|
24
|
-
this.subscribers.delete(ws);
|
|
25
|
-
continue;
|
|
26
|
-
}
|
|
27
|
-
ws.ping();
|
|
28
|
-
}
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
subscribe(ws: WebSocket): void {
|
|
32
|
-
this.subscribers.add(ws);
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
unsubscribe(ws: WebSocket): void {
|
|
36
|
-
this.subscribers.delete(ws);
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
broadcast(event: ClientBridgeEvent): void {
|
|
40
|
-
const payload = JSON.stringify(event);
|
|
41
|
-
for (const ws of this.subscribers) {
|
|
42
|
-
if (ws.readyState === 1) {
|
|
43
|
-
ws.send(payload);
|
|
44
|
-
}
|
|
45
|
-
}
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
reload(): void {
|
|
49
|
-
this.broadcast({ type: 'reload' });
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
cssUpdate(path: string): void {
|
|
53
|
-
this.broadcast({ type: 'css-update', path, timestamp: Date.now() });
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
update(path: string): void {
|
|
57
|
-
this.broadcast({ type: 'update', path, timestamp: Date.now() });
|
|
58
|
-
}
|
|
59
|
-
|
|
60
|
-
error(message: string): void {
|
|
61
|
-
this.broadcast({ type: 'error', message });
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
get subscriberCount(): number {
|
|
65
|
-
return this.subscribers.size;
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
/**
|
|
69
|
-
* Stops the heartbeat timer and clears all subscribers.
|
|
70
|
-
* Call this when the dev server is shutting down.
|
|
71
|
-
*/
|
|
72
|
-
destroy(): void {
|
|
73
|
-
if (this.heartbeatTimer !== null) {
|
|
74
|
-
clearInterval(this.heartbeatTimer);
|
|
75
|
-
this.heartbeatTimer = null;
|
|
76
|
-
}
|
|
77
|
-
this.subscribers.clear();
|
|
78
|
-
}
|
|
79
|
-
}
|
|
@@ -1,271 +0,0 @@
|
|
|
1
|
-
import fs from 'node:fs';
|
|
2
|
-
import path from 'node:path';
|
|
3
|
-
import { fileURLToPath } from 'node:url';
|
|
4
|
-
import { RESOLVED_ASSETS_DIR } from '../../constants.ts';
|
|
5
|
-
import { defaultBuildAdapter } from '../../build/build-adapter.ts';
|
|
6
|
-
import type { DefaultHmrContext, EcoPagesAppConfig, IHmrManager, IClientBridge } from '../../internal-types.ts';
|
|
7
|
-
import type { EcoBuildPlugin } from '../../build/build-types.ts';
|
|
8
|
-
import { fileSystem } from '@ecopages/file-system';
|
|
9
|
-
import type { HmrStrategy } from '../../hmr/hmr-strategy.ts';
|
|
10
|
-
import { DefaultHmrStrategy } from '../../hmr/strategies/default-hmr-strategy.ts';
|
|
11
|
-
import { JsHmrStrategy } from '../../hmr/strategies/js-hmr-strategy.ts';
|
|
12
|
-
import { appLogger } from '../../global/app-logger.ts';
|
|
13
|
-
import type { ClientBridgeEvent } from '../../public-types.ts';
|
|
14
|
-
|
|
15
|
-
export interface NodeHmrManagerParams {
|
|
16
|
-
appConfig: EcoPagesAppConfig;
|
|
17
|
-
bridge: IClientBridge;
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
export class NodeHmrManager implements IHmrManager {
|
|
21
|
-
public readonly appConfig: EcoPagesAppConfig;
|
|
22
|
-
private readonly bridge: IClientBridge;
|
|
23
|
-
private watchers = new Map<string, fs.FSWatcher>();
|
|
24
|
-
private watchedFiles = new Map<string, string>();
|
|
25
|
-
private specifierMap = new Map<string, string>();
|
|
26
|
-
/**
|
|
27
|
-
* Node-only reverse invalidation index: dependency file -> affected entrypoints.
|
|
28
|
-
*/
|
|
29
|
-
private dependencyEntrypoints = new Map<string, Set<string>>();
|
|
30
|
-
/**
|
|
31
|
-
* Node-only forward index: entrypoint -> latest dependency set.
|
|
32
|
-
*/
|
|
33
|
-
private entrypointDependencies = new Map<string, Set<string>>();
|
|
34
|
-
private distDir: string;
|
|
35
|
-
private plugins: EcoBuildPlugin[] = [];
|
|
36
|
-
private enabled = true;
|
|
37
|
-
private strategies: HmrStrategy[] = [];
|
|
38
|
-
|
|
39
|
-
constructor({ appConfig, bridge }: NodeHmrManagerParams) {
|
|
40
|
-
this.appConfig = appConfig;
|
|
41
|
-
this.bridge = bridge;
|
|
42
|
-
this.distDir = path.join(this.appConfig.absolutePaths.distDir, RESOLVED_ASSETS_DIR, '_hmr');
|
|
43
|
-
this.cleanDistDir();
|
|
44
|
-
this.initializeStrategies();
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
/**
|
|
48
|
-
* Ensures the HMR output directory exists.
|
|
49
|
-
*
|
|
50
|
-
* This must not remove the directory because multiple app processes
|
|
51
|
-
* can share the same dist path during e2e runs.
|
|
52
|
-
*/
|
|
53
|
-
private cleanDistDir(): void {
|
|
54
|
-
fileSystem.ensureDir(this.distDir);
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
private initializeStrategies(): void {
|
|
58
|
-
const jsContext = {
|
|
59
|
-
getWatchedFiles: () => this.watchedFiles,
|
|
60
|
-
getSpecifierMap: () => this.specifierMap,
|
|
61
|
-
getDependencyEntrypoints: (filePath: string) =>
|
|
62
|
-
new Set(this.dependencyEntrypoints.get(path.resolve(filePath)) ?? []),
|
|
63
|
-
setEntrypointDependencies: (entrypointPath: string, dependencies: string[]) =>
|
|
64
|
-
this.setEntrypointDependencies(entrypointPath, dependencies),
|
|
65
|
-
getDistDir: () => this.distDir,
|
|
66
|
-
getPlugins: () => this.plugins,
|
|
67
|
-
getSrcDir: () => this.appConfig.absolutePaths.srcDir,
|
|
68
|
-
};
|
|
69
|
-
|
|
70
|
-
this.strategies = [new JsHmrStrategy(jsContext), new DefaultHmrStrategy()];
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
public registerStrategy(strategy: HmrStrategy): void {
|
|
74
|
-
this.strategies.push(strategy);
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
public setPlugins(plugins: EcoBuildPlugin[]): void {
|
|
78
|
-
this.plugins = [...plugins];
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
public setEnabled(enabled: boolean): void {
|
|
82
|
-
this.enabled = enabled;
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
public isEnabled(): boolean {
|
|
86
|
-
return this.enabled;
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
public registerSpecifierMap(map: Record<string, string>): void {
|
|
90
|
-
for (const [specifier, url] of Object.entries(map)) {
|
|
91
|
-
this.specifierMap.set(specifier, url);
|
|
92
|
-
}
|
|
93
|
-
}
|
|
94
|
-
|
|
95
|
-
public async buildRuntime(): Promise<void> {
|
|
96
|
-
const currentDir = path.dirname(fileURLToPath(import.meta.url));
|
|
97
|
-
const runtimeSource = path.resolve(currentDir, '../../hmr/client/hmr-runtime.ts');
|
|
98
|
-
|
|
99
|
-
const result = await defaultBuildAdapter.build({
|
|
100
|
-
entrypoints: [runtimeSource],
|
|
101
|
-
outdir: this.distDir,
|
|
102
|
-
naming: '_hmr_runtime.js',
|
|
103
|
-
minify: false,
|
|
104
|
-
...defaultBuildAdapter.getTranspileOptions('hmr-runtime'),
|
|
105
|
-
plugins: this.plugins,
|
|
106
|
-
});
|
|
107
|
-
|
|
108
|
-
if (!result.success) {
|
|
109
|
-
appLogger.error('[HMR] Failed to build runtime script:', result.logs);
|
|
110
|
-
}
|
|
111
|
-
}
|
|
112
|
-
|
|
113
|
-
public getRuntimePath(): string {
|
|
114
|
-
return path.join(this.distDir, '_hmr_runtime.js');
|
|
115
|
-
}
|
|
116
|
-
|
|
117
|
-
public broadcast(event: ClientBridgeEvent) {
|
|
118
|
-
appLogger.debug(
|
|
119
|
-
`[HMR] Broadcasting ${event.type} event, path=${event.path || 'all'}, subscribers=${this.bridge.subscriberCount}`,
|
|
120
|
-
);
|
|
121
|
-
this.bridge.broadcast(event);
|
|
122
|
-
}
|
|
123
|
-
|
|
124
|
-
public async handleFileChange(filePath: string): Promise<void> {
|
|
125
|
-
const sorted = [...this.strategies].sort((a, b) => b.priority - a.priority);
|
|
126
|
-
const strategy = sorted.find((s) => {
|
|
127
|
-
try {
|
|
128
|
-
return s.matches(filePath);
|
|
129
|
-
} catch (err) {
|
|
130
|
-
appLogger.error(`[NodeHmrManager] Error checking match for ${s.constructor.name}:`, err as Error);
|
|
131
|
-
return false;
|
|
132
|
-
}
|
|
133
|
-
});
|
|
134
|
-
|
|
135
|
-
if (!strategy) {
|
|
136
|
-
appLogger.warn(`[HMR] No strategy found for ${filePath}`);
|
|
137
|
-
return;
|
|
138
|
-
}
|
|
139
|
-
|
|
140
|
-
appLogger.debug(`[NodeHmrManager] Selected strategy: ${strategy.constructor.name}`);
|
|
141
|
-
|
|
142
|
-
const action = await strategy.process(filePath);
|
|
143
|
-
|
|
144
|
-
if (action.type === 'broadcast') {
|
|
145
|
-
if (action.events) {
|
|
146
|
-
for (const event of action.events) {
|
|
147
|
-
this.broadcast(event);
|
|
148
|
-
}
|
|
149
|
-
}
|
|
150
|
-
}
|
|
151
|
-
}
|
|
152
|
-
|
|
153
|
-
public getOutputUrl(entrypointPath: string): string | undefined {
|
|
154
|
-
return this.watchedFiles.get(entrypointPath);
|
|
155
|
-
}
|
|
156
|
-
|
|
157
|
-
public getWatchedFiles(): Map<string, string> {
|
|
158
|
-
return this.watchedFiles;
|
|
159
|
-
}
|
|
160
|
-
|
|
161
|
-
public getSpecifierMap(): Map<string, string> {
|
|
162
|
-
return this.specifierMap;
|
|
163
|
-
}
|
|
164
|
-
|
|
165
|
-
public getDistDir(): string {
|
|
166
|
-
return this.distDir;
|
|
167
|
-
}
|
|
168
|
-
|
|
169
|
-
public getPlugins(): EcoBuildPlugin[] {
|
|
170
|
-
return this.plugins;
|
|
171
|
-
}
|
|
172
|
-
|
|
173
|
-
public getDefaultContext(): DefaultHmrContext {
|
|
174
|
-
return {
|
|
175
|
-
getWatchedFiles: () => this.watchedFiles,
|
|
176
|
-
getSpecifierMap: () => this.specifierMap,
|
|
177
|
-
getDistDir: () => this.distDir,
|
|
178
|
-
getPlugins: () => this.plugins,
|
|
179
|
-
getSrcDir: () => this.appConfig.absolutePaths.srcDir,
|
|
180
|
-
getLayoutsDir: () => this.appConfig.absolutePaths.layoutsDir,
|
|
181
|
-
getPagesDir: () => this.appConfig.absolutePaths.pagesDir,
|
|
182
|
-
};
|
|
183
|
-
}
|
|
184
|
-
|
|
185
|
-
/**
|
|
186
|
-
* Updates Node HMR dependency indexes for selective invalidation.
|
|
187
|
-
*
|
|
188
|
-
* @remarks
|
|
189
|
-
* Graph data comes from Node/esbuild build metadata and does not affect Bun
|
|
190
|
-
* HMR behavior.
|
|
191
|
-
*/
|
|
192
|
-
private setEntrypointDependencies(entrypointPath: string, dependencies: string[]): void {
|
|
193
|
-
const normalizedEntrypoint = path.resolve(entrypointPath);
|
|
194
|
-
const previousDependencies = this.entrypointDependencies.get(normalizedEntrypoint);
|
|
195
|
-
|
|
196
|
-
if (previousDependencies) {
|
|
197
|
-
for (const dependencyPath of previousDependencies) {
|
|
198
|
-
const entrypoints = this.dependencyEntrypoints.get(dependencyPath);
|
|
199
|
-
if (!entrypoints) {
|
|
200
|
-
continue;
|
|
201
|
-
}
|
|
202
|
-
|
|
203
|
-
entrypoints.delete(normalizedEntrypoint);
|
|
204
|
-
if (entrypoints.size === 0) {
|
|
205
|
-
this.dependencyEntrypoints.delete(dependencyPath);
|
|
206
|
-
}
|
|
207
|
-
}
|
|
208
|
-
}
|
|
209
|
-
|
|
210
|
-
const normalizedDependencies = new Set<string>([
|
|
211
|
-
normalizedEntrypoint,
|
|
212
|
-
...dependencies.map((dependencyPath) => path.resolve(dependencyPath)),
|
|
213
|
-
]);
|
|
214
|
-
|
|
215
|
-
this.entrypointDependencies.set(normalizedEntrypoint, normalizedDependencies);
|
|
216
|
-
|
|
217
|
-
for (const dependencyPath of normalizedDependencies) {
|
|
218
|
-
const entrypoints = this.dependencyEntrypoints.get(dependencyPath) ?? new Set<string>();
|
|
219
|
-
entrypoints.add(normalizedEntrypoint);
|
|
220
|
-
this.dependencyEntrypoints.set(dependencyPath, entrypoints);
|
|
221
|
-
}
|
|
222
|
-
}
|
|
223
|
-
|
|
224
|
-
public async registerEntrypoint(entrypointPath: string): Promise<string> {
|
|
225
|
-
if (this.watchedFiles.has(entrypointPath)) {
|
|
226
|
-
return this.watchedFiles.get(entrypointPath)!;
|
|
227
|
-
}
|
|
228
|
-
|
|
229
|
-
const srcDir = this.appConfig.absolutePaths.srcDir;
|
|
230
|
-
const relativePath = path.relative(srcDir, entrypointPath);
|
|
231
|
-
const relativePathJs = relativePath.replace(/\.(tsx?|jsx?|mdx?)$/, '.js');
|
|
232
|
-
const encodedPathJs = this.encodeDynamicSegments(relativePathJs);
|
|
233
|
-
|
|
234
|
-
const urlPath = encodedPathJs.split(path.sep).join('/');
|
|
235
|
-
const outputUrl = `/${path.join(RESOLVED_ASSETS_DIR, '_hmr', urlPath)}`;
|
|
236
|
-
const outputPath = path.join(this.distDir, urlPath);
|
|
237
|
-
|
|
238
|
-
this.watchedFiles.set(entrypointPath, outputUrl);
|
|
239
|
-
|
|
240
|
-
await this.handleFileChange(entrypointPath);
|
|
241
|
-
|
|
242
|
-
if (!fileSystem.exists(outputPath)) {
|
|
243
|
-
const fallback = await defaultBuildAdapter.build({
|
|
244
|
-
entrypoints: [entrypointPath],
|
|
245
|
-
outdir: this.distDir,
|
|
246
|
-
naming: encodedPathJs,
|
|
247
|
-
minify: false,
|
|
248
|
-
external: Array.from(this.specifierMap.keys()),
|
|
249
|
-
...defaultBuildAdapter.getTranspileOptions('hmr-entrypoint'),
|
|
250
|
-
plugins: this.plugins,
|
|
251
|
-
});
|
|
252
|
-
|
|
253
|
-
if (!fallback.success) {
|
|
254
|
-
appLogger.error(`[HMR] Fallback build failed for ${entrypointPath}:`, fallback.logs);
|
|
255
|
-
}
|
|
256
|
-
}
|
|
257
|
-
|
|
258
|
-
return outputUrl;
|
|
259
|
-
}
|
|
260
|
-
|
|
261
|
-
private encodeDynamicSegments(filepath: string): string {
|
|
262
|
-
return filepath.replace(/\[([^\]]+)\]/g, '_$1_');
|
|
263
|
-
}
|
|
264
|
-
|
|
265
|
-
public stop() {
|
|
266
|
-
for (const watcher of this.watchers.values()) {
|
|
267
|
-
watcher.close();
|
|
268
|
-
}
|
|
269
|
-
this.watchers.clear();
|
|
270
|
-
}
|
|
271
|
-
}
|