@nativescript/vite 8.0.0-alpha.3 → 8.0.0-alpha.31
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +51 -11
- package/configuration/angular.d.ts +34 -1
- package/configuration/angular.js +373 -163
- package/configuration/angular.js.map +1 -1
- package/configuration/base.js +184 -14
- package/configuration/base.js.map +1 -1
- package/configuration/javascript.js +5 -72
- package/configuration/javascript.js.map +1 -1
- package/configuration/solid.js +27 -1
- package/configuration/solid.js.map +1 -1
- package/configuration/typescript.js +5 -75
- package/configuration/typescript.js.map +1 -1
- package/helpers/app-components.d.ts +2 -1
- package/helpers/app-components.js.map +1 -1
- package/helpers/app-css-state.d.ts +8 -0
- package/helpers/app-css-state.js +8 -0
- package/helpers/app-css-state.js.map +1 -0
- package/helpers/bundler-context.d.ts +11 -0
- package/helpers/bundler-context.js +71 -0
- package/helpers/bundler-context.js.map +1 -0
- package/helpers/config-as-json.js +10 -0
- package/helpers/config-as-json.js.map +1 -1
- package/helpers/dev-host.d.ts +341 -0
- package/helpers/dev-host.js +617 -0
- package/helpers/dev-host.js.map +1 -0
- package/helpers/esbuild-platform-resolver.js +4 -1
- package/helpers/esbuild-platform-resolver.js.map +1 -1
- package/helpers/global-defines.d.ts +51 -0
- package/helpers/global-defines.js +77 -0
- package/helpers/global-defines.js.map +1 -1
- package/helpers/hmr-scope.d.ts +26 -0
- package/helpers/hmr-scope.js +67 -0
- package/helpers/hmr-scope.js.map +1 -0
- package/helpers/init.js +0 -18
- package/helpers/init.js.map +1 -1
- package/helpers/logging.d.ts +1 -0
- package/helpers/logging.js +63 -3
- package/helpers/logging.js.map +1 -1
- package/helpers/main-entry.d.ts +2 -1
- package/helpers/main-entry.js +430 -47
- package/helpers/main-entry.js.map +1 -1
- package/helpers/nativeclass-esbuild-plugin.d.ts +2 -1
- package/helpers/nativeclass-esbuild-plugin.js.map +1 -1
- package/helpers/nativeclass-transform.js.map +1 -1
- package/helpers/nativeclass-transformer-plugin.d.ts +9 -2
- package/helpers/nativeclass-transformer-plugin.js +157 -14
- package/helpers/nativeclass-transformer-plugin.js.map +1 -1
- package/helpers/nativescript-package-resolver.js +8 -3
- package/helpers/nativescript-package-resolver.js.map +1 -1
- package/helpers/normalize-id.d.ts +42 -0
- package/helpers/normalize-id.js +60 -0
- package/helpers/normalize-id.js.map +1 -0
- package/helpers/ns-core-url.d.ts +88 -0
- package/helpers/ns-core-url.js +191 -0
- package/helpers/ns-core-url.js.map +1 -0
- package/helpers/package-platform-aliases.js +4 -3
- package/helpers/package-platform-aliases.js.map +1 -1
- package/helpers/platform-types.d.ts +2 -0
- package/helpers/platform-types.js +2 -0
- package/helpers/platform-types.js.map +1 -0
- package/helpers/project.d.ts +35 -0
- package/helpers/project.js +120 -2
- package/helpers/project.js.map +1 -1
- package/helpers/resolver.js +17 -2
- package/helpers/resolver.js.map +1 -1
- package/helpers/ts-config-paths.d.ts +14 -0
- package/helpers/ts-config-paths.js +89 -8
- package/helpers/ts-config-paths.js.map +1 -1
- package/helpers/typescript-check.d.ts +2 -1
- package/helpers/typescript-check.js.map +1 -1
- package/helpers/workers.d.ts +20 -19
- package/helpers/workers.js +624 -4
- package/helpers/workers.js.map +1 -1
- package/hmr/client/css-handler.d.ts +1 -0
- package/hmr/client/css-handler.js +33 -20
- package/hmr/client/css-handler.js.map +1 -1
- package/hmr/client/css-update-overlay.d.ts +18 -0
- package/hmr/client/css-update-overlay.js +27 -0
- package/hmr/client/css-update-overlay.js.map +1 -0
- package/hmr/client/framework-client-strategy.d.ts +73 -0
- package/hmr/client/framework-client-strategy.js +19 -0
- package/hmr/client/framework-client-strategy.js.map +1 -0
- package/hmr/client/hmr-pending-overlay.d.ts +27 -0
- package/hmr/client/hmr-pending-overlay.js +50 -0
- package/hmr/client/hmr-pending-overlay.js.map +1 -0
- package/hmr/client/index.js +459 -164
- package/hmr/client/index.js.map +1 -1
- package/hmr/client/utils.d.ts +6 -1
- package/hmr/client/utils.js +184 -8
- package/hmr/client/utils.js.map +1 -1
- package/hmr/entry-runtime.d.ts +2 -1
- package/hmr/entry-runtime.js +252 -65
- package/hmr/entry-runtime.js.map +1 -1
- package/hmr/frameworks/angular/build/angular-linker.d.ts +12 -0
- package/hmr/frameworks/angular/build/angular-linker.js +109 -0
- package/hmr/frameworks/angular/build/angular-linker.js.map +1 -0
- package/hmr/frameworks/angular/build/inject-component-hmr-registration.d.ts +112 -0
- package/hmr/frameworks/angular/build/inject-component-hmr-registration.js +291 -0
- package/hmr/frameworks/angular/build/inject-component-hmr-registration.js.map +1 -0
- package/hmr/frameworks/angular/build/inject-hmr-vite-ignore.d.ts +75 -0
- package/hmr/frameworks/angular/build/inject-hmr-vite-ignore.js +221 -0
- package/hmr/frameworks/angular/build/inject-hmr-vite-ignore.js.map +1 -0
- package/{helpers/angular → hmr/frameworks/angular/build}/inline-decorator-component-templates.js +1 -170
- package/hmr/frameworks/angular/build/inline-decorator-component-templates.js.map +1 -0
- package/hmr/frameworks/angular/build/js-lexer.d.ts +4 -0
- package/{helpers/angular/synthesize-decorator-ctor-parameters.js → hmr/frameworks/angular/build/js-lexer.js} +22 -96
- package/hmr/frameworks/angular/build/js-lexer.js.map +1 -0
- package/hmr/frameworks/angular/build/shared-linker.d.ts +39 -0
- package/hmr/frameworks/angular/build/shared-linker.js +128 -0
- package/hmr/frameworks/angular/build/shared-linker.js.map +1 -0
- package/hmr/frameworks/angular/build/synthesize-decorator-ctor-parameters.js +88 -0
- package/hmr/frameworks/angular/build/synthesize-decorator-ctor-parameters.js.map +1 -0
- package/{helpers/angular → hmr/frameworks/angular/build}/synthesize-injectable-factories.js +1 -174
- package/hmr/frameworks/angular/build/synthesize-injectable-factories.js.map +1 -0
- package/{helpers/angular → hmr/frameworks/angular/build}/util.d.ts +1 -0
- package/hmr/frameworks/angular/build/util.js +155 -0
- package/hmr/frameworks/angular/build/util.js.map +1 -0
- package/hmr/frameworks/angular/client/index.d.ts +1 -0
- package/hmr/frameworks/angular/client/index.js +778 -20
- package/hmr/frameworks/angular/client/index.js.map +1 -1
- package/hmr/frameworks/angular/client/strategy.d.ts +9 -0
- package/hmr/frameworks/angular/client/strategy.js +19 -0
- package/hmr/frameworks/angular/client/strategy.js.map +1 -0
- package/hmr/frameworks/angular/server/angular-root-component.d.ts +79 -0
- package/hmr/frameworks/angular/server/angular-root-component.js +149 -0
- package/hmr/frameworks/angular/server/angular-root-component.js.map +1 -0
- package/hmr/frameworks/angular/server/linker.js +1 -4
- package/hmr/frameworks/angular/server/linker.js.map +1 -1
- package/hmr/frameworks/angular/server/strategy.js +448 -12
- package/hmr/frameworks/angular/server/strategy.js.map +1 -1
- package/hmr/{server → frameworks/angular/server}/websocket-angular-entry.js +2 -2
- package/hmr/frameworks/angular/server/websocket-angular-entry.js.map +1 -0
- package/hmr/{server → frameworks/angular/server}/websocket-angular-hot-update.d.ts +17 -11
- package/hmr/frameworks/angular/server/websocket-angular-hot-update.js +336 -0
- package/hmr/frameworks/angular/server/websocket-angular-hot-update.js.map +1 -0
- package/hmr/frameworks/solid/build/solid-jsx-deps.d.ts +15 -0
- package/hmr/frameworks/solid/build/solid-jsx-deps.js +178 -0
- package/hmr/frameworks/solid/build/solid-jsx-deps.js.map +1 -0
- package/hmr/frameworks/solid/server/strategy.js +360 -16
- package/hmr/frameworks/solid/server/strategy.js.map +1 -1
- package/hmr/frameworks/typescript/server/strategy.js +28 -14
- package/hmr/frameworks/typescript/server/strategy.js.map +1 -1
- package/hmr/frameworks/vue/client/index.js +30 -199
- package/hmr/frameworks/vue/client/index.js.map +1 -1
- package/hmr/frameworks/vue/client/strategy.d.ts +7 -0
- package/hmr/frameworks/vue/client/strategy.js +83 -0
- package/hmr/frameworks/vue/client/strategy.js.map +1 -0
- package/hmr/frameworks/vue/client/vue-sfc-update-overlay.d.ts +82 -0
- package/hmr/frameworks/vue/client/vue-sfc-update-overlay.js +133 -0
- package/hmr/frameworks/vue/client/vue-sfc-update-overlay.js.map +1 -0
- package/hmr/frameworks/vue/server/sfc-route-assemble.d.ts +7 -0
- package/hmr/frameworks/vue/server/sfc-route-assemble.js +706 -0
- package/hmr/frameworks/vue/server/sfc-route-assemble.js.map +1 -0
- package/hmr/frameworks/vue/server/sfc-route-meta.d.ts +7 -0
- package/hmr/frameworks/vue/server/sfc-route-meta.js +80 -0
- package/hmr/frameworks/vue/server/sfc-route-meta.js.map +1 -0
- package/hmr/frameworks/vue/server/sfc-route-serve.d.ts +8 -0
- package/hmr/frameworks/vue/server/sfc-route-serve.js +457 -0
- package/hmr/frameworks/vue/server/sfc-route-serve.js.map +1 -0
- package/hmr/frameworks/vue/server/sfc-route-shared.d.ts +19 -0
- package/hmr/frameworks/vue/server/sfc-route-shared.js +14 -0
- package/hmr/frameworks/vue/server/sfc-route-shared.js.map +1 -0
- package/hmr/frameworks/vue/server/strategy.js +244 -0
- package/hmr/frameworks/vue/server/strategy.js.map +1 -1
- package/hmr/frameworks/vue/server/websocket-sfc.d.ts +15 -0
- package/hmr/frameworks/vue/server/websocket-sfc.js +20 -0
- package/hmr/frameworks/vue/server/websocket-sfc.js.map +1 -0
- package/hmr/helpers/ast-normalizer.js +52 -5
- package/hmr/helpers/ast-normalizer.js.map +1 -1
- package/hmr/helpers/cjs-named-exports.d.ts +23 -0
- package/hmr/helpers/cjs-named-exports.js +152 -0
- package/hmr/helpers/cjs-named-exports.js.map +1 -0
- package/hmr/helpers/package-exports.d.ts +16 -0
- package/hmr/helpers/package-exports.js +396 -0
- package/hmr/helpers/package-exports.js.map +1 -0
- package/hmr/server/constants.js +13 -4
- package/hmr/server/constants.js.map +1 -1
- package/hmr/server/core-sanitize.d.ts +90 -7
- package/hmr/server/core-sanitize.js +211 -56
- package/hmr/server/core-sanitize.js.map +1 -1
- package/hmr/server/device-transform-helpers.d.ts +24 -0
- package/hmr/server/device-transform-helpers.js +327 -0
- package/hmr/server/device-transform-helpers.js.map +1 -0
- package/hmr/server/framework-strategy.d.ts +95 -11
- package/hmr/server/hmr-module-graph.d.ts +37 -0
- package/hmr/server/hmr-module-graph.js +214 -0
- package/hmr/server/hmr-module-graph.js.map +1 -0
- package/hmr/server/import-map.d.ts +11 -2
- package/hmr/server/import-map.js +59 -40
- package/hmr/server/import-map.js.map +1 -1
- package/hmr/server/index.js +7 -16
- package/hmr/server/index.js.map +1 -1
- package/hmr/server/ns-core-cjs-shape.d.ts +204 -0
- package/hmr/server/ns-core-cjs-shape.js +271 -0
- package/hmr/server/ns-core-cjs-shape.js.map +1 -0
- package/hmr/server/ns-rt-bridge.d.ts +51 -0
- package/hmr/server/ns-rt-bridge.js +131 -0
- package/hmr/server/ns-rt-bridge.js.map +1 -0
- package/hmr/server/ns-rt-route.d.ts +5 -0
- package/hmr/server/ns-rt-route.js +35 -0
- package/hmr/server/ns-rt-route.js.map +1 -0
- package/hmr/server/perf-instrumentation.d.ts +114 -0
- package/hmr/server/perf-instrumentation.js +195 -0
- package/hmr/server/perf-instrumentation.js.map +1 -0
- package/hmr/server/process-code-for-device.d.ts +15 -0
- package/hmr/server/process-code-for-device.js +654 -0
- package/hmr/server/process-code-for-device.js.map +1 -0
- package/hmr/server/require-guard.d.ts +1 -0
- package/hmr/server/require-guard.js +12 -0
- package/hmr/server/require-guard.js.map +1 -0
- package/hmr/server/rewrite-imports.d.ts +2 -0
- package/hmr/server/rewrite-imports.js +604 -0
- package/hmr/server/rewrite-imports.js.map +1 -0
- package/hmr/server/route-helpers.d.ts +7 -0
- package/hmr/server/route-helpers.js +13 -0
- package/hmr/server/route-helpers.js.map +1 -0
- package/hmr/server/server-origin.d.ts +12 -0
- package/hmr/server/server-origin.js +66 -0
- package/hmr/server/server-origin.js.map +1 -0
- package/hmr/server/shared-transform-request.js +12 -5
- package/hmr/server/shared-transform-request.js.map +1 -1
- package/hmr/server/transform-cache-invalidation.d.ts +11 -0
- package/hmr/server/transform-cache-invalidation.js +84 -0
- package/hmr/server/transform-cache-invalidation.js.map +1 -0
- package/hmr/server/vendor-bare-module-shims.d.ts +4 -0
- package/hmr/server/vendor-bare-module-shims.js +80 -0
- package/hmr/server/vendor-bare-module-shims.js.map +1 -0
- package/hmr/server/vite-plugin.js +60 -42
- package/hmr/server/vite-plugin.js.map +1 -1
- package/hmr/server/websocket-core-bridge.d.ts +41 -6
- package/hmr/server/websocket-core-bridge.js +72 -75
- package/hmr/server/websocket-core-bridge.js.map +1 -1
- package/hmr/server/websocket-css-hot-update.d.ts +33 -0
- package/hmr/server/websocket-css-hot-update.js +65 -0
- package/hmr/server/websocket-css-hot-update.js.map +1 -0
- package/hmr/server/websocket-device-transform.d.ts +3 -0
- package/hmr/server/websocket-device-transform.js +7 -0
- package/hmr/server/websocket-device-transform.js.map +1 -0
- package/hmr/server/websocket-graph-upsert.d.ts +15 -0
- package/hmr/server/websocket-graph-upsert.js +20 -0
- package/hmr/server/websocket-graph-upsert.js.map +1 -1
- package/hmr/server/websocket-hmr-pending.d.ts +37 -0
- package/hmr/server/websocket-hmr-pending.js +55 -0
- package/hmr/server/websocket-hmr-pending.js.map +1 -0
- package/hmr/server/websocket-hot-update.d.ts +77 -0
- package/hmr/server/websocket-hot-update.js +330 -0
- package/hmr/server/websocket-hot-update.js.map +1 -0
- package/hmr/server/websocket-import-map-route.d.ts +15 -0
- package/hmr/server/websocket-import-map-route.js +46 -0
- package/hmr/server/websocket-import-map-route.js.map +1 -0
- package/hmr/server/websocket-module-bindings.js +3 -3
- package/hmr/server/websocket-module-bindings.js.map +1 -1
- package/hmr/server/websocket-module-specifiers.d.ts +66 -2
- package/hmr/server/websocket-module-specifiers.js +202 -19
- package/hmr/server/websocket-module-specifiers.js.map +1 -1
- package/hmr/server/websocket-ns-core.d.ts +21 -0
- package/hmr/server/websocket-ns-core.js +306 -0
- package/hmr/server/websocket-ns-core.js.map +1 -0
- package/hmr/server/websocket-ns-entry.d.ts +21 -0
- package/hmr/server/websocket-ns-entry.js +150 -0
- package/hmr/server/websocket-ns-entry.js.map +1 -0
- package/hmr/server/websocket-ns-m-paths.d.ts +3 -0
- package/hmr/server/websocket-ns-m-paths.js +92 -0
- package/hmr/server/websocket-ns-m-paths.js.map +1 -0
- package/hmr/server/websocket-ns-m-request.d.ts +45 -0
- package/hmr/server/websocket-ns-m-request.js +196 -0
- package/hmr/server/websocket-ns-m-request.js.map +1 -0
- package/hmr/server/websocket-ns-m.d.ts +33 -0
- package/hmr/server/websocket-ns-m.js +748 -0
- package/hmr/server/websocket-ns-m.js.map +1 -0
- package/hmr/server/websocket-served-module-helpers.d.ts +39 -0
- package/hmr/server/websocket-served-module-helpers.js +654 -0
- package/hmr/server/websocket-served-module-helpers.js.map +1 -0
- package/hmr/server/websocket-txn.d.ts +6 -0
- package/hmr/server/websocket-txn.js +39 -0
- package/hmr/server/websocket-txn.js.map +1 -0
- package/hmr/server/websocket-vendor-unifier.d.ts +9 -0
- package/hmr/server/websocket-vendor-unifier.js +46 -0
- package/hmr/server/websocket-vendor-unifier.js.map +1 -0
- package/hmr/server/websocket.d.ts +8 -39
- package/hmr/server/websocket.js +602 -6049
- package/hmr/server/websocket.js.map +1 -1
- package/hmr/shared/ns-globals.d.ts +118 -0
- package/hmr/shared/ns-globals.js +27 -0
- package/hmr/shared/ns-globals.js.map +1 -0
- package/hmr/shared/protocol.d.ts +136 -0
- package/hmr/shared/protocol.js +28 -0
- package/hmr/shared/protocol.js.map +1 -0
- package/hmr/shared/runtime/boot-placeholder-ui.d.ts +69 -0
- package/hmr/shared/runtime/boot-placeholder-ui.js +101 -0
- package/hmr/shared/runtime/boot-placeholder-ui.js.map +1 -0
- package/hmr/shared/runtime/boot-progress.d.ts +40 -0
- package/hmr/shared/runtime/boot-progress.js +128 -0
- package/hmr/shared/runtime/boot-progress.js.map +1 -0
- package/hmr/shared/runtime/boot-timeline.d.ts +18 -0
- package/hmr/shared/runtime/boot-timeline.js +52 -0
- package/hmr/shared/runtime/boot-timeline.js.map +1 -0
- package/hmr/shared/runtime/dev-overlay-snapshots.d.ts +31 -0
- package/hmr/shared/runtime/dev-overlay-snapshots.js +324 -0
- package/hmr/shared/runtime/dev-overlay-snapshots.js.map +1 -0
- package/hmr/shared/runtime/dev-overlay.d.ts +75 -26
- package/hmr/shared/runtime/dev-overlay.js +990 -260
- package/hmr/shared/runtime/dev-overlay.js.map +1 -1
- package/hmr/shared/runtime/module-provenance.js +1 -4
- package/hmr/shared/runtime/module-provenance.js.map +1 -1
- package/hmr/shared/runtime/root-placeholder-view.d.ts +19 -0
- package/hmr/shared/runtime/root-placeholder-view.js +310 -0
- package/hmr/shared/runtime/root-placeholder-view.js.map +1 -0
- package/hmr/shared/runtime/root-placeholder.js +352 -194
- package/hmr/shared/runtime/root-placeholder.js.map +1 -1
- package/hmr/shared/runtime/session-bootstrap.js +164 -1
- package/hmr/shared/runtime/session-bootstrap.js.map +1 -1
- package/hmr/shared/runtime/vendor-bootstrap.js +1 -9
- package/hmr/shared/runtime/vendor-bootstrap.js.map +1 -1
- package/hmr/shared/vendor/manifest-collect.d.ts +4 -0
- package/hmr/shared/vendor/manifest-collect.js +512 -0
- package/hmr/shared/vendor/manifest-collect.js.map +1 -0
- package/hmr/shared/vendor/manifest-loader.d.ts +2 -1
- package/hmr/shared/vendor/manifest-loader.js +3 -2
- package/hmr/shared/vendor/manifest-loader.js.map +1 -1
- package/hmr/shared/vendor/manifest.d.ts +1 -7
- package/hmr/shared/vendor/manifest.js +102 -741
- package/hmr/shared/vendor/manifest.js.map +1 -1
- package/hmr/shared/vendor/vendor-device-shim.d.ts +1 -0
- package/hmr/shared/vendor/vendor-device-shim.js +208 -0
- package/hmr/shared/vendor/vendor-device-shim.js.map +1 -0
- package/hmr/shared/vendor/vendor-esbuild-plugins.d.ts +16 -0
- package/hmr/shared/vendor/vendor-esbuild-plugins.js +203 -0
- package/hmr/shared/vendor/vendor-esbuild-plugins.js.map +1 -0
- package/index.d.ts +1 -0
- package/index.js +5 -0
- package/index.js.map +1 -1
- package/package.json +55 -11
- package/runtime/core-aliases-early.js +17 -41
- package/runtime/core-aliases-early.js.map +1 -1
- package/helpers/angular/angular-linker.d.ts +0 -13
- package/helpers/angular/angular-linker.js +0 -194
- package/helpers/angular/angular-linker.js.map +0 -1
- package/helpers/angular/inline-decorator-component-templates.js.map +0 -1
- package/helpers/angular/shared-linker.d.ts +0 -11
- package/helpers/angular/shared-linker.js +0 -75
- package/helpers/angular/shared-linker.js.map +0 -1
- package/helpers/angular/synthesize-decorator-ctor-parameters.js.map +0 -1
- package/helpers/angular/synthesize-injectable-factories.js.map +0 -1
- package/helpers/angular/util.js +0 -67
- package/helpers/angular/util.js.map +0 -1
- package/helpers/prelink-angular.d.ts +0 -2
- package/helpers/prelink-angular.js +0 -117
- package/helpers/prelink-angular.js.map +0 -1
- package/hmr/server/websocket-angular-entry.js.map +0 -1
- package/hmr/server/websocket-angular-hot-update.js +0 -239
- package/hmr/server/websocket-angular-hot-update.js.map +0 -1
- /package/{helpers/angular → hmr/frameworks/angular/build}/inline-decorator-component-templates.d.ts +0 -0
- /package/{helpers/angular → hmr/frameworks/angular/build}/synthesize-decorator-ctor-parameters.d.ts +0 -0
- /package/{helpers/angular → hmr/frameworks/angular/build}/synthesize-injectable-factories.d.ts +0 -0
- /package/hmr/{server → frameworks/angular/server}/websocket-angular-entry.d.ts +0 -0
|
@@ -0,0 +1,748 @@
|
|
|
1
|
+
import * as path from 'path';
|
|
2
|
+
import { parse as babelParse } from '@babel/parser';
|
|
3
|
+
import traverse from '@babel/traverse';
|
|
4
|
+
import { sanitizeStrayCoreReferences } from './core-sanitize.js';
|
|
5
|
+
import { getMonorepoWorkspaceRoot } from '../../helpers/project.js';
|
|
6
|
+
import { isRuntimeGraphExcludedPath } from './runtime-graph-filter.js';
|
|
7
|
+
import { buildPiniaVendorShim, buildVueVendorShim } from './vendor-bare-module-shims.js';
|
|
8
|
+
import { getNumericServeVersionTag, rewriteNsMImportPathForHmr } from './websocket-ns-m-paths.js';
|
|
9
|
+
import { setDeviceModuleHeaders } from './route-helpers.js';
|
|
10
|
+
import { filterExistingNodeModulesTransformCandidates, getBlockedDeviceNodeModulesReason, resolveCandidateFilePath, stripDecoratedServePrefixes, tryReadRawExplicitJavaScriptModule } from './websocket-module-specifiers.js';
|
|
11
|
+
import { assertNoOptimizedArtifacts, buildBootProgressSnippet, dedupeRtNamedImportsAgainstDestructures, deduplicateLinkerImports, ensureDestructureCoreImports, ensureGuardPlainDynamicImports, ensureVariableDynamicImportHelper, ensureVersionedRtImports, expandStarExports, hoistTopLevelStaticImports, MODULE_IMPORT_ANALYSIS_PLUGINS, wrapCommonJsModuleForDevice } from './websocket-served-module-helpers.js';
|
|
12
|
+
import { cleanCode, collectImportDependencies, processCodeForDevice, rewriteImports } from './websocket-device-transform.js';
|
|
13
|
+
import { REQUIRE_GUARD_SNIPPET } from './require-guard.js';
|
|
14
|
+
import { getServerOrigin } from './server-origin.js';
|
|
15
|
+
const babelTraverse = traverse?.default || traverse;
|
|
16
|
+
/**
|
|
17
|
+
* Registers the `/ns/m/*` device module server: the HTTP endpoint every
|
|
18
|
+
* NativeScript device uses to fetch app/source modules (and AnalogJS Angular
|
|
19
|
+
* `/@ng/component` live-reload requests) as device-ready ESM. This is the
|
|
20
|
+
* single hottest route in the HMR server.
|
|
21
|
+
*/
|
|
22
|
+
export function registerNsModuleServerRoute(server, options) {
|
|
23
|
+
server.middlewares.use(async (req, res, next) => {
|
|
24
|
+
try {
|
|
25
|
+
const urlObj = new URL(req.url || '', 'http://localhost');
|
|
26
|
+
if (!urlObj.pathname.startsWith('/ns/m'))
|
|
27
|
+
return next();
|
|
28
|
+
// Closure deps injected by createHmrWebSocketPlugin (see websocket.ts).
|
|
29
|
+
const verbose = options.verbose;
|
|
30
|
+
const APP_VIRTUAL_WITH_SLASH = options.appVirtualWithSlash;
|
|
31
|
+
const sfcFileMap = options.sfcFileMap;
|
|
32
|
+
const depFileMap = options.depFileMap;
|
|
33
|
+
const sharedTransformRequest = options.sharedTransformRequest;
|
|
34
|
+
const ensureInitialGraphPopulationStarted = options.ensureInitialGraphPopulationStarted;
|
|
35
|
+
const strategy = options.getStrategy();
|
|
36
|
+
// Delegate AnalogJS Angular component live-reload endpoints.
|
|
37
|
+
//
|
|
38
|
+
// Angular 21's `ɵɵgetReplaceMetadataURL` (in @angular/core
|
|
39
|
+
// _debug_node-chunk.mjs) builds the metadata-replacement URL as
|
|
40
|
+
// `new URL('./@ng/component?c=<id>&t=<ts>', import.meta.url).href`.
|
|
41
|
+
// Because `import.meta.url` for a NS-served module is
|
|
42
|
+
// `http://host:port/ns/m/<project-relative>/component.ts`, the
|
|
43
|
+
// resolved metadata URL ends up *nested* under the component's
|
|
44
|
+
// directory: `/ns/m/<dir>/@ng/component?c=...&t=...`.
|
|
45
|
+
//
|
|
46
|
+
// AnalogJS's `liveReloadPlugin` registers a middleware that matches
|
|
47
|
+
// `/@ng/component` anywhere in `req.url` and returns either an empty
|
|
48
|
+
// module body (no HMR update available) or the metadata-replacement
|
|
49
|
+
// code (after a save invalidates the file). Without this delegation
|
|
50
|
+
// the NS `/ns/m/` middleware would treat the path as a file lookup,
|
|
51
|
+
// fail to resolve `@ng/component` against disk, and respond with
|
|
52
|
+
// 404 — which surfaces as `HTTP fetch/compile failed` at the
|
|
53
|
+
// component's own `_HmrLoad(Date.now())` call on initial boot and
|
|
54
|
+
// blocks Angular component bootstrapping.
|
|
55
|
+
//
|
|
56
|
+
// Calling `next()` here lets AnalogJS's middleware (or any other
|
|
57
|
+
// middleware later in the chain) handle the request. Analog's
|
|
58
|
+
// middleware reads only the `?c=` query string and is pathname-
|
|
59
|
+
// agnostic, so we don't need to rewrite `req.url` for it to work.
|
|
60
|
+
//
|
|
61
|
+
// HOWEVER: AnalogJS responds with an EMPTY body (`res.end('')`)
|
|
62
|
+
// for non-invalidated component IDs (initial boot, before any
|
|
63
|
+
// file save). The iOS HTTP ESM loader's
|
|
64
|
+
// `LoadHttpModuleForUrl` (ModuleInternalCallbacks.mm) treats an
|
|
65
|
+
// empty body as a fetch failure (`body.empty() → reject`), even
|
|
66
|
+
// when the HTTP status is 200 OK. That bubbles up as
|
|
67
|
+
// `HTTP fetch/compile failed` at the device's `__ns_import(...)`
|
|
68
|
+
// inside each component's `_HmrLoad(Date.now())` and crashes
|
|
69
|
+
// Angular's component bootstrap. To make Analog's empty
|
|
70
|
+
// "no-update" response acceptable to the iOS loader, we wrap
|
|
71
|
+
// `res.write` / `res.end` and substitute a minimal valid ESM
|
|
72
|
+
// module body (`export {}`) when downstream writes nothing.
|
|
73
|
+
// Non-empty bodies (real HMR update payloads after a save)
|
|
74
|
+
// pass through unchanged.
|
|
75
|
+
if (urlObj.pathname.includes('/@ng/component')) {
|
|
76
|
+
const chunks = [];
|
|
77
|
+
const origEnd = res.end.bind(res);
|
|
78
|
+
let ended = false;
|
|
79
|
+
const captureChunk = (chunk) => {
|
|
80
|
+
if (chunk == null)
|
|
81
|
+
return;
|
|
82
|
+
if (typeof chunk === 'string') {
|
|
83
|
+
chunks.push(chunk);
|
|
84
|
+
}
|
|
85
|
+
else if (Buffer.isBuffer(chunk)) {
|
|
86
|
+
chunks.push(chunk.toString('utf8'));
|
|
87
|
+
}
|
|
88
|
+
else {
|
|
89
|
+
chunks.push(String(chunk));
|
|
90
|
+
}
|
|
91
|
+
};
|
|
92
|
+
res.write = function (chunk, ..._args) {
|
|
93
|
+
captureChunk(chunk);
|
|
94
|
+
return true;
|
|
95
|
+
};
|
|
96
|
+
res.end = function (chunk, ..._args) {
|
|
97
|
+
if (ended)
|
|
98
|
+
return true;
|
|
99
|
+
ended = true;
|
|
100
|
+
captureChunk(chunk);
|
|
101
|
+
let body = chunks.join('');
|
|
102
|
+
if (body.length === 0) {
|
|
103
|
+
body = '// [ns:m] empty Angular component metadata — substituted with valid empty module to satisfy iOS HTTP loader (rejects empty bodies)\nexport {};\n';
|
|
104
|
+
}
|
|
105
|
+
try {
|
|
106
|
+
res.setHeader('Content-Length', Buffer.byteLength(body, 'utf8'));
|
|
107
|
+
}
|
|
108
|
+
catch { }
|
|
109
|
+
return origEnd(body);
|
|
110
|
+
};
|
|
111
|
+
return next();
|
|
112
|
+
}
|
|
113
|
+
// Previously we awaited `populateInitialGraph(server)` here so
|
|
114
|
+
// graphVersion would be non-zero for the first /ns/m request.
|
|
115
|
+
// That gave deterministic URL tags but blocked the cold boot on a
|
|
116
|
+
// full src/ tree walk (hundreds of transformRequest calls, 3-6s).
|
|
117
|
+
//
|
|
118
|
+
// graphVersion now starts at 1 and stays stable during cold boot
|
|
119
|
+
// (see `upsertGraphModule`'s bumpVersion option and the inline
|
|
120
|
+
// comment at the graphVersion declaration). We kick off the
|
|
121
|
+
// initial population in the background so it doesn't block the
|
|
122
|
+
// first response. `handleHotUpdate` awaits the same promise so
|
|
123
|
+
// the first HMR event still sees a fully populated graph.
|
|
124
|
+
ensureInitialGraphPopulationStarted(server);
|
|
125
|
+
// Cold-boot counter is now hooked via the leading boot-trace
|
|
126
|
+
// middleware (see `configureServer` — it records the request
|
|
127
|
+
// and tracks finish() via res.on('close'/'finish')). This
|
|
128
|
+
// handler used to record here but that missed the
|
|
129
|
+
// round-trip timing and didn't track per-route breakdowns.
|
|
130
|
+
setDeviceModuleHeaders(res);
|
|
131
|
+
// Support both query (?path=/abs) and path-style (/ns/m/abs)
|
|
132
|
+
let spec = urlObj.searchParams.get('path') || '';
|
|
133
|
+
// Optional graph version pin for deterministic boot
|
|
134
|
+
let forcedVer = urlObj.searchParams.get('v');
|
|
135
|
+
let bootTaggedRequest = false;
|
|
136
|
+
if (!spec) {
|
|
137
|
+
const base = '/ns/m';
|
|
138
|
+
let rest = urlObj.pathname.slice(base.length);
|
|
139
|
+
if (rest && rest !== '/')
|
|
140
|
+
spec = rest;
|
|
141
|
+
}
|
|
142
|
+
// Special-case stub for anomalous '@' imports emitted as '/__invalid_at__.mjs'
|
|
143
|
+
if (spec === '/__invalid_at__.mjs' || spec === '__invalid_at__.mjs') {
|
|
144
|
+
res.statusCode = 200;
|
|
145
|
+
res.end("// invalid '@' import stub\nexport {}\n");
|
|
146
|
+
return;
|
|
147
|
+
}
|
|
148
|
+
if (!spec) {
|
|
149
|
+
res.statusCode = 200;
|
|
150
|
+
res.end('export {}\n');
|
|
151
|
+
return;
|
|
152
|
+
}
|
|
153
|
+
const serverRoot = (server.config?.root || process.cwd());
|
|
154
|
+
const monorepoWorkspaceRoot = getMonorepoWorkspaceRoot(serverRoot);
|
|
155
|
+
spec = spec.replace(/[?#].*$/, '');
|
|
156
|
+
// Accept path-based boot/HMR prefixes:
|
|
157
|
+
// /ns/m/__ns_boot__/b1/<real-spec>
|
|
158
|
+
// /ns/m/__ns_hmr__/<tag>/<real-spec>
|
|
159
|
+
// /ns/m/__ns_boot__/b1/__ns_hmr__/<tag>/<real-spec>
|
|
160
|
+
// The iOS HTTP ESM loader canonicalizes cache keys by stripping query params,
|
|
161
|
+
// so we must carry the cache-buster in the path.
|
|
162
|
+
try {
|
|
163
|
+
const decorated = stripDecoratedServePrefixes(spec);
|
|
164
|
+
spec = decorated.cleanedSpec;
|
|
165
|
+
bootTaggedRequest = decorated.bootTaggedRequest;
|
|
166
|
+
forcedVer || (forcedVer = decorated.forcedVer);
|
|
167
|
+
}
|
|
168
|
+
catch { }
|
|
169
|
+
// Normalize absolute filesystem paths back to project-relative ids (e.g. /src/app.ts)
|
|
170
|
+
try {
|
|
171
|
+
const toPosix = (p) => p.replace(/\\/g, '/');
|
|
172
|
+
const rootPosix = toPosix(serverRoot);
|
|
173
|
+
const specPosix = toPosix(spec);
|
|
174
|
+
// If spec is an absolute path under the project root, convert to '/'+relative
|
|
175
|
+
const isAbsFs = /^\//.test(specPosix) || /^[A-Za-z]:\//.test(spec); // posix or win drive
|
|
176
|
+
if (isAbsFs) {
|
|
177
|
+
let rel = specPosix.startsWith(rootPosix) ? specPosix.slice(rootPosix.length) : require('path').posix.relative(rootPosix, specPosix);
|
|
178
|
+
if (!rel.startsWith('..')) {
|
|
179
|
+
if (!rel.startsWith('/'))
|
|
180
|
+
rel = '/' + rel;
|
|
181
|
+
// Ensure leading '/src' style when path maps into src
|
|
182
|
+
spec = rel;
|
|
183
|
+
}
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
catch { }
|
|
187
|
+
// Serve Vite virtual modules (/@id/ prefix). These are internal
|
|
188
|
+
// virtual modules (e.g., \0nsvite:nsconfig-json for ~/package.json)
|
|
189
|
+
// that don't exist on disk. Decode the ID and load via plugin container.
|
|
190
|
+
if (spec.startsWith('/@id/')) {
|
|
191
|
+
try {
|
|
192
|
+
// First try Vite's transform pipeline directly
|
|
193
|
+
const vr = await sharedTransformRequest(spec);
|
|
194
|
+
if (vr?.code) {
|
|
195
|
+
res.statusCode = 200;
|
|
196
|
+
res.end(vr.code);
|
|
197
|
+
return;
|
|
198
|
+
}
|
|
199
|
+
}
|
|
200
|
+
catch { }
|
|
201
|
+
try {
|
|
202
|
+
// Fallback: decode the virtual module ID (__x00__ → \0) and
|
|
203
|
+
// load through the plugin container directly
|
|
204
|
+
const rawId = spec.slice('/@id/'.length).replace(/__x00__/g, '\0');
|
|
205
|
+
const loadResult = await server.pluginContainer.load(rawId);
|
|
206
|
+
if (loadResult) {
|
|
207
|
+
const code = typeof loadResult === 'string' ? loadResult : loadResult.code;
|
|
208
|
+
if (code) {
|
|
209
|
+
res.statusCode = 200;
|
|
210
|
+
res.end(code);
|
|
211
|
+
return;
|
|
212
|
+
}
|
|
213
|
+
}
|
|
214
|
+
}
|
|
215
|
+
catch { }
|
|
216
|
+
}
|
|
217
|
+
if (spec.startsWith('@/'))
|
|
218
|
+
spec = APP_VIRTUAL_WITH_SLASH + spec.slice(2);
|
|
219
|
+
if (spec.startsWith('./'))
|
|
220
|
+
spec = spec.slice(1);
|
|
221
|
+
const blockedNodeModulesReason = getBlockedDeviceNodeModulesReason(spec);
|
|
222
|
+
if (blockedNodeModulesReason) {
|
|
223
|
+
res.statusCode = 404;
|
|
224
|
+
res.end(`// [ns:m] blocked device import\nthrow new Error(${JSON.stringify(`[ns/m] ${blockedNodeModulesReason}`)});\nexport {};\n`);
|
|
225
|
+
return;
|
|
226
|
+
}
|
|
227
|
+
if (!spec.startsWith('/'))
|
|
228
|
+
spec = '/' + spec;
|
|
229
|
+
const hasExt = /\.(ts|tsx|js|jsx|mjs|mts|cts|vue)$/i.test(spec);
|
|
230
|
+
const baseNoExt = hasExt ? spec.replace(/\.(ts|tsx|js|jsx|mjs|mts|cts)$/i, '') : spec;
|
|
231
|
+
const candidates = [...(hasExt ? [spec] : []), baseNoExt + '.ts', baseNoExt + '.js', baseNoExt + '.tsx', baseNoExt + '.jsx', baseNoExt + '.mjs', baseNoExt + '.mts', baseNoExt + '.cts', baseNoExt + '.vue', baseNoExt + '/index.ts', baseNoExt + '/index.js', baseNoExt + '/index.tsx', baseNoExt + '/index.jsx', baseNoExt + '/index.mjs'];
|
|
232
|
+
const transformCandidates = filterExistingNodeModulesTransformCandidates(spec, candidates, serverRoot, monorepoWorkspaceRoot);
|
|
233
|
+
let transformed = null;
|
|
234
|
+
let resolvedCandidate = null;
|
|
235
|
+
const rawExplicitModule = tryReadRawExplicitJavaScriptModule(spec, serverRoot);
|
|
236
|
+
if (rawExplicitModule) {
|
|
237
|
+
transformed = { code: rawExplicitModule.code };
|
|
238
|
+
resolvedCandidate = rawExplicitModule.resolvedId;
|
|
239
|
+
}
|
|
240
|
+
// Queue and dedupe transformRequest calls so heavy app graphs do not
|
|
241
|
+
// overwhelm Vite with concurrent work. Slow-transform warnings start only
|
|
242
|
+
// when the transform actually begins executing, and requests stay pending
|
|
243
|
+
// until Vite returns a real result.
|
|
244
|
+
const transformWithTimeout = (url, timeoutMs = 120000) => {
|
|
245
|
+
return sharedTransformRequest(url, timeoutMs);
|
|
246
|
+
};
|
|
247
|
+
if (!transformed?.code) {
|
|
248
|
+
for (const cand of transformCandidates) {
|
|
249
|
+
try {
|
|
250
|
+
const r = await transformWithTimeout(cand);
|
|
251
|
+
if (r?.code) {
|
|
252
|
+
transformed = r;
|
|
253
|
+
resolvedCandidate = cand;
|
|
254
|
+
break;
|
|
255
|
+
}
|
|
256
|
+
}
|
|
257
|
+
catch { }
|
|
258
|
+
}
|
|
259
|
+
}
|
|
260
|
+
// Fallback 1: ask Vite to resolve the id, then transform the resolved id (handles aliases and virtual ids)
|
|
261
|
+
if (!transformed?.code) {
|
|
262
|
+
try {
|
|
263
|
+
const rid = await server.pluginContainer?.resolveId?.(spec, undefined);
|
|
264
|
+
const ridStr = typeof rid === 'string' ? rid : rid?.id || null;
|
|
265
|
+
if (ridStr) {
|
|
266
|
+
const r = await transformWithTimeout(ridStr);
|
|
267
|
+
if (r?.code) {
|
|
268
|
+
transformed = r;
|
|
269
|
+
resolvedCandidate = ridStr;
|
|
270
|
+
}
|
|
271
|
+
}
|
|
272
|
+
}
|
|
273
|
+
catch { }
|
|
274
|
+
}
|
|
275
|
+
// Fallback 1b: if spec is a /node_modules/ path, extract bare specifier
|
|
276
|
+
// and try resolveId with that. This handles package.json "exports" field
|
|
277
|
+
// resolution (e.g., solid-js/jsx-runtime → solid-js/dist/solid.js).
|
|
278
|
+
if (!transformed?.code && spec.includes('/node_modules/')) {
|
|
279
|
+
try {
|
|
280
|
+
const nmIdx = spec.lastIndexOf('/node_modules/');
|
|
281
|
+
const bare = spec.slice(nmIdx + '/node_modules/'.length);
|
|
282
|
+
if (bare && !bare.startsWith('.')) {
|
|
283
|
+
const rid = await server.pluginContainer?.resolveId?.(bare, undefined);
|
|
284
|
+
const ridStr = typeof rid === 'string' ? rid : rid?.id || null;
|
|
285
|
+
if (ridStr) {
|
|
286
|
+
const r = await sharedTransformRequest(ridStr);
|
|
287
|
+
if (r?.code) {
|
|
288
|
+
transformed = r;
|
|
289
|
+
resolvedCandidate = ridStr;
|
|
290
|
+
}
|
|
291
|
+
}
|
|
292
|
+
}
|
|
293
|
+
}
|
|
294
|
+
catch { }
|
|
295
|
+
}
|
|
296
|
+
// Fallback 2: try /@fs absolute path under project root (Vite file system alias).
|
|
297
|
+
// In a monorepo with hoisted node_modules the file may live above
|
|
298
|
+
// `serverRoot`, so try the workspace root next.
|
|
299
|
+
if (!transformed?.code) {
|
|
300
|
+
try {
|
|
301
|
+
const toPosix = (p) => p.replace(/\\/g, '/');
|
|
302
|
+
const rootsToTry = [serverRoot, ...(monorepoWorkspaceRoot && path.resolve(monorepoWorkspaceRoot) !== path.resolve(serverRoot) ? [monorepoWorkspaceRoot] : [])];
|
|
303
|
+
for (const root of rootsToTry) {
|
|
304
|
+
const rootPosix = toPosix(root).replace(/\/$/, '');
|
|
305
|
+
const absPosix = `${rootPosix}${spec.startsWith('/') ? '' : '/'}${spec}`;
|
|
306
|
+
const fsId = `/@fs${absPosix}`;
|
|
307
|
+
if (resolveCandidateFilePath(fsId, serverRoot, monorepoWorkspaceRoot)) {
|
|
308
|
+
const r = await transformWithTimeout(fsId);
|
|
309
|
+
if (r?.code) {
|
|
310
|
+
transformed = r;
|
|
311
|
+
resolvedCandidate = fsId;
|
|
312
|
+
break;
|
|
313
|
+
}
|
|
314
|
+
}
|
|
315
|
+
}
|
|
316
|
+
}
|
|
317
|
+
catch { }
|
|
318
|
+
}
|
|
319
|
+
// Fallback 3: try adding ?import to hint Vite's transform pipeline
|
|
320
|
+
if (!transformed?.code) {
|
|
321
|
+
for (const cand of transformCandidates) {
|
|
322
|
+
try {
|
|
323
|
+
const r = await transformWithTimeout(`${cand}${cand.includes('?') ? '&' : '?'}import`);
|
|
324
|
+
if (r?.code) {
|
|
325
|
+
transformed = r;
|
|
326
|
+
resolvedCandidate = `${cand}?import`;
|
|
327
|
+
break;
|
|
328
|
+
}
|
|
329
|
+
}
|
|
330
|
+
catch { }
|
|
331
|
+
}
|
|
332
|
+
}
|
|
333
|
+
// Solid HMR: patch the served `@solid-refresh` runtime so $$refreshESM
|
|
334
|
+
// applies registry updates inline on module re-evaluation. The full
|
|
335
|
+
// patch (and its server-side diagnostics) lives in the Solid strategy's
|
|
336
|
+
// `transformNodeModule` hook; every other flavor leaves the hook
|
|
337
|
+
// undefined, so this is a no-op for them.
|
|
338
|
+
try {
|
|
339
|
+
if (transformed?.code && strategy?.transformNodeModule) {
|
|
340
|
+
const patched = strategy.transformNodeModule(transformed.code, resolvedCandidate || spec || '', verbose);
|
|
341
|
+
if (patched !== transformed.code) {
|
|
342
|
+
// Work on a copy to avoid mutating Vite's cached TransformResult
|
|
343
|
+
transformed = { ...transformed, code: patched };
|
|
344
|
+
}
|
|
345
|
+
}
|
|
346
|
+
}
|
|
347
|
+
catch { }
|
|
348
|
+
// NOTE: Path-based cache busting for /ns/m/* imports is applied in the
|
|
349
|
+
// finalize step below (after rewriteImports adds the /ns/m/ prefix).
|
|
350
|
+
// The block here only handles TypeScript-specific graph population.
|
|
351
|
+
try {
|
|
352
|
+
if (transformed?.code) {
|
|
353
|
+
const code = transformed.code;
|
|
354
|
+
// TypeScript-specific graph population: when TS flavor is active
|
|
355
|
+
// and this is an application module under the virtual app root,
|
|
356
|
+
// upsert it into the HMR graph so ns:hmr-full-graph is non-empty.
|
|
357
|
+
try {
|
|
358
|
+
if (strategy?.flavor === 'typescript') {
|
|
359
|
+
const id = (resolvedCandidate || spec).replace(/[?#].*$/, '');
|
|
360
|
+
// Only track app modules (under APP_VIRTUAL_WITH_SLASH) and ts/js/tsx/jsx/mjs.
|
|
361
|
+
const isApp = id.startsWith(APP_VIRTUAL_WITH_SLASH) || id.startsWith('/app/');
|
|
362
|
+
if (isApp && /\.(ts|tsx|js|jsx|mjs|mts|cts)$/i.test(id) && !isRuntimeGraphExcludedPath(id)) {
|
|
363
|
+
const deps = Array.from(collectImportDependencies(code, id));
|
|
364
|
+
if (verbose) {
|
|
365
|
+
console.log('[hmr-ws][ts-graph] candidate', { id, depsCount: deps.length });
|
|
366
|
+
}
|
|
367
|
+
// Serve-time warm-up: no live edit happened, so don't bump
|
|
368
|
+
// graphVersion.
|
|
369
|
+
options.upsertGraphModule(id, code, deps, { bumpVersion: false });
|
|
370
|
+
}
|
|
371
|
+
}
|
|
372
|
+
}
|
|
373
|
+
catch { }
|
|
374
|
+
}
|
|
375
|
+
}
|
|
376
|
+
catch { }
|
|
377
|
+
// If transformRequest failed, handle bare-module vendor shims for 'vue' and 'pinia'
|
|
378
|
+
if (!transformed?.code) {
|
|
379
|
+
const bare = spec.startsWith('/') ? spec.slice(1) : spec;
|
|
380
|
+
const isBare = bare && !bare.includes('/') && !/\.(ts|tsx|js|jsx|mjs|mts|cts|vue)$/i.test(bare);
|
|
381
|
+
if (isBare && (bare === 'vue' || bare === 'nativescript-vue' || bare === 'pinia')) {
|
|
382
|
+
const pkg = bare;
|
|
383
|
+
let code = '';
|
|
384
|
+
if (pkg === 'vue' || pkg === 'nativescript-vue') {
|
|
385
|
+
code = buildVueVendorShim(pkg);
|
|
386
|
+
}
|
|
387
|
+
else if (pkg === 'pinia') {
|
|
388
|
+
code = buildPiniaVendorShim();
|
|
389
|
+
}
|
|
390
|
+
res.statusCode = 200;
|
|
391
|
+
res.end(code || 'export {}\n');
|
|
392
|
+
return;
|
|
393
|
+
}
|
|
394
|
+
// Generic bare module resolution via Vite plugin container
|
|
395
|
+
if (isBare) {
|
|
396
|
+
try {
|
|
397
|
+
const resolved = await server.pluginContainer?.resolveId?.(spec, undefined);
|
|
398
|
+
const resolvedId = typeof resolved === 'string' ? resolved : resolved?.id || null;
|
|
399
|
+
if (resolvedId) {
|
|
400
|
+
const r = await server.transformRequest(resolvedId);
|
|
401
|
+
if (r?.code) {
|
|
402
|
+
transformed = r;
|
|
403
|
+
resolvedCandidate = resolvedId;
|
|
404
|
+
}
|
|
405
|
+
}
|
|
406
|
+
}
|
|
407
|
+
catch { }
|
|
408
|
+
}
|
|
409
|
+
if (!transformed?.code) {
|
|
410
|
+
// Emit a module that throws with context for easier on-device debugging
|
|
411
|
+
try {
|
|
412
|
+
const tried = Array.from(new Set(transformCandidates.length > 0 ? transformCandidates : candidates)).slice(0, 12);
|
|
413
|
+
const out = `// [ns:m] transform miss path=${spec} tried=${tried.length}\n` + `throw new Error(${JSON.stringify(`[ns/m] transform failed for ${spec} (tried ${tried.length} candidates).`)});\nexport {};\n`;
|
|
414
|
+
res.statusCode = 404;
|
|
415
|
+
res.end(out);
|
|
416
|
+
return;
|
|
417
|
+
}
|
|
418
|
+
catch {
|
|
419
|
+
res.statusCode = 404;
|
|
420
|
+
res.end('export {}\n');
|
|
421
|
+
return;
|
|
422
|
+
}
|
|
423
|
+
}
|
|
424
|
+
}
|
|
425
|
+
let code = transformed.code;
|
|
426
|
+
// Prepend guard to capture any URL-based require attempts
|
|
427
|
+
code = REQUIRE_GUARD_SNIPPET + code;
|
|
428
|
+
code = cleanCode(code, strategy);
|
|
429
|
+
const isNodeMod = /(?:^|\/)node_modules\//.test(resolvedCandidate || spec || '');
|
|
430
|
+
code = processCodeForDevice(code, false, true, isNodeMod, resolvedCandidate || spec);
|
|
431
|
+
// Solid HMR: The NativeScript iOS/Android runtime provides import.meta.hot
|
|
432
|
+
// natively (via InitializeImportMetaHot in HMRSupport.mm) with C++-backed
|
|
433
|
+
// persistent hot.data that survives across module re-evaluations.
|
|
434
|
+
// cleanCode() strips Vite's __vite__createHotContext assignment, which is
|
|
435
|
+
// correct — the runtime's native hot context is better.
|
|
436
|
+
const projectRoot = server.config?.root || process.cwd();
|
|
437
|
+
const serverOrigin = getServerOrigin(server);
|
|
438
|
+
// Served-module import rewrite, routed through the active framework
|
|
439
|
+
// strategy. Angular overrides with its register-only entry pass
|
|
440
|
+
// (`rewriteServedModule`); every other flavor falls through to the shared
|
|
441
|
+
// `rewriteImports` default.
|
|
442
|
+
const servedModuleCtx = {
|
|
443
|
+
moduleId: resolvedCandidate || spec,
|
|
444
|
+
sfcFileMap,
|
|
445
|
+
depFileMap,
|
|
446
|
+
projectRoot,
|
|
447
|
+
serverOrigin,
|
|
448
|
+
verbose: !!verbose,
|
|
449
|
+
};
|
|
450
|
+
code = strategy?.rewriteServedModule ? strategy.rewriteServedModule(code, servedModuleCtx) : rewriteImports(code, servedModuleCtx.moduleId, sfcFileMap, depFileMap, projectRoot, !!verbose, undefined, serverOrigin, true);
|
|
451
|
+
// Expand `export * from "url"` into explicit named re-exports.
|
|
452
|
+
// NativeScript's HTTP ESM loader may not propagate star-re-exports across
|
|
453
|
+
// HTTP module boundaries (the namespace object gets direct exports but
|
|
454
|
+
// misses re-exported names). By expanding to `export { a, b } from "url"`,
|
|
455
|
+
// the engine sees explicit named exports and resolves them correctly.
|
|
456
|
+
try {
|
|
457
|
+
code = await expandStarExports(code, server, server.config?.root || process.cwd(), verbose, sharedTransformRequest);
|
|
458
|
+
}
|
|
459
|
+
catch (e) {
|
|
460
|
+
if (verbose)
|
|
461
|
+
console.warn('[ns/m] export* expansion failed:', e?.message);
|
|
462
|
+
}
|
|
463
|
+
// Dedupe any /ns/rt named imports that duplicate destructured bindings off default /ns/rt
|
|
464
|
+
try {
|
|
465
|
+
code = dedupeRtNamedImportsAgainstDestructures(code);
|
|
466
|
+
}
|
|
467
|
+
catch { }
|
|
468
|
+
code = ensureVariableDynamicImportHelper(code);
|
|
469
|
+
// Final safety: guard any plain dynamic import(...) occurrences to reroute anomalous '@' specs
|
|
470
|
+
try {
|
|
471
|
+
code = ensureGuardPlainDynamicImports(code);
|
|
472
|
+
}
|
|
473
|
+
catch { }
|
|
474
|
+
// Extra hardening before the fast-fail assertion: run the
|
|
475
|
+
// consolidated stray-core-reference safety net. If any
|
|
476
|
+
// rewrite occurred, leave a diagnostic marker so the
|
|
477
|
+
// pipeline review log explains why the served code carries
|
|
478
|
+
// it.
|
|
479
|
+
try {
|
|
480
|
+
const __before = code;
|
|
481
|
+
code = sanitizeStrayCoreReferences(code);
|
|
482
|
+
if (code !== __before) {
|
|
483
|
+
code = `// [hmr-sanitize] core-literal->bridge\n` + code;
|
|
484
|
+
}
|
|
485
|
+
}
|
|
486
|
+
catch { }
|
|
487
|
+
// Final pass: deduplicate/resolve any bare-specifier imports that slipped
|
|
488
|
+
// through the pipeline (e.g., extracted from JSDoc comments by import-splitting
|
|
489
|
+
// regexes, or injected by the Angular linker on already-resolved code).
|
|
490
|
+
try {
|
|
491
|
+
code = deduplicateLinkerImports(code);
|
|
492
|
+
}
|
|
493
|
+
catch { }
|
|
494
|
+
// CJS/UMD wrapping: if a module uses module.exports but has no ESM export default,
|
|
495
|
+
// wrap it with CJS shims so the device HTTP ESM loader can consume it.
|
|
496
|
+
// This handles npm packages that use CommonJS but aren't pre-bundled by Vite.
|
|
497
|
+
//
|
|
498
|
+
// Key constraints this must handle:
|
|
499
|
+
// - CJS modules often declare local vars with the same names as their exports
|
|
500
|
+
// (e.g. `function createLTTB() {...}; exports.createLTTB = createLTTB;`)
|
|
501
|
+
// so `export var { createLTTB }` would cause a duplicate declaration.
|
|
502
|
+
// - UMD modules reference `this` at top level (undefined in ESM) but
|
|
503
|
+
// typically fall back to `self` or `globalThis`.
|
|
504
|
+
// - `module`, `exports` must be shims since they don't exist in ESM.
|
|
505
|
+
try {
|
|
506
|
+
code = wrapCommonJsModuleForDevice(code, resolvedCandidate || null);
|
|
507
|
+
}
|
|
508
|
+
catch { }
|
|
509
|
+
try {
|
|
510
|
+
assertNoOptimizedArtifacts(code, `NS M ${resolvedCandidate || spec}`);
|
|
511
|
+
}
|
|
512
|
+
catch (e) {
|
|
513
|
+
res.statusCode = 500;
|
|
514
|
+
return void res.end(`throw new Error(${JSON.stringify(e?.message || String(e))});\nexport {};`);
|
|
515
|
+
}
|
|
516
|
+
// Defensive export normalization: if a module defines `routes` and only exports it named,
|
|
517
|
+
// add a default export alias so both `import { routes }` and `import routes` work.
|
|
518
|
+
try {
|
|
519
|
+
if (!/\bexport\s+default\b/.test(code)) {
|
|
520
|
+
const hasNamedRoutes = /\bexport\s*\{\s*routes\s*\}/.test(code);
|
|
521
|
+
const hasConstRoutes = /\bconst\s+routes\s*=/.test(code) || /\bvar\s+routes\s*=/.test(code) || /\blet\s+routes\s*=/.test(code);
|
|
522
|
+
if (hasNamedRoutes && hasConstRoutes) {
|
|
523
|
+
code += `\nexport default routes;\n`;
|
|
524
|
+
}
|
|
525
|
+
}
|
|
526
|
+
}
|
|
527
|
+
catch { }
|
|
528
|
+
// `/ns/rt` and `/ns/core` URL versioning.
|
|
529
|
+
//
|
|
530
|
+
// Older versions of the server emitted `/ns/rt/<ver>` and
|
|
531
|
+
// `/ns/core/<ver>` so V8's HTTP module cache would see a
|
|
532
|
+
// fresh URL on every save. The runtime canonicalizer
|
|
533
|
+
// (`CanonicalizeHttpUrlKey` in HMRSupport.mm) collapses
|
|
534
|
+
// these version segments to the bare `/ns/rt` and
|
|
535
|
+
// `/ns/core` keys before lookup, so V8 actually saw a
|
|
536
|
+
// single cache entry — but the server was doing extra
|
|
537
|
+
// work to inject a version segment that the runtime then
|
|
538
|
+
// immediately stripped. Now that the runtime supports
|
|
539
|
+
// explicit eviction (and these bridge endpoints don't
|
|
540
|
+
// change at HMR time anyway), the version segment is
|
|
541
|
+
// purely vestigial.
|
|
542
|
+
//
|
|
543
|
+
// Rather than rip the helpers out (which would touch
|
|
544
|
+
// every ensureVersionedImports caller and risk bumping
|
|
545
|
+
// older runtimes), we keep them but pass `verNum=0`. The
|
|
546
|
+
// helpers still normalize URL shape (strip the absolute
|
|
547
|
+
// origin prefix when present) but emit a stable
|
|
548
|
+
// `/ns/rt/0` / `/ns/core/0` URL — which collapses to
|
|
549
|
+
// `/ns/rt` / `/ns/core` in the runtime.
|
|
550
|
+
try {
|
|
551
|
+
const verNum = 0;
|
|
552
|
+
code = ensureVersionedRtImports(code, getServerOrigin(server), verNum);
|
|
553
|
+
code = strategy.ensureVersionedImports?.(code, getServerOrigin(server), verNum) ?? code;
|
|
554
|
+
}
|
|
555
|
+
catch { }
|
|
556
|
+
// `/ns/m` URL finalize step.
|
|
557
|
+
//
|
|
558
|
+
// `rewriteNsMImportPathForHmr` is a canonicalizer: it
|
|
559
|
+
// strips legacy `__ns_hmr__/<tag>/` segments and adds
|
|
560
|
+
// `__ns_boot__/b1/` only for boot-tagged requests. The
|
|
561
|
+
// `ver` parameter is preserved on the signature for API
|
|
562
|
+
// compatibility but is ignored for app modules (cache
|
|
563
|
+
// busting is driven by `__nsInvalidateModules`, not URL
|
|
564
|
+
// versioning). We pass `'v0'` as a stable placeholder —
|
|
565
|
+
// the canonicalizer emits the same URL regardless of
|
|
566
|
+
// this value, but a constant placeholder makes the
|
|
567
|
+
// contract explicit.
|
|
568
|
+
//
|
|
569
|
+
// SFC URLs (line below, `/ns/sfc/${verTag}/...`) still
|
|
570
|
+
// embed a version because the Vue SFC pathway does not
|
|
571
|
+
// yet have an eviction protocol. The runtime
|
|
572
|
+
// canonicalizer does NOT strip `/ns/sfc/<ver>/`, so Vue
|
|
573
|
+
// users still see per-save SFC re-fetches — that's a
|
|
574
|
+
// known follow-up.
|
|
575
|
+
try {
|
|
576
|
+
const verTag = (() => {
|
|
577
|
+
const numeric = getNumericServeVersionTag(forcedVer, Number(options.getGraphVersion() || 0));
|
|
578
|
+
return numeric > 0 ? `v${numeric}` : 'v0';
|
|
579
|
+
})();
|
|
580
|
+
const origin = getServerOrigin(server);
|
|
581
|
+
const rewritePath = (p) => rewriteNsMImportPathForHmr(p, 'v0', bootTaggedRequest);
|
|
582
|
+
// /ns/m URL forms — all collapse to canonical stable
|
|
583
|
+
// URLs via the Phase 3a rewriter.
|
|
584
|
+
// 1) Static imports: import ... from "/ns/m/..."
|
|
585
|
+
code = code.replace(/(from\s*["'])(\/ns\/m\/[^"'?]+)(["'])/g, (_m, a, p, b) => `${a}${rewritePath(p)}${b}`);
|
|
586
|
+
// 2) Side-effect imports: import "/ns/m/..."
|
|
587
|
+
code = code.replace(/(import\s*(?!\()\s*["'])(\/ns\/m\/[^"'?]+)(["'])/g, (_m, a, p, b) => `${a}${rewritePath(p)}${b}`);
|
|
588
|
+
// 3) Dynamic imports: import("/ns/m/...")
|
|
589
|
+
code = code.replace(/(import\(\s*["'])(\/ns\/m\/[^"'?]+)(["']\s*\))/g, (_m, a, p, b) => `${a}${rewritePath(p)}${b}`);
|
|
590
|
+
// 4) new URL("/ns/m/...", import.meta.url)
|
|
591
|
+
code = code.replace(/(new\s+URL\(\s*["'])(\/ns\/m\/[^"'?]+)(["']\s*,\s*import\.meta\.url\s*\))/g, (_m, a, p, b) => `${a}${rewritePath(p)}${b}`);
|
|
592
|
+
// 5) __ns_import(new URL('/ns/m/...', import.meta.url).href)
|
|
593
|
+
code = code.replace(/(new\s+URL\(\s*["'])(\/ns\/m\/[^"'?]+)(["']\s*,\s*import\.meta\.url\s*\)\.href)/g, (_m, a, p, b) => `${a}${rewritePath(p)}${b}`);
|
|
594
|
+
// 6) Force absolute HTTP for new URL('/ns/m/...', import.meta.url).href → canonical stable URL.
|
|
595
|
+
try {
|
|
596
|
+
code = code.replace(/new\s+URL\(\s*["'](\/ns\/m\/[^"'?]+)(?:\?[^"']*)?["']\s*,\s*import\.meta\.url\s*\)\.href/g, (_m, p1) => `${JSON.stringify(`${origin}${rewritePath(p1)}`)}`);
|
|
597
|
+
}
|
|
598
|
+
catch { }
|
|
599
|
+
// 7) SFC URLs (Vue) — still versioned. See header comment.
|
|
600
|
+
try {
|
|
601
|
+
code = code.replace(/new\s+URL\(\s*["']\/ns\/sfc(\/[^"'?]+)(?:\?[^"']*)?["']\s*,\s*import\.meta\.url\s*\)\.href/g, (_m, p1) => `${JSON.stringify(`${origin}/ns/sfc/${verTag}${p1}`)}`);
|
|
602
|
+
}
|
|
603
|
+
catch { }
|
|
604
|
+
}
|
|
605
|
+
catch { }
|
|
606
|
+
// Final guard: eliminate any lingering named imports from /ns/core to avoid
|
|
607
|
+
// evaluation-time "does not provide an export named ..." in the device runtime.
|
|
608
|
+
try {
|
|
609
|
+
code = ensureDestructureCoreImports(code);
|
|
610
|
+
}
|
|
611
|
+
catch { }
|
|
612
|
+
// Boot-time module graph progress: while the app is still replacing the
|
|
613
|
+
// placeholder, emit lightweight progress updates as /ns/m modules begin
|
|
614
|
+
// evaluating. This keeps the overlay moving during large initial graphs.
|
|
615
|
+
try {
|
|
616
|
+
if (bootTaggedRequest) {
|
|
617
|
+
const bootModuleLabel = String(spec || '').replace(/\\/g, '/');
|
|
618
|
+
const bootProgressSnippet = buildBootProgressSnippet(bootModuleLabel);
|
|
619
|
+
code = bootProgressSnippet + code;
|
|
620
|
+
code = hoistTopLevelStaticImports(code);
|
|
621
|
+
}
|
|
622
|
+
}
|
|
623
|
+
catch { }
|
|
624
|
+
// Dev-only: link-check static imports to surface missing bindings early
|
|
625
|
+
try {
|
|
626
|
+
const devCheck = process.env.NODE_ENV !== 'production';
|
|
627
|
+
if (devCheck) {
|
|
628
|
+
const ast = babelParse(code, {
|
|
629
|
+
sourceType: 'module',
|
|
630
|
+
plugins: MODULE_IMPORT_ANALYSIS_PLUGINS,
|
|
631
|
+
});
|
|
632
|
+
const imports = [];
|
|
633
|
+
babelTraverse(ast, {
|
|
634
|
+
ImportDeclaration(p) {
|
|
635
|
+
const src = p.node.source.value;
|
|
636
|
+
if (typeof src !== 'string')
|
|
637
|
+
return;
|
|
638
|
+
const wantsDefault = p.node.specifiers.some((s) => s.type === 'ImportDefaultSpecifier');
|
|
639
|
+
imports.push({ src, wantsDefault });
|
|
640
|
+
},
|
|
641
|
+
});
|
|
642
|
+
// Resolve and verify each static import that asks for default
|
|
643
|
+
for (const imp of imports) {
|
|
644
|
+
if (!imp.wantsDefault)
|
|
645
|
+
continue;
|
|
646
|
+
// Only check our served endpoints and app modules
|
|
647
|
+
if (/^https?:\/\/[^\s]+\/ns\//.test(imp.src) || /^https?:\/\/[^\s]+\/.+/.test(imp.src)) {
|
|
648
|
+
const u = new URL(imp.src, 'http://localhost');
|
|
649
|
+
// Fetch target module's sanitized code using server.transformRequest or by routing through our own endpoints heuristically
|
|
650
|
+
let targetCode = '';
|
|
651
|
+
try {
|
|
652
|
+
if (u.pathname.startsWith('/ns/asm')) {
|
|
653
|
+
// Reconstruct: call our own assembler handler to get code (preferred)
|
|
654
|
+
const target = await server.transformRequest(imp.src.replace(/^https?:\/\/[^/]+/, ''));
|
|
655
|
+
targetCode = target?.code || '';
|
|
656
|
+
}
|
|
657
|
+
else if (u.pathname.startsWith('/ns/sfc')) {
|
|
658
|
+
// Delegator re-exports default from /ns/asm — skip; assembler will be checked when imported by upstream
|
|
659
|
+
continue;
|
|
660
|
+
}
|
|
661
|
+
else if (u.pathname.startsWith('/ns/m')) {
|
|
662
|
+
// Resolve to local project path and transform with same candidate logic as /ns/m handler
|
|
663
|
+
let local = u.pathname.replace(/^\/ns\/m/, '');
|
|
664
|
+
try {
|
|
665
|
+
// Normalize project-relative path
|
|
666
|
+
if (local.startsWith('@/'))
|
|
667
|
+
local = APP_VIRTUAL_WITH_SLASH + local.slice(2);
|
|
668
|
+
if (local.startsWith('./'))
|
|
669
|
+
local = local.slice(1);
|
|
670
|
+
if (!local.startsWith('/'))
|
|
671
|
+
local = '/' + local;
|
|
672
|
+
const hasExt = /(\.ts|\.tsx|\.js|\.jsx|\.mjs|\.mts|\.cts|\.vue)$/i.test(local);
|
|
673
|
+
const baseNoExt = hasExt ? local.replace(/\.(ts|tsx|js|jsx|mjs|mts|cts)$/i, '') : local;
|
|
674
|
+
const cands = [...(hasExt ? [local] : []), baseNoExt + '.ts', baseNoExt + '.js', baseNoExt + '.tsx', baseNoExt + '.jsx', baseNoExt + '.mjs', baseNoExt + '.mts', baseNoExt + '.cts', baseNoExt + '.vue', baseNoExt + '/index.ts', baseNoExt + '/index.js', baseNoExt + '/index.tsx', baseNoExt + '/index.jsx', baseNoExt + '/index.mjs'];
|
|
675
|
+
let t = null;
|
|
676
|
+
for (const cand of cands) {
|
|
677
|
+
try {
|
|
678
|
+
const r = await server.transformRequest(cand);
|
|
679
|
+
if (r?.code) {
|
|
680
|
+
t = r;
|
|
681
|
+
break;
|
|
682
|
+
}
|
|
683
|
+
}
|
|
684
|
+
catch { }
|
|
685
|
+
if (t?.code)
|
|
686
|
+
break;
|
|
687
|
+
}
|
|
688
|
+
if (!t?.code) {
|
|
689
|
+
try {
|
|
690
|
+
const rid = await server.pluginContainer?.resolveId?.(local, undefined);
|
|
691
|
+
const ridStr = typeof rid === 'string' ? rid : rid?.id || null;
|
|
692
|
+
if (ridStr) {
|
|
693
|
+
const r2 = await server.transformRequest(ridStr);
|
|
694
|
+
if (r2?.code)
|
|
695
|
+
t = r2;
|
|
696
|
+
}
|
|
697
|
+
}
|
|
698
|
+
catch { }
|
|
699
|
+
}
|
|
700
|
+
targetCode = t?.code || '';
|
|
701
|
+
}
|
|
702
|
+
catch { }
|
|
703
|
+
}
|
|
704
|
+
else if (u.pathname.startsWith('/ns/rt') || u.pathname.startsWith('/ns/core')) {
|
|
705
|
+
// Bridges export named/default as needed; skip default check
|
|
706
|
+
continue;
|
|
707
|
+
}
|
|
708
|
+
}
|
|
709
|
+
catch { }
|
|
710
|
+
if (!targetCode)
|
|
711
|
+
continue;
|
|
712
|
+
const hasDefault = /\bexport\s+default\b/.test(targetCode) || /export\s*\{\s*default\s*(?:as\s*default)?\s*\}/.test(targetCode);
|
|
713
|
+
if (!hasDefault) {
|
|
714
|
+
// CJS/UMD modules won't have `export default` — they get CJS-wrapped
|
|
715
|
+
// by the serving pipeline. Only warn, don't fatally block the importer.
|
|
716
|
+
const hasCjsPattern = /\bmodule\s*\.\s*exports\b/.test(targetCode) || /\bexports\s*\.\s*\w/.test(targetCode);
|
|
717
|
+
if (hasCjsPattern) {
|
|
718
|
+
if (verbose) {
|
|
719
|
+
console.warn(`[ns:m][link-check] CJS module without export default: ${u.pathname} (will be CJS-wrapped at serve time)`);
|
|
720
|
+
}
|
|
721
|
+
continue;
|
|
722
|
+
}
|
|
723
|
+
const msg = `[link-check] Missing default export in ${u.pathname}${u.search} (imported by ${resolvedCandidate || spec})`;
|
|
724
|
+
// Emit a module that throws to surface the exact offender
|
|
725
|
+
res.statusCode = 200;
|
|
726
|
+
res.end(`throw new Error(${JSON.stringify(msg)});\nexport {};`);
|
|
727
|
+
return;
|
|
728
|
+
}
|
|
729
|
+
}
|
|
730
|
+
}
|
|
731
|
+
}
|
|
732
|
+
}
|
|
733
|
+
catch (eLC) {
|
|
734
|
+
if (verbose) {
|
|
735
|
+
console.warn('[ns:m][link-check] failed', eLC?.message || eLC);
|
|
736
|
+
}
|
|
737
|
+
}
|
|
738
|
+
res.statusCode = 200;
|
|
739
|
+
res.end(code);
|
|
740
|
+
}
|
|
741
|
+
catch (e) {
|
|
742
|
+
console.warn('[sfc-asm] error serving', req.url, e && e.message ? e.message : e);
|
|
743
|
+
res.statusCode = 500;
|
|
744
|
+
res.end('export {}\n');
|
|
745
|
+
}
|
|
746
|
+
});
|
|
747
|
+
}
|
|
748
|
+
//# sourceMappingURL=websocket-ns-m.js.map
|