@simplysm/sd-cli 14.0.30 → 14.0.32
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/dist/{utils → angular}/angular-build-pipeline.d.ts +0 -2
- package/dist/angular/angular-build-pipeline.d.ts.map +1 -0
- package/dist/{utils → angular}/angular-build-pipeline.js +3 -6
- package/dist/angular/angular-build-pipeline.js.map +1 -0
- package/dist/{utils → angular}/angular-build.d.ts +1 -1
- package/dist/angular/angular-build.d.ts.map +1 -0
- package/dist/{utils → angular}/angular-build.js +1 -1
- package/dist/angular/angular-build.js.map +1 -0
- package/dist/{utils → angular}/angular-compiler.d.ts +0 -3
- package/dist/angular/angular-compiler.d.ts.map +1 -0
- package/dist/{utils → angular}/angular-compiler.js +1 -45
- package/dist/angular/angular-compiler.js.map +1 -0
- package/dist/angular/client-transform-stylesheet.js +1 -1
- package/dist/angular/client-transform-stylesheet.js.map +1 -1
- package/dist/{utils → angular}/ngtsc-build-core.d.ts +3 -3
- package/dist/angular/ngtsc-build-core.d.ts.map +1 -0
- package/dist/angular/ngtsc-build-core.js.map +1 -0
- package/dist/angular/scss-compiler.d.ts.map +1 -0
- package/dist/angular/scss-compiler.js.map +1 -0
- package/dist/angular/vite-angular-plugin.d.ts +2 -10
- package/dist/angular/vite-angular-plugin.d.ts.map +1 -1
- package/dist/angular/vite-angular-plugin.js +20 -286
- package/dist/angular/vite-angular-plugin.js.map +1 -1
- package/dist/capacitor/capacitor-build.d.ts +14 -0
- package/dist/capacitor/capacitor-build.d.ts.map +1 -0
- package/dist/capacitor/capacitor-build.js +105 -0
- package/dist/capacitor/capacitor-build.js.map +1 -0
- package/dist/capacitor/capacitor-config-writer.d.ts +11 -0
- package/dist/capacitor/capacitor-config-writer.d.ts.map +1 -0
- package/dist/capacitor/capacitor-config-writer.js +54 -0
- package/dist/capacitor/capacitor-config-writer.js.map +1 -0
- package/dist/capacitor/capacitor-icon.d.ts +5 -0
- package/dist/capacitor/capacitor-icon.d.ts.map +1 -0
- package/dist/capacitor/capacitor-icon.js +58 -0
- package/dist/capacitor/capacitor-icon.js.map +1 -0
- package/dist/capacitor/capacitor-npm-config.d.ts +11 -0
- package/dist/capacitor/capacitor-npm-config.d.ts.map +1 -0
- package/dist/capacitor/capacitor-npm-config.js +145 -0
- package/dist/capacitor/capacitor-npm-config.js.map +1 -0
- package/dist/capacitor/capacitor.d.ts +0 -45
- package/dist/capacitor/capacitor.d.ts.map +1 -1
- package/dist/capacitor/capacitor.js +15 -354
- package/dist/capacitor/capacitor.js.map +1 -1
- package/dist/commands/check.js +2 -2
- package/dist/commands/check.js.map +1 -1
- package/dist/commands/dev.d.ts +3 -3
- package/dist/commands/dev.d.ts.map +1 -1
- package/dist/commands/dev.js +3 -3
- package/dist/commands/dev.js.map +1 -1
- package/dist/commands/lint.d.ts +1 -1
- package/dist/commands/lint.d.ts.map +1 -1
- package/dist/commands/lint.js +1 -1
- package/dist/commands/lint.js.map +1 -1
- package/dist/commands/publish/deployment-phase.d.ts +12 -0
- package/dist/commands/publish/deployment-phase.d.ts.map +1 -0
- package/dist/commands/publish/deployment-phase.js +94 -0
- package/dist/commands/publish/deployment-phase.js.map +1 -0
- package/dist/commands/publish/env-utils.d.ts +10 -0
- package/dist/commands/publish/env-utils.d.ts.map +1 -0
- package/dist/commands/publish/env-utils.js +41 -0
- package/dist/commands/publish/env-utils.js.map +1 -0
- package/dist/commands/publish/git-phase.d.ts +12 -0
- package/dist/commands/publish/git-phase.d.ts.map +1 -0
- package/dist/commands/publish/git-phase.js +79 -0
- package/dist/commands/publish/git-phase.js.map +1 -0
- package/dist/commands/{publish.d.ts → publish/index.d.ts} +1 -1
- package/dist/commands/publish/index.d.ts.map +1 -0
- package/dist/commands/publish/index.js +211 -0
- package/dist/commands/publish/index.js.map +1 -0
- package/dist/commands/publish/local-publisher.d.ts +6 -0
- package/dist/commands/publish/local-publisher.d.ts.map +1 -0
- package/dist/commands/publish/local-publisher.js +16 -0
- package/dist/commands/publish/local-publisher.js.map +1 -0
- package/dist/commands/publish/npm-publisher.d.ts +6 -0
- package/dist/commands/publish/npm-publisher.d.ts.map +1 -0
- package/dist/commands/publish/npm-publisher.js +21 -0
- package/dist/commands/publish/npm-publisher.js.map +1 -0
- package/dist/commands/publish/post-publish-phase.d.ts +8 -0
- package/dist/commands/publish/post-publish-phase.d.ts.map +1 -0
- package/dist/commands/publish/post-publish-phase.js +34 -0
- package/dist/commands/publish/post-publish-phase.js.map +1 -0
- package/dist/commands/publish/storage-publisher.d.ts +18 -0
- package/dist/commands/publish/storage-publisher.d.ts.map +1 -0
- package/dist/commands/publish/storage-publisher.js +173 -0
- package/dist/commands/publish/storage-publisher.js.map +1 -0
- package/dist/commands/publish/version-upgrade.d.ts +28 -0
- package/dist/commands/publish/version-upgrade.d.ts.map +1 -0
- package/dist/commands/publish/version-upgrade.js +96 -0
- package/dist/commands/publish/version-upgrade.js.map +1 -0
- package/dist/commands/replace-deps.js +1 -1
- package/dist/commands/replace-deps.js.map +1 -1
- package/dist/commands/watch.d.ts +3 -4
- package/dist/commands/watch.d.ts.map +1 -1
- package/dist/commands/watch.js +3 -4
- package/dist/commands/watch.js.map +1 -1
- package/dist/deps/replace-deps/collect-deps.d.ts +6 -0
- package/dist/deps/replace-deps/collect-deps.d.ts.map +1 -0
- package/dist/deps/replace-deps/collect-deps.js +71 -0
- package/dist/deps/replace-deps/collect-deps.js.map +1 -0
- package/dist/{utils/replace-deps.d.ts → deps/replace-deps/replace-deps-resolve.d.ts} +7 -24
- package/dist/deps/replace-deps/replace-deps-resolve.d.ts.map +1 -0
- package/dist/{utils/replace-deps.js → deps/replace-deps/replace-deps-resolve.js} +4 -152
- package/dist/deps/replace-deps/replace-deps-resolve.js.map +1 -0
- package/dist/deps/replace-deps/replace-deps.d.ts +36 -0
- package/dist/deps/replace-deps/replace-deps.d.ts.map +1 -0
- package/dist/deps/replace-deps/replace-deps.js +155 -0
- package/dist/deps/replace-deps/replace-deps.js.map +1 -0
- package/dist/{utils → deps/server-externals}/server-production-files.d.ts +1 -1
- package/dist/deps/server-externals/server-production-files.d.ts.map +1 -0
- package/dist/{utils → deps/server-externals}/server-production-files.js +1 -1
- package/dist/deps/server-externals/server-production-files.js.map +1 -0
- package/dist/dev-server/dev-http-server.d.ts +23 -0
- package/dist/dev-server/dev-http-server.d.ts.map +1 -0
- package/dist/dev-server/dev-http-server.js +116 -0
- package/dist/dev-server/dev-http-server.js.map +1 -0
- package/dist/dev-server/hmr-client-script.d.ts +13 -0
- package/dist/dev-server/hmr-client-script.d.ts.map +1 -0
- package/dist/dev-server/hmr-client-script.js +73 -0
- package/dist/dev-server/hmr-client-script.js.map +1 -0
- package/dist/dev-server/hmr-service.d.ts +23 -0
- package/dist/dev-server/hmr-service.d.ts.map +1 -0
- package/dist/dev-server/hmr-service.js +139 -0
- package/dist/dev-server/hmr-service.js.map +1 -0
- package/dist/electron/electron.d.ts +5 -0
- package/dist/electron/electron.d.ts.map +1 -1
- package/dist/electron/electron.js +17 -24
- package/dist/electron/electron.js.map +1 -1
- package/dist/engines/BaseEngine.d.ts +18 -4
- package/dist/engines/BaseEngine.d.ts.map +1 -1
- package/dist/engines/BaseEngine.js +45 -66
- package/dist/engines/BaseEngine.js.map +1 -1
- package/dist/engines/{ViteEngine.d.ts → EsbuildClientEngine.d.ts} +11 -18
- package/dist/engines/EsbuildClientEngine.d.ts.map +1 -0
- package/dist/engines/{ViteEngine.js → EsbuildClientEngine.js} +28 -55
- package/dist/engines/EsbuildClientEngine.js.map +1 -0
- package/dist/engines/NgtscEngine.d.ts +2 -2
- package/dist/engines/NgtscEngine.d.ts.map +1 -1
- package/dist/engines/NgtscEngine.js +1 -9
- package/dist/engines/NgtscEngine.js.map +1 -1
- package/dist/engines/ServerEsbuildEngine.d.ts +2 -2
- package/dist/engines/ServerEsbuildEngine.d.ts.map +1 -1
- package/dist/engines/ServerEsbuildEngine.js +1 -9
- package/dist/engines/ServerEsbuildEngine.js.map +1 -1
- package/dist/engines/TscEngine.d.ts +2 -2
- package/dist/engines/TscEngine.d.ts.map +1 -1
- package/dist/engines/TscEngine.js +1 -9
- package/dist/engines/TscEngine.js.map +1 -1
- package/dist/engines/index.d.ts +15 -5
- package/dist/engines/index.d.ts.map +1 -1
- package/dist/engines/index.js +21 -5
- package/dist/engines/index.js.map +1 -1
- package/dist/engines/types.d.ts +3 -3
- package/dist/engines/types.d.ts.map +1 -1
- package/dist/esbuild/esbuild-client-config.d.ts +38 -0
- package/dist/esbuild/esbuild-client-config.d.ts.map +1 -0
- package/dist/esbuild/esbuild-client-config.js +171 -0
- package/dist/esbuild/esbuild-client-config.js.map +1 -0
- package/dist/esbuild/esbuild-config.d.ts.map +1 -0
- package/dist/{utils → esbuild}/esbuild-config.js +1 -0
- package/dist/esbuild/esbuild-config.js.map +1 -0
- package/dist/esbuild/esbuild-index-html.d.ts +39 -0
- package/dist/esbuild/esbuild-index-html.d.ts.map +1 -0
- package/dist/esbuild/esbuild-index-html.js +68 -0
- package/dist/esbuild/esbuild-index-html.js.map +1 -0
- package/dist/esbuild/esbuild-pwa.d.ts +21 -0
- package/dist/esbuild/esbuild-pwa.d.ts.map +1 -0
- package/dist/esbuild/esbuild-pwa.js +105 -0
- package/dist/esbuild/esbuild-pwa.js.map +1 -0
- package/dist/esbuild/esbuild-scss-plugin.d.ts +6 -0
- package/dist/esbuild/esbuild-scss-plugin.d.ts.map +1 -0
- package/dist/esbuild/esbuild-scss-plugin.js +41 -0
- package/dist/esbuild/esbuild-scss-plugin.js.map +1 -0
- package/dist/lint/lint-core.d.ts.map +1 -0
- package/dist/lint/lint-core.js.map +1 -0
- package/dist/lint/lint-utils.d.ts.map +1 -0
- package/dist/lint/lint-utils.js.map +1 -0
- package/dist/lint/lint-with-program.d.ts.map +1 -0
- package/dist/lint/lint-with-program.js.map +1 -0
- package/dist/orchestrators/BaseOrchestrator.d.ts +44 -0
- package/dist/orchestrators/BaseOrchestrator.d.ts.map +1 -0
- package/dist/orchestrators/BaseOrchestrator.js +92 -0
- package/dist/orchestrators/BaseOrchestrator.js.map +1 -0
- package/dist/orchestrators/BuildOrchestrator.d.ts +45 -3
- package/dist/orchestrators/BuildOrchestrator.d.ts.map +1 -1
- package/dist/orchestrators/BuildOrchestrator.js +170 -143
- package/dist/orchestrators/BuildOrchestrator.js.map +1 -1
- package/dist/orchestrators/DevOrchestrator.d.ts +39 -0
- package/dist/orchestrators/DevOrchestrator.d.ts.map +1 -0
- package/dist/orchestrators/DevOrchestrator.js +249 -0
- package/dist/orchestrators/DevOrchestrator.js.map +1 -0
- package/dist/orchestrators/ServerRuntimeManager.d.ts +22 -0
- package/dist/orchestrators/ServerRuntimeManager.d.ts.map +1 -0
- package/dist/orchestrators/ServerRuntimeManager.js +66 -0
- package/dist/orchestrators/ServerRuntimeManager.js.map +1 -0
- package/dist/orchestrators/TypecheckOrchestrator.d.ts +17 -2
- package/dist/orchestrators/TypecheckOrchestrator.d.ts.map +1 -1
- package/dist/orchestrators/TypecheckOrchestrator.js +122 -108
- package/dist/orchestrators/TypecheckOrchestrator.js.map +1 -1
- package/dist/orchestrators/WatchOrchestrator.d.ts +33 -0
- package/dist/orchestrators/WatchOrchestrator.d.ts.map +1 -0
- package/dist/orchestrators/WatchOrchestrator.js +158 -0
- package/dist/orchestrators/WatchOrchestrator.js.map +1 -0
- package/dist/orchestrators/types.d.ts +17 -0
- package/dist/orchestrators/types.d.ts.map +1 -0
- package/dist/orchestrators/types.js +2 -0
- package/dist/orchestrators/types.js.map +1 -0
- package/dist/runtime/ResultCollector.d.ts.map +1 -0
- package/dist/runtime/ResultCollector.js.map +1 -0
- package/dist/runtime/SignalHandler.d.ts.map +1 -0
- package/dist/runtime/SignalHandler.js.map +1 -0
- package/dist/{utils → runtime}/engine-stop.d.ts +1 -1
- package/dist/runtime/engine-stop.d.ts.map +1 -0
- package/dist/{utils → runtime}/engine-stop.js +1 -1
- package/dist/runtime/engine-stop.js.map +1 -0
- package/dist/runtime/engine-watch-events.d.ts +43 -0
- package/dist/runtime/engine-watch-events.d.ts.map +1 -0
- package/dist/runtime/engine-watch-events.js +72 -0
- package/dist/runtime/engine-watch-events.js.map +1 -0
- package/dist/{utils → runtime}/rebuild-manager.d.ts +1 -0
- package/dist/runtime/rebuild-manager.d.ts.map +1 -0
- package/dist/{utils → runtime}/rebuild-manager.js +8 -1
- package/dist/runtime/rebuild-manager.js.map +1 -0
- package/dist/runtime/worker-events.d.ts +22 -0
- package/dist/runtime/worker-events.d.ts.map +1 -0
- package/dist/runtime/worker-events.js +2 -0
- package/dist/runtime/worker-events.js.map +1 -0
- package/dist/runtime/worker-utils.d.ts.map +1 -0
- package/dist/runtime/worker-utils.js.map +1 -0
- package/dist/sd-cli-entry.d.ts.map +1 -1
- package/dist/sd-cli-entry.js +61 -54
- package/dist/sd-cli-entry.js.map +1 -1
- package/dist/sd-cli.js +1 -1
- package/dist/sd-cli.js.map +1 -1
- package/dist/sd-config.types.d.ts +6 -15
- package/dist/sd-config.types.d.ts.map +1 -1
- package/dist/typecheck/typecheck-non-package.d.ts.map +1 -0
- package/dist/{utils → typecheck}/typecheck-non-package.js +1 -1
- package/dist/typecheck/typecheck-non-package.js.map +1 -0
- package/dist/typecheck/typecheck-serialization.d.ts.map +1 -0
- package/dist/typecheck/typecheck-serialization.js.map +1 -0
- package/dist/utils/diagnostic-utils.d.ts +5 -0
- package/dist/utils/diagnostic-utils.d.ts.map +1 -1
- package/dist/utils/diagnostic-utils.js +15 -0
- package/dist/utils/diagnostic-utils.js.map +1 -1
- package/dist/utils/orchestrator-utils.d.ts +1 -5
- package/dist/utils/orchestrator-utils.d.ts.map +1 -1
- package/dist/utils/orchestrator-utils.js +2 -5
- package/dist/utils/orchestrator-utils.js.map +1 -1
- package/dist/utils/output-utils.d.ts +1 -1
- package/dist/utils/output-utils.d.ts.map +1 -1
- package/dist/utils/package-classify.d.ts +54 -0
- package/dist/utils/package-classify.d.ts.map +1 -0
- package/dist/utils/package-classify.js +134 -0
- package/dist/utils/package-classify.js.map +1 -0
- package/dist/utils/package-utils.d.ts +1 -58
- package/dist/utils/package-utils.d.ts.map +1 -1
- package/dist/utils/package-utils.js +0 -193
- package/dist/utils/package-utils.js.map +1 -1
- package/dist/utils/tsc-build.d.ts +1 -1
- package/dist/utils/tsc-build.d.ts.map +1 -1
- package/dist/utils/tsc-build.js +1 -1
- package/dist/utils/tsc-build.js.map +1 -1
- package/dist/workers/build-change-filter.d.ts +8 -0
- package/dist/workers/build-change-filter.d.ts.map +1 -0
- package/dist/workers/build-change-filter.js +16 -0
- package/dist/workers/build-change-filter.js.map +1 -0
- package/dist/workers/build-watch-paths.d.ts +20 -0
- package/dist/workers/build-watch-paths.d.ts.map +1 -0
- package/dist/workers/build-watch-paths.js +29 -0
- package/dist/workers/build-watch-paths.js.map +1 -0
- package/dist/workers/client.worker.d.ts +11 -18
- package/dist/workers/client.worker.d.ts.map +1 -1
- package/dist/workers/client.worker.js +218 -289
- package/dist/workers/client.worker.js.map +1 -1
- package/dist/workers/library-build.worker.d.ts +2 -2
- package/dist/workers/library-build.worker.d.ts.map +1 -1
- package/dist/workers/library-build.worker.js +13 -24
- package/dist/workers/library-build.worker.js.map +1 -1
- package/dist/workers/lint.worker.d.ts +1 -1
- package/dist/workers/lint.worker.d.ts.map +1 -1
- package/dist/workers/lint.worker.js +1 -1
- package/dist/workers/lint.worker.js.map +1 -1
- package/dist/workers/ngtsc-build.worker.d.ts +1 -1
- package/dist/workers/ngtsc-build.worker.d.ts.map +1 -1
- package/dist/workers/ngtsc-build.worker.js +19 -35
- package/dist/workers/ngtsc-build.worker.js.map +1 -1
- package/dist/workers/server-build.worker.d.ts +2 -2
- package/dist/workers/server-build.worker.d.ts.map +1 -1
- package/dist/workers/server-build.worker.js +36 -137
- package/dist/workers/server-build.worker.js.map +1 -1
- package/dist/workers/server-esbuild-context.d.ts +47 -0
- package/dist/workers/server-esbuild-context.d.ts.map +1 -0
- package/dist/workers/server-esbuild-context.js +92 -0
- package/dist/workers/server-esbuild-context.js.map +1 -0
- package/dist/workers/server-runtime.worker.d.ts.map +1 -1
- package/dist/workers/server-runtime.worker.js +3 -1
- package/dist/workers/server-runtime.worker.js.map +1 -1
- package/dist/workers/server-watch-manager.d.ts +44 -0
- package/dist/workers/server-watch-manager.d.ts.map +1 -0
- package/dist/workers/server-watch-manager.js +87 -0
- package/dist/workers/server-watch-manager.js.map +1 -0
- package/dist/workers/shared-worker-lifecycle.d.ts +14 -0
- package/dist/workers/shared-worker-lifecycle.d.ts.map +1 -0
- package/dist/workers/shared-worker-lifecycle.js +17 -0
- package/dist/workers/shared-worker-lifecycle.js.map +1 -0
- package/package.json +9 -9
- package/src/{utils → angular}/angular-build-pipeline.ts +3 -8
- package/src/{utils → angular}/angular-build.ts +1 -1
- package/src/{utils → angular}/angular-compiler.ts +1 -64
- package/src/angular/client-transform-stylesheet.ts +1 -1
- package/src/{utils → angular}/ngtsc-build-core.ts +3 -3
- package/src/angular/vite-angular-plugin.ts +22 -355
- package/src/capacitor/capacitor-build.ts +142 -0
- package/src/capacitor/capacitor-config-writer.ts +66 -0
- package/src/capacitor/capacitor-icon.ts +75 -0
- package/src/capacitor/capacitor-npm-config.ts +192 -0
- package/src/capacitor/capacitor.ts +32 -441
- package/src/commands/check.ts +2 -2
- package/src/commands/dev.ts +6 -6
- package/src/commands/lint.ts +1 -1
- package/src/commands/publish/deployment-phase.ts +125 -0
- package/src/commands/publish/env-utils.ts +44 -0
- package/src/commands/publish/git-phase.ts +99 -0
- package/src/commands/publish/index.ts +266 -0
- package/src/commands/publish/local-publisher.ts +23 -0
- package/src/commands/publish/npm-publisher.ts +30 -0
- package/src/commands/publish/post-publish-phase.ts +43 -0
- package/src/commands/publish/storage-publisher.ts +208 -0
- package/src/commands/publish/version-upgrade.ts +132 -0
- package/src/commands/replace-deps.ts +1 -1
- package/src/commands/watch.ts +6 -7
- package/src/deps/replace-deps/collect-deps.ts +92 -0
- package/src/{utils/replace-deps.ts → deps/replace-deps/replace-deps-resolve.ts} +4 -188
- package/src/deps/replace-deps/replace-deps.ts +193 -0
- package/src/{utils → deps/server-externals}/server-production-files.ts +2 -2
- package/src/dev-server/dev-http-server.ts +149 -0
- package/src/dev-server/hmr-client-script.ts +74 -0
- package/src/dev-server/hmr-service.ts +178 -0
- package/src/electron/electron.ts +21 -28
- package/src/engines/BaseEngine.ts +64 -83
- package/src/engines/{ViteEngine.ts → EsbuildClientEngine.ts} +33 -72
- package/src/engines/NgtscEngine.ts +3 -11
- package/src/engines/ServerEsbuildEngine.ts +3 -11
- package/src/engines/TscEngine.ts +3 -11
- package/src/engines/index.ts +29 -9
- package/src/engines/types.ts +3 -3
- package/src/esbuild/esbuild-client-config.ts +230 -0
- package/src/{utils → esbuild}/esbuild-config.ts +1 -0
- package/src/esbuild/esbuild-index-html.ts +119 -0
- package/src/esbuild/esbuild-pwa.ts +139 -0
- package/src/esbuild/esbuild-scss-plugin.ts +48 -0
- package/src/orchestrators/BaseOrchestrator.ts +118 -0
- package/src/orchestrators/BuildOrchestrator.ts +234 -171
- package/src/orchestrators/DevOrchestrator.ts +315 -0
- package/src/orchestrators/ServerRuntimeManager.ts +85 -0
- package/src/orchestrators/TypecheckOrchestrator.ts +166 -117
- package/src/orchestrators/WatchOrchestrator.ts +203 -0
- package/src/orchestrators/types.ts +18 -0
- package/src/{utils → runtime}/engine-stop.ts +1 -1
- package/src/runtime/engine-watch-events.ts +121 -0
- package/src/{utils → runtime}/rebuild-manager.ts +8 -1
- package/src/runtime/worker-events.ts +25 -0
- package/src/sd-cli-entry.ts +69 -54
- package/src/sd-cli.ts +1 -1
- package/src/sd-config.types.ts +6 -16
- package/src/{utils → typecheck}/typecheck-non-package.ts +1 -1
- package/src/utils/diagnostic-utils.ts +15 -0
- package/src/utils/orchestrator-utils.ts +2 -6
- package/src/utils/output-utils.ts +1 -1
- package/src/utils/package-classify.ts +182 -0
- package/src/utils/package-utils.ts +0 -257
- package/src/utils/tsc-build.ts +1 -1
- package/src/workers/build-change-filter.ts +27 -0
- package/src/workers/build-watch-paths.ts +54 -0
- package/src/workers/client.worker.ts +258 -328
- package/src/workers/library-build.worker.ts +15 -34
- package/src/workers/lint.worker.ts +1 -1
- package/src/workers/ngtsc-build.worker.ts +19 -46
- package/src/workers/server-build.worker.ts +38 -168
- package/src/workers/server-esbuild-context.ts +122 -0
- package/src/workers/server-runtime.worker.ts +4 -1
- package/src/workers/server-watch-manager.ts +124 -0
- package/src/workers/shared-worker-lifecycle.ts +24 -0
- package/tests/angular/angular-build-pipeline.spec.ts +2 -2
- package/tests/angular/angular-compiler-aot.acc.spec.ts +68 -0
- package/tests/angular/angular-compiler-aot.spec.ts +80 -0
- package/tests/angular/angular-compiler-hmr-removal.verify.md +16 -0
- package/tests/angular/vite-angular-plugin-legacy-watch.spec.ts +0 -17
- package/tests/angular/vite-angular-plugin-vitest.spec.ts +1 -6
- package/tests/angular/vite-angular-plugin-vitest.verify.md +20 -0
- package/tests/angular/vite-angular-plugin.spec.ts +4 -178
- package/tests/capacitor/capacitor-android.spec.ts +1 -0
- package/tests/capacitor/capacitor-build.spec.ts +1 -0
- package/tests/capacitor/capacitor-config-writer.acc.spec.ts +108 -0
- package/tests/capacitor/capacitor-config-writer.spec.ts +95 -0
- package/tests/capacitor/capacitor-icon.spec.ts +1 -0
- package/tests/capacitor/capacitor-init.spec.ts +1 -0
- package/tests/capacitor/capacitor-npm-config.acc.spec.ts +236 -0
- package/tests/capacitor/capacitor-npm-config.spec.ts +132 -0
- package/tests/capacitor/capacitor-run.spec.ts +1 -0
- package/tests/capacitor/capacitor-workspace.spec.ts +1 -0
- package/tests/commands/check.spec.ts +2 -2
- package/tests/commands/deployment-phase.acc.spec.ts +142 -0
- package/tests/commands/git-phase.acc.spec.ts +158 -0
- package/tests/commands/lint.spec.ts +1 -1
- package/tests/commands/post-publish-phase.acc.spec.ts +82 -0
- package/tests/commands/publish-npm-local-split.verify.md +9 -0
- package/tests/commands/publish-responsibility-split.verify.md +13 -0
- package/tests/commands/publish-storage-split.verify.md +8 -0
- package/tests/commands/publish.spec.ts +1 -1
- package/tests/commands/typecheck.spec.ts +18 -18
- package/tests/deps/deps-directory-separation.verify.md +15 -0
- package/tests/engines/base-engine.spec.ts +65 -6
- package/tests/engines/engine-adapter-isolation.spec.ts +11 -18
- package/tests/engines/engine-selection.spec.ts +38 -5
- package/tests/engines/engine-typecheck-selection.acc.spec.ts +85 -0
- package/tests/engines/engine-typecheck-selection.verify.md +8 -0
- package/tests/engines/esbuild-client-engine.acc.spec.ts +161 -0
- package/tests/engines/esbuild-client-engine.spec.ts +320 -0
- package/tests/engines/esbuild-client-engine.verify.md +15 -0
- package/tests/engines/normalize-result.verify.md +9 -0
- package/tests/engines/vite-dependency-cleanup.verify.md +24 -0
- package/tests/orchestrators/build-orchestrator.spec.ts +3 -3
- package/tests/orchestrators/dev-orchestrator.spec.ts +799 -0
- package/tests/orchestrators/orchestrator-baseenv.verify.md +10 -0
- package/tests/orchestrators/orchestrator-diagnostic-formatting.verify.md +10 -0
- package/tests/orchestrators/orchestrator-initializemode-signature.verify.md +9 -0
- package/tests/orchestrators/typecheck-orchestrator.spec.ts +11 -11
- package/tests/orchestrators/watch-orchestrator.spec.ts +511 -0
- package/tests/{infra → runtime}/result-collector.spec.ts +1 -1
- package/tests/{infra → runtime}/signal-handler.spec.ts +1 -1
- package/tests/sd-cli-entry.spec.ts +9 -0
- package/tests/utils/angular-build.spec.ts +15 -20
- package/tests/utils/angular-compiler-emit.spec.ts +2 -2
- package/tests/utils/angular-compiler.spec.ts +2 -2
- package/tests/utils/angular-source-file-cache.spec.ts +2 -2
- package/tests/utils/concurrency.spec.ts +2 -10
- package/tests/utils/dev-http-server.acc.spec.ts +206 -0
- package/tests/utils/dev-http-server.spec.ts +181 -0
- package/tests/utils/dev-http-server.verify.md +8 -0
- package/tests/utils/diagnostic-utils.spec.ts +42 -1
- package/tests/utils/engine-stop.spec.ts +1 -1
- package/tests/utils/engine-watch-events.acc.spec.ts +217 -0
- package/tests/utils/engine-watch-events.spec.ts +141 -0
- package/tests/utils/engine-watch-events.verify.md +17 -0
- package/tests/utils/esbuild-client-config.acc.spec.ts +443 -0
- package/tests/utils/esbuild-client-config.spec.ts +590 -0
- package/tests/utils/esbuild-client-config.verify.md +26 -0
- package/tests/utils/esbuild-config.spec.ts +11 -1
- package/tests/utils/esbuild-index-html.acc.spec.ts +166 -0
- package/tests/utils/esbuild-index-html.spec.ts +194 -0
- package/tests/utils/esbuild-index-html.verify.md +10 -0
- package/tests/utils/esbuild-pwa.acc.spec.ts +203 -0
- package/tests/utils/esbuild-pwa.spec.ts +189 -0
- package/tests/utils/esbuild-pwa.verify.md +9 -0
- package/tests/utils/esbuild-scss-plugin.acc.spec.ts +111 -0
- package/tests/utils/esbuild-scss-plugin.spec.ts +150 -0
- package/tests/utils/esbuild-scss-plugin.verify.md +8 -0
- package/tests/utils/external-modules.spec.ts +1 -1
- package/tests/utils/hmr-client-script.acc.spec.ts +128 -0
- package/tests/utils/hmr-client-script.spec.ts +44 -0
- package/tests/utils/hmr-service-dispatcher.acc.spec.ts +217 -0
- package/tests/utils/hmr-service-dispatcher.spec.ts +143 -0
- package/tests/utils/hmr-service.acc.spec.ts +139 -0
- package/tests/utils/hmr-service.spec.ts +131 -0
- package/tests/utils/hmr-service.verify.md +17 -0
- package/tests/utils/lint-core.spec.ts +2 -1
- package/tests/utils/lint-utils.spec.ts +1 -1
- package/tests/utils/lint-with-program.spec.ts +1 -1
- package/tests/utils/ngtsc-build-core-write-emit.spec.ts +19 -19
- package/tests/utils/ngtsc-build-core.spec.ts +4 -4
- package/tests/utils/orchestrator-utils.spec.ts +2 -2
- package/tests/utils/output-utils.spec.ts +1 -1
- package/tests/utils/package-utils.spec.ts +1 -1
- package/tests/utils/rebuild-manager.spec.ts +20 -7
- package/tests/utils/replace-deps-split.verify.md +15 -0
- package/tests/utils/replace-deps-watch.acc.spec.ts +131 -0
- package/tests/utils/replace-deps-watch.spec.ts +91 -0
- package/tests/utils/replace-deps-watch.verify.md +9 -0
- package/tests/utils/replace-deps.spec.ts +1 -1
- package/tests/utils/scss-compiler.spec.ts +1 -1
- package/tests/utils/tsc-build.spec.ts +1 -1
- package/tests/utils/typecheck-non-package.spec.ts +2 -2
- package/tests/utils/worker-utils.spec.ts +2 -1
- package/tests/workers/build-change-filter.acc.spec.ts +78 -0
- package/tests/workers/build-change-filter.spec.ts +39 -0
- package/tests/workers/build-watch-paths-library.verify.md +10 -0
- package/tests/workers/build-watch-paths-ngtsc-server.verify.md +12 -0
- package/tests/workers/build-watch-paths.acc.spec.ts +101 -0
- package/tests/workers/build-watch-paths.spec.ts +121 -0
- package/tests/workers/client-worker-browser-support.verify.md +7 -0
- package/tests/workers/client-worker-onend-sync.verify.md +7 -0
- package/tests/workers/client-worker.acc.spec.ts +185 -0
- package/tests/workers/client-worker.spec.ts +91 -178
- package/tests/workers/library-build-lint.spec.ts +3 -3
- package/tests/workers/library-build-worker.spec.ts +10 -11
- package/tests/workers/ngtsc-build-lint.spec.ts +4 -4
- package/tests/workers/ngtsc-build-worker.spec.ts +2 -2
- package/tests/workers/server-build-lint.spec.ts +4 -4
- package/tests/workers/server-build-worker.spec.ts +14 -15
- package/tests/workers/server-esbuild-context-integration.verify.md +10 -0
- package/tests/workers/server-esbuild-context.acc.spec.ts +98 -0
- package/tests/workers/server-esbuild-context.spec.ts +198 -0
- package/tests/workers/server-runtime-worker.spec.ts +4 -3
- package/tests/workers/server-watch-manager.acc.spec.ts +162 -0
- package/tests/workers/server-watch-manager.spec.ts +199 -0
- package/tests/workers/shared-worker-lifecycle.acc.spec.ts +27 -0
- package/tests/workers/shared-worker-lifecycle.spec.ts +47 -0
- package/dist/angular/vite-postcss-inline-plugin.d.ts +0 -18
- package/dist/angular/vite-postcss-inline-plugin.d.ts.map +0 -1
- package/dist/angular/vite-postcss-inline-plugin.js +0 -108
- package/dist/angular/vite-postcss-inline-plugin.js.map +0 -1
- package/dist/commands/publish.d.ts.map +0 -1
- package/dist/commands/publish.js +0 -689
- package/dist/commands/publish.js.map +0 -1
- package/dist/engines/ViteEngine.d.ts.map +0 -1
- package/dist/engines/ViteEngine.js.map +0 -1
- package/dist/infra/ResultCollector.d.ts.map +0 -1
- package/dist/infra/ResultCollector.js.map +0 -1
- package/dist/infra/SignalHandler.d.ts.map +0 -1
- package/dist/infra/SignalHandler.js.map +0 -1
- package/dist/orchestrators/DevWatchOrchestrator.d.ts +0 -63
- package/dist/orchestrators/DevWatchOrchestrator.d.ts.map +0 -1
- package/dist/orchestrators/DevWatchOrchestrator.js +0 -478
- package/dist/orchestrators/DevWatchOrchestrator.js.map +0 -1
- package/dist/utils/angular-build-pipeline.d.ts.map +0 -1
- package/dist/utils/angular-build-pipeline.js.map +0 -1
- package/dist/utils/angular-build.d.ts.map +0 -1
- package/dist/utils/angular-build.js.map +0 -1
- package/dist/utils/angular-compiler.d.ts.map +0 -1
- package/dist/utils/angular-compiler.js.map +0 -1
- package/dist/utils/engine-stop.d.ts.map +0 -1
- package/dist/utils/engine-stop.js.map +0 -1
- package/dist/utils/esbuild-config.d.ts.map +0 -1
- package/dist/utils/esbuild-config.js.map +0 -1
- package/dist/utils/hmr-candidates.d.ts +0 -15
- package/dist/utils/hmr-candidates.d.ts.map +0 -1
- package/dist/utils/hmr-candidates.js +0 -234
- package/dist/utils/hmr-candidates.js.map +0 -1
- package/dist/utils/lint-core.d.ts.map +0 -1
- package/dist/utils/lint-core.js.map +0 -1
- package/dist/utils/lint-utils.d.ts.map +0 -1
- package/dist/utils/lint-utils.js.map +0 -1
- package/dist/utils/lint-with-program.d.ts.map +0 -1
- package/dist/utils/lint-with-program.js.map +0 -1
- package/dist/utils/ngtsc-build-core.d.ts.map +0 -1
- package/dist/utils/ngtsc-build-core.js.map +0 -1
- package/dist/utils/rebuild-manager.d.ts.map +0 -1
- package/dist/utils/rebuild-manager.js.map +0 -1
- package/dist/utils/replace-deps.d.ts.map +0 -1
- package/dist/utils/replace-deps.js.map +0 -1
- package/dist/utils/scss-compiler.d.ts.map +0 -1
- package/dist/utils/scss-compiler.js.map +0 -1
- package/dist/utils/server-production-files.d.ts.map +0 -1
- package/dist/utils/server-production-files.js.map +0 -1
- package/dist/utils/typecheck-non-package.d.ts.map +0 -1
- package/dist/utils/typecheck-non-package.js.map +0 -1
- package/dist/utils/typecheck-serialization.d.ts.map +0 -1
- package/dist/utils/typecheck-serialization.js.map +0 -1
- package/dist/utils/vite-config.d.ts +0 -50
- package/dist/utils/vite-config.d.ts.map +0 -1
- package/dist/utils/vite-config.js +0 -242
- package/dist/utils/vite-config.js.map +0 -1
- package/dist/utils/vite-pwa-plugin.d.ts +0 -9
- package/dist/utils/vite-pwa-plugin.d.ts.map +0 -1
- package/dist/utils/vite-pwa-plugin.js +0 -139
- package/dist/utils/vite-pwa-plugin.js.map +0 -1
- package/dist/utils/vite-scope-watch-plugin.d.ts +0 -24
- package/dist/utils/vite-scope-watch-plugin.d.ts.map +0 -1
- package/dist/utils/vite-scope-watch-plugin.js +0 -51
- package/dist/utils/vite-scope-watch-plugin.js.map +0 -1
- package/dist/utils/worker-events.d.ts +0 -66
- package/dist/utils/worker-events.d.ts.map +0 -1
- package/dist/utils/worker-events.js +0 -55
- package/dist/utils/worker-events.js.map +0 -1
- package/dist/utils/worker-utils.d.ts.map +0 -1
- package/dist/utils/worker-utils.js.map +0 -1
- package/src/angular/vite-postcss-inline-plugin.ts +0 -139
- package/src/commands/publish.ts +0 -850
- package/src/orchestrators/DevWatchOrchestrator.ts +0 -594
- package/src/utils/hmr-candidates.ts +0 -327
- package/src/utils/vite-config.ts +0 -318
- package/src/utils/vite-pwa-plugin.ts +0 -168
- package/src/utils/vite-scope-watch-plugin.ts +0 -77
- package/src/utils/worker-events.ts +0 -128
- package/tests/angular/angular-compiler-hmr.spec.ts +0 -152
- package/tests/angular/hmr-candidates.spec.ts +0 -158
- package/tests/angular/linker-disk-cache.spec.ts +0 -171
- package/tests/angular/vite-angular-plugin-hmr-fallback.spec.ts +0 -333
- package/tests/angular/vite-angular-plugin-hmr.spec.ts +0 -320
- package/tests/angular/vite-angular-plugin-scss-hmr.spec.ts +0 -95
- package/tests/angular/vite-postcss-inline-plugin.spec.ts +0 -60
- package/tests/engines/vite-engine.spec.ts +0 -409
- package/tests/orchestrators/dev-watch-orchestrator.spec.ts +0 -1542
- package/tests/utils/vite-config.spec.ts +0 -780
- package/tests/utils/vite-pwa-plugin.spec.ts +0 -401
- package/tests/utils/vite-scope-watch-plugin.spec.ts +0 -218
- package/tests/utils/worker-events.spec.ts +0 -147
- package/tests/workers/client-worker-legacy.spec.ts +0 -659
- /package/dist/{utils → angular}/ngtsc-build-core.js +0 -0
- /package/dist/{utils → angular}/scss-compiler.d.ts +0 -0
- /package/dist/{utils → angular}/scss-compiler.js +0 -0
- /package/dist/{utils → esbuild}/esbuild-config.d.ts +0 -0
- /package/dist/{utils → lint}/lint-core.d.ts +0 -0
- /package/dist/{utils → lint}/lint-core.js +0 -0
- /package/dist/{utils → lint}/lint-utils.d.ts +0 -0
- /package/dist/{utils → lint}/lint-utils.js +0 -0
- /package/dist/{utils → lint}/lint-with-program.d.ts +0 -0
- /package/dist/{utils → lint}/lint-with-program.js +0 -0
- /package/dist/{infra → runtime}/ResultCollector.d.ts +0 -0
- /package/dist/{infra → runtime}/ResultCollector.js +0 -0
- /package/dist/{infra → runtime}/SignalHandler.d.ts +0 -0
- /package/dist/{infra → runtime}/SignalHandler.js +0 -0
- /package/dist/{utils → runtime}/worker-utils.d.ts +0 -0
- /package/dist/{utils → runtime}/worker-utils.js +0 -0
- /package/dist/{utils → typecheck}/typecheck-non-package.d.ts +0 -0
- /package/dist/{utils → typecheck}/typecheck-serialization.d.ts +0 -0
- /package/dist/{utils → typecheck}/typecheck-serialization.js +0 -0
- /package/src/{utils → angular}/scss-compiler.ts +0 -0
- /package/src/{utils → lint}/lint-core.ts +0 -0
- /package/src/{utils → lint}/lint-utils.ts +0 -0
- /package/src/{utils → lint}/lint-with-program.ts +0 -0
- /package/src/{infra → runtime}/ResultCollector.ts +0 -0
- /package/src/{infra → runtime}/SignalHandler.ts +0 -0
- /package/src/{utils → runtime}/worker-utils.ts +0 -0
- /package/src/{utils → typecheck}/typecheck-serialization.ts +0 -0
|
@@ -0,0 +1,193 @@
|
|
|
1
|
+
import fs from "fs";
|
|
2
|
+
import path from "path";
|
|
3
|
+
import { consola } from "consola";
|
|
4
|
+
import { fsx, pathx, FsWatcher } from "@simplysm/core-node";
|
|
5
|
+
import { exec } from "child_process";
|
|
6
|
+
import { promisify } from "util";
|
|
7
|
+
import type { ReplaceDepEntry } from "./replace-deps-resolve";
|
|
8
|
+
import { resolveAllReplaceDepEntries } from "./replace-deps-resolve";
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* 복사 시 제외할 이름 목록
|
|
12
|
+
*/
|
|
13
|
+
const EXCLUDED_NAMES = new Set(["node_modules", "package.json", ".cache", "tests"]);
|
|
14
|
+
|
|
15
|
+
/**
|
|
16
|
+
* replaceDeps 복사용 필터 함수
|
|
17
|
+
* node_modules, package.json, .cache, tests를 제외한다.
|
|
18
|
+
*
|
|
19
|
+
* @param itemPath - 복사할 항목의 절대 경로
|
|
20
|
+
* @returns 복사 대상이면 true, 제외 대상이면 false
|
|
21
|
+
*/
|
|
22
|
+
function replaceDepsCopyFilter(itemPath: string): boolean {
|
|
23
|
+
const basename = path.basename(itemPath);
|
|
24
|
+
return !EXCLUDED_NAMES.has(basename);
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
/**
|
|
28
|
+
* watchReplaceDeps의 반환 타입
|
|
29
|
+
*/
|
|
30
|
+
export interface WatchReplaceDepResult {
|
|
31
|
+
entries: ReplaceDepEntry[];
|
|
32
|
+
dispose: () => void;
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
/**
|
|
36
|
+
* replaceDeps 설정에 따라 node_modules의 패키지를 소스 디렉토리로 교체한다.
|
|
37
|
+
*
|
|
38
|
+
* 1. pnpm-workspace.yaml 파싱 → 워크스페이스 패키지 경로
|
|
39
|
+
* 2. [루트, ...워크스페이스 패키지] node_modules에서 매칭 패키지 탐색
|
|
40
|
+
* 3. 기존 symlink/디렉토리 제거 → 소스 경로 복사 (node_modules, package.json, .cache, tests 제외)
|
|
41
|
+
*
|
|
42
|
+
* @param projectRoot - 프로젝트 루트 경로
|
|
43
|
+
* @param replaceDeps - sd.config.ts의 replaceDeps 설정
|
|
44
|
+
*/
|
|
45
|
+
export async function setupReplaceDeps(
|
|
46
|
+
projectRoot: string,
|
|
47
|
+
replaceDeps: Record<string, string>,
|
|
48
|
+
): Promise<void> {
|
|
49
|
+
const logger = consola.withTag("sd:cli:replace-deps");
|
|
50
|
+
let setupCount = 0;
|
|
51
|
+
|
|
52
|
+
logger.start("replace-deps 설정 중...");
|
|
53
|
+
|
|
54
|
+
const entries = await resolveAllReplaceDepEntries(projectRoot, replaceDeps, logger);
|
|
55
|
+
|
|
56
|
+
for (const { targetName, resolvedSourcePath, actualTargetPath } of entries) {
|
|
57
|
+
try {
|
|
58
|
+
// 소스 파일을 actualTargetPath에 덮어쓰기 복사 (기존 디렉토리 유지, symlink 보존)
|
|
59
|
+
await fsx.copy(resolvedSourcePath, actualTargetPath, replaceDepsCopyFilter);
|
|
60
|
+
|
|
61
|
+
setupCount += 1;
|
|
62
|
+
} catch (err) {
|
|
63
|
+
logger.error(`[${targetName}] 복사 실패: ${err instanceof Error ? err.message : err}`);
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
logger.success(`replace-deps 설정 완료 (${setupCount}개 의존성 교체)`);
|
|
68
|
+
|
|
69
|
+
// 교체된 패키지의 postinstall 스크립트 실행
|
|
70
|
+
for (const { targetName, resolvedSourcePath, actualTargetPath } of entries) {
|
|
71
|
+
const sourcePkgJsonPath = pathx.posix(path.join(resolvedSourcePath, "package.json"));
|
|
72
|
+
try {
|
|
73
|
+
const pkgJson = JSON.parse(await fs.promises.readFile(sourcePkgJsonPath, "utf-8"));
|
|
74
|
+
const postinstall = pkgJson.scripts?.postinstall as string | undefined;
|
|
75
|
+
if (postinstall == null) continue;
|
|
76
|
+
|
|
77
|
+
logger.warn(`[${targetName}] postinstall 스크립트 실행: ${postinstall}`);
|
|
78
|
+
logger.start(`[${targetName}] postinstall 실행 중...`);
|
|
79
|
+
await promisify(exec)(postinstall, { cwd: actualTargetPath });
|
|
80
|
+
logger.success(`[${targetName}] postinstall 실행 완료`);
|
|
81
|
+
} catch (err) {
|
|
82
|
+
logger.error(
|
|
83
|
+
`[${targetName}] postinstall 실패: ${err instanceof Error ? err.message : err}`,
|
|
84
|
+
);
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
/**
|
|
90
|
+
* replaceDeps 설정에 따라 소스 디렉토리를 감시하고 변경사항을 대상 경로에 복사한다.
|
|
91
|
+
*
|
|
92
|
+
* 1. pnpm-workspace.yaml 파싱 → 워크스페이스 패키지 경로
|
|
93
|
+
* 2. [루트, ...워크스페이스 패키지] node_modules에서 매칭 패키지 탐색
|
|
94
|
+
* 3. FsWatcher로 소스 디렉토리 감시 (300ms 딜레이)
|
|
95
|
+
* 4. 변경사항을 대상 경로에 복사 (node_modules, package.json, .cache, tests 제외)
|
|
96
|
+
*
|
|
97
|
+
* @param projectRoot - 프로젝트 루트 경로
|
|
98
|
+
* @param replaceDeps - sd.config.ts의 replaceDeps 설정
|
|
99
|
+
* @param options - 옵션. onChanged: 파일 복사 완료 후 호출되는 콜백
|
|
100
|
+
* @returns entries 및 dispose 함수
|
|
101
|
+
*/
|
|
102
|
+
export async function watchReplaceDeps(
|
|
103
|
+
projectRoot: string,
|
|
104
|
+
replaceDeps: Record<string, string>,
|
|
105
|
+
options?: { onChanged?: () => void },
|
|
106
|
+
): Promise<WatchReplaceDepResult> {
|
|
107
|
+
const logger = consola.withTag("sd:cli:replace-deps:watch");
|
|
108
|
+
|
|
109
|
+
const entries = await resolveAllReplaceDepEntries(projectRoot, replaceDeps, logger);
|
|
110
|
+
|
|
111
|
+
// 소스 디렉토리 감시자 설정
|
|
112
|
+
const watchers: FsWatcher[] = [];
|
|
113
|
+
const watchedSources = new Set<string>();
|
|
114
|
+
|
|
115
|
+
logger.start(`replace-deps 워치 시작 중... (${entries.length}개 대상)`);
|
|
116
|
+
|
|
117
|
+
for (const entry of entries) {
|
|
118
|
+
if (watchedSources.has(entry.resolvedSourcePath)) continue;
|
|
119
|
+
watchedSources.add(entry.resolvedSourcePath);
|
|
120
|
+
|
|
121
|
+
const excludedPaths = [...EXCLUDED_NAMES].map((name) =>
|
|
122
|
+
pathx.posix(path.join(entry.resolvedSourcePath, name)),
|
|
123
|
+
);
|
|
124
|
+
|
|
125
|
+
const watcher = await FsWatcher.watch([entry.resolvedSourcePath], {
|
|
126
|
+
followSymlinks: false,
|
|
127
|
+
ignored: [...EXCLUDED_NAMES].map((name) => `**/${name}`),
|
|
128
|
+
});
|
|
129
|
+
watcher.onChange({ delay: 300 }, async (changeInfos) => {
|
|
130
|
+
for (const { path: changedPath } of changeInfos) {
|
|
131
|
+
// 제외 항목 필터: basename 매칭 또는 제외 디렉토리 내 경로
|
|
132
|
+
if (
|
|
133
|
+
EXCLUDED_NAMES.has(path.basename(changedPath)) ||
|
|
134
|
+
excludedPaths.some((ep) => pathx.isChildPath(changedPath, ep))
|
|
135
|
+
) {
|
|
136
|
+
continue;
|
|
137
|
+
}
|
|
138
|
+
|
|
139
|
+
// 이 소스 경로를 사용하는 모든 항목에 대해 복사
|
|
140
|
+
for (const e of entries) {
|
|
141
|
+
if (e.resolvedSourcePath !== entry.resolvedSourcePath) continue;
|
|
142
|
+
|
|
143
|
+
// 소스로부터의 상대 경로 계산
|
|
144
|
+
const relativePath = pathx.posix(path.relative(e.resolvedSourcePath, changedPath));
|
|
145
|
+
const destPath = pathx.posix(path.join(e.actualTargetPath, relativePath));
|
|
146
|
+
|
|
147
|
+
try {
|
|
148
|
+
// 소스 존재 여부 확인
|
|
149
|
+
let sourceExists = false;
|
|
150
|
+
try {
|
|
151
|
+
await fs.promises.access(changedPath);
|
|
152
|
+
sourceExists = true;
|
|
153
|
+
} catch {
|
|
154
|
+
// 소스가 삭제됨
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
if (sourceExists) {
|
|
158
|
+
// 소스가 디렉토리인지 파일인지 확인
|
|
159
|
+
const stat = await fs.promises.stat(changedPath);
|
|
160
|
+
if (stat.isDirectory()) {
|
|
161
|
+
await fsx.mkdir(destPath);
|
|
162
|
+
} else {
|
|
163
|
+
await fsx.mkdir(pathx.posix(path.dirname(destPath)));
|
|
164
|
+
await fsx.copy(changedPath, destPath, replaceDepsCopyFilter);
|
|
165
|
+
}
|
|
166
|
+
} else {
|
|
167
|
+
// 소스가 삭제됨 → 대상도 삭제
|
|
168
|
+
await fsx.rm(destPath);
|
|
169
|
+
}
|
|
170
|
+
} catch (err) {
|
|
171
|
+
logger.error(
|
|
172
|
+
`[${e.targetName}] 복사 실패 (${relativePath}): ${err instanceof Error ? err.message : err}`,
|
|
173
|
+
);
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
options?.onChanged?.();
|
|
178
|
+
});
|
|
179
|
+
|
|
180
|
+
watchers.push(watcher);
|
|
181
|
+
}
|
|
182
|
+
|
|
183
|
+
logger.success("replace-deps 워치 준비 완료");
|
|
184
|
+
|
|
185
|
+
return {
|
|
186
|
+
entries,
|
|
187
|
+
dispose: () => {
|
|
188
|
+
for (const watcher of watchers) {
|
|
189
|
+
void watcher.close();
|
|
190
|
+
}
|
|
191
|
+
},
|
|
192
|
+
};
|
|
193
|
+
}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import type { ServerBuildInfo } from "
|
|
1
|
+
import type { ServerBuildInfo } from "../../workers/server-build.worker";
|
|
2
2
|
import path from "path";
|
|
3
3
|
import fs from "fs";
|
|
4
4
|
import { cpx } from "@simplysm/core-node";
|
|
5
5
|
import { consola } from "consola";
|
|
6
|
-
import { collectAllDependencyExternals } from "
|
|
6
|
+
import { collectAllDependencyExternals } from "../../esbuild/esbuild-config";
|
|
7
7
|
|
|
8
8
|
const logger = consola.withTag("sd:cli:server-production-files");
|
|
9
9
|
|
|
@@ -0,0 +1,149 @@
|
|
|
1
|
+
import http from "node:http";
|
|
2
|
+
import fs from "node:fs";
|
|
3
|
+
import { pipeline } from "node:stream/promises";
|
|
4
|
+
import path from "path";
|
|
5
|
+
import mime from "mime";
|
|
6
|
+
|
|
7
|
+
export interface DevHttpServerOptions {
|
|
8
|
+
/** dist/ 디렉토리 경로 */
|
|
9
|
+
distDir: string;
|
|
10
|
+
/** basePath (예: "/my-app/") — 항상 /로 시작하고 /로 끝남 */
|
|
11
|
+
basePath: string;
|
|
12
|
+
/** listen 포트 (0: 자동 할당) */
|
|
13
|
+
port: number;
|
|
14
|
+
/** 정적 파일 서빙 전에 실행되는 요청 핸들러. true 반환 시 처리 완료 */
|
|
15
|
+
onRequest?: (req: http.IncomingMessage, res: http.ServerResponse) => boolean;
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
export interface DevHttpServer {
|
|
19
|
+
/** 서버 시작, 실제 할당된 포트 반환 */
|
|
20
|
+
listen(): Promise<number>;
|
|
21
|
+
/** 서버 종료 */
|
|
22
|
+
close(): Promise<void>;
|
|
23
|
+
/** 내부 http.Server 인스턴스 (Feature 2.2에서 WebSocket 연결용) */
|
|
24
|
+
readonly httpServer: http.Server;
|
|
25
|
+
/** listen 후 실제 포트 (listen 전에는 undefined) */
|
|
26
|
+
readonly port: number | undefined;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
export function createDevHttpServer(options: DevHttpServerOptions): DevHttpServer {
|
|
30
|
+
const { distDir, basePath, port: listenPort, onRequest } = options;
|
|
31
|
+
|
|
32
|
+
let actualPort: number | undefined;
|
|
33
|
+
|
|
34
|
+
/** stat → 스트리밍 응답. 성공 시 true, ENOENT/디렉토리 시 false, 기타 에러 시 throw */
|
|
35
|
+
async function serveFile(
|
|
36
|
+
filePath: string,
|
|
37
|
+
res: http.ServerResponse,
|
|
38
|
+
): Promise<boolean> {
|
|
39
|
+
try {
|
|
40
|
+
const stat = await fs.promises.stat(filePath);
|
|
41
|
+
if (stat.isDirectory()) return false;
|
|
42
|
+
|
|
43
|
+
const contentType = mime.getType(path.extname(filePath)) ?? "application/octet-stream";
|
|
44
|
+
res.writeHead(200, { "Content-Type": contentType, "Cache-Control": "no-cache" });
|
|
45
|
+
await pipeline(fs.createReadStream(filePath), res);
|
|
46
|
+
return true;
|
|
47
|
+
} catch (err) {
|
|
48
|
+
if (res.headersSent) {
|
|
49
|
+
if (!res.writableEnded) res.end();
|
|
50
|
+
return true;
|
|
51
|
+
}
|
|
52
|
+
if (isEnoent(err)) return false;
|
|
53
|
+
throw err;
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
async function serveStatic(
|
|
58
|
+
req: http.IncomingMessage,
|
|
59
|
+
res: http.ServerResponse,
|
|
60
|
+
): Promise<void> {
|
|
61
|
+
try {
|
|
62
|
+
const url = (req.url ?? "/").split("?")[0];
|
|
63
|
+
|
|
64
|
+
// basePath prefix 확인
|
|
65
|
+
if (!url.startsWith(basePath)) {
|
|
66
|
+
res.writeHead(404);
|
|
67
|
+
res.end("Not Found");
|
|
68
|
+
return;
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
let relativePath = url.slice(basePath.length);
|
|
72
|
+
|
|
73
|
+
// 빈 경로 또는 / → index.html
|
|
74
|
+
if (relativePath === "" || relativePath === "/") {
|
|
75
|
+
relativePath = "index.html";
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
// 선행 슬래시 제거
|
|
79
|
+
if (relativePath.startsWith("/")) {
|
|
80
|
+
relativePath = relativePath.slice(1);
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
const filePath = path.join(distDir, relativePath);
|
|
84
|
+
|
|
85
|
+
// 1. 요청 파일 서빙 시도
|
|
86
|
+
if (await serveFile(filePath, res)) return;
|
|
87
|
+
|
|
88
|
+
// 2. SPA fallback: index.html 서빙 시도
|
|
89
|
+
if (await serveFile(path.join(distDir, "index.html"), res)) return;
|
|
90
|
+
|
|
91
|
+
// 3. 둘 다 없으면 404
|
|
92
|
+
res.writeHead(404);
|
|
93
|
+
res.end("Not Found");
|
|
94
|
+
} catch {
|
|
95
|
+
if (!res.headersSent) {
|
|
96
|
+
res.writeHead(500);
|
|
97
|
+
res.end("Internal Server Error");
|
|
98
|
+
} else if (!res.writableEnded) {
|
|
99
|
+
res.end();
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
function isEnoent(err: unknown): boolean {
|
|
105
|
+
return err != null && typeof err === "object" && "code" in err && (err as { code: string }).code === "ENOENT";
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
const httpServer = http.createServer((req, res) => {
|
|
109
|
+
// onRequest 훅: 처리되면 정적 파일 서빙 건너뜀
|
|
110
|
+
if (onRequest != null && onRequest(req, res)) {
|
|
111
|
+
return;
|
|
112
|
+
}
|
|
113
|
+
void serveStatic(req, res);
|
|
114
|
+
});
|
|
115
|
+
|
|
116
|
+
return {
|
|
117
|
+
listen(): Promise<number> {
|
|
118
|
+
return new Promise<number>((resolve, reject) => {
|
|
119
|
+
httpServer.listen(listenPort, "0.0.0.0", () => {
|
|
120
|
+
const addr = httpServer.address();
|
|
121
|
+
if (typeof addr === "object" && addr != null) {
|
|
122
|
+
actualPort = addr.port;
|
|
123
|
+
resolve(addr.port);
|
|
124
|
+
} else {
|
|
125
|
+
reject(new Error("HTTP 서버 포트를 감지할 수 없습니다."));
|
|
126
|
+
}
|
|
127
|
+
});
|
|
128
|
+
httpServer.on("error", reject);
|
|
129
|
+
});
|
|
130
|
+
},
|
|
131
|
+
close(): Promise<void> {
|
|
132
|
+
return new Promise<void>((resolve, reject) => {
|
|
133
|
+
httpServer.close((err) => {
|
|
134
|
+
if (err != null) reject(err);
|
|
135
|
+
else {
|
|
136
|
+
actualPort = undefined;
|
|
137
|
+
resolve();
|
|
138
|
+
}
|
|
139
|
+
});
|
|
140
|
+
});
|
|
141
|
+
},
|
|
142
|
+
get httpServer() {
|
|
143
|
+
return httpServer;
|
|
144
|
+
},
|
|
145
|
+
get port() {
|
|
146
|
+
return actualPort;
|
|
147
|
+
},
|
|
148
|
+
};
|
|
149
|
+
}
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* HMR 클라이언트 스크립트를 생성한다.
|
|
3
|
+
* Chrome 61+ 호환 문법으로 작성 (optional chaining, nullish coalescing 미사용).
|
|
4
|
+
* @param basePath basePath (예: "/app/")
|
|
5
|
+
*/
|
|
6
|
+
export function getHmrClientScript(_basePath: string): string {
|
|
7
|
+
return [
|
|
8
|
+
"(function() {",
|
|
9
|
+
" var ws = null;",
|
|
10
|
+
" var reconnectDelay = 1000;",
|
|
11
|
+
"",
|
|
12
|
+
" function connect() {",
|
|
13
|
+
' ws = new WebSocket("ws://" + location.hostname + ":" + location.port);',
|
|
14
|
+
"",
|
|
15
|
+
" ws.onmessage = function(e) {",
|
|
16
|
+
" var msg = JSON.parse(e.data);",
|
|
17
|
+
"",
|
|
18
|
+
' if (msg.type === "component-update") {',
|
|
19
|
+
' if (typeof globalThis.__hmr_dispatch === "function") {',
|
|
20
|
+
" var ids = msg.ids;",
|
|
21
|
+
" for (var i = 0; i < ids.length; i++) {",
|
|
22
|
+
' globalThis.__hmr_dispatch("angular:component-update", {',
|
|
23
|
+
" id: ids[i],",
|
|
24
|
+
" timestamp: msg.timestamp",
|
|
25
|
+
" });",
|
|
26
|
+
" }",
|
|
27
|
+
" }",
|
|
28
|
+
"",
|
|
29
|
+
' } else if (msg.type === "css-update") {',
|
|
30
|
+
' var links = document.querySelectorAll(\'link[rel="stylesheet"]\');',
|
|
31
|
+
" var files = msg.files;",
|
|
32
|
+
" for (var j = 0; j < links.length; j++) {",
|
|
33
|
+
' var href = links[j].getAttribute("href");',
|
|
34
|
+
" if (href) {",
|
|
35
|
+
' var base = href.split("?")[0];',
|
|
36
|
+
' var fileName = base.substring(base.lastIndexOf("/") + 1);',
|
|
37
|
+
" if (files && files.indexOf(fileName) !== -1) {",
|
|
38
|
+
' links[j].setAttribute("href", base + "?t=" + msg.timestamp);',
|
|
39
|
+
" }",
|
|
40
|
+
" }",
|
|
41
|
+
" }",
|
|
42
|
+
"",
|
|
43
|
+
' } else if (msg.type === "full-reload") {',
|
|
44
|
+
" location.reload();",
|
|
45
|
+
" }",
|
|
46
|
+
" };",
|
|
47
|
+
"",
|
|
48
|
+
" ws.onclose = function() {",
|
|
49
|
+
" setTimeout(connect, reconnectDelay);",
|
|
50
|
+
" };",
|
|
51
|
+
" }",
|
|
52
|
+
"",
|
|
53
|
+
" connect();",
|
|
54
|
+
"})();",
|
|
55
|
+
].join("\n");
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
/**
|
|
59
|
+
* index.html에 HMR 클라이언트 스크립트를 주입하는 postTransform을 생성한다.
|
|
60
|
+
* Feature 1.2의 GenerateIndexHtmlOptions.postTransform에 전달하여 사용.
|
|
61
|
+
* @param basePath basePath (예: "/app/")
|
|
62
|
+
*/
|
|
63
|
+
export function createHmrPostTransform(basePath: string): (content: string) => Promise<string> {
|
|
64
|
+
const script = getHmrClientScript(basePath);
|
|
65
|
+
const scriptTag = `<script>${script}</script>`;
|
|
66
|
+
|
|
67
|
+
return (html: string): Promise<string> => {
|
|
68
|
+
const bodyCloseIdx = html.lastIndexOf("</body>");
|
|
69
|
+
if (bodyCloseIdx !== -1) {
|
|
70
|
+
return Promise.resolve(html.slice(0, bodyCloseIdx) + scriptTag + html.slice(bodyCloseIdx));
|
|
71
|
+
}
|
|
72
|
+
return Promise.resolve(html + scriptTag);
|
|
73
|
+
};
|
|
74
|
+
}
|
|
@@ -0,0 +1,178 @@
|
|
|
1
|
+
import type http from "node:http";
|
|
2
|
+
import type { IncomingMessage, ServerResponse } from "node:http";
|
|
3
|
+
import type esbuild from "esbuild";
|
|
4
|
+
import { WebSocketServer, type WebSocket } from "ws";
|
|
5
|
+
|
|
6
|
+
export interface HmrServiceOptions {
|
|
7
|
+
/** HTTP 서버 (WebSocket upgrade 연결용) */
|
|
8
|
+
httpServer: http.Server;
|
|
9
|
+
/** basePath (예: "/my-app/") — 항상 /로 시작하고 /로 끝남 */
|
|
10
|
+
basePath: string;
|
|
11
|
+
/** templateUpdates Map (createCompilerPlugin과 공유) */
|
|
12
|
+
templateUpdates: Map<string, string>;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
export interface HmrService {
|
|
16
|
+
/** 모든 연결된 WebSocket 클라이언트에 메시지를 전송한다 */
|
|
17
|
+
broadcast(message: Record<string, unknown>): void;
|
|
18
|
+
/** esbuild onEnd에서 호출: 변경 판별 + WS 메시지 디스패치 (100ms 디바운스) */
|
|
19
|
+
onBuildEnd(metafile: esbuild.Metafile): void;
|
|
20
|
+
/** HTTP 요청 핸들러 (/@ng/component 엔드포인트). true 반환 시 처리 완료 */
|
|
21
|
+
handleRequest(req: IncomingMessage, res: ServerResponse): boolean;
|
|
22
|
+
/** 리소스 정리 (WebSocket 서버 종료) */
|
|
23
|
+
close(): void;
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
export function createHmrService(options: HmrServiceOptions): HmrService {
|
|
27
|
+
const { httpServer, basePath, templateUpdates } = options;
|
|
28
|
+
const clients = new Set<WebSocket>();
|
|
29
|
+
|
|
30
|
+
const wss = new WebSocketServer({ server: httpServer });
|
|
31
|
+
|
|
32
|
+
wss.on("connection", (ws) => {
|
|
33
|
+
clients.add(ws);
|
|
34
|
+
ws.on("close", () => {
|
|
35
|
+
clients.delete(ws);
|
|
36
|
+
});
|
|
37
|
+
});
|
|
38
|
+
|
|
39
|
+
let prevOutputs: Map<string, number> | undefined;
|
|
40
|
+
let debounceTimer: ReturnType<typeof setTimeout> | undefined;
|
|
41
|
+
let pendingMetafile: esbuild.Metafile | undefined;
|
|
42
|
+
|
|
43
|
+
function onBuildEnd(metafile: esbuild.Metafile): void {
|
|
44
|
+
pendingMetafile = metafile;
|
|
45
|
+
if (debounceTimer != null) clearTimeout(debounceTimer);
|
|
46
|
+
debounceTimer = setTimeout(() => {
|
|
47
|
+
debounceTimer = undefined;
|
|
48
|
+
dispatchHmrMessage();
|
|
49
|
+
}, 100);
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
function collectOutputs(metafile: esbuild.Metafile): Map<string, number> {
|
|
53
|
+
const outputs = new Map<string, number>();
|
|
54
|
+
for (const [outputPath, output] of Object.entries(metafile.outputs)) {
|
|
55
|
+
const normalizedPath = outputPath.replace(/\\/g, "/");
|
|
56
|
+
if (normalizedPath.endsWith(".js") || normalizedPath.endsWith(".css")) {
|
|
57
|
+
outputs.set(normalizedPath, output.bytes);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
return outputs;
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
function dispatchHmrMessage(): void {
|
|
64
|
+
if (pendingMetafile == null) return;
|
|
65
|
+
const metafile = pendingMetafile;
|
|
66
|
+
pendingMetafile = undefined;
|
|
67
|
+
|
|
68
|
+
const timestamp = Date.now();
|
|
69
|
+
const currentOutputs = collectOutputs(metafile);
|
|
70
|
+
|
|
71
|
+
// 1. templateUpdates에 entry가 있으면 component-update
|
|
72
|
+
if (templateUpdates.size > 0) {
|
|
73
|
+
broadcast({
|
|
74
|
+
type: "component-update",
|
|
75
|
+
ids: [...templateUpdates.keys()],
|
|
76
|
+
timestamp,
|
|
77
|
+
});
|
|
78
|
+
prevOutputs = currentOutputs;
|
|
79
|
+
return;
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
// 2. 이전 빌드와 비교하여 JS/CSS 변경 판별
|
|
83
|
+
if (prevOutputs == null) {
|
|
84
|
+
// 첫 번째 빌드 → full-reload
|
|
85
|
+
prevOutputs = currentOutputs;
|
|
86
|
+
broadcast({ type: "full-reload" });
|
|
87
|
+
return;
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
let jsChanged = false;
|
|
91
|
+
let cssChanged = false;
|
|
92
|
+
const changedCssFiles: string[] = [];
|
|
93
|
+
|
|
94
|
+
for (const [path, bytes] of currentOutputs) {
|
|
95
|
+
const prevBytes = prevOutputs.get(path);
|
|
96
|
+
if (prevBytes !== bytes) {
|
|
97
|
+
if (path.endsWith(".css")) {
|
|
98
|
+
cssChanged = true;
|
|
99
|
+
changedCssFiles.push(path.split("/").pop() ?? path);
|
|
100
|
+
} else {
|
|
101
|
+
jsChanged = true;
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
// 삭제된 파일 체크
|
|
107
|
+
for (const [path] of prevOutputs) {
|
|
108
|
+
if (!currentOutputs.has(path)) {
|
|
109
|
+
if (path.endsWith(".css")) {
|
|
110
|
+
cssChanged = true;
|
|
111
|
+
} else {
|
|
112
|
+
jsChanged = true;
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
prevOutputs = currentOutputs;
|
|
118
|
+
|
|
119
|
+
// 3. JS 변경 없고 CSS만 변경 → css-update
|
|
120
|
+
if (!jsChanged && cssChanged && changedCssFiles.length > 0) {
|
|
121
|
+
broadcast({ type: "css-update", files: changedCssFiles, timestamp });
|
|
122
|
+
return;
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
// 4. JS 변경 또는 기타 → full-reload
|
|
126
|
+
broadcast({ type: "full-reload" });
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
function broadcast(message: Record<string, unknown>): void {
|
|
130
|
+
const data = JSON.stringify(message);
|
|
131
|
+
for (const ws of clients) {
|
|
132
|
+
if (ws.readyState === ws.OPEN) {
|
|
133
|
+
ws.send(data);
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
|
|
138
|
+
function handleRequest(req: IncomingMessage, res: ServerResponse): boolean {
|
|
139
|
+
const rawUrl = req.url ?? "";
|
|
140
|
+
const parsedUrl = new URL(rawUrl, "http://localhost");
|
|
141
|
+
const pathname = decodeURIComponent(parsedUrl.pathname);
|
|
142
|
+
|
|
143
|
+
// basePath 제거 후 /@ng/component 확인
|
|
144
|
+
let strippedPathname: string;
|
|
145
|
+
if (basePath !== "/" && pathname.startsWith(basePath)) {
|
|
146
|
+
strippedPathname = pathname.slice(basePath.length - 1);
|
|
147
|
+
} else if (basePath === "/") {
|
|
148
|
+
strippedPathname = pathname;
|
|
149
|
+
} else {
|
|
150
|
+
return false;
|
|
151
|
+
}
|
|
152
|
+
|
|
153
|
+
if (!strippedPathname.startsWith("/@ng/component")) {
|
|
154
|
+
return false;
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
const componentId = parsedUrl.searchParams.get("c") ?? "";
|
|
158
|
+
const body = templateUpdates.get(componentId) ?? "";
|
|
159
|
+
|
|
160
|
+
res.writeHead(200, {
|
|
161
|
+
"Content-Type": "text/javascript",
|
|
162
|
+
"Cache-Control": "no-cache",
|
|
163
|
+
});
|
|
164
|
+
res.end(body);
|
|
165
|
+
return true;
|
|
166
|
+
}
|
|
167
|
+
|
|
168
|
+
function close(): void {
|
|
169
|
+
if (debounceTimer != null) clearTimeout(debounceTimer);
|
|
170
|
+
for (const ws of clients) {
|
|
171
|
+
ws.close();
|
|
172
|
+
}
|
|
173
|
+
clients.clear();
|
|
174
|
+
wss.close();
|
|
175
|
+
}
|
|
176
|
+
|
|
177
|
+
return { broadcast, onBuildEnd, handleRequest, close };
|
|
178
|
+
}
|