@ecopages/core 0.2.0-alpha.23 → 0.2.0-alpha.25
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/package.json +93 -226
- package/src/adapters/abstract/application-adapter.test.ts +172 -0
- package/src/adapters/abstract/application-adapter.ts +379 -0
- package/src/adapters/abstract/router-adapter.ts +30 -0
- package/src/adapters/abstract/server-adapter.ts +79 -0
- package/src/adapters/bun/client-bridge.ts +62 -0
- package/src/adapters/bun/create-app.ts +180 -0
- package/src/adapters/bun/hmr-manager.test.ts +267 -0
- package/src/adapters/bun/hmr-manager.ts +406 -0
- package/src/adapters/bun/index.ts +2 -0
- package/src/adapters/bun/server-adapter.ts +500 -0
- package/src/adapters/bun/server-lifecycle.ts +124 -0
- package/src/adapters/create-app.test.ts +10 -0
- package/src/adapters/create-app.ts +91 -0
- package/src/adapters/index.ts +2 -0
- package/src/adapters/node/create-app.test.ts +53 -0
- package/src/adapters/node/create-app.ts +183 -0
- package/src/adapters/node/node-client-bridge.test.ts +198 -0
- package/src/adapters/node/node-client-bridge.ts +79 -0
- package/src/adapters/node/node-hmr-manager.test.ts +322 -0
- package/src/adapters/node/node-hmr-manager.ts +378 -0
- package/src/adapters/node/server-adapter.ts +502 -0
- package/src/adapters/node/static-content-server.test.ts +60 -0
- package/src/adapters/node/static-content-server.ts +239 -0
- package/src/adapters/shared/api-response.test.ts +97 -0
- package/src/adapters/shared/api-response.ts +104 -0
- package/src/adapters/shared/application-adapter.ts +199 -0
- package/src/adapters/shared/define-api-handler.ts +66 -0
- package/src/adapters/shared/explicit-static-route-matcher.test.ts +381 -0
- package/src/adapters/shared/explicit-static-route-matcher.ts +140 -0
- package/src/adapters/shared/file-route-middleware-pipeline.test.ts +90 -0
- package/src/adapters/shared/file-route-middleware-pipeline.ts +127 -0
- package/src/adapters/shared/fs-server-response-factory.test.ts +187 -0
- package/src/adapters/shared/fs-server-response-factory.ts +118 -0
- package/src/adapters/shared/fs-server-response-matcher.test.ts +285 -0
- package/src/adapters/shared/fs-server-response-matcher.ts +189 -0
- package/src/adapters/shared/hmr-entrypoint-registrar.ts +149 -0
- package/src/adapters/shared/hmr-html-response.ts +52 -0
- package/src/adapters/shared/hmr-manager.contract.test.ts +232 -0
- package/src/adapters/shared/hmr-manager.dispatch.test.ts +220 -0
- package/src/adapters/shared/render-context.test.ts +150 -0
- package/src/adapters/shared/render-context.ts +123 -0
- package/src/adapters/shared/runtime-bootstrap.ts +79 -0
- package/src/adapters/shared/server-adapter.test.ts +77 -0
- package/src/adapters/shared/server-adapter.ts +493 -0
- package/src/adapters/shared/server-route-handler.test.ts +110 -0
- package/src/adapters/shared/server-route-handler.ts +153 -0
- package/src/adapters/shared/server-static-builder.test.ts +338 -0
- package/src/adapters/shared/server-static-builder.ts +170 -0
- package/src/build/build-adapter-serialization.test.ts +281 -0
- package/src/build/build-adapter.test.ts +1240 -0
- package/src/build/build-adapter.ts +1012 -0
- package/src/build/build-manifest.ts +54 -0
- package/src/build/build-types.ts +83 -0
- package/src/build/dev-build-coordinator.ts +220 -0
- package/src/build/esbuild-build-adapter.ts +660 -0
- package/src/build/runtime-build-executor.test.ts +81 -0
- package/src/build/runtime-build-executor.ts +40 -0
- package/src/build/runtime-specifier-alias-plugin.test.ts +67 -0
- package/src/build/runtime-specifier-alias-plugin.ts +62 -0
- package/src/build/runtime-specifier-aliases.ts +135 -0
- package/src/config/config-builder.test.ts +443 -0
- package/src/config/config-builder.ts +742 -0
- package/src/config/config-builder.typecheck.test.ts +96 -0
- package/src/config/{constants.d.ts → constants.ts} +22 -13
- package/src/dev/sc-server.ts +143 -0
- package/src/eco/eco.browser.test.ts +43 -0
- package/src/eco/eco.browser.ts +118 -0
- package/src/eco/eco.test.ts +654 -0
- package/src/eco/eco.ts +205 -0
- package/src/eco/eco.types.ts +221 -0
- package/src/eco/eco.utils.test.ts +219 -0
- package/src/eco/eco.utils.ts +5 -0
- package/src/eco/global-injector-map.test.ts +42 -0
- package/src/eco/global-injector-map.ts +112 -0
- package/src/eco/lazy-injector-map.test.ts +66 -0
- package/src/eco/lazy-injector-map.ts +120 -0
- package/src/eco/module-dependencies.test.ts +30 -0
- package/src/eco/module-dependencies.ts +75 -0
- package/src/errors/http-error.test.ts +134 -0
- package/src/errors/http-error.ts +72 -0
- package/src/errors/{index.d.ts → index.ts} +2 -2
- package/src/errors/locals-access-error.ts +7 -0
- package/src/global/app-logger.ts +4 -0
- package/src/global/utils.test.ts +12 -0
- 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 +160 -0
- package/src/hmr/hmr-strategy.test.ts +124 -0
- package/src/hmr/hmr-strategy.ts +177 -0
- package/src/hmr/hmr.postcss.test.e2e.ts +41 -0
- package/src/hmr/hmr.test.e2e.ts +66 -0
- package/src/hmr/strategies/default-hmr-strategy.ts +60 -0
- package/src/hmr/strategies/js-hmr-strategy.test.ts +335 -0
- package/src/hmr/strategies/js-hmr-strategy.ts +320 -0
- package/src/index.browser.ts +3 -0
- package/src/index.ts +15 -0
- package/src/integrations/ghtml/ghtml-renderer.test.ts +253 -0
- package/src/integrations/ghtml/ghtml-renderer.ts +97 -0
- package/src/integrations/ghtml/ghtml.constants.ts +1 -0
- package/src/integrations/ghtml/ghtml.plugin.ts +28 -0
- package/src/plugins/alias-resolver-plugin.test.ts +41 -0
- package/src/plugins/alias-resolver-plugin.ts +63 -0
- package/src/plugins/eco-component-meta-plugin.test.ts +406 -0
- package/src/plugins/eco-component-meta-plugin.ts +495 -0
- package/src/plugins/foreign-jsx-override-plugin.test.ts +65 -0
- package/src/plugins/foreign-jsx-override-plugin.ts +67 -0
- package/src/plugins/integration-plugin.test.ts +156 -0
- package/src/plugins/integration-plugin.ts +311 -0
- package/src/plugins/processor.test.ts +148 -0
- package/src/plugins/processor.ts +240 -0
- package/src/plugins/{runtime-capability.d.ts → runtime-capability.ts} +8 -3
- package/src/plugins/source-transform.test.ts +82 -0
- package/src/plugins/source-transform.ts +123 -0
- package/src/route-renderer/orchestration/boundary-planning.service.ts +146 -0
- package/src/route-renderer/orchestration/component-render-context.ts +318 -0
- package/src/route-renderer/orchestration/integration-renderer.test.ts +2088 -0
- package/src/route-renderer/orchestration/integration-renderer.ts +1285 -0
- package/src/route-renderer/orchestration/page-packaging.service.test.ts +76 -0
- package/src/route-renderer/orchestration/page-packaging.service.ts +85 -0
- package/src/route-renderer/orchestration/processed-asset-dedupe.ts +25 -0
- package/src/route-renderer/orchestration/queued-boundary-runtime.service.test.ts +319 -0
- package/src/route-renderer/orchestration/queued-boundary-runtime.service.ts +289 -0
- package/src/route-renderer/orchestration/render-execution.service.test.ts +196 -0
- package/src/route-renderer/orchestration/render-execution.service.ts +182 -0
- package/src/route-renderer/orchestration/render-output.utils.ts +302 -0
- package/src/route-renderer/orchestration/render-preparation.service.test.ts +569 -0
- package/src/route-renderer/orchestration/render-preparation.service.ts +508 -0
- package/src/route-renderer/orchestration/route-shell-composer.service.ts +162 -0
- package/src/route-renderer/orchestration/template-serialization.test.ts +110 -0
- package/src/route-renderer/orchestration/template-serialization.ts +117 -0
- package/src/route-renderer/page-loading/component-dependency-collection.ts +196 -0
- package/src/route-renderer/page-loading/declared-asset-collection.ts +156 -0
- package/src/route-renderer/page-loading/dependency-resolver.test.ts +665 -0
- package/src/route-renderer/page-loading/dependency-resolver.ts +150 -0
- package/src/route-renderer/page-loading/ecopages-virtual-imports.ts +75 -0
- package/src/route-renderer/page-loading/lazy-entry-collection.ts +167 -0
- package/src/route-renderer/page-loading/lazy-trigger-planning.ts +74 -0
- package/src/route-renderer/page-loading/module-declaration-aggregation.ts +60 -0
- package/src/route-renderer/page-loading/module-declaration-scripts.ts +16 -0
- package/src/route-renderer/page-loading/page-dependency-bundling.ts +205 -0
- package/src/route-renderer/page-loading/page-module-loader.test.ts +183 -0
- package/src/route-renderer/page-loading/page-module-loader.ts +184 -0
- package/src/route-renderer/route-renderer.ts +136 -0
- package/src/router/client/link-intent.test.browser.ts +51 -0
- package/src/router/client/link-intent.ts +92 -0
- package/src/router/client/navigation-coordinator.test.ts +237 -0
- package/src/router/client/navigation-coordinator.ts +453 -0
- package/src/router/server/fs-router-scanner.test.ts +83 -0
- package/src/router/server/fs-router-scanner.ts +224 -0
- package/src/router/server/fs-router.test.ts +214 -0
- package/src/router/server/fs-router.ts +122 -0
- package/src/services/assets/asset-processing-service/asset-dependency-keys.ts +66 -0
- package/src/services/assets/asset-processing-service/asset-processing.service.test.ts +476 -0
- package/src/services/assets/asset-processing-service/asset-processing.service.ts +345 -0
- package/src/services/assets/asset-processing-service/asset.factory.test.ts +63 -0
- package/src/services/assets/asset-processing-service/asset.factory.ts +105 -0
- package/src/services/assets/asset-processing-service/assets.types.ts +125 -0
- package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.test.ts +74 -0
- package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.ts +96 -0
- package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.test.ts +67 -0
- package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.ts +78 -0
- package/src/services/assets/asset-processing-service/grouped-content-bundles.ts +104 -0
- package/src/services/assets/asset-processing-service/index.ts +5 -0
- package/src/services/assets/asset-processing-service/{processor.interface.d.ts → processor.interface.ts} +10 -5
- package/src/services/assets/asset-processing-service/processor.registry.ts +18 -0
- package/src/services/assets/asset-processing-service/processors/base/base-processor.test.ts +59 -0
- package/src/services/assets/asset-processing-service/processors/base/base-processor.ts +83 -0
- package/src/services/assets/asset-processing-service/processors/base/base-script-processor.ts +174 -0
- package/src/services/assets/asset-processing-service/processors/index.ts +5 -0
- package/src/services/assets/asset-processing-service/processors/script/content-script.processor.test.ts +192 -0
- package/src/services/assets/asset-processing-service/processors/script/content-script.processor.ts +134 -0
- package/src/services/assets/asset-processing-service/processors/script/file-script.processor.test.ts +326 -0
- package/src/services/assets/asset-processing-service/processors/script/file-script.processor.ts +110 -0
- package/src/services/assets/asset-processing-service/processors/script/node-module-script.processor.test.ts +227 -0
- package/src/services/assets/asset-processing-service/processors/script/node-module-script.processor.ts +87 -0
- package/src/services/assets/asset-processing-service/processors/stylesheet/content-stylesheet.processor.test.ts +261 -0
- package/src/services/assets/asset-processing-service/processors/stylesheet/content-stylesheet.processor.ts +71 -0
- package/src/services/assets/asset-processing-service/processors/stylesheet/file-stylesheet.processor.ts +81 -0
- package/src/services/assets/asset-processing-service/ungrouped-dependency-processing.ts +65 -0
- package/src/services/assets/browser-bundle.service.test.ts +66 -0
- package/src/services/assets/browser-bundle.service.ts +109 -0
- package/src/services/cache/cache.types.ts +126 -0
- package/src/services/cache/index.ts +18 -0
- package/src/services/cache/memory-cache-store.test.ts +225 -0
- package/src/services/cache/memory-cache-store.ts +130 -0
- package/src/services/cache/page-cache-service.test.ts +175 -0
- package/src/services/cache/page-cache-service.ts +202 -0
- package/src/services/cache/page-request-cache-coordinator.service.test.ts +79 -0
- package/src/services/cache/page-request-cache-coordinator.service.ts +131 -0
- package/src/services/html/html-rewriter-provider.service.test.ts +183 -0
- package/src/services/html/html-rewriter-provider.service.ts +104 -0
- package/src/services/html/html-transformer.service.test.ts +479 -0
- package/src/services/html/html-transformer.service.ts +275 -0
- package/src/services/invalidation/development-invalidation.service.test.ts +87 -0
- package/src/services/invalidation/development-invalidation.service.ts +262 -0
- package/src/services/module-loading/app-module-loader.service.ts +9 -0
- package/src/services/module-loading/app-server-module-transpiler.service.test.ts +130 -0
- package/src/services/module-loading/app-server-module-transpiler.service.ts +143 -0
- package/src/services/module-loading/host-module-loader-registry.ts +15 -0
- package/src/services/module-loading/{module-loading-types.d.ts → module-loading-types.ts} +1 -0
- package/src/services/module-loading/node-bootstrap-plugin.test.ts +335 -0
- package/src/services/module-loading/node-bootstrap-plugin.ts +297 -0
- package/src/services/module-loading/page-module-import.service.test.ts +504 -0
- package/src/services/module-loading/page-module-import.service.ts +252 -0
- package/src/services/module-loading/server-module-transpiler.service.test.ts +243 -0
- package/src/services/module-loading/server-module-transpiler.service.ts +104 -0
- package/src/services/module-loading/source-module-support.ts +19 -0
- package/src/services/runtime-state/dev-graph.service.ts +217 -0
- package/src/services/runtime-state/entrypoint-dependency-graph.service.ts +136 -0
- package/src/services/runtime-state/runtime-specifier-registry.service.ts +96 -0
- package/src/services/runtime-state/server-invalidation-state.service.ts +68 -0
- package/src/services/validation/schema-validation-service.test.ts +223 -0
- package/src/services/validation/schema-validation-service.ts +204 -0
- package/src/services/validation/{standard-schema.types.d.ts → standard-schema.types.ts} +20 -17
- package/src/static-site-generator/static-site-generator.test.ts +316 -0
- package/src/static-site-generator/static-site-generator.ts +462 -0
- package/src/types/internal-types.ts +242 -0
- package/src/types/public-types.ts +1443 -0
- package/src/utils/deep-merge.test.ts +114 -0
- package/src/utils/deep-merge.ts +47 -0
- package/src/utils/hash.ts +5 -0
- package/src/utils/html-escaping.ts +9 -0
- package/src/utils/invariant.test.ts +22 -0
- package/src/utils/invariant.ts +15 -0
- package/src/utils/locals-utils.ts +37 -0
- package/src/utils/parse-cli-args.test.ts +69 -0
- package/src/utils/parse-cli-args.ts +105 -0
- package/src/utils/path-utils.module.ts +14 -0
- package/src/utils/path-utils.test.ts +15 -0
- package/src/utils/resolve-work-dir.ts +45 -0
- package/src/utils/runtime.ts +44 -0
- package/src/utils/server-utils.module.ts +67 -0
- package/src/utils/server-utils.test.ts +38 -0
- package/src/watchers/project-watcher.integration.test.ts +337 -0
- package/src/watchers/project-watcher.test-helpers.ts +41 -0
- package/src/watchers/project-watcher.test.ts +768 -0
- package/src/watchers/project-watcher.ts +357 -0
- package/CHANGELOG.md +0 -51
- package/src/adapters/abstract/application-adapter.d.ts +0 -194
- package/src/adapters/abstract/application-adapter.js +0 -121
- package/src/adapters/abstract/router-adapter.d.ts +0 -26
- package/src/adapters/abstract/router-adapter.js +0 -5
- package/src/adapters/abstract/server-adapter.d.ts +0 -69
- package/src/adapters/abstract/server-adapter.js +0 -15
- package/src/adapters/bun/client-bridge.d.ts +0 -34
- package/src/adapters/bun/client-bridge.js +0 -48
- package/src/adapters/bun/create-app.d.ts +0 -52
- package/src/adapters/bun/create-app.js +0 -116
- package/src/adapters/bun/hmr-manager.d.ts +0 -143
- package/src/adapters/bun/hmr-manager.js +0 -333
- package/src/adapters/bun/index.d.ts +0 -2
- package/src/adapters/bun/index.js +0 -8
- package/src/adapters/bun/server-adapter.d.ts +0 -155
- package/src/adapters/bun/server-adapter.js +0 -374
- package/src/adapters/bun/server-lifecycle.d.ts +0 -63
- package/src/adapters/bun/server-lifecycle.js +0 -92
- package/src/adapters/create-app.d.ts +0 -20
- package/src/adapters/create-app.js +0 -66
- package/src/adapters/index.d.ts +0 -2
- package/src/adapters/index.js +0 -8
- package/src/adapters/node/create-app.d.ts +0 -18
- package/src/adapters/node/create-app.js +0 -149
- package/src/adapters/node/node-client-bridge.d.ts +0 -26
- package/src/adapters/node/node-client-bridge.js +0 -66
- package/src/adapters/node/node-hmr-manager.d.ts +0 -133
- package/src/adapters/node/node-hmr-manager.js +0 -311
- package/src/adapters/node/server-adapter.d.ts +0 -161
- package/src/adapters/node/server-adapter.js +0 -359
- package/src/adapters/node/static-content-server.d.ts +0 -60
- package/src/adapters/node/static-content-server.js +0 -194
- package/src/adapters/shared/api-response.d.ts +0 -52
- package/src/adapters/shared/api-response.js +0 -96
- package/src/adapters/shared/application-adapter.d.ts +0 -18
- package/src/adapters/shared/application-adapter.js +0 -90
- package/src/adapters/shared/define-api-handler.d.ts +0 -25
- package/src/adapters/shared/define-api-handler.js +0 -15
- package/src/adapters/shared/explicit-static-route-matcher.d.ts +0 -38
- package/src/adapters/shared/explicit-static-route-matcher.js +0 -103
- package/src/adapters/shared/file-route-middleware-pipeline.d.ts +0 -65
- package/src/adapters/shared/file-route-middleware-pipeline.js +0 -99
- package/src/adapters/shared/fs-server-response-factory.d.ts +0 -19
- package/src/adapters/shared/fs-server-response-factory.js +0 -97
- package/src/adapters/shared/fs-server-response-matcher.d.ts +0 -67
- package/src/adapters/shared/fs-server-response-matcher.js +0 -147
- package/src/adapters/shared/hmr-entrypoint-registrar.d.ts +0 -55
- package/src/adapters/shared/hmr-entrypoint-registrar.js +0 -87
- package/src/adapters/shared/hmr-html-response.d.ts +0 -22
- package/src/adapters/shared/hmr-html-response.js +0 -32
- package/src/adapters/shared/render-context.d.ts +0 -15
- package/src/adapters/shared/render-context.js +0 -72
- package/src/adapters/shared/runtime-bootstrap.d.ts +0 -38
- package/src/adapters/shared/runtime-bootstrap.js +0 -43
- package/src/adapters/shared/server-adapter.d.ts +0 -97
- package/src/adapters/shared/server-adapter.js +0 -390
- package/src/adapters/shared/server-route-handler.d.ts +0 -89
- package/src/adapters/shared/server-route-handler.js +0 -111
- package/src/adapters/shared/server-static-builder.d.ts +0 -70
- package/src/adapters/shared/server-static-builder.js +0 -100
- package/src/build/build-adapter.d.ts +0 -239
- package/src/build/build-adapter.js +0 -642
- package/src/build/build-manifest.d.ts +0 -27
- package/src/build/build-manifest.js +0 -30
- package/src/build/build-types.d.ts +0 -57
- package/src/build/build-types.js +0 -0
- package/src/build/dev-build-coordinator.d.ts +0 -72
- package/src/build/dev-build-coordinator.js +0 -154
- package/src/build/esbuild-build-adapter.d.ts +0 -78
- package/src/build/esbuild-build-adapter.js +0 -505
- package/src/build/runtime-build-executor.d.ts +0 -14
- package/src/build/runtime-build-executor.js +0 -22
- package/src/build/runtime-specifier-alias-plugin.d.ts +0 -15
- package/src/build/runtime-specifier-alias-plugin.js +0 -35
- package/src/build/runtime-specifier-aliases.d.ts +0 -5
- package/src/build/runtime-specifier-aliases.js +0 -95
- package/src/config/config-builder.d.ts +0 -252
- package/src/config/config-builder.js +0 -603
- package/src/config/constants.js +0 -25
- package/src/dev/sc-server.d.ts +0 -30
- package/src/dev/sc-server.js +0 -111
- package/src/eco/eco.browser.d.ts +0 -2
- package/src/eco/eco.browser.js +0 -83
- package/src/eco/eco.d.ts +0 -9
- package/src/eco/eco.js +0 -85
- package/src/eco/eco.types.d.ts +0 -178
- package/src/eco/eco.types.js +0 -0
- package/src/eco/eco.utils.d.ts +0 -1
- package/src/eco/eco.utils.js +0 -10
- package/src/eco/global-injector-map.d.ts +0 -16
- package/src/eco/global-injector-map.js +0 -80
- package/src/eco/lazy-injector-map.d.ts +0 -8
- package/src/eco/lazy-injector-map.js +0 -70
- package/src/eco/module-dependencies.d.ts +0 -18
- package/src/eco/module-dependencies.js +0 -49
- package/src/errors/http-error.d.ts +0 -31
- package/src/errors/http-error.js +0 -50
- package/src/errors/index.js +0 -4
- package/src/errors/locals-access-error.d.ts +0 -4
- package/src/errors/locals-access-error.js +0 -9
- package/src/global/app-logger.d.ts +0 -2
- package/src/global/app-logger.js +0 -6
- package/src/hmr/client/hmr-runtime.d.ts +0 -5
- package/src/hmr/client/hmr-runtime.js +0 -109
- package/src/hmr/hmr-strategy.d.ts +0 -162
- package/src/hmr/hmr-strategy.js +0 -44
- package/src/hmr/hmr.postcss.test.e2e.d.ts +0 -1
- package/src/hmr/hmr.postcss.test.e2e.js +0 -31
- package/src/hmr/hmr.test.e2e.d.ts +0 -1
- package/src/hmr/hmr.test.e2e.js +0 -43
- package/src/hmr/strategies/default-hmr-strategy.d.ts +0 -43
- package/src/hmr/strategies/default-hmr-strategy.js +0 -34
- package/src/hmr/strategies/js-hmr-strategy.d.ts +0 -139
- package/src/hmr/strategies/js-hmr-strategy.js +0 -178
- package/src/index.browser.d.ts +0 -3
- package/src/index.browser.js +0 -4
- package/src/index.d.ts +0 -6
- package/src/index.js +0 -21
- package/src/integrations/ghtml/ghtml-renderer.d.ts +0 -20
- package/src/integrations/ghtml/ghtml-renderer.js +0 -63
- package/src/integrations/ghtml/ghtml.constants.d.ts +0 -1
- package/src/integrations/ghtml/ghtml.constants.js +0 -4
- package/src/integrations/ghtml/ghtml.plugin.d.ts +0 -16
- package/src/integrations/ghtml/ghtml.plugin.js +0 -20
- package/src/plugins/alias-resolver-plugin.d.ts +0 -2
- package/src/plugins/alias-resolver-plugin.js +0 -53
- package/src/plugins/eco-component-meta-plugin.d.ts +0 -108
- package/src/plugins/eco-component-meta-plugin.js +0 -163
- package/src/plugins/foreign-jsx-override-plugin.d.ts +0 -31
- package/src/plugins/foreign-jsx-override-plugin.js +0 -35
- package/src/plugins/integration-plugin.d.ts +0 -219
- package/src/plugins/integration-plugin.js +0 -196
- package/src/plugins/processor.d.ts +0 -95
- package/src/plugins/processor.js +0 -136
- package/src/plugins/runtime-capability.js +0 -0
- package/src/plugins/source-transform.d.ts +0 -46
- package/src/plugins/source-transform.js +0 -71
- package/src/route-renderer/orchestration/boundary-planning.service.d.ts +0 -25
- package/src/route-renderer/orchestration/boundary-planning.service.js +0 -97
- package/src/route-renderer/orchestration/component-render-context.d.ts +0 -83
- package/src/route-renderer/orchestration/component-render-context.js +0 -147
- package/src/route-renderer/orchestration/integration-renderer.d.ts +0 -554
- package/src/route-renderer/orchestration/integration-renderer.js +0 -957
- package/src/route-renderer/orchestration/queued-boundary-runtime.service.d.ts +0 -89
- package/src/route-renderer/orchestration/queued-boundary-runtime.service.js +0 -155
- package/src/route-renderer/orchestration/render-execution.service.d.ts +0 -43
- package/src/route-renderer/orchestration/render-execution.service.js +0 -106
- package/src/route-renderer/orchestration/render-output.utils.d.ts +0 -46
- package/src/route-renderer/orchestration/render-output.utils.js +0 -65
- package/src/route-renderer/orchestration/render-preparation.service.d.ts +0 -120
- package/src/route-renderer/orchestration/render-preparation.service.js +0 -341
- package/src/route-renderer/orchestration/route-shell-composer.service.d.ts +0 -50
- package/src/route-renderer/orchestration/route-shell-composer.service.js +0 -81
- package/src/route-renderer/orchestration/template-serialization.d.ts +0 -38
- package/src/route-renderer/orchestration/template-serialization.js +0 -45
- package/src/route-renderer/page-loading/dependency-resolver.d.ts +0 -35
- package/src/route-renderer/page-loading/dependency-resolver.js +0 -444
- package/src/route-renderer/page-loading/page-module-loader.d.ts +0 -90
- package/src/route-renderer/page-loading/page-module-loader.js +0 -127
- package/src/route-renderer/route-renderer.d.ts +0 -67
- package/src/route-renderer/route-renderer.js +0 -103
- package/src/router/client/link-intent.js +0 -34
- package/src/router/client/link-intent.test.browser.d.ts +0 -1
- package/src/router/client/link-intent.test.browser.js +0 -43
- package/src/router/client/navigation-coordinator.d.ts +0 -149
- package/src/router/client/navigation-coordinator.js +0 -215
- package/src/router/server/fs-router-scanner.d.ts +0 -41
- package/src/router/server/fs-router-scanner.js +0 -161
- package/src/router/server/fs-router.d.ts +0 -26
- package/src/router/server/fs-router.js +0 -100
- package/src/services/assets/asset-processing-service/asset-processing.service.d.ts +0 -120
- package/src/services/assets/asset-processing-service/asset-processing.service.js +0 -331
- package/src/services/assets/asset-processing-service/asset.factory.d.ts +0 -17
- package/src/services/assets/asset-processing-service/asset.factory.js +0 -82
- package/src/services/assets/asset-processing-service/assets.types.d.ts +0 -89
- 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 +0 -55
- package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.js +0 -48
- package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.d.ts +0 -20
- package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.js +0 -41
- package/src/services/assets/asset-processing-service/index.d.ts +0 -5
- package/src/services/assets/asset-processing-service/index.js +0 -5
- package/src/services/assets/asset-processing-service/processor.interface.js +0 -6
- package/src/services/assets/asset-processing-service/processor.registry.d.ts +0 -8
- package/src/services/assets/asset-processing-service/processor.registry.js +0 -15
- package/src/services/assets/asset-processing-service/processors/base/base-processor.d.ts +0 -24
- package/src/services/assets/asset-processing-service/processors/base/base-processor.js +0 -64
- package/src/services/assets/asset-processing-service/processors/base/base-script-processor.d.ts +0 -17
- package/src/services/assets/asset-processing-service/processors/base/base-script-processor.js +0 -72
- package/src/services/assets/asset-processing-service/processors/index.d.ts +0 -5
- package/src/services/assets/asset-processing-service/processors/index.js +0 -5
- package/src/services/assets/asset-processing-service/processors/script/content-script.processor.d.ts +0 -5
- package/src/services/assets/asset-processing-service/processors/script/content-script.processor.js +0 -57
- package/src/services/assets/asset-processing-service/processors/script/file-script.processor.d.ts +0 -9
- package/src/services/assets/asset-processing-service/processors/script/file-script.processor.js +0 -88
- package/src/services/assets/asset-processing-service/processors/script/node-module-script.processor.d.ts +0 -7
- package/src/services/assets/asset-processing-service/processors/script/node-module-script.processor.js +0 -75
- package/src/services/assets/asset-processing-service/processors/stylesheet/content-stylesheet.processor.d.ts +0 -5
- package/src/services/assets/asset-processing-service/processors/stylesheet/content-stylesheet.processor.js +0 -25
- package/src/services/assets/asset-processing-service/processors/stylesheet/file-stylesheet.processor.d.ts +0 -9
- package/src/services/assets/asset-processing-service/processors/stylesheet/file-stylesheet.processor.js +0 -66
- package/src/services/assets/browser-bundle.service.d.ts +0 -32
- package/src/services/assets/browser-bundle.service.js +0 -33
- package/src/services/cache/cache.types.d.ts +0 -107
- package/src/services/cache/cache.types.js +0 -0
- package/src/services/cache/index.d.ts +0 -7
- package/src/services/cache/index.js +0 -7
- package/src/services/cache/memory-cache-store.d.ts +0 -42
- package/src/services/cache/memory-cache-store.js +0 -98
- package/src/services/cache/page-cache-service.d.ts +0 -70
- package/src/services/cache/page-cache-service.js +0 -152
- package/src/services/cache/page-request-cache-coordinator.service.d.ts +0 -75
- package/src/services/cache/page-request-cache-coordinator.service.js +0 -109
- package/src/services/html/html-rewriter-provider.service.d.ts +0 -37
- package/src/services/html/html-rewriter-provider.service.js +0 -68
- package/src/services/html/html-transformer.service.d.ts +0 -77
- package/src/services/html/html-transformer.service.js +0 -215
- package/src/services/invalidation/development-invalidation.service.d.ts +0 -74
- package/src/services/invalidation/development-invalidation.service.js +0 -190
- package/src/services/module-loading/app-module-loader.service.d.ts +0 -28
- package/src/services/module-loading/app-module-loader.service.js +0 -35
- package/src/services/module-loading/app-server-module-transpiler.service.d.ts +0 -24
- package/src/services/module-loading/app-server-module-transpiler.service.js +0 -109
- package/src/services/module-loading/host-module-loader-registry.d.ts +0 -4
- package/src/services/module-loading/host-module-loader-registry.js +0 -15
- package/src/services/module-loading/module-loading-types.js +0 -0
- package/src/services/module-loading/node-bootstrap-plugin.d.ts +0 -42
- package/src/services/module-loading/node-bootstrap-plugin.js +0 -204
- package/src/services/module-loading/page-module-import.service.d.ts +0 -76
- package/src/services/module-loading/page-module-import.service.js +0 -173
- package/src/services/module-loading/server-module-transpiler.service.d.ts +0 -72
- package/src/services/module-loading/server-module-transpiler.service.js +0 -64
- package/src/services/runtime-state/dev-graph.service.d.ts +0 -118
- package/src/services/runtime-state/dev-graph.service.js +0 -162
- package/src/services/runtime-state/entrypoint-dependency-graph.service.d.ts +0 -41
- package/src/services/runtime-state/entrypoint-dependency-graph.service.js +0 -85
- package/src/services/runtime-state/runtime-specifier-registry.service.d.ts +0 -69
- package/src/services/runtime-state/runtime-specifier-registry.service.js +0 -37
- package/src/services/runtime-state/server-invalidation-state.service.d.ts +0 -26
- package/src/services/runtime-state/server-invalidation-state.service.js +0 -35
- package/src/services/validation/schema-validation-service.d.ts +0 -122
- package/src/services/validation/schema-validation-service.js +0 -101
- package/src/services/validation/standard-schema.types.js +0 -0
- package/src/static-site-generator/static-site-generator.d.ts +0 -104
- package/src/static-site-generator/static-site-generator.js +0 -338
- package/src/types/internal-types.d.ts +0 -231
- package/src/types/internal-types.js +0 -0
- package/src/types/public-types.d.ts +0 -1219
- package/src/types/public-types.js +0 -0
- package/src/utils/deep-merge.d.ts +0 -14
- package/src/utils/deep-merge.js +0 -32
- package/src/utils/hash.d.ts +0 -1
- package/src/utils/hash.js +0 -7
- package/src/utils/html-escaping.d.ts +0 -7
- package/src/utils/html-escaping.js +0 -6
- package/src/utils/html.js +0 -4
- package/src/utils/invariant.d.ts +0 -5
- package/src/utils/invariant.js +0 -11
- package/src/utils/locals-utils.d.ts +0 -15
- package/src/utils/locals-utils.js +0 -24
- package/src/utils/parse-cli-args.d.ts +0 -27
- package/src/utils/parse-cli-args.js +0 -62
- package/src/utils/path-utils.module.d.ts +0 -5
- package/src/utils/path-utils.module.js +0 -14
- package/src/utils/resolve-work-dir.d.ts +0 -11
- package/src/utils/resolve-work-dir.js +0 -31
- package/src/utils/runtime.d.ts +0 -11
- package/src/utils/runtime.js +0 -40
- package/src/utils/server-utils.module.d.ts +0 -19
- package/src/utils/server-utils.module.js +0 -56
- package/src/watchers/project-watcher.d.ts +0 -136
- package/src/watchers/project-watcher.js +0 -275
- package/src/watchers/project-watcher.test-helpers.d.ts +0 -4
- package/src/watchers/project-watcher.test-helpers.js +0 -52
- /package/src/utils/{html.d.ts → html.ts} +0 -0
|
@@ -0,0 +1,357 @@
|
|
|
1
|
+
import path from 'node:path';
|
|
2
|
+
import chokidar, { type FSWatcher } from 'chokidar';
|
|
3
|
+
import { fileSystem } from '@ecopages/file-system';
|
|
4
|
+
import { appLogger } from '../global/app-logger.ts';
|
|
5
|
+
import type { EcoPagesAppConfig, IHmrManager, IClientBridge } from '../types/internal-types.ts';
|
|
6
|
+
import type { ProcessorWatchConfig, ProcessorWatchContext } from '../plugins/processor.ts';
|
|
7
|
+
import { DevelopmentInvalidationService } from '../services/invalidation/development-invalidation.service.ts';
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* Configuration options for the ProjectWatcher
|
|
11
|
+
* @interface ProjectWatcherConfig
|
|
12
|
+
* @property {EcoPagesAppConfig} config - The application configuration
|
|
13
|
+
* @property {() => Promise<void>} refreshRouterRoutesCallback - Callback to refresh router routes
|
|
14
|
+
* @property {IHmrManager} hmrManager - The HMR manager instance
|
|
15
|
+
* @property {ClientBridge} bridge - The client bridge instance
|
|
16
|
+
*/
|
|
17
|
+
export interface ProjectWatcherConfig {
|
|
18
|
+
config: EcoPagesAppConfig;
|
|
19
|
+
refreshRouterRoutesCallback: () => Promise<void>;
|
|
20
|
+
hmrManager: IHmrManager;
|
|
21
|
+
bridge: IClientBridge;
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
/**
|
|
25
|
+
* ProjectWatcher handles file system changes for hot module replacement (HMR).
|
|
26
|
+
* It uses chokidar to watch for file changes and triggers appropriate actions:
|
|
27
|
+
* - Uncaches modules when files change
|
|
28
|
+
* - Refreshes router routes for page files
|
|
29
|
+
* - Triggers HMR server reload
|
|
30
|
+
* - Handles processor-specific file changes
|
|
31
|
+
*
|
|
32
|
+
* The watcher uses chokidar's built-in debouncing through `awaitWriteFinish`
|
|
33
|
+
* to handle rapid file changes efficiently:
|
|
34
|
+
* - stabilityThreshold: 50ms - Time to wait for writes to stabilize
|
|
35
|
+
* - pollInterval: 50ms - Interval to poll for file changes
|
|
36
|
+
*
|
|
37
|
+
* @class ProjectWatcher
|
|
38
|
+
*/
|
|
39
|
+
export class ProjectWatcher {
|
|
40
|
+
/**
|
|
41
|
+
* Duplicate identical watcher events within this window are ignored.
|
|
42
|
+
*
|
|
43
|
+
* Some editors or save pipelines emit two near-identical filesystem change
|
|
44
|
+
* notifications for the same file. Ecopages should treat those as one logical
|
|
45
|
+
* update so HMR and route refresh work are not repeated unnecessarily.
|
|
46
|
+
*/
|
|
47
|
+
private static readonly duplicateChangeWindowMs = 150;
|
|
48
|
+
private appConfig: EcoPagesAppConfig;
|
|
49
|
+
private refreshRouterRoutesCallback: () => Promise<void>;
|
|
50
|
+
private hmrManager: IHmrManager;
|
|
51
|
+
private bridge: IClientBridge;
|
|
52
|
+
private readonly invalidationService: DevelopmentInvalidationService;
|
|
53
|
+
private watcher: FSWatcher | null = null;
|
|
54
|
+
private lastHandledChange = new Map<string, number>();
|
|
55
|
+
private changeQueue: Promise<void> = Promise.resolve();
|
|
56
|
+
|
|
57
|
+
constructor({ config, refreshRouterRoutesCallback, hmrManager, bridge }: ProjectWatcherConfig) {
|
|
58
|
+
this.appConfig = config;
|
|
59
|
+
this.refreshRouterRoutesCallback = refreshRouterRoutesCallback;
|
|
60
|
+
this.hmrManager = hmrManager;
|
|
61
|
+
this.bridge = bridge;
|
|
62
|
+
this.invalidationService = new DevelopmentInvalidationService(config);
|
|
63
|
+
this.triggerRouterRefresh = this.triggerRouterRefresh.bind(this);
|
|
64
|
+
this.handleError = this.handleError.bind(this);
|
|
65
|
+
this.handleFileChange = this.handleFileChange.bind(this);
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
/**
|
|
69
|
+
* Uncaches modules in the source directory to ensure fresh imports.
|
|
70
|
+
* This is necessary for hot module replacement to work correctly.
|
|
71
|
+
* @private
|
|
72
|
+
*/
|
|
73
|
+
private uncacheModules(): void {
|
|
74
|
+
if (typeof require === 'undefined') return;
|
|
75
|
+
|
|
76
|
+
const { srcDir, rootDir } = this.appConfig;
|
|
77
|
+
const regex = new RegExp(`${rootDir}/${srcDir}/.*`);
|
|
78
|
+
|
|
79
|
+
for (const key in require.cache) {
|
|
80
|
+
if (regex.test(key)) {
|
|
81
|
+
delete require.cache[key];
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
private isRouteSourceFile(filePath: string): boolean {
|
|
87
|
+
return this.invalidationService.isRouteSourceFile(filePath);
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
private isIncludeSourceFile(filePath: string): boolean {
|
|
91
|
+
return this.invalidationService.isIncludeSourceFile(filePath);
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
/**
|
|
95
|
+
* Handles public directory file changes by copying only the changed file.
|
|
96
|
+
* @param filePath - Absolute path of the changed file
|
|
97
|
+
*/
|
|
98
|
+
private async handlePublicDirFileChange(filePath: string): Promise<void> {
|
|
99
|
+
try {
|
|
100
|
+
const relativePath = path.relative(this.appConfig.absolutePaths.publicDir, filePath);
|
|
101
|
+
const destPath = path.join(this.appConfig.absolutePaths.distDir, relativePath);
|
|
102
|
+
|
|
103
|
+
if (fileSystem.exists(filePath)) {
|
|
104
|
+
const destDir = path.dirname(destPath);
|
|
105
|
+
fileSystem.ensureDir(destDir);
|
|
106
|
+
await fileSystem.copyFileAsync(filePath, destPath);
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
this.bridge.reload();
|
|
110
|
+
} catch (error) {
|
|
111
|
+
appLogger.error(`Failed to copy public file: ${error instanceof Error ? error.message : String(error)}`);
|
|
112
|
+
this.bridge.reload();
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
/**
|
|
117
|
+
* Serializes file change handling so that concurrent chokidar events are
|
|
118
|
+
* processed one at a time, preventing overlapping builds and race conditions.
|
|
119
|
+
*/
|
|
120
|
+
private enqueueChange(task: () => Promise<void>): void {
|
|
121
|
+
const queuedTask = this.changeQueue.then(task, task);
|
|
122
|
+
this.changeQueue = queuedTask.catch(() => undefined);
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
/**
|
|
126
|
+
* Handles file changes by uncaching modules, refreshing routes, and delegating appropriately.
|
|
127
|
+
* Follows 5-rule priority:
|
|
128
|
+
* 0. Public directory match? -> copy file and reload
|
|
129
|
+
* 1. additionalWatchPaths match? -> reload
|
|
130
|
+
* 2. Include template source? -> reload after processor notifications
|
|
131
|
+
* 3. Processor-owned asset? -> processor already handled it via notification, skip HMR
|
|
132
|
+
* 4. Otherwise -> HMR strategies
|
|
133
|
+
*
|
|
134
|
+
* Processors that watch a file extension as a dependency (e.g. PostCSS watching
|
|
135
|
+
* .tsx for Tailwind class scanning) are always notified first, but do not
|
|
136
|
+
* prevent the file from flowing through the normal HMR strategy pipeline.
|
|
137
|
+
*
|
|
138
|
+
* Duplicate identical watcher events for the same file are coalesced within a
|
|
139
|
+
* short window before any of the priority rules run.
|
|
140
|
+
* @param rawPath - Path of the changed file
|
|
141
|
+
* @param event - The type of file system event
|
|
142
|
+
*/
|
|
143
|
+
private async handleFileChange(rawPath: string, event: 'change' | 'add' | 'unlink' = 'change'): Promise<void> {
|
|
144
|
+
const filePath = path.resolve(rawPath);
|
|
145
|
+
const now = Date.now();
|
|
146
|
+
const lastHandledAt = this.lastHandledChange.get(filePath);
|
|
147
|
+
if (lastHandledAt !== undefined && now - lastHandledAt < ProjectWatcher.duplicateChangeWindowMs) {
|
|
148
|
+
return;
|
|
149
|
+
}
|
|
150
|
+
this.lastHandledChange.set(filePath, now);
|
|
151
|
+
|
|
152
|
+
try {
|
|
153
|
+
const plan = this.invalidationService.planFileChange(filePath);
|
|
154
|
+
|
|
155
|
+
if (plan.category === 'public-asset') {
|
|
156
|
+
await this.handlePublicDirFileChange(filePath);
|
|
157
|
+
return;
|
|
158
|
+
}
|
|
159
|
+
|
|
160
|
+
this.uncacheModules();
|
|
161
|
+
if (plan.invalidateServerModules) {
|
|
162
|
+
this.invalidationService.invalidateServerModules([filePath]);
|
|
163
|
+
}
|
|
164
|
+
|
|
165
|
+
if (plan.refreshRoutes) {
|
|
166
|
+
await this.refreshRouterRoutesCallback();
|
|
167
|
+
}
|
|
168
|
+
|
|
169
|
+
if (plan.category === 'additional-watch') {
|
|
170
|
+
this.bridge.reload();
|
|
171
|
+
return;
|
|
172
|
+
}
|
|
173
|
+
|
|
174
|
+
await this.notifyProcessors(filePath, event);
|
|
175
|
+
|
|
176
|
+
if (plan.category === 'include-source') {
|
|
177
|
+
this.bridge.reload();
|
|
178
|
+
return;
|
|
179
|
+
}
|
|
180
|
+
|
|
181
|
+
if (plan.processorHandledAsset) {
|
|
182
|
+
return;
|
|
183
|
+
}
|
|
184
|
+
|
|
185
|
+
if (plan.delegateToHmr) {
|
|
186
|
+
await this.hmrManager.handleFileChange(filePath);
|
|
187
|
+
}
|
|
188
|
+
} catch (error) {
|
|
189
|
+
if (error instanceof Error) {
|
|
190
|
+
this.bridge.error(error.message);
|
|
191
|
+
this.handleError(error);
|
|
192
|
+
}
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
|
|
196
|
+
/**
|
|
197
|
+
* Notifies all processors whose watch config matches the given file extension.
|
|
198
|
+
* This is called before checking processor ownership so that dependency-only
|
|
199
|
+
* processors (e.g. PostCSS watching .tsx for class scanning) receive their
|
|
200
|
+
* notifications regardless of whether they own the file.
|
|
201
|
+
*/
|
|
202
|
+
private async notifyProcessors(filePath: string, event: 'change' | 'add' | 'unlink'): Promise<void> {
|
|
203
|
+
const ctx: ProcessorWatchContext = { path: filePath, bridge: this.bridge };
|
|
204
|
+
|
|
205
|
+
for (const processor of this.appConfig.processors.values()) {
|
|
206
|
+
const watchConfig = processor.getWatchConfig();
|
|
207
|
+
if (!watchConfig) continue;
|
|
208
|
+
|
|
209
|
+
const { extensions = [] } = watchConfig;
|
|
210
|
+
if (extensions.length && !extensions.some((ext) => filePath.endsWith(ext))) {
|
|
211
|
+
continue;
|
|
212
|
+
}
|
|
213
|
+
|
|
214
|
+
const handler = this.getProcessorHandler(watchConfig, event);
|
|
215
|
+
if (handler) {
|
|
216
|
+
await handler(ctx);
|
|
217
|
+
}
|
|
218
|
+
}
|
|
219
|
+
}
|
|
220
|
+
|
|
221
|
+
private getProcessorHandler(
|
|
222
|
+
watchConfig: ProcessorWatchConfig,
|
|
223
|
+
event: 'change' | 'add' | 'unlink',
|
|
224
|
+
): ((ctx: ProcessorWatchContext) => Promise<void>) | undefined {
|
|
225
|
+
switch (event) {
|
|
226
|
+
case 'change':
|
|
227
|
+
return watchConfig.onChange;
|
|
228
|
+
case 'add':
|
|
229
|
+
return watchConfig.onCreate;
|
|
230
|
+
case 'unlink':
|
|
231
|
+
return watchConfig.onDelete;
|
|
232
|
+
}
|
|
233
|
+
}
|
|
234
|
+
|
|
235
|
+
/**
|
|
236
|
+
* Checks if a file is in the public directory.
|
|
237
|
+
*/
|
|
238
|
+
private isPublicDirFile(filePath: string): boolean {
|
|
239
|
+
return this.invalidationService.isPublicDirFile(filePath);
|
|
240
|
+
}
|
|
241
|
+
|
|
242
|
+
/**
|
|
243
|
+
* Checks if file path matches any additionalWatchPaths patterns.
|
|
244
|
+
*/
|
|
245
|
+
private matchesAdditionalWatchPaths(filePath: string): boolean {
|
|
246
|
+
return this.invalidationService.matchesAdditionalWatchPaths(filePath);
|
|
247
|
+
}
|
|
248
|
+
|
|
249
|
+
/**
|
|
250
|
+
* Checks if a file is handled by a processor.
|
|
251
|
+
* Processors that declare asset capabilities own those file types.
|
|
252
|
+
* Processors without capabilities fall back to checking watch extensions.
|
|
253
|
+
*/
|
|
254
|
+
private isHandledByProcessor(filePath: string): boolean {
|
|
255
|
+
return this.invalidationService.isProcessorOwnedAsset(filePath);
|
|
256
|
+
}
|
|
257
|
+
|
|
258
|
+
/**
|
|
259
|
+
* Triggers router refresh for page directory changes.
|
|
260
|
+
* This ensures the router is updated when pages are added or removed.
|
|
261
|
+
*
|
|
262
|
+
* @param {string} path - Path of the changed directory
|
|
263
|
+
*/
|
|
264
|
+
async triggerRouterRefresh(changedPath: string): Promise<void> {
|
|
265
|
+
const resolvedPath = path.resolve(changedPath);
|
|
266
|
+
const isPageDir =
|
|
267
|
+
resolvedPath.startsWith(this.appConfig.absolutePaths.pagesDir) && path.extname(resolvedPath) === '';
|
|
268
|
+
|
|
269
|
+
if (isPageDir || this.isRouteSourceFile(resolvedPath)) {
|
|
270
|
+
await this.refreshRouterRoutesCallback();
|
|
271
|
+
}
|
|
272
|
+
}
|
|
273
|
+
|
|
274
|
+
/**
|
|
275
|
+
* Handles and logs errors that occur during file watching.
|
|
276
|
+
*
|
|
277
|
+
* @param {unknown} error - The error to handle
|
|
278
|
+
*/
|
|
279
|
+
handleError(error: unknown) {
|
|
280
|
+
if (error instanceof Error) {
|
|
281
|
+
this.hmrManager.broadcast({ type: 'error', message: error.message });
|
|
282
|
+
}
|
|
283
|
+
appLogger.error(`Watcher error: ${error}`);
|
|
284
|
+
}
|
|
285
|
+
|
|
286
|
+
/**
|
|
287
|
+
* Creates and configures the file system watcher.
|
|
288
|
+
* This sets up:
|
|
289
|
+
* 1. Page file watching
|
|
290
|
+
* 2. Directory watching
|
|
291
|
+
* 3. Error handling
|
|
292
|
+
*
|
|
293
|
+
* Processor notifications are dispatched inside handleFileChange, ensuring
|
|
294
|
+
* a single unified event pipeline with no parallel chokidar bindings.
|
|
295
|
+
*
|
|
296
|
+
* Uses chokidar's built-in debouncing through `awaitWriteFinish` to handle
|
|
297
|
+
* rapid file changes efficiently.
|
|
298
|
+
*/
|
|
299
|
+
public async createWatcherSubscription() {
|
|
300
|
+
if (this.watcher) {
|
|
301
|
+
return this.watcher;
|
|
302
|
+
}
|
|
303
|
+
|
|
304
|
+
const processorPaths: string[] = [];
|
|
305
|
+
for (const processor of this.appConfig.processors.values()) {
|
|
306
|
+
const watchConfig = processor.getWatchConfig();
|
|
307
|
+
if (!watchConfig) continue;
|
|
308
|
+
processorPaths.push(...watchConfig.paths);
|
|
309
|
+
}
|
|
310
|
+
|
|
311
|
+
if (fileSystem.exists(this.appConfig.absolutePaths.includesDir)) {
|
|
312
|
+
processorPaths.push(this.appConfig.absolutePaths.includesDir);
|
|
313
|
+
}
|
|
314
|
+
|
|
315
|
+
if (fileSystem.exists(this.appConfig.absolutePaths.srcDir)) {
|
|
316
|
+
processorPaths.push(this.appConfig.absolutePaths.srcDir);
|
|
317
|
+
}
|
|
318
|
+
|
|
319
|
+
if (fileSystem.exists(this.appConfig.absolutePaths.pagesDir)) {
|
|
320
|
+
processorPaths.push(this.appConfig.absolutePaths.pagesDir);
|
|
321
|
+
}
|
|
322
|
+
|
|
323
|
+
if (fileSystem.exists(this.appConfig.absolutePaths.publicDir)) {
|
|
324
|
+
processorPaths.push(this.appConfig.absolutePaths.publicDir);
|
|
325
|
+
}
|
|
326
|
+
|
|
327
|
+
if (this.appConfig.additionalWatchPaths.length) {
|
|
328
|
+
processorPaths.push(...this.appConfig.additionalWatchPaths);
|
|
329
|
+
}
|
|
330
|
+
|
|
331
|
+
this.watcher = chokidar.watch(processorPaths, {
|
|
332
|
+
ignoreInitial: true,
|
|
333
|
+
ignorePermissionErrors: true,
|
|
334
|
+
awaitWriteFinish: {
|
|
335
|
+
stabilityThreshold: 50,
|
|
336
|
+
pollInterval: 50,
|
|
337
|
+
},
|
|
338
|
+
});
|
|
339
|
+
|
|
340
|
+
this.watcher
|
|
341
|
+
.on('change', (p) => this.enqueueChange(() => this.handleFileChange(p, 'change')))
|
|
342
|
+
.on('add', (p) => this.enqueueChange(() => this.handleFileChange(p, 'add')))
|
|
343
|
+
.on('addDir', (p) => this.enqueueChange(() => this.triggerRouterRefresh(p)))
|
|
344
|
+
.on('unlink', (p) => this.enqueueChange(() => this.handleFileChange(p, 'unlink')))
|
|
345
|
+
.on('unlinkDir', (p) => this.enqueueChange(() => this.triggerRouterRefresh(p)))
|
|
346
|
+
.on('error', (error) => this.handleError(error));
|
|
347
|
+
|
|
348
|
+
for (const processor of this.appConfig.processors.values()) {
|
|
349
|
+
const watchConfig = processor.getWatchConfig();
|
|
350
|
+
if (watchConfig?.onError) {
|
|
351
|
+
this.watcher.on('error', watchConfig.onError as (error: unknown) => void);
|
|
352
|
+
}
|
|
353
|
+
}
|
|
354
|
+
|
|
355
|
+
return this.watcher;
|
|
356
|
+
}
|
|
357
|
+
}
|
package/CHANGELOG.md
DELETED
|
@@ -1,51 +0,0 @@
|
|
|
1
|
-
# Changelog
|
|
2
|
-
|
|
3
|
-
All notable changes to `@ecopages/core` are documented here.
|
|
4
|
-
|
|
5
|
-
> **Note:** Changelog tracking begins at version `0.2.0`. Changes prior to this release are not recorded here but are available in the git history.
|
|
6
|
-
|
|
7
|
-
## [UNRELEASED] — TBD
|
|
8
|
-
|
|
9
|
-
### Features
|
|
10
|
-
|
|
11
|
-
- Added app-owned runtime and build ownership around `createApp()`, host module loading, the browser-safe `eco` export, `eco.html()`, `eco.layout()`, and the published `EcoPagesAppConfig` surface.
|
|
12
|
-
- Added boundary-plan metadata and a compatibility `renderBoundary()` payload contract for mixed-renderer orchestration.
|
|
13
|
-
|
|
14
|
-
### Refactoring
|
|
15
|
-
|
|
16
|
-
- Consolidated runtime state around shared module-loading services, app-owned build execution, and the universal `createApp()` boundary.
|
|
17
|
-
- Simplified route-renderer orchestration around renderer-owned boundary runtimes, shared string-boundary queue helpers, and a smaller component render context.
|
|
18
|
-
- Centralized shared integration renderer bootstrapping so package integrations only append renderer-specific config instead of duplicating core lifecycle wiring.
|
|
19
|
-
- Moved shared queued boundary resolution to attachment-policy payloads and constructor-injectable planning services.
|
|
20
|
-
- Extracted shared page, layout, and document-shell composition into a narrow `RouteShellComposer` while keeping renderer-owned boundary handoff in `IntegrationRenderer`.
|
|
21
|
-
- Removed marker-era compatibility capture, the shared route-level fallback resolver, deprecated `@ecopages/core/node*` escape hatches, and other dead route-renderer internals.
|
|
22
|
-
|
|
23
|
-
### Bug Fixes
|
|
24
|
-
|
|
25
|
-
- Fixed mixed-integration page, layout, document, and component rendering to resolve foreign boundaries inside their owning renderer across the built-in integrations.
|
|
26
|
-
- Fixed host/runtime module loading, published build-helper exports, asset output normalization, explicit render flows, and static or preview build stability across Bun, Node, Vite, and Nitro.
|
|
27
|
-
- Fixed development project watcher setup to register chokidar paths and handlers only once per app runtime.
|
|
28
|
-
- Fixed development script-entry registration to build only the requested HMR entrypoint instead of fanning out across all watched script entrypoints during startup.
|
|
29
|
-
- Fixed Node bootstrap runtime package linking to refresh dangling `.eco/node_modules` symlinks instead of failing with `EEXIST` during page transpilation.
|
|
30
|
-
- Fixed request-time and static-generation page inspection to preserve integration-specific page loading without reusing the normal render module identity.
|
|
31
|
-
- Fixed Node preview and static-generation React runtime resolution so app-owned page modules and server rendering share one React module identity.
|
|
32
|
-
- Fixed Bun browser output normalization so batched multi-entrypoint HMR rebuilds match emitted files to their expected served paths instead of Bun output order.
|
|
33
|
-
- Fixed render-preparation graph traversal so sparse component dependency arrays do not break custom 404 rendering or file-system response fallback flows.
|
|
34
|
-
|
|
35
|
-
### Documentation
|
|
36
|
-
|
|
37
|
-
- Added architecture and API documentation for config, plugins, services, adapters, HMR, routing, and rendering.
|
|
38
|
-
|
|
39
|
-
### Tests
|
|
40
|
-
|
|
41
|
-
- Added regression coverage for app-owned runtime services, Node fallback paths, and cross-runtime invalidation behavior.
|
|
42
|
-
- Strengthened the core ghtml integration tests so route and explicit render paths await real outcomes and cover `renderToResponse` behavior.
|
|
43
|
-
- Added core regression coverage for boundary plans, payload contracts, and typed mixed-boundary context flow.
|
|
44
|
-
|
|
45
|
-
---
|
|
46
|
-
|
|
47
|
-
## Migration Notes
|
|
48
|
-
|
|
49
|
-
- `createApp` is now the recommended entrypoint. Import it from `@ecopages/core/create-app`.
|
|
50
|
-
- `defineApiHandler` keeps the same call shape, but the handler context is now explicitly runtime-agnostic.
|
|
51
|
-
- The old explicit `renderingMode` config option has been removed and full orchestration is always active.
|
|
@@ -1,194 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* This file defines the abstract class for application adapters in EcoPages.
|
|
3
|
-
* It provides a common interface for different runtimes (e.g., Node.js, Deno) to implement.
|
|
4
|
-
* The class includes methods for handling HTTP requests and managing application state.
|
|
5
|
-
* It also includes a method for parsing command-line arguments.
|
|
6
|
-
*
|
|
7
|
-
* @module ApplicationAdapter
|
|
8
|
-
*/
|
|
9
|
-
import type { SourceModuleLoader } from '../../services/module-loading/module-loading-types.js';
|
|
10
|
-
import type { EcoPagesAppConfig } from '../../types/internal-types.js';
|
|
11
|
-
import type { ApiHandler, ApiHandlerContext, ErrorHandler, Middleware, RouteOptions, StaticRoute, ViewLoader } from '../../types/public-types.js';
|
|
12
|
-
import { type ReturnParseCliArgs } from '../../utils/parse-cli-args.js';
|
|
13
|
-
/**
|
|
14
|
-
* Runtime bootstrap options layered on top of the app config.
|
|
15
|
-
*
|
|
16
|
-
* These options let a host runtime embed Ecopages without mutating process
|
|
17
|
-
* globals or app runtime state before calling `createApp()`.
|
|
18
|
-
*/
|
|
19
|
-
export interface ApplicationRuntimeOptions {
|
|
20
|
-
/**
|
|
21
|
-
* Forces the app into the embedded-runtime CLI mode used by host
|
|
22
|
-
* environments.
|
|
23
|
-
*
|
|
24
|
-
* When enabled and no explicit `hostModuleLoader` is provided, the
|
|
25
|
-
* adapter auto-detects a host module loader from the global scope.
|
|
26
|
-
*/
|
|
27
|
-
embedded?: boolean;
|
|
28
|
-
/**
|
|
29
|
-
* Explicit source module loader for request-time imports.
|
|
30
|
-
*
|
|
31
|
-
* When omitted in embedded mode, the adapter attempts automatic
|
|
32
|
-
* detection from globals set by the host environment.
|
|
33
|
-
*/
|
|
34
|
-
hostModuleLoader?: SourceModuleLoader;
|
|
35
|
-
}
|
|
36
|
-
/**
|
|
37
|
-
* Configuration options for application adapters
|
|
38
|
-
*/
|
|
39
|
-
export interface ApplicationAdapterOptions {
|
|
40
|
-
appConfig: EcoPagesAppConfig;
|
|
41
|
-
serverOptions?: Record<string, any>;
|
|
42
|
-
runtime?: ApplicationRuntimeOptions;
|
|
43
|
-
/**
|
|
44
|
-
* Options for clearing the output directory before starting the server
|
|
45
|
-
* @default false
|
|
46
|
-
*/
|
|
47
|
-
clearOutput?: boolean;
|
|
48
|
-
}
|
|
49
|
-
/**
|
|
50
|
-
* Common interface for application adapters
|
|
51
|
-
*/
|
|
52
|
-
export interface ApplicationAdapter<T = any> {
|
|
53
|
-
start(): Promise<T | void>;
|
|
54
|
-
}
|
|
55
|
-
/**
|
|
56
|
-
* Handler function type for route handlers
|
|
57
|
-
*/
|
|
58
|
-
export type RouteHandler<TRequest extends Request = Request, TServer = any, TContext extends ApiHandlerContext<TRequest, TServer> = ApiHandlerContext<TRequest, TServer>> = (context: TContext) => Promise<Response> | Response;
|
|
59
|
-
export type RouteGroupDefinition<TRequest extends Request = Request, TServer = any> = {
|
|
60
|
-
prefix: string;
|
|
61
|
-
middleware?: readonly Middleware<TRequest, TServer, any>[];
|
|
62
|
-
routes: readonly ApiHandler<string, TRequest, TServer>[];
|
|
63
|
-
};
|
|
64
|
-
/**
|
|
65
|
-
* Abstract base class for application adapters across different runtimes
|
|
66
|
-
*/
|
|
67
|
-
export declare abstract class AbstractApplicationAdapter<TOptions extends ApplicationAdapterOptions = ApplicationAdapterOptions, TServer = any, TRequest extends Request = any> implements ApplicationAdapter<TServer> {
|
|
68
|
-
protected appConfig: EcoPagesAppConfig;
|
|
69
|
-
protected serverOptions: Record<string, any>;
|
|
70
|
-
protected cliArgs: ReturnParseCliArgs;
|
|
71
|
-
protected runtimeOptions: ApplicationRuntimeOptions;
|
|
72
|
-
protected apiHandlers: ApiHandler[];
|
|
73
|
-
protected staticRoutes: StaticRoute[];
|
|
74
|
-
protected errorHandler?: ErrorHandler;
|
|
75
|
-
constructor(options: TOptions);
|
|
76
|
-
private clearDistFolder;
|
|
77
|
-
/**
|
|
78
|
-
* Register a GET route handler.
|
|
79
|
-
*
|
|
80
|
-
* Use verb methods for inline route definitions.
|
|
81
|
-
* For dynamic HTTP method registration, use `route(...)`.
|
|
82
|
-
*/
|
|
83
|
-
abstract get<P extends string, TContext extends ApiHandlerContext<TRequest, TServer> = ApiHandlerContext<TRequest, TServer>>(path: P, handler: RouteHandler<TRequest, TServer, TContext>, options?: RouteOptions<TRequest, TServer, TContext>): this;
|
|
84
|
-
/**
|
|
85
|
-
* Register a POST route handler
|
|
86
|
-
*/
|
|
87
|
-
abstract post<P extends string, TContext extends ApiHandlerContext<TRequest, TServer> = ApiHandlerContext<TRequest, TServer>>(path: P, handler: RouteHandler<TRequest, TServer, TContext>, options?: RouteOptions<TRequest, TServer, TContext>): this;
|
|
88
|
-
/**
|
|
89
|
-
* Register a PUT route handler
|
|
90
|
-
*/
|
|
91
|
-
abstract put<P extends string, TContext extends ApiHandlerContext<TRequest, TServer> = ApiHandlerContext<TRequest, TServer>>(path: P, handler: RouteHandler<TRequest, TServer, TContext>, options?: RouteOptions<TRequest, TServer, TContext>): this;
|
|
92
|
-
/**
|
|
93
|
-
* Register a DELETE route handler
|
|
94
|
-
*/
|
|
95
|
-
abstract delete<P extends string, TContext extends ApiHandlerContext<TRequest, TServer> = ApiHandlerContext<TRequest, TServer>>(path: P, handler: RouteHandler<TRequest, TServer, TContext>, options?: RouteOptions<TRequest, TServer, TContext>): this;
|
|
96
|
-
/**
|
|
97
|
-
* Register a PATCH route handler
|
|
98
|
-
*/
|
|
99
|
-
abstract patch<P extends string, TContext extends ApiHandlerContext<TRequest, TServer> = ApiHandlerContext<TRequest, TServer>>(path: P, handler: RouteHandler<TRequest, TServer, TContext>, options?: RouteOptions<TRequest, TServer, TContext>): this;
|
|
100
|
-
/**
|
|
101
|
-
* Register an OPTIONS route handler
|
|
102
|
-
*/
|
|
103
|
-
abstract options<P extends string, TContext extends ApiHandlerContext<TRequest, TServer> = ApiHandlerContext<TRequest, TServer>>(path: P, handler: RouteHandler<TRequest, TServer, TContext>, options?: RouteOptions<TRequest, TServer, TContext>): this;
|
|
104
|
-
/**
|
|
105
|
-
* Register a HEAD route handler
|
|
106
|
-
*/
|
|
107
|
-
abstract head<P extends string, TContext extends ApiHandlerContext<TRequest, TServer> = ApiHandlerContext<TRequest, TServer>>(path: P, handler: RouteHandler<TRequest, TServer, TContext>, options?: RouteOptions<TRequest, TServer, TContext>): this;
|
|
108
|
-
/**
|
|
109
|
-
* Register a route with an explicit HTTP method.
|
|
110
|
-
*
|
|
111
|
-
* This is useful when the method is determined programmatically, or when
|
|
112
|
-
* registering a pre-built route declaration object by forwarding its
|
|
113
|
-
* `path`, `method`, and `handler` fields.
|
|
114
|
-
*/
|
|
115
|
-
abstract route<P extends string>(path: P, method: ApiHandler['method'], handler: RouteHandler<TRequest, TServer>, options?: RouteOptions<TRequest, TServer>): this;
|
|
116
|
-
/**
|
|
117
|
-
* Register a pre-built API handler declaration.
|
|
118
|
-
*/
|
|
119
|
-
abstract add(handler: ApiHandler<string, TRequest, TServer>): this;
|
|
120
|
-
/**
|
|
121
|
-
* Internal method to add route handlers to the API handlers array
|
|
122
|
-
*/
|
|
123
|
-
protected addRouteHandler<P extends string, TSpecRequest extends TRequest = TRequest, TSpecServer extends TServer = TServer, TContext extends ApiHandlerContext<TSpecRequest, TSpecServer> = ApiHandlerContext<TSpecRequest, TSpecServer>>(path: P, method: ApiHandler['method'], handler: RouteHandler<TSpecRequest, TSpecServer, TContext>, middleware?: Middleware<TSpecRequest, TSpecServer, TContext>[], schema?: ApiHandler['schema']): this;
|
|
124
|
-
/**
|
|
125
|
-
* Create a route group with shared prefix and middleware.
|
|
126
|
-
* Routes defined within the group inherit the prefix and middleware.
|
|
127
|
-
*
|
|
128
|
-
* Each adapter implements this with its own builder type to support
|
|
129
|
-
* runtime-specific features (e.g., Bun's path parameter inference).
|
|
130
|
-
* Implementations may also support passing a pre-built group object.
|
|
131
|
-
*
|
|
132
|
-
* @param prefix - URL prefix for all routes in the group (e.g., '/api/v1')
|
|
133
|
-
* @param callback - Function that receives a builder to define routes
|
|
134
|
-
* @param options - Optional group-level middleware
|
|
135
|
-
*/
|
|
136
|
-
abstract group(prefix: string, callback: (builder: unknown) => void, options?: {
|
|
137
|
-
middleware?: readonly Middleware<TRequest, TServer, any>[];
|
|
138
|
-
}): this;
|
|
139
|
-
abstract group(group: RouteGroupDefinition<TRequest, TServer>): this;
|
|
140
|
-
/**
|
|
141
|
-
* Get all registered API handlers
|
|
142
|
-
*/
|
|
143
|
-
getApiHandlers(): ApiHandler[];
|
|
144
|
-
/**
|
|
145
|
-
* Register a view for static generation at build time.
|
|
146
|
-
* The view must have staticPaths defined for dynamic routes.
|
|
147
|
-
*
|
|
148
|
-
* Uses a loader function to enable HMR in development.
|
|
149
|
-
*
|
|
150
|
-
* @param path - URL path pattern (e.g., '/posts/:slug')
|
|
151
|
-
* @param loader - A function that dynamically imports the eco.page view module
|
|
152
|
-
* @example
|
|
153
|
-
* ```typescript
|
|
154
|
-
* app.static('/login', () => import('./src/views/login.kita'))
|
|
155
|
-
* app.static('/posts/:slug', () => import('./src/views/post-view.kita'))
|
|
156
|
-
* ```
|
|
157
|
-
*/
|
|
158
|
-
static<P>(path: string, loader: ViewLoader<P>): this;
|
|
159
|
-
/**
|
|
160
|
-
* Get all registered static routes
|
|
161
|
-
*/
|
|
162
|
-
getStaticRoutes(): StaticRoute[];
|
|
163
|
-
/**
|
|
164
|
-
* Register a global error handler for all routes.
|
|
165
|
-
* Useful for logging, monitoring integration, and custom error formatting.
|
|
166
|
-
*
|
|
167
|
-
* @example
|
|
168
|
-
* ```typescript
|
|
169
|
-
* app.onError(async (error, ctx) => {
|
|
170
|
-
* logger.error(error);
|
|
171
|
-
* return ctx.response.status(500).json({ error: 'Something went wrong' });
|
|
172
|
-
* });
|
|
173
|
-
* ```
|
|
174
|
-
*/
|
|
175
|
-
onError(handler: ErrorHandler<TRequest, TServer>): this;
|
|
176
|
-
/**
|
|
177
|
-
* Get the registered error handler
|
|
178
|
-
*/
|
|
179
|
-
getErrorHandler(): ErrorHandler | undefined;
|
|
180
|
-
/**
|
|
181
|
-
* Initialize the server adapter based on the runtime
|
|
182
|
-
*/
|
|
183
|
-
protected abstract initializeServerAdapter(): Promise<any>;
|
|
184
|
-
/**
|
|
185
|
-
* Start the application server
|
|
186
|
-
*/
|
|
187
|
-
abstract start(): Promise<TServer | void>;
|
|
188
|
-
/**
|
|
189
|
-
* Handles a standard Web request without requiring a bound network server.
|
|
190
|
-
* This is the primary interoperability surface for embedding Ecopages inside
|
|
191
|
-
* other runtimes and frameworks.
|
|
192
|
-
*/
|
|
193
|
-
abstract fetch(request: TRequest): Promise<Response>;
|
|
194
|
-
}
|