@rangojs/router 0.0.0-experimental.fb6e2f40 → 0.0.0-experimental.fce7fbd1
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 +120 -25
- package/dist/__internal.d.ts +83 -0
- package/dist/__internal.d.ts.map +1 -0
- package/dist/__internal.js +19 -0
- package/dist/__internal.js.map +1 -0
- package/dist/__mocks__/version.d.ts +7 -0
- package/dist/__mocks__/version.d.ts.map +1 -0
- package/dist/__mocks__/version.js +7 -0
- package/dist/__mocks__/version.js.map +1 -0
- package/dist/__tests__/client-href.test.d.ts +2 -0
- package/dist/__tests__/client-href.test.d.ts.map +1 -0
- package/dist/__tests__/client-href.test.js +74 -0
- package/dist/__tests__/client-href.test.js.map +1 -0
- package/dist/__tests__/component-utils.test.d.ts +2 -0
- package/dist/__tests__/component-utils.test.d.ts.map +1 -0
- package/dist/__tests__/component-utils.test.js +51 -0
- package/dist/__tests__/component-utils.test.js.map +1 -0
- package/dist/__tests__/event-controller.test.d.ts +2 -0
- package/dist/__tests__/event-controller.test.d.ts.map +1 -0
- package/dist/__tests__/event-controller.test.js +538 -0
- package/dist/__tests__/event-controller.test.js.map +1 -0
- package/dist/__tests__/helpers/route-tree.d.ts +118 -0
- package/dist/__tests__/helpers/route-tree.d.ts.map +1 -0
- package/dist/__tests__/helpers/route-tree.js +374 -0
- package/dist/__tests__/helpers/route-tree.js.map +1 -0
- package/dist/__tests__/match-result.test.d.ts +2 -0
- package/dist/__tests__/match-result.test.d.ts.map +1 -0
- package/dist/__tests__/match-result.test.js +154 -0
- package/dist/__tests__/match-result.test.js.map +1 -0
- package/dist/__tests__/navigation-store.test.d.ts +2 -0
- package/dist/__tests__/navigation-store.test.d.ts.map +1 -0
- package/dist/__tests__/navigation-store.test.js +440 -0
- package/dist/__tests__/navigation-store.test.js.map +1 -0
- package/dist/__tests__/partial-update.test.d.ts +2 -0
- package/dist/__tests__/partial-update.test.d.ts.map +1 -0
- package/dist/__tests__/partial-update.test.js +1009 -0
- package/dist/__tests__/partial-update.test.js.map +1 -0
- package/dist/__tests__/reverse-types.test.d.ts +8 -0
- package/dist/__tests__/reverse-types.test.d.ts.map +1 -0
- package/dist/__tests__/reverse-types.test.js +656 -0
- package/dist/__tests__/reverse-types.test.js.map +1 -0
- package/dist/__tests__/route-definition.test.d.ts +2 -0
- package/dist/__tests__/route-definition.test.d.ts.map +1 -0
- package/dist/__tests__/route-definition.test.js +55 -0
- package/dist/__tests__/route-definition.test.js.map +1 -0
- package/dist/__tests__/router-helpers.test.d.ts +2 -0
- package/dist/__tests__/router-helpers.test.d.ts.map +1 -0
- package/dist/__tests__/router-helpers.test.js +377 -0
- package/dist/__tests__/router-helpers.test.js.map +1 -0
- package/dist/__tests__/router-integration-2.test.d.ts +2 -0
- package/dist/__tests__/router-integration-2.test.d.ts.map +1 -0
- package/dist/__tests__/router-integration-2.test.js +426 -0
- package/dist/__tests__/router-integration-2.test.js.map +1 -0
- package/dist/__tests__/router-integration.test.d.ts +2 -0
- package/dist/__tests__/router-integration.test.d.ts.map +1 -0
- package/dist/__tests__/router-integration.test.js +1051 -0
- package/dist/__tests__/router-integration.test.js.map +1 -0
- package/dist/__tests__/search-params.test.d.ts +5 -0
- package/dist/__tests__/search-params.test.d.ts.map +1 -0
- package/dist/__tests__/search-params.test.js +306 -0
- package/dist/__tests__/search-params.test.js.map +1 -0
- package/dist/__tests__/segment-system.test.d.ts +2 -0
- package/dist/__tests__/segment-system.test.d.ts.map +1 -0
- package/dist/__tests__/segment-system.test.js +627 -0
- package/dist/__tests__/segment-system.test.js.map +1 -0
- package/dist/__tests__/static-handler-types.test.d.ts +8 -0
- package/dist/__tests__/static-handler-types.test.d.ts.map +1 -0
- package/dist/__tests__/static-handler-types.test.js +63 -0
- package/dist/__tests__/static-handler-types.test.js.map +1 -0
- package/dist/__tests__/urls.test.d.ts +2 -0
- package/dist/__tests__/urls.test.d.ts.map +1 -0
- package/dist/__tests__/urls.test.js +421 -0
- package/dist/__tests__/urls.test.js.map +1 -0
- package/dist/__tests__/use-mount.test.d.ts +2 -0
- package/dist/__tests__/use-mount.test.d.ts.map +1 -0
- package/dist/__tests__/use-mount.test.js +35 -0
- package/dist/__tests__/use-mount.test.js.map +1 -0
- package/dist/bin/rango.d.ts +2 -0
- package/dist/bin/rango.d.ts.map +1 -0
- package/dist/bin/rango.js +147 -57
- package/dist/bin/rango.js.map +1 -0
- package/dist/browser/event-controller.d.ts +191 -0
- package/dist/browser/event-controller.d.ts.map +1 -0
- package/dist/browser/event-controller.js +559 -0
- package/dist/browser/event-controller.js.map +1 -0
- package/dist/browser/index.d.ts +2 -0
- package/dist/browser/index.d.ts.map +1 -0
- package/dist/browser/index.js +14 -0
- package/dist/browser/index.js.map +1 -0
- package/dist/browser/link-interceptor.d.ts +38 -0
- package/dist/browser/link-interceptor.d.ts.map +1 -0
- package/dist/browser/link-interceptor.js +99 -0
- package/dist/browser/link-interceptor.js.map +1 -0
- package/dist/browser/logging.d.ts +10 -0
- package/dist/browser/logging.d.ts.map +1 -0
- package/dist/browser/logging.js +29 -0
- package/dist/browser/logging.js.map +1 -0
- package/dist/browser/lru-cache.d.ts +17 -0
- package/dist/browser/lru-cache.d.ts.map +1 -0
- package/dist/browser/lru-cache.js +50 -0
- package/dist/browser/lru-cache.js.map +1 -0
- package/dist/browser/merge-segment-loaders.d.ts +39 -0
- package/dist/browser/merge-segment-loaders.d.ts.map +1 -0
- package/dist/browser/merge-segment-loaders.js +102 -0
- package/dist/browser/merge-segment-loaders.js.map +1 -0
- package/dist/browser/navigation-bridge.d.ts +102 -0
- package/dist/browser/navigation-bridge.d.ts.map +1 -0
- package/dist/browser/navigation-bridge.js +708 -0
- package/dist/browser/navigation-bridge.js.map +1 -0
- package/dist/browser/navigation-client.d.ts +25 -0
- package/dist/browser/navigation-client.d.ts.map +1 -0
- package/dist/browser/navigation-client.js +157 -0
- package/dist/browser/navigation-client.js.map +1 -0
- package/dist/browser/navigation-store.d.ts +101 -0
- package/dist/browser/navigation-store.d.ts.map +1 -0
- package/dist/browser/navigation-store.js +625 -0
- package/dist/browser/navigation-store.js.map +1 -0
- package/dist/browser/partial-update.d.ts +75 -0
- package/dist/browser/partial-update.d.ts.map +1 -0
- package/dist/browser/partial-update.js +426 -0
- package/dist/browser/partial-update.js.map +1 -0
- package/dist/browser/react/Link.d.ts +86 -0
- package/dist/browser/react/Link.d.ts.map +1 -0
- package/dist/browser/react/Link.js +128 -0
- package/dist/browser/react/Link.js.map +1 -0
- package/dist/browser/react/NavigationProvider.d.ts +63 -0
- package/dist/browser/react/NavigationProvider.d.ts.map +1 -0
- package/dist/browser/react/NavigationProvider.js +216 -0
- package/dist/browser/react/NavigationProvider.js.map +1 -0
- package/dist/browser/react/ScrollRestoration.d.ts +75 -0
- package/dist/browser/react/ScrollRestoration.d.ts.map +1 -0
- package/dist/browser/react/ScrollRestoration.js +57 -0
- package/dist/browser/react/ScrollRestoration.js.map +1 -0
- package/dist/browser/react/context.d.ts +46 -0
- package/dist/browser/react/context.d.ts.map +1 -0
- package/dist/browser/react/context.js +10 -0
- package/dist/browser/react/context.js.map +1 -0
- package/dist/browser/react/index.d.ts +11 -0
- package/dist/browser/react/index.d.ts.map +1 -0
- package/dist/browser/react/index.js +22 -0
- package/dist/browser/react/index.js.map +1 -0
- package/dist/browser/react/location-state-shared.d.ts +63 -0
- package/dist/browser/react/location-state-shared.d.ts.map +1 -0
- package/dist/browser/react/location-state-shared.js +81 -0
- package/dist/browser/react/location-state-shared.js.map +1 -0
- package/dist/browser/react/location-state.d.ts +23 -0
- package/dist/browser/react/location-state.d.ts.map +1 -0
- package/dist/browser/react/location-state.js +29 -0
- package/dist/browser/react/location-state.js.map +1 -0
- package/dist/browser/react/mount-context.d.ts +24 -0
- package/dist/browser/react/mount-context.d.ts.map +1 -0
- package/dist/browser/react/mount-context.js +24 -0
- package/dist/browser/react/mount-context.js.map +1 -0
- package/dist/browser/react/use-action.d.ts +64 -0
- package/dist/browser/react/use-action.d.ts.map +1 -0
- package/dist/browser/react/use-action.js +134 -0
- package/dist/browser/react/use-action.js.map +1 -0
- package/dist/browser/react/use-client-cache.d.ts +41 -0
- package/dist/browser/react/use-client-cache.d.ts.map +1 -0
- package/dist/browser/react/use-client-cache.js +39 -0
- package/dist/browser/react/use-client-cache.js.map +1 -0
- package/dist/browser/react/use-handle.d.ts +31 -0
- package/dist/browser/react/use-handle.d.ts.map +1 -0
- package/dist/browser/react/use-handle.js +144 -0
- package/dist/browser/react/use-handle.js.map +1 -0
- package/dist/browser/react/use-href.d.ts +33 -0
- package/dist/browser/react/use-href.d.ts.map +1 -0
- package/dist/browser/react/use-href.js +39 -0
- package/dist/browser/react/use-href.js.map +1 -0
- package/dist/browser/react/use-link-status.d.ts +37 -0
- package/dist/browser/react/use-link-status.d.ts.map +1 -0
- package/dist/browser/react/use-link-status.js +99 -0
- package/dist/browser/react/use-link-status.js.map +1 -0
- package/dist/browser/react/use-mount.d.ts +25 -0
- package/dist/browser/react/use-mount.d.ts.map +1 -0
- package/dist/browser/react/use-mount.js +30 -0
- package/dist/browser/react/use-mount.js.map +1 -0
- package/dist/browser/react/use-navigation.d.ts +27 -0
- package/dist/browser/react/use-navigation.d.ts.map +1 -0
- package/dist/browser/react/use-navigation.js +87 -0
- package/dist/browser/react/use-navigation.js.map +1 -0
- package/dist/browser/react/use-segments.d.ts +38 -0
- package/dist/browser/react/use-segments.d.ts.map +1 -0
- package/dist/browser/react/use-segments.js +130 -0
- package/dist/browser/react/use-segments.js.map +1 -0
- package/dist/browser/request-controller.d.ts +26 -0
- package/dist/browser/request-controller.d.ts.map +1 -0
- package/dist/browser/request-controller.js +147 -0
- package/dist/browser/request-controller.js.map +1 -0
- package/dist/browser/rsc-router.d.ts +129 -0
- package/dist/browser/rsc-router.d.ts.map +1 -0
- package/dist/browser/rsc-router.js +195 -0
- package/dist/browser/rsc-router.js.map +1 -0
- package/dist/browser/scroll-restoration.d.ts +93 -0
- package/dist/browser/scroll-restoration.d.ts.map +1 -0
- package/dist/browser/scroll-restoration.js +321 -0
- package/dist/browser/scroll-restoration.js.map +1 -0
- package/dist/browser/segment-structure-assert.d.ts +17 -0
- package/dist/browser/segment-structure-assert.d.ts.map +1 -0
- package/dist/browser/segment-structure-assert.js +59 -0
- package/dist/browser/segment-structure-assert.js.map +1 -0
- package/dist/browser/server-action-bridge.d.ts +26 -0
- package/dist/browser/server-action-bridge.d.ts.map +1 -0
- package/dist/browser/server-action-bridge.js +668 -0
- package/dist/browser/server-action-bridge.js.map +1 -0
- package/dist/browser/shallow.d.ts +12 -0
- package/dist/browser/shallow.d.ts.map +1 -0
- package/dist/browser/shallow.js +34 -0
- package/dist/browser/shallow.js.map +1 -0
- package/dist/browser/types.d.ts +369 -0
- package/dist/browser/types.d.ts.map +1 -0
- package/dist/browser/types.js +2 -0
- package/dist/browser/types.js.map +1 -0
- package/dist/build/__tests__/generate-cli.test.d.ts +2 -0
- package/dist/build/__tests__/generate-cli.test.d.ts.map +1 -0
- package/dist/build/__tests__/generate-cli.test.js +237 -0
- package/dist/build/__tests__/generate-cli.test.js.map +1 -0
- package/dist/build/__tests__/generate-manifest.test.d.ts +2 -0
- package/dist/build/__tests__/generate-manifest.test.d.ts.map +1 -0
- package/dist/build/__tests__/generate-manifest.test.js +119 -0
- package/dist/build/__tests__/generate-manifest.test.js.map +1 -0
- package/dist/build/__tests__/generate-route-types.test.d.ts +2 -0
- package/dist/build/__tests__/generate-route-types.test.d.ts.map +1 -0
- package/dist/build/__tests__/generate-route-types.test.js +620 -0
- package/dist/build/__tests__/generate-route-types.test.js.map +1 -0
- package/dist/build/__tests__/per-router-manifest.test.d.ts +2 -0
- package/dist/build/__tests__/per-router-manifest.test.d.ts.map +1 -0
- package/dist/build/__tests__/per-router-manifest.test.js +308 -0
- package/dist/build/__tests__/per-router-manifest.test.js.map +1 -0
- package/dist/build/generate-manifest.d.ts +81 -0
- package/dist/build/generate-manifest.d.ts.map +1 -0
- package/dist/build/generate-manifest.js +276 -0
- package/dist/build/generate-manifest.js.map +1 -0
- package/dist/build/generate-route-types.d.ts +115 -0
- package/dist/build/generate-route-types.d.ts.map +1 -0
- package/dist/build/generate-route-types.js +740 -0
- package/dist/build/generate-route-types.js.map +1 -0
- package/dist/build/index.d.ts +21 -0
- package/dist/build/index.d.ts.map +1 -0
- package/dist/build/index.js +21 -0
- package/dist/build/index.js.map +1 -0
- package/dist/build/route-trie.d.ts +71 -0
- package/dist/build/route-trie.d.ts.map +1 -0
- package/dist/build/route-trie.js +175 -0
- package/dist/build/route-trie.js.map +1 -0
- package/dist/cache/__tests__/cache-scope.test.d.ts +2 -0
- package/dist/cache/__tests__/cache-scope.test.d.ts.map +1 -0
- package/dist/cache/__tests__/cache-scope.test.js +208 -0
- package/dist/cache/__tests__/cache-scope.test.js.map +1 -0
- package/dist/cache/__tests__/document-cache.test.d.ts +2 -0
- package/dist/cache/__tests__/document-cache.test.d.ts.map +1 -0
- package/dist/cache/__tests__/document-cache.test.js +345 -0
- package/dist/cache/__tests__/document-cache.test.js.map +1 -0
- package/dist/cache/__tests__/memory-segment-store.test.d.ts +2 -0
- package/dist/cache/__tests__/memory-segment-store.test.d.ts.map +1 -0
- package/dist/cache/__tests__/memory-segment-store.test.js +425 -0
- package/dist/cache/__tests__/memory-segment-store.test.js.map +1 -0
- package/dist/cache/__tests__/memory-store.test.d.ts +2 -0
- package/dist/cache/__tests__/memory-store.test.d.ts.map +1 -0
- package/dist/cache/__tests__/memory-store.test.js +367 -0
- package/dist/cache/__tests__/memory-store.test.js.map +1 -0
- package/dist/cache/cache-scope.d.ts +102 -0
- package/dist/cache/cache-scope.d.ts.map +1 -0
- package/dist/cache/cache-scope.js +440 -0
- package/dist/cache/cache-scope.js.map +1 -0
- package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts +2 -0
- package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts.map +1 -0
- package/dist/cache/cf/__tests__/cf-cache-store.test.js +330 -0
- package/dist/cache/cf/__tests__/cf-cache-store.test.js.map +1 -0
- package/dist/cache/cf/cf-cache-store.d.ts +165 -0
- package/dist/cache/cf/cf-cache-store.d.ts.map +1 -0
- package/dist/cache/cf/cf-cache-store.js +242 -0
- package/dist/cache/cf/cf-cache-store.js.map +1 -0
- package/dist/cache/cf/index.d.ts +14 -0
- package/dist/cache/cf/index.d.ts.map +1 -0
- package/dist/cache/cf/index.js +17 -0
- package/dist/cache/cf/index.js.map +1 -0
- package/dist/cache/document-cache.d.ts +64 -0
- package/dist/cache/document-cache.d.ts.map +1 -0
- package/dist/cache/document-cache.js +228 -0
- package/dist/cache/document-cache.js.map +1 -0
- package/dist/cache/index.d.ts +19 -0
- package/dist/cache/index.d.ts.map +1 -0
- package/dist/cache/index.js +21 -0
- package/dist/cache/index.js.map +1 -0
- package/dist/cache/memory-segment-store.d.ts +110 -0
- package/dist/cache/memory-segment-store.d.ts.map +1 -0
- package/dist/cache/memory-segment-store.js +117 -0
- package/dist/cache/memory-segment-store.js.map +1 -0
- package/dist/cache/memory-store.d.ts +41 -0
- package/dist/cache/memory-store.d.ts.map +1 -0
- package/dist/cache/memory-store.js +191 -0
- package/dist/cache/memory-store.js.map +1 -0
- package/dist/cache/types.d.ts +317 -0
- package/dist/cache/types.d.ts.map +1 -0
- package/dist/cache/types.js +12 -0
- package/dist/cache/types.js.map +1 -0
- package/dist/client.d.ts +248 -0
- package/dist/client.d.ts.map +1 -0
- package/dist/client.js +367 -0
- package/dist/client.js.map +1 -0
- package/dist/client.rsc.d.ts +26 -0
- package/dist/client.rsc.d.ts.map +1 -0
- package/dist/client.rsc.js +46 -0
- package/dist/client.rsc.js.map +1 -0
- package/dist/component-utils.d.ts +36 -0
- package/dist/component-utils.d.ts.map +1 -0
- package/dist/component-utils.js +61 -0
- package/dist/component-utils.js.map +1 -0
- package/dist/components/DefaultDocument.d.ts +13 -0
- package/dist/components/DefaultDocument.d.ts.map +1 -0
- package/dist/components/DefaultDocument.js +15 -0
- package/dist/components/DefaultDocument.js.map +1 -0
- package/dist/debug.d.ts +58 -0
- package/dist/debug.d.ts.map +1 -0
- package/dist/debug.js +157 -0
- package/dist/debug.js.map +1 -0
- package/dist/default-error-boundary.d.ts +11 -0
- package/dist/default-error-boundary.d.ts.map +1 -0
- package/dist/default-error-boundary.js +45 -0
- package/dist/default-error-boundary.js.map +1 -0
- package/dist/deps/browser.d.ts +2 -0
- package/dist/deps/browser.d.ts.map +1 -0
- package/dist/deps/browser.js +3 -0
- package/dist/deps/browser.js.map +1 -0
- package/dist/deps/html-stream-client.d.ts +2 -0
- package/dist/deps/html-stream-client.d.ts.map +1 -0
- package/dist/deps/html-stream-client.js +3 -0
- package/dist/deps/html-stream-client.js.map +1 -0
- package/dist/deps/html-stream-server.d.ts +2 -0
- package/dist/deps/html-stream-server.d.ts.map +1 -0
- package/dist/deps/html-stream-server.js +3 -0
- package/dist/deps/html-stream-server.js.map +1 -0
- package/dist/deps/rsc.d.ts +2 -0
- package/dist/deps/rsc.d.ts.map +1 -0
- package/dist/deps/rsc.js +4 -0
- package/dist/deps/rsc.js.map +1 -0
- package/dist/deps/ssr.d.ts +2 -0
- package/dist/deps/ssr.d.ts.map +1 -0
- package/dist/deps/ssr.js +3 -0
- package/dist/deps/ssr.js.map +1 -0
- package/dist/errors.d.ts +174 -0
- package/dist/errors.d.ts.map +1 -0
- package/dist/errors.js +241 -0
- package/dist/errors.js.map +1 -0
- package/dist/handle.d.ts +78 -0
- package/dist/handle.d.ts.map +1 -0
- package/dist/handle.js +82 -0
- package/dist/handle.js.map +1 -0
- package/dist/handles/MetaTags.d.ts +14 -0
- package/dist/handles/MetaTags.d.ts.map +1 -0
- package/dist/handles/MetaTags.js +136 -0
- package/dist/handles/MetaTags.js.map +1 -0
- package/dist/handles/index.d.ts +6 -0
- package/dist/handles/index.d.ts.map +1 -0
- package/dist/handles/index.js +6 -0
- package/dist/handles/index.js.map +1 -0
- package/dist/handles/meta.d.ts +39 -0
- package/dist/handles/meta.d.ts.map +1 -0
- package/dist/handles/meta.js +202 -0
- package/dist/handles/meta.js.map +1 -0
- package/dist/host/__tests__/errors.test.d.ts +2 -0
- package/dist/host/__tests__/errors.test.d.ts.map +1 -0
- package/dist/host/__tests__/errors.test.js +76 -0
- package/dist/host/__tests__/errors.test.js.map +1 -0
- package/dist/host/__tests__/pattern-comprehensive.test.d.ts +2 -0
- package/dist/host/__tests__/pattern-comprehensive.test.d.ts.map +1 -0
- package/dist/host/__tests__/pattern-comprehensive.test.js +732 -0
- package/dist/host/__tests__/pattern-comprehensive.test.js.map +1 -0
- package/dist/host/__tests__/pattern-matcher.test.d.ts +2 -0
- package/dist/host/__tests__/pattern-matcher.test.d.ts.map +1 -0
- package/dist/host/__tests__/pattern-matcher.test.js +251 -0
- package/dist/host/__tests__/pattern-matcher.test.js.map +1 -0
- package/dist/host/__tests__/router.test.d.ts +2 -0
- package/dist/host/__tests__/router.test.d.ts.map +1 -0
- package/dist/host/__tests__/router.test.js +241 -0
- package/dist/host/__tests__/router.test.js.map +1 -0
- package/dist/host/__tests__/testing.test.d.ts +2 -0
- package/dist/host/__tests__/testing.test.d.ts.map +1 -0
- package/dist/host/__tests__/testing.test.js +64 -0
- package/dist/host/__tests__/testing.test.js.map +1 -0
- package/dist/host/__tests__/utils.test.d.ts +2 -0
- package/dist/host/__tests__/utils.test.d.ts.map +1 -0
- package/dist/host/__tests__/utils.test.js +29 -0
- package/dist/host/__tests__/utils.test.js.map +1 -0
- package/dist/host/cookie-handler.d.ts +34 -0
- package/dist/host/cookie-handler.d.ts.map +1 -0
- package/dist/host/cookie-handler.js +124 -0
- package/dist/host/cookie-handler.js.map +1 -0
- package/dist/host/errors.d.ts +56 -0
- package/dist/host/errors.d.ts.map +1 -0
- package/dist/host/errors.js +79 -0
- package/dist/host/errors.js.map +1 -0
- package/dist/host/index.d.ts +29 -0
- package/dist/host/index.d.ts.map +1 -0
- package/dist/host/index.js +32 -0
- package/dist/host/index.js.map +1 -0
- package/dist/host/pattern-matcher.d.ts +36 -0
- package/dist/host/pattern-matcher.d.ts.map +1 -0
- package/dist/host/pattern-matcher.js +172 -0
- package/dist/host/pattern-matcher.js.map +1 -0
- package/dist/host/router.d.ts +26 -0
- package/dist/host/router.d.ts.map +1 -0
- package/dist/host/router.js +218 -0
- package/dist/host/router.js.map +1 -0
- package/dist/host/testing.d.ts +36 -0
- package/dist/host/testing.d.ts.map +1 -0
- package/dist/host/testing.js +55 -0
- package/dist/host/testing.js.map +1 -0
- package/dist/host/types.d.ts +115 -0
- package/dist/host/types.d.ts.map +1 -0
- package/dist/host/types.js +7 -0
- package/dist/host/types.js.map +1 -0
- package/dist/host/utils.d.ts +21 -0
- package/dist/host/utils.d.ts.map +1 -0
- package/dist/host/utils.js +23 -0
- package/dist/host/utils.js.map +1 -0
- package/dist/href-client.d.ts +131 -0
- package/dist/href-client.d.ts.map +1 -0
- package/dist/href-client.js +64 -0
- package/dist/href-client.js.map +1 -0
- package/dist/href-context.d.ts +29 -0
- package/dist/href-context.d.ts.map +1 -0
- package/dist/href-context.js +21 -0
- package/dist/href-context.js.map +1 -0
- package/dist/index.d.ts +73 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +91 -0
- package/dist/index.js.map +1 -0
- package/dist/index.rsc.d.ts +32 -0
- package/dist/index.rsc.d.ts.map +1 -0
- package/dist/index.rsc.js +40 -0
- package/dist/index.rsc.js.map +1 -0
- package/dist/internal-debug.d.ts +2 -0
- package/dist/internal-debug.d.ts.map +1 -0
- package/dist/internal-debug.js +5 -0
- package/dist/internal-debug.js.map +1 -0
- package/dist/loader.d.ts +14 -0
- package/dist/loader.d.ts.map +1 -0
- package/dist/loader.js +20 -0
- package/dist/loader.js.map +1 -0
- package/dist/loader.rsc.d.ts +19 -0
- package/dist/loader.rsc.d.ts.map +1 -0
- package/dist/loader.rsc.js +99 -0
- package/dist/loader.rsc.js.map +1 -0
- package/dist/network-error-thrower.d.ts +17 -0
- package/dist/network-error-thrower.d.ts.map +1 -0
- package/dist/network-error-thrower.js +14 -0
- package/dist/network-error-thrower.js.map +1 -0
- package/dist/outlet-context.d.ts +13 -0
- package/dist/outlet-context.d.ts.map +1 -0
- package/dist/outlet-context.js +3 -0
- package/dist/outlet-context.js.map +1 -0
- package/dist/prerender/__tests__/param-hash.test.d.ts +2 -0
- package/dist/prerender/__tests__/param-hash.test.d.ts.map +1 -0
- package/dist/prerender/__tests__/param-hash.test.js +148 -0
- package/dist/prerender/__tests__/param-hash.test.js.map +1 -0
- package/dist/prerender/param-hash.d.ts +16 -0
- package/dist/prerender/param-hash.d.ts.map +1 -0
- package/dist/prerender/param-hash.js +36 -0
- package/dist/prerender/param-hash.js.map +1 -0
- package/dist/prerender/store.d.ts +38 -0
- package/dist/prerender/store.d.ts.map +1 -0
- package/dist/prerender/store.js +61 -0
- package/dist/prerender/store.js.map +1 -0
- package/dist/prerender.d.ts +66 -0
- package/dist/prerender.d.ts.map +1 -0
- package/dist/prerender.js +57 -0
- package/dist/prerender.js.map +1 -0
- package/dist/reverse.d.ts +196 -0
- package/dist/reverse.d.ts.map +1 -0
- package/dist/reverse.js +78 -0
- package/dist/reverse.js.map +1 -0
- package/dist/root-error-boundary.d.ts +33 -0
- package/dist/root-error-boundary.d.ts.map +1 -0
- package/dist/root-error-boundary.js +165 -0
- package/dist/root-error-boundary.js.map +1 -0
- package/dist/route-content-wrapper.d.ts +46 -0
- package/dist/route-content-wrapper.d.ts.map +1 -0
- package/dist/route-content-wrapper.js +77 -0
- package/dist/route-content-wrapper.js.map +1 -0
- package/dist/route-definition.d.ts +421 -0
- package/dist/route-definition.d.ts.map +1 -0
- package/dist/route-definition.js +868 -0
- package/dist/route-definition.js.map +1 -0
- package/dist/route-map-builder.d.ts +155 -0
- package/dist/route-map-builder.d.ts.map +1 -0
- package/dist/route-map-builder.js +237 -0
- package/dist/route-map-builder.js.map +1 -0
- package/dist/route-types.d.ts +165 -0
- package/dist/route-types.d.ts.map +1 -0
- package/dist/route-types.js +7 -0
- package/dist/route-types.js.map +1 -0
- package/dist/router/__tests__/handler-context.test.d.ts +2 -0
- package/dist/router/__tests__/handler-context.test.d.ts.map +1 -0
- package/dist/router/__tests__/handler-context.test.js +65 -0
- package/dist/router/__tests__/handler-context.test.js.map +1 -0
- package/dist/router/__tests__/loader-cycle-detection.test.d.ts +2 -0
- package/dist/router/__tests__/loader-cycle-detection.test.d.ts.map +1 -0
- package/dist/router/__tests__/loader-cycle-detection.test.js +221 -0
- package/dist/router/__tests__/loader-cycle-detection.test.js.map +1 -0
- package/dist/router/__tests__/match-context.test.d.ts +2 -0
- package/dist/router/__tests__/match-context.test.d.ts.map +1 -0
- package/dist/router/__tests__/match-context.test.js +92 -0
- package/dist/router/__tests__/match-context.test.js.map +1 -0
- package/dist/router/__tests__/match-pipelines.test.d.ts +2 -0
- package/dist/router/__tests__/match-pipelines.test.d.ts.map +1 -0
- package/dist/router/__tests__/match-pipelines.test.js +417 -0
- package/dist/router/__tests__/match-pipelines.test.js.map +1 -0
- package/dist/router/__tests__/match-result.test.d.ts +2 -0
- package/dist/router/__tests__/match-result.test.d.ts.map +1 -0
- package/dist/router/__tests__/match-result.test.js +457 -0
- package/dist/router/__tests__/match-result.test.js.map +1 -0
- package/dist/router/__tests__/on-error.test.d.ts +2 -0
- package/dist/router/__tests__/on-error.test.d.ts.map +1 -0
- package/dist/router/__tests__/on-error.test.js +678 -0
- package/dist/router/__tests__/on-error.test.js.map +1 -0
- package/dist/router/__tests__/pattern-matching.test.d.ts +2 -0
- package/dist/router/__tests__/pattern-matching.test.d.ts.map +1 -0
- package/dist/router/__tests__/pattern-matching.test.js +629 -0
- package/dist/router/__tests__/pattern-matching.test.js.map +1 -0
- package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts +2 -0
- package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts.map +1 -0
- package/dist/router/__tests__/segment-resolution-parallel-loading.test.js +155 -0
- package/dist/router/__tests__/segment-resolution-parallel-loading.test.js.map +1 -0
- package/dist/router/error-handling.d.ts +77 -0
- package/dist/router/error-handling.d.ts.map +1 -0
- package/dist/router/error-handling.js +202 -0
- package/dist/router/error-handling.js.map +1 -0
- package/dist/router/handler-context.d.ts +20 -0
- package/dist/router/handler-context.d.ts.map +1 -0
- package/dist/router/handler-context.js +198 -0
- package/dist/router/handler-context.js.map +1 -0
- package/dist/router/intercept-resolution.d.ts +66 -0
- package/dist/router/intercept-resolution.d.ts.map +1 -0
- package/dist/router/intercept-resolution.js +246 -0
- package/dist/router/intercept-resolution.js.map +1 -0
- package/dist/router/loader-resolution.d.ts +64 -0
- package/dist/router/loader-resolution.d.ts.map +1 -0
- package/dist/router/loader-resolution.js +284 -0
- package/dist/router/loader-resolution.js.map +1 -0
- package/dist/router/logging.d.ts +15 -0
- package/dist/router/logging.d.ts.map +1 -0
- package/dist/router/logging.js +99 -0
- package/dist/router/logging.js.map +1 -0
- package/dist/router/manifest.d.ts +22 -0
- package/dist/router/manifest.d.ts.map +1 -0
- package/dist/router/manifest.js +181 -0
- package/dist/router/manifest.js.map +1 -0
- package/dist/router/match-api.d.ts +35 -0
- package/dist/router/match-api.d.ts.map +1 -0
- package/dist/router/match-api.js +406 -0
- package/dist/router/match-api.js.map +1 -0
- package/dist/router/match-context.d.ts +206 -0
- package/dist/router/match-context.d.ts.map +1 -0
- package/dist/router/match-context.js +17 -0
- package/dist/router/match-context.js.map +1 -0
- package/dist/router/match-middleware/background-revalidation.d.ts +127 -0
- package/dist/router/match-middleware/background-revalidation.d.ts.map +1 -0
- package/dist/router/match-middleware/background-revalidation.js +75 -0
- package/dist/router/match-middleware/background-revalidation.js.map +1 -0
- package/dist/router/match-middleware/cache-lookup.d.ts +112 -0
- package/dist/router/match-middleware/cache-lookup.d.ts.map +1 -0
- package/dist/router/match-middleware/cache-lookup.js +257 -0
- package/dist/router/match-middleware/cache-lookup.js.map +1 -0
- package/dist/router/match-middleware/cache-store.d.ts +113 -0
- package/dist/router/match-middleware/cache-store.d.ts.map +1 -0
- package/dist/router/match-middleware/cache-store.js +108 -0
- package/dist/router/match-middleware/cache-store.js.map +1 -0
- package/dist/router/match-middleware/index.d.ts +81 -0
- package/dist/router/match-middleware/index.d.ts.map +1 -0
- package/dist/router/match-middleware/index.js +80 -0
- package/dist/router/match-middleware/index.js.map +1 -0
- package/dist/router/match-middleware/intercept-resolution.d.ts +117 -0
- package/dist/router/match-middleware/intercept-resolution.d.ts.map +1 -0
- package/dist/router/match-middleware/intercept-resolution.js +134 -0
- package/dist/router/match-middleware/intercept-resolution.js.map +1 -0
- package/dist/router/match-middleware/segment-resolution.d.ts +99 -0
- package/dist/router/match-middleware/segment-resolution.d.ts.map +1 -0
- package/dist/router/match-middleware/segment-resolution.js +53 -0
- package/dist/router/match-middleware/segment-resolution.js.map +1 -0
- package/dist/router/match-pipelines.d.ts +147 -0
- package/dist/router/match-pipelines.d.ts.map +1 -0
- package/dist/router/match-pipelines.js +82 -0
- package/dist/router/match-pipelines.js.map +1 -0
- package/dist/router/match-result.d.ts +126 -0
- package/dist/router/match-result.d.ts.map +1 -0
- package/dist/router/match-result.js +93 -0
- package/dist/router/match-result.js.map +1 -0
- package/dist/router/metrics.d.ts +20 -0
- package/dist/router/metrics.d.ts.map +1 -0
- package/dist/router/metrics.js +47 -0
- package/dist/router/metrics.js.map +1 -0
- package/dist/router/middleware.d.ts +249 -0
- package/dist/router/middleware.d.ts.map +1 -0
- package/dist/router/middleware.js +434 -0
- package/dist/router/middleware.js.map +1 -0
- package/dist/router/middleware.test.d.ts +2 -0
- package/dist/router/middleware.test.d.ts.map +1 -0
- package/dist/router/middleware.test.js +816 -0
- package/dist/router/middleware.test.js.map +1 -0
- package/dist/router/pattern-matching.d.ts +149 -0
- package/dist/router/pattern-matching.d.ts.map +1 -0
- package/dist/router/pattern-matching.js +349 -0
- package/dist/router/pattern-matching.js.map +1 -0
- package/dist/router/revalidation.d.ts +44 -0
- package/dist/router/revalidation.d.ts.map +1 -0
- package/dist/router/revalidation.js +147 -0
- package/dist/router/revalidation.js.map +1 -0
- package/dist/router/router-context.d.ts +135 -0
- package/dist/router/router-context.d.ts.map +1 -0
- package/dist/router/router-context.js +36 -0
- package/dist/router/router-context.js.map +1 -0
- package/dist/router/segment-resolution.d.ts +127 -0
- package/dist/router/segment-resolution.d.ts.map +1 -0
- package/dist/router/segment-resolution.js +919 -0
- package/dist/router/segment-resolution.js.map +1 -0
- package/dist/router/trie-matching.d.ts +40 -0
- package/dist/router/trie-matching.d.ts.map +1 -0
- package/dist/router/trie-matching.js +127 -0
- package/dist/router/trie-matching.js.map +1 -0
- package/dist/router/types.d.ts +136 -0
- package/dist/router/types.d.ts.map +1 -0
- package/dist/router/types.js +7 -0
- package/dist/router/types.js.map +1 -0
- package/dist/router.d.ts +753 -0
- package/dist/router.d.ts.map +1 -0
- package/dist/router.gen.d.ts +6 -0
- package/dist/router.gen.d.ts.map +1 -0
- package/dist/router.gen.js +6 -0
- package/dist/router.gen.js.map +1 -0
- package/dist/router.js +1304 -0
- package/dist/router.js.map +1 -0
- package/dist/rsc/__tests__/helpers.test.d.ts +2 -0
- package/dist/rsc/__tests__/helpers.test.d.ts.map +1 -0
- package/dist/rsc/__tests__/helpers.test.js +140 -0
- package/dist/rsc/__tests__/helpers.test.js.map +1 -0
- package/dist/rsc/handler.d.ts +45 -0
- package/dist/rsc/handler.d.ts.map +1 -0
- package/dist/rsc/handler.js +1172 -0
- package/dist/rsc/handler.js.map +1 -0
- package/dist/rsc/helpers.d.ts +16 -0
- package/dist/rsc/helpers.d.ts.map +1 -0
- package/dist/rsc/helpers.js +55 -0
- package/dist/rsc/helpers.js.map +1 -0
- package/dist/rsc/index.d.ts +22 -0
- package/dist/rsc/index.d.ts.map +1 -0
- package/dist/rsc/index.js +23 -0
- package/dist/rsc/index.js.map +1 -0
- package/dist/rsc/nonce.d.ts +9 -0
- package/dist/rsc/nonce.d.ts.map +1 -0
- package/dist/rsc/nonce.js +18 -0
- package/dist/rsc/nonce.js.map +1 -0
- package/dist/rsc/types.d.ts +206 -0
- package/dist/rsc/types.d.ts.map +1 -0
- package/dist/rsc/types.js +8 -0
- package/dist/rsc/types.js.map +1 -0
- package/dist/search-params.d.ts +103 -0
- package/dist/search-params.d.ts.map +1 -0
- package/dist/search-params.js +74 -0
- package/dist/search-params.js.map +1 -0
- package/dist/segment-system.d.ts +75 -0
- package/dist/segment-system.d.ts.map +1 -0
- package/dist/segment-system.js +336 -0
- package/dist/segment-system.js.map +1 -0
- package/dist/server/context.d.ts +245 -0
- package/dist/server/context.d.ts.map +1 -0
- package/dist/server/context.js +197 -0
- package/dist/server/context.js.map +1 -0
- package/dist/server/fetchable-loader-store.d.ts +18 -0
- package/dist/server/fetchable-loader-store.d.ts.map +1 -0
- package/dist/server/fetchable-loader-store.js +18 -0
- package/dist/server/fetchable-loader-store.js.map +1 -0
- package/dist/server/handle-store.d.ts +85 -0
- package/dist/server/handle-store.d.ts.map +1 -0
- package/dist/server/handle-store.js +142 -0
- package/dist/server/handle-store.js.map +1 -0
- package/dist/server/loader-registry.d.ts +55 -0
- package/dist/server/loader-registry.d.ts.map +1 -0
- package/dist/server/loader-registry.js +132 -0
- package/dist/server/loader-registry.js.map +1 -0
- package/dist/server/request-context.d.ts +226 -0
- package/dist/server/request-context.d.ts.map +1 -0
- package/dist/server/request-context.js +290 -0
- package/dist/server/request-context.js.map +1 -0
- package/dist/server/root-layout.d.ts +4 -0
- package/dist/server/root-layout.d.ts.map +1 -0
- package/dist/server/root-layout.js +5 -0
- package/dist/server/root-layout.js.map +1 -0
- package/dist/server.d.ts +15 -0
- package/dist/server.d.ts.map +1 -0
- package/dist/server.js +20 -0
- package/dist/server.js.map +1 -0
- package/dist/ssr/__tests__/ssr-handler.test.d.ts +2 -0
- package/dist/ssr/__tests__/ssr-handler.test.d.ts.map +1 -0
- package/dist/ssr/__tests__/ssr-handler.test.js +132 -0
- package/dist/ssr/__tests__/ssr-handler.test.js.map +1 -0
- package/dist/ssr/index.d.ts +98 -0
- package/dist/ssr/index.d.ts.map +1 -0
- package/dist/ssr/index.js +158 -0
- package/dist/ssr/index.js.map +1 -0
- package/dist/static-handler.d.ts +50 -0
- package/dist/static-handler.d.ts.map +1 -0
- package/dist/static-handler.gen.d.ts +5 -0
- package/dist/static-handler.gen.d.ts.map +1 -0
- package/dist/static-handler.gen.js +5 -0
- package/dist/static-handler.gen.js.map +1 -0
- package/dist/static-handler.js +29 -0
- package/dist/static-handler.js.map +1 -0
- package/dist/testing/vitest.js +48 -0
- package/dist/theme/ThemeProvider.d.ts +20 -0
- package/dist/theme/ThemeProvider.d.ts.map +1 -0
- package/dist/theme/ThemeProvider.js +240 -0
- package/dist/theme/ThemeProvider.js.map +1 -0
- package/dist/theme/ThemeScript.d.ts +48 -0
- package/dist/theme/ThemeScript.d.ts.map +1 -0
- package/dist/theme/ThemeScript.js +13 -0
- package/dist/theme/ThemeScript.js.map +1 -0
- package/dist/theme/__tests__/theme.test.d.ts +2 -0
- package/dist/theme/__tests__/theme.test.d.ts.map +1 -0
- package/dist/theme/__tests__/theme.test.js +103 -0
- package/dist/theme/__tests__/theme.test.js.map +1 -0
- package/dist/theme/constants.d.ts +29 -0
- package/dist/theme/constants.d.ts.map +1 -0
- package/dist/theme/constants.js +48 -0
- package/dist/theme/constants.js.map +1 -0
- package/dist/theme/index.d.ts +31 -0
- package/dist/theme/index.d.ts.map +1 -0
- package/dist/theme/index.js +36 -0
- package/dist/theme/index.js.map +1 -0
- package/dist/theme/theme-context.d.ts +40 -0
- package/dist/theme/theme-context.d.ts.map +1 -0
- package/dist/theme/theme-context.js +60 -0
- package/dist/theme/theme-context.js.map +1 -0
- package/dist/theme/theme-script.d.ts +27 -0
- package/dist/theme/theme-script.d.ts.map +1 -0
- package/dist/theme/theme-script.js +147 -0
- package/dist/theme/theme-script.js.map +1 -0
- package/dist/theme/types.d.ts +163 -0
- package/dist/theme/types.d.ts.map +1 -0
- package/dist/theme/types.js +11 -0
- package/dist/theme/types.js.map +1 -0
- package/dist/theme/use-theme.d.ts +12 -0
- package/dist/theme/use-theme.d.ts.map +1 -0
- package/dist/theme/use-theme.js +40 -0
- package/dist/theme/use-theme.js.map +1 -0
- package/dist/types.d.ts +1479 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +10 -0
- package/dist/types.js.map +1 -0
- package/dist/urls.d.ts +441 -0
- package/dist/urls.d.ts.map +1 -0
- package/dist/urls.gen.d.ts +8 -0
- package/dist/urls.gen.d.ts.map +1 -0
- package/dist/urls.gen.js +8 -0
- package/dist/urls.gen.js.map +1 -0
- package/dist/urls.js +443 -0
- package/dist/urls.js.map +1 -0
- package/dist/use-loader.d.ts +127 -0
- package/dist/use-loader.d.ts.map +1 -0
- package/dist/use-loader.js +237 -0
- package/dist/use-loader.js.map +1 -0
- package/dist/vite/__tests__/ast-handler-extract.test.d.ts +2 -0
- package/dist/vite/__tests__/ast-handler-extract.test.d.ts.map +1 -0
- package/dist/vite/__tests__/ast-handler-extract.test.js +294 -0
- package/dist/vite/__tests__/ast-handler-extract.test.js.map +1 -0
- package/dist/vite/__tests__/expose-id-utils.test.d.ts +2 -0
- package/dist/vite/__tests__/expose-id-utils.test.d.ts.map +1 -0
- package/dist/vite/__tests__/expose-id-utils.test.js +224 -0
- package/dist/vite/__tests__/expose-id-utils.test.js.map +1 -0
- package/dist/vite/__tests__/expose-internal-ids.test.d.ts +2 -0
- package/dist/vite/__tests__/expose-internal-ids.test.d.ts.map +1 -0
- package/dist/vite/__tests__/expose-internal-ids.test.js +647 -0
- package/dist/vite/__tests__/expose-internal-ids.test.js.map +1 -0
- package/dist/vite/__tests__/expose-router-id.test.d.ts +2 -0
- package/dist/vite/__tests__/expose-router-id.test.d.ts.map +1 -0
- package/dist/vite/__tests__/expose-router-id.test.js +39 -0
- package/dist/vite/__tests__/expose-router-id.test.js.map +1 -0
- package/dist/vite/ast-handler-extract.d.ts +49 -0
- package/dist/vite/ast-handler-extract.d.ts.map +1 -0
- package/dist/vite/ast-handler-extract.js +249 -0
- package/dist/vite/ast-handler-extract.js.map +1 -0
- package/dist/vite/expose-action-id.d.ts +19 -0
- package/dist/vite/expose-action-id.d.ts.map +1 -0
- package/dist/vite/expose-action-id.js +250 -0
- package/dist/vite/expose-action-id.js.map +1 -0
- package/dist/vite/expose-id-utils.d.ts +69 -0
- package/dist/vite/expose-id-utils.d.ts.map +1 -0
- package/dist/vite/expose-id-utils.js +289 -0
- package/dist/vite/expose-id-utils.js.map +1 -0
- package/dist/vite/expose-internal-ids.d.ts +22 -0
- package/dist/vite/expose-internal-ids.d.ts.map +1 -0
- package/dist/vite/expose-internal-ids.js +886 -0
- package/dist/vite/expose-internal-ids.js.map +1 -0
- package/dist/vite/index.d.ts +149 -0
- package/dist/vite/index.d.ts.map +1 -0
- package/dist/vite/index.js +2309 -833
- package/dist/vite/index.js.bak +5448 -0
- package/dist/vite/index.js.map +1 -0
- package/dist/vite/index.named-routes.gen.ts +103 -0
- package/dist/vite/package-resolution.d.ts +43 -0
- package/dist/vite/package-resolution.d.ts.map +1 -0
- package/dist/vite/package-resolution.js +112 -0
- package/dist/vite/package-resolution.js.map +1 -0
- package/dist/vite/plugins/cloudflare-protocol-loader-hook.mjs +76 -0
- package/dist/vite/virtual-entries.d.ts +25 -0
- package/dist/vite/virtual-entries.d.ts.map +1 -0
- package/dist/vite/virtual-entries.js +110 -0
- package/dist/vite/virtual-entries.js.map +1 -0
- package/package.json +57 -11
- package/skills/breadcrumbs/SKILL.md +3 -1
- package/skills/bundle-analysis/SKILL.md +159 -0
- package/skills/cache-guide/SKILL.md +220 -30
- package/skills/caching/SKILL.md +116 -8
- package/skills/composability/SKILL.md +27 -2
- package/skills/document-cache/SKILL.md +78 -55
- package/skills/handler-use/SKILL.md +364 -0
- package/skills/hooks/SKILL.md +229 -20
- package/skills/host-router/SKILL.md +45 -20
- package/skills/i18n/SKILL.md +276 -0
- package/skills/intercept/SKILL.md +46 -4
- package/skills/layout/SKILL.md +28 -7
- package/skills/links/SKILL.md +247 -17
- package/skills/loader/SKILL.md +219 -9
- package/skills/middleware/SKILL.md +47 -12
- package/skills/migrate-nextjs/SKILL.md +562 -0
- package/skills/migrate-react-router/SKILL.md +769 -0
- package/skills/mime-routes/SKILL.md +27 -0
- package/skills/observability/SKILL.md +137 -0
- package/skills/parallel/SKILL.md +71 -6
- package/skills/prerender/SKILL.md +14 -33
- package/skills/rango/SKILL.md +242 -22
- package/skills/react-compiler/SKILL.md +168 -0
- package/skills/response-routes/SKILL.md +66 -9
- package/skills/route/SKILL.md +57 -4
- package/skills/router-setup/SKILL.md +3 -3
- package/skills/server-actions/SKILL.md +751 -0
- package/skills/streams-and-websockets/SKILL.md +283 -0
- package/skills/testing/SKILL.md +599 -0
- package/skills/typesafety/SKILL.md +319 -27
- package/skills/use-cache/SKILL.md +34 -5
- package/skills/view-transitions/SKILL.md +294 -0
- package/src/__augment-tests__/augment.ts +81 -0
- package/src/__augment-tests__/augmented.check.ts +117 -0
- package/src/browser/action-coordinator.ts +53 -36
- package/src/browser/app-shell.ts +52 -0
- package/src/browser/event-controller.ts +86 -70
- package/src/browser/history-state.ts +21 -0
- package/src/browser/index.ts +3 -3
- package/src/browser/navigation-bridge.ts +86 -11
- package/src/browser/navigation-client.ts +76 -28
- package/src/browser/navigation-store.ts +32 -9
- package/src/browser/navigation-transaction.ts +10 -28
- package/src/browser/partial-update.ts +64 -26
- package/src/browser/prefetch/cache.ts +129 -21
- package/src/browser/prefetch/fetch.ts +148 -16
- package/src/browser/prefetch/queue.ts +36 -5
- package/src/browser/rango-state.ts +53 -13
- package/src/browser/react/Link.tsx +30 -2
- package/src/browser/react/NavigationProvider.tsx +72 -31
- package/src/browser/react/filter-segment-order.ts +51 -7
- package/src/browser/react/index.ts +3 -0
- package/src/browser/react/location-state-shared.ts +175 -4
- package/src/browser/react/location-state.ts +39 -13
- package/src/browser/react/use-handle.ts +17 -9
- package/src/browser/react/use-navigation.ts +22 -2
- package/src/browser/react/use-params.ts +20 -8
- package/src/browser/react/use-reverse.ts +106 -0
- package/src/browser/react/use-router.ts +22 -2
- package/src/browser/react/use-segments.ts +11 -8
- package/src/browser/response-adapter.ts +25 -0
- package/src/browser/rsc-router.tsx +64 -22
- package/src/browser/scroll-restoration.ts +22 -14
- package/src/browser/segment-reconciler.ts +36 -14
- package/src/browser/segment-structure-assert.ts +2 -2
- package/src/browser/server-action-bridge.ts +23 -30
- package/src/browser/types.ts +21 -0
- package/src/build/collect-fallback-refs.ts +107 -0
- package/src/build/generate-manifest.ts +60 -35
- package/src/build/generate-route-types.ts +2 -0
- package/src/build/index.ts +2 -0
- package/src/build/route-trie.ts +52 -25
- package/src/build/route-types/codegen.ts +4 -4
- package/src/build/route-types/include-resolution.ts +1 -1
- package/src/build/route-types/per-module-writer.ts +7 -4
- package/src/build/route-types/router-processing.ts +55 -14
- package/src/build/route-types/scan-filter.ts +1 -1
- package/src/build/route-types/source-scan.ts +118 -0
- package/src/build/runtime-discovery.ts +9 -20
- package/src/cache/cache-scope.ts +28 -42
- package/src/cache/cf/cf-cache-store.ts +54 -13
- package/src/client.rsc.tsx +3 -0
- package/src/client.tsx +92 -182
- package/src/context-var.ts +5 -5
- package/src/decode-loader-results.ts +36 -0
- package/src/errors.ts +30 -1
- package/src/handle.ts +26 -13
- package/src/host/index.ts +2 -2
- package/src/host/router.ts +129 -57
- package/src/host/types.ts +31 -2
- package/src/host/utils.ts +1 -1
- package/src/href-client.ts +140 -20
- package/src/index.rsc.ts +9 -4
- package/src/index.ts +57 -15
- package/src/loader-store.ts +500 -0
- package/src/loader.rsc.ts +2 -5
- package/src/loader.ts +3 -10
- package/src/missing-id-error.ts +68 -0
- package/src/outlet-context.ts +1 -1
- package/src/prerender.ts +4 -4
- package/src/response-utils.ts +37 -0
- package/src/reverse.ts +65 -36
- package/src/route-content-wrapper.tsx +6 -28
- package/src/route-definition/dsl-helpers.ts +384 -257
- package/src/route-definition/helper-factories.ts +29 -139
- package/src/route-definition/helpers-types.ts +100 -28
- package/src/route-definition/resolve-handler-use.ts +6 -0
- package/src/route-definition/use-item-types.ts +32 -0
- package/src/route-types.ts +26 -41
- package/src/router/basename.ts +14 -0
- package/src/router/content-negotiation.ts +15 -2
- package/src/router/error-handling.ts +1 -1
- package/src/router/handler-context.ts +21 -38
- package/src/router/intercept-resolution.ts +4 -18
- package/src/router/lazy-includes.ts +8 -8
- package/src/router/loader-resolution.ts +89 -49
- package/src/router/manifest.ts +22 -13
- package/src/router/match-api.ts +4 -3
- package/src/router/match-handlers.ts +63 -20
- package/src/router/match-middleware/cache-lookup.ts +54 -96
- package/src/router/match-middleware/cache-store.ts +3 -2
- package/src/router/match-middleware/segment-resolution.ts +1 -1
- package/src/router/match-result.ts +103 -4
- package/src/router/metrics.ts +1 -1
- package/src/router/middleware-types.ts +15 -26
- package/src/router/middleware.ts +99 -84
- package/src/router/pattern-matching.ts +101 -17
- package/src/router/prerender-match.ts +1 -1
- package/src/router/preview-match.ts +3 -1
- package/src/router/request-classification.ts +4 -28
- package/src/router/revalidation.ts +58 -2
- package/src/router/router-interfaces.ts +45 -28
- package/src/router/router-options.ts +40 -1
- package/src/router/router-registry.ts +2 -5
- package/src/router/segment-resolution/fresh.ts +32 -6
- package/src/router/segment-resolution/revalidation.ts +154 -107
- package/src/router/segment-resolution/view-transition-default.ts +36 -0
- package/src/router/substitute-pattern-params.ts +56 -0
- package/src/router/telemetry.ts +99 -0
- package/src/router/trie-matching.ts +18 -13
- package/src/router/types.ts +8 -0
- package/src/router/url-params.ts +49 -0
- package/src/router.ts +38 -23
- package/src/rsc/handler-context.ts +2 -2
- package/src/rsc/handler.ts +41 -74
- package/src/rsc/helpers.ts +91 -43
- package/src/rsc/index.ts +1 -1
- package/src/rsc/loader-fetch.ts +23 -3
- package/src/rsc/origin-guard.ts +28 -10
- package/src/rsc/progressive-enhancement.ts +14 -2
- package/src/rsc/response-route-handler.ts +46 -53
- package/src/rsc/rsc-rendering.ts +40 -52
- package/src/rsc/runtime-warnings.ts +9 -10
- package/src/rsc/server-action.ts +23 -37
- package/src/rsc/ssr-setup.ts +16 -0
- package/src/rsc/types.ts +9 -2
- package/src/search-params.ts +4 -4
- package/src/segment-content-promise.ts +67 -0
- package/src/segment-loader-promise.ts +122 -0
- package/src/segment-system.tsx +132 -116
- package/src/serialize.ts +243 -0
- package/src/server/context.ts +143 -53
- package/src/server/cookie-store.ts +28 -4
- package/src/server/handle-store.ts +19 -0
- package/src/server/request-context.ts +50 -44
- package/src/ssr/index.tsx +5 -1
- package/src/static-handler.ts +1 -1
- package/src/testing/cache-status.ts +166 -0
- package/src/testing/collect-handle.ts +63 -0
- package/src/testing/dispatch.ts +440 -0
- package/src/testing/dom.entry.ts +22 -0
- package/src/testing/e2e/fixture.ts +154 -0
- package/src/testing/e2e/index.ts +149 -0
- package/src/testing/e2e/matchers.ts +51 -0
- package/src/testing/e2e/page-helpers.ts +272 -0
- package/src/testing/e2e/parity.ts +306 -0
- package/src/testing/e2e/server.ts +183 -0
- package/src/testing/flight-matchers.ts +104 -0
- package/src/testing/flight-runtime.d.ts +21 -0
- package/src/testing/flight.entry.ts +22 -0
- package/src/testing/flight.ts +182 -0
- package/src/testing/generated-routes.ts +223 -0
- package/src/testing/index.ts +105 -0
- package/src/testing/internal/context.ts +193 -0
- package/src/testing/render-route.tsx +536 -0
- package/src/testing/run-loader.ts +296 -0
- package/src/testing/run-middleware.ts +170 -0
- package/src/testing/vitest-stubs/cloudflare-email.ts +9 -0
- package/src/testing/vitest-stubs/cloudflare-workers.ts +21 -0
- package/src/testing/vitest-stubs/plugin-rsc.ts +16 -0
- package/src/testing/vitest-stubs/version.ts +5 -0
- package/src/testing/vitest.ts +183 -0
- package/src/types/global-namespace.ts +39 -26
- package/src/types/handler-context.ts +68 -50
- package/src/types/index.ts +1 -0
- package/src/types/loader-types.ts +5 -6
- package/src/types/request-scope.ts +126 -0
- package/src/types/route-entry.ts +11 -0
- package/src/types/segments.ts +36 -2
- package/src/urls/include-helper.ts +34 -67
- package/src/urls/index.ts +0 -3
- package/src/urls/path-helper-types.ts +41 -7
- package/src/urls/path-helper.ts +17 -52
- package/src/urls/pattern-types.ts +36 -19
- package/src/urls/response-types.ts +22 -29
- package/src/urls/type-extraction.ts +26 -116
- package/src/urls/urls-function.ts +1 -5
- package/src/use-loader.tsx +416 -42
- package/src/vite/debug.ts +185 -0
- package/src/vite/discovery/bundle-postprocess.ts +6 -6
- package/src/vite/discovery/discover-routers.ts +101 -51
- package/src/vite/discovery/discovery-errors.ts +194 -0
- package/src/vite/discovery/gate-state.ts +171 -0
- package/src/vite/discovery/prerender-collection.ts +185 -103
- package/src/vite/discovery/route-types-writer.ts +40 -84
- package/src/vite/discovery/self-gen-tracking.ts +27 -1
- package/src/vite/discovery/state.ts +33 -0
- package/src/vite/discovery/virtual-module-codegen.ts +13 -23
- package/src/vite/index.ts +2 -0
- package/src/vite/plugin-types.ts +67 -0
- package/src/vite/plugins/cjs-to-esm.ts +8 -7
- package/src/vite/plugins/client-ref-dedup.ts +16 -0
- package/src/vite/plugins/client-ref-hashing.ts +28 -5
- package/src/vite/plugins/cloudflare-protocol-loader-hook.d.mts +23 -0
- package/src/vite/plugins/cloudflare-protocol-loader-hook.mjs +76 -0
- package/src/vite/plugins/cloudflare-protocol-stub.ts +214 -0
- package/src/vite/plugins/expose-action-id.ts +54 -30
- package/src/vite/plugins/expose-id-utils.ts +24 -8
- package/src/vite/plugins/expose-ids/export-analysis.ts +100 -20
- package/src/vite/plugins/expose-ids/handler-transform.ts +12 -35
- package/src/vite/plugins/expose-ids/loader-transform.ts +3 -5
- package/src/vite/plugins/expose-ids/router-transform.ts +20 -3
- package/src/vite/plugins/expose-internal-ids.ts +544 -317
- package/src/vite/plugins/performance-tracks.ts +29 -25
- package/src/vite/plugins/use-cache-transform.ts +65 -50
- package/src/vite/plugins/version-injector.ts +39 -23
- package/src/vite/plugins/version-plugin.ts +59 -2
- package/src/vite/plugins/virtual-entries.ts +2 -2
- package/src/vite/rango.ts +116 -29
- package/src/vite/router-discovery.ts +774 -102
- package/src/vite/utils/ast-handler-extract.ts +15 -15
- package/src/vite/utils/banner.ts +1 -1
- package/src/vite/utils/bundle-analysis.ts +4 -2
- package/src/vite/utils/client-chunks.ts +190 -0
- package/src/vite/utils/forward-user-plugins.ts +193 -0
- package/src/vite/utils/manifest-utils.ts +21 -5
- package/src/vite/utils/package-resolution.ts +41 -1
- package/src/vite/utils/prerender-utils.ts +21 -6
- package/src/vite/utils/shared-utils.ts +107 -26
- package/src/browser/action-response-classifier.ts +0 -99
|
@@ -10,15 +10,20 @@ import type { Plugin } from "vite";
|
|
|
10
10
|
import { createServer as createViteServer } from "vite";
|
|
11
11
|
import { resolve } from "node:path";
|
|
12
12
|
import { readFileSync } from "node:fs";
|
|
13
|
-
import { createRequire } from "node:module";
|
|
13
|
+
import { createRequire, register } from "node:module";
|
|
14
14
|
import { pathToFileURL } from "node:url";
|
|
15
15
|
import {
|
|
16
16
|
formatNestedRouterConflictError,
|
|
17
17
|
findNestedRouterConflict,
|
|
18
18
|
findRouterFiles,
|
|
19
19
|
} from "../build/generate-route-types.js";
|
|
20
|
+
import { firstCodeMatchIndex } from "../build/route-types/source-scan.js";
|
|
20
21
|
import { createVersionPlugin } from "./plugins/version-plugin.js";
|
|
21
22
|
import { createVirtualStubPlugin } from "./plugins/virtual-stub-plugin.js";
|
|
23
|
+
import {
|
|
24
|
+
BUILD_ENV_GLOBAL_KEY,
|
|
25
|
+
createCloudflareProtocolStubPlugin,
|
|
26
|
+
} from "./plugins/cloudflare-protocol-stub.js";
|
|
22
27
|
import {
|
|
23
28
|
exposeInternalIds,
|
|
24
29
|
exposeRouterId,
|
|
@@ -31,7 +36,10 @@ import {
|
|
|
31
36
|
type DiscoveryState,
|
|
32
37
|
type PluginOptions,
|
|
33
38
|
} from "./discovery/state.js";
|
|
34
|
-
import {
|
|
39
|
+
import {
|
|
40
|
+
consumeSelfGenWrite,
|
|
41
|
+
peekSelfGenWrite,
|
|
42
|
+
} from "./discovery/self-gen-tracking.js";
|
|
35
43
|
import { discoverRouters } from "./discovery/discover-routers.js";
|
|
36
44
|
import {
|
|
37
45
|
writeCombinedRouteTypesWithTracking,
|
|
@@ -43,10 +51,65 @@ import {
|
|
|
43
51
|
generatePerRouterModule,
|
|
44
52
|
} from "./discovery/virtual-module-codegen.js";
|
|
45
53
|
import { postprocessBundle } from "./discovery/bundle-postprocess.js";
|
|
54
|
+
import { createDiscoveryGate } from "./discovery/gate-state.js";
|
|
46
55
|
import { resetStagedBuildAssets } from "./utils/prerender-utils.js";
|
|
56
|
+
import { resolveRscEntryFromConfig } from "./utils/shared-utils.js";
|
|
57
|
+
import {
|
|
58
|
+
pickForwardedRunnerConfig,
|
|
59
|
+
selectForwardableResolvePlugins,
|
|
60
|
+
} from "./utils/forward-user-plugins.js";
|
|
61
|
+
import { createRangoDebugger, timed, timedSync, NS } from "./debug.js";
|
|
62
|
+
|
|
63
|
+
const debugDiscovery = createRangoDebugger(NS.discovery);
|
|
64
|
+
const debugRoutes = createRangoDebugger(NS.routes);
|
|
65
|
+
const debugBuild = createRangoDebugger(NS.build);
|
|
66
|
+
const debugDev = createRangoDebugger(NS.dev);
|
|
47
67
|
|
|
48
68
|
export { VIRTUAL_ROUTES_MANIFEST_ID };
|
|
49
69
|
|
|
70
|
+
// ============================================================================
|
|
71
|
+
// Node ESM Loader Hook Registration
|
|
72
|
+
// ============================================================================
|
|
73
|
+
|
|
74
|
+
/**
|
|
75
|
+
* Registers a Node ESM loader hook that resolves `cloudflare:*` specifiers
|
|
76
|
+
* to a data: URL stub. Defense-in-depth alongside the Vite transform in
|
|
77
|
+
* `cloudflare-protocol-stub.ts`:
|
|
78
|
+
*
|
|
79
|
+
* - The Vite transform catches `cloudflare:*` imports in modules that flow
|
|
80
|
+
* through Vite's plugin pipeline. That's the vast majority of cases.
|
|
81
|
+
* - The Node loader catches imports in modules that Vite/Rollup externalize
|
|
82
|
+
* (e.g. the `partyserver` package, which has a top-level
|
|
83
|
+
* `import { DurableObject, env } from "cloudflare:workers"` and ships
|
|
84
|
+
* shapes plugin-rsc marks as external). Externalized modules are loaded
|
|
85
|
+
* via Node's native ESM loader, which rejects URL schemes.
|
|
86
|
+
*
|
|
87
|
+
* Registration is process-global and one-shot. The hook only intercepts
|
|
88
|
+
* `cloudflare:*` specifiers; everything else passes through via
|
|
89
|
+
* `nextResolve()`. It runs in a separate worker thread (Node ESM loader
|
|
90
|
+
* architecture), so it can't read the `globalThis[BUILD_ENV_GLOBAL_KEY]`
|
|
91
|
+
* bridge that the Vite transform uses — the stubs served here always
|
|
92
|
+
* return `env = {}`. That's fine because externalized libraries don't
|
|
93
|
+
* typically access `env` at module top level; user source (where real
|
|
94
|
+
* `env` matters at build time) flows through the Vite transform.
|
|
95
|
+
*/
|
|
96
|
+
let loaderHookRegistered = false;
|
|
97
|
+
function ensureCloudflareProtocolLoaderRegistered(): void {
|
|
98
|
+
if (loaderHookRegistered) return;
|
|
99
|
+
loaderHookRegistered = true;
|
|
100
|
+
try {
|
|
101
|
+
register(
|
|
102
|
+
new URL("./plugins/cloudflare-protocol-loader-hook.mjs", import.meta.url),
|
|
103
|
+
);
|
|
104
|
+
} catch (err: any) {
|
|
105
|
+
// register() requires Node 18.19+ / 20.6+. Older Node still has the
|
|
106
|
+
// Vite transform as primary defense.
|
|
107
|
+
console.warn(
|
|
108
|
+
`[rango] Could not register Node ESM loader hook for cloudflare:* imports (${err?.message ?? err}). Falling back to Vite transform only.`,
|
|
109
|
+
);
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
|
|
50
113
|
// ============================================================================
|
|
51
114
|
// Temp Server Factory
|
|
52
115
|
// ============================================================================
|
|
@@ -66,15 +129,32 @@ async function createTempRscServer(
|
|
|
66
129
|
state: DiscoveryState,
|
|
67
130
|
options: { forceBuild?: boolean; cacheDir?: string } = {},
|
|
68
131
|
) {
|
|
132
|
+
// Install the Node ESM loader hook before any module evaluation so
|
|
133
|
+
// `cloudflare:*` specifiers in externalized/loader-delegated modules
|
|
134
|
+
// (e.g. packages plugin-rsc marks as external) resolve to stubs
|
|
135
|
+
// instead of crashing Node's native loader.
|
|
136
|
+
ensureCloudflareProtocolLoaderRegistered();
|
|
69
137
|
const { default: rsc } = await import("@vitejs/plugin-rsc");
|
|
138
|
+
// Mirror the user's resolution config + plugins so discovery (and the
|
|
139
|
+
// prerender/static rendering that shares this runner) resolves modules the
|
|
140
|
+
// same way the real environment does. Falls back to the legacy alias-only
|
|
141
|
+
// behavior if configResolved hasn't populated the parity slice yet.
|
|
142
|
+
const runnerConfig = state.userRunnerConfig;
|
|
143
|
+
const resolveConfig = runnerConfig?.resolve ?? {
|
|
144
|
+
alias: state.userResolveAlias,
|
|
145
|
+
};
|
|
146
|
+
const oxcConfig = runnerConfig?.oxc ?? {
|
|
147
|
+
jsx: { runtime: "automatic", importSource: "react" },
|
|
148
|
+
};
|
|
70
149
|
return createViteServer({
|
|
71
150
|
root: state.projectRoot,
|
|
72
151
|
configFile: false,
|
|
73
152
|
server: { middlewareMode: true },
|
|
74
153
|
appType: "custom",
|
|
75
154
|
logLevel: "silent",
|
|
76
|
-
resolve:
|
|
77
|
-
|
|
155
|
+
resolve: resolveConfig,
|
|
156
|
+
...(runnerConfig?.define ? { define: runnerConfig.define } : {}),
|
|
157
|
+
oxc: oxcConfig as any,
|
|
78
158
|
...(options.cacheDir && { cacheDir: options.cacheDir }),
|
|
79
159
|
plugins: [
|
|
80
160
|
rsc({
|
|
@@ -88,10 +168,15 @@ async function createTempRscServer(
|
|
|
88
168
|
...(options.forceBuild ? [hashClientRefs(state.projectRoot)] : []),
|
|
89
169
|
createVersionPlugin(),
|
|
90
170
|
createVirtualStubPlugin(),
|
|
171
|
+
createCloudflareProtocolStubPlugin(),
|
|
91
172
|
// Dev prerender must use dev-mode IDs (path-based) to match the workerd
|
|
92
173
|
// runtime. forceBuild produces hashed IDs for production bundle consistency.
|
|
93
174
|
exposeInternalIds(options.forceBuild ? { forceBuild: true } : undefined),
|
|
94
175
|
exposeRouterId(),
|
|
176
|
+
// Forwarded user resolution plugins (e.g. vite-tsconfig-paths). Stripped
|
|
177
|
+
// to resolveId/load and placed last so framework resolution runs first;
|
|
178
|
+
// Vite re-sorts by `enforce`, so `enforce: "pre"` resolvers still lead.
|
|
179
|
+
...state.userResolvePlugins,
|
|
95
180
|
],
|
|
96
181
|
});
|
|
97
182
|
}
|
|
@@ -119,7 +204,7 @@ async function resolveBuildEnv(
|
|
|
119
204
|
if (option === "auto") {
|
|
120
205
|
if (factoryCtx.preset !== "cloudflare") {
|
|
121
206
|
throw new Error(
|
|
122
|
-
'[
|
|
207
|
+
'[rango] buildEnv: "auto" is only supported with preset: "cloudflare". ' +
|
|
123
208
|
"Use a factory function or plain object for other presets.",
|
|
124
209
|
);
|
|
125
210
|
}
|
|
@@ -141,7 +226,7 @@ async function resolveBuildEnv(
|
|
|
141
226
|
};
|
|
142
227
|
} catch (err: any) {
|
|
143
228
|
throw new Error(
|
|
144
|
-
'[
|
|
229
|
+
'[rango] buildEnv: "auto" requires wrangler to be installed.\n' +
|
|
145
230
|
`Install it with: pnpm add -D wrangler\n${err.message}`,
|
|
146
231
|
);
|
|
147
232
|
}
|
|
@@ -177,6 +262,11 @@ async function acquireBuildEnv(
|
|
|
177
262
|
|
|
178
263
|
s.resolvedBuildEnv = result.env;
|
|
179
264
|
s.buildEnvDispose = result.dispose ?? null;
|
|
265
|
+
// Bridge the resolved env into `cloudflare:workers`'s stubbed `env`
|
|
266
|
+
// export so user code that does `import { env } from "cloudflare:workers"`
|
|
267
|
+
// sees the real bindings proxy during discovery + prerender instead of
|
|
268
|
+
// an empty object. The stub reads this global at module-evaluation time.
|
|
269
|
+
(globalThis as Record<string, unknown>)[BUILD_ENV_GLOBAL_KEY] = result.env;
|
|
180
270
|
return true;
|
|
181
271
|
}
|
|
182
272
|
|
|
@@ -188,11 +278,12 @@ async function releaseBuildEnv(s: DiscoveryState): Promise<void> {
|
|
|
188
278
|
try {
|
|
189
279
|
await s.buildEnvDispose();
|
|
190
280
|
} catch (err: any) {
|
|
191
|
-
console.warn(`[
|
|
281
|
+
console.warn(`[rango] buildEnv dispose failed: ${err.message}`);
|
|
192
282
|
}
|
|
193
283
|
s.buildEnvDispose = null;
|
|
194
284
|
}
|
|
195
285
|
s.resolvedBuildEnv = undefined;
|
|
286
|
+
delete (globalThis as Record<string, unknown>)[BUILD_ENV_GLOBAL_KEY];
|
|
196
287
|
}
|
|
197
288
|
|
|
198
289
|
/**
|
|
@@ -240,23 +331,28 @@ export function createRouterDiscoveryPlugin(
|
|
|
240
331
|
viteMode = config.mode;
|
|
241
332
|
// Capture user's resolve aliases for the temp server
|
|
242
333
|
s.userResolveAlias = config.resolve.alias;
|
|
334
|
+
// Capture the data-only resolution config (resolve.*, define, oxc) and
|
|
335
|
+
// the user's resolution plugins (resolveId/load) so the discovery temp
|
|
336
|
+
// server resolves modules the same way the real environment does.
|
|
337
|
+
// Without this, both flavors of user resolution are absent during
|
|
338
|
+
// discovery/prerender/static rendering even though they apply at request
|
|
339
|
+
// time: third-party resolvers (e.g. vite-tsconfig-paths, forwarded as
|
|
340
|
+
// plugins) and Vite 8's native resolve.tsconfigPaths (forwarded in the
|
|
341
|
+
// data slice). See utils/forward-user-plugins.ts.
|
|
342
|
+
s.userRunnerConfig = pickForwardedRunnerConfig(config);
|
|
343
|
+
s.userResolvePlugins = selectForwardableResolvePlugins(
|
|
344
|
+
config.plugins as any,
|
|
345
|
+
);
|
|
243
346
|
// Node preset: pick up auto-discovered router path from the config() hook.
|
|
244
347
|
// The auto-discover plugin runs in config() using Vite's resolved root,
|
|
245
348
|
// populating the mutable ref before configResolved fires.
|
|
246
349
|
if (!s.resolvedEntryPath && opts?.routerPathRef?.path) {
|
|
247
350
|
s.resolvedEntryPath = opts.routerPathRef.path;
|
|
248
351
|
}
|
|
249
|
-
// Cloudflare preset:
|
|
250
|
-
// The @cloudflare/vite-plugin reads wrangler config (toml/json/jsonc)
|
|
251
|
-
// and sets optimizeDeps.entries on the RSC environment.
|
|
352
|
+
// Cloudflare preset: entry comes from the resolved RSC env config.
|
|
252
353
|
if (!s.resolvedEntryPath) {
|
|
253
|
-
const
|
|
254
|
-
|
|
255
|
-
if (typeof entries === "string") {
|
|
256
|
-
s.resolvedEntryPath = entries;
|
|
257
|
-
} else if (Array.isArray(entries) && entries.length > 0) {
|
|
258
|
-
s.resolvedEntryPath = entries[0];
|
|
259
|
-
}
|
|
354
|
+
const entry = resolveRscEntryFromConfig(config);
|
|
355
|
+
if (entry) s.resolvedEntryPath = entry;
|
|
260
356
|
}
|
|
261
357
|
// Generate combined named-routes.gen.ts from static source parsing.
|
|
262
358
|
// Runs before the dev server starts so the gen file exists immediately for IDE.
|
|
@@ -295,6 +391,17 @@ export function createRouterDiscoveryPlugin(
|
|
|
295
391
|
resolveDiscovery = resolve;
|
|
296
392
|
});
|
|
297
393
|
|
|
394
|
+
// Manifest-readiness gate + rediscovery scheduler.
|
|
395
|
+
// The virtual:rsc-router/routes-manifest module's `load()` hook
|
|
396
|
+
// awaits `s.discoveryDone`; the gate is reset on each discovery
|
|
397
|
+
// cycle so workerd's HMR reloads block until the new gen file is
|
|
398
|
+
// written. State machine + transitions are extracted into
|
|
399
|
+
// ./discovery/gate-state.ts and unit-tested there — see the
|
|
400
|
+
// module's JSDoc for the four-flag contract.
|
|
401
|
+
const gate = createDiscoveryGate(s, debugDiscovery);
|
|
402
|
+
const beginDiscoveryGate = gate.beginGate;
|
|
403
|
+
const resolveDiscoveryGate = gate.resolveGate;
|
|
404
|
+
|
|
298
405
|
// Compute dev server origin from resolved URLs (preferred) or config port (fallback).
|
|
299
406
|
// Called after discovery (or in the load hook) when the server may be listening.
|
|
300
407
|
const getDevServerOrigin = () =>
|
|
@@ -317,10 +424,103 @@ export function createRouterDiscoveryPlugin(
|
|
|
317
424
|
releaseBuildEnv(s).catch(() => {});
|
|
318
425
|
});
|
|
319
426
|
|
|
427
|
+
// Mirror the build-path contract (router-discovery.ts ~line 878):
|
|
428
|
+
// set __rscRouterDiscoveryActive before running user modules so any
|
|
429
|
+
// module-level router.reverse() calls return a placeholder instead
|
|
430
|
+
// of throwing. The temp Vite server's module runner has its own
|
|
431
|
+
// module context; the flag must be on globalThis to cross that
|
|
432
|
+
// boundary. Cleared in finally so the dev request handlers run with
|
|
433
|
+
// strict reverse() semantics afterwards.
|
|
434
|
+
async function importEntryAndRegistry(tempRscEnv: any): Promise<void> {
|
|
435
|
+
const flagAlreadySet = !!(globalThis as any).__rscRouterDiscoveryActive;
|
|
436
|
+
if (!flagAlreadySet) {
|
|
437
|
+
(globalThis as any).__rscRouterDiscoveryActive = true;
|
|
438
|
+
}
|
|
439
|
+
try {
|
|
440
|
+
debugDiscovery?.(
|
|
441
|
+
"importEntryAndRegistry: importing entry (flag=%s)",
|
|
442
|
+
(globalThis as any).__rscRouterDiscoveryActive ?? false,
|
|
443
|
+
);
|
|
444
|
+
await tempRscEnv.runner.import(s.resolvedEntryPath!);
|
|
445
|
+
debugDiscovery?.(
|
|
446
|
+
"importEntryAndRegistry: entry import OK, fetching RouterRegistry",
|
|
447
|
+
);
|
|
448
|
+
const serverMod = await tempRscEnv.runner.import(
|
|
449
|
+
"@rangojs/router/server",
|
|
450
|
+
);
|
|
451
|
+
prerenderNodeRegistry = serverMod.RouterRegistry;
|
|
452
|
+
debugDiscovery?.(
|
|
453
|
+
"importEntryAndRegistry: registry size=%d",
|
|
454
|
+
prerenderNodeRegistry?.size ?? 0,
|
|
455
|
+
);
|
|
456
|
+
} finally {
|
|
457
|
+
if (!flagAlreadySet) {
|
|
458
|
+
delete (globalThis as any).__rscRouterDiscoveryActive;
|
|
459
|
+
debugDiscovery?.(
|
|
460
|
+
"importEntryAndRegistry: cleared __rscRouterDiscoveryActive",
|
|
461
|
+
);
|
|
462
|
+
}
|
|
463
|
+
}
|
|
464
|
+
}
|
|
465
|
+
|
|
320
466
|
async function getOrCreateTempServer(): Promise<any | null> {
|
|
321
|
-
if
|
|
322
|
-
|
|
467
|
+
// Reuse path: if a temp server is already alive, prefer reusing
|
|
468
|
+
// it over orphaning the existing instance and spinning up a new
|
|
469
|
+
// one. This handles two cases:
|
|
470
|
+
//
|
|
471
|
+
// 1. Steady-state cache hit (cold-start completed, registry
|
|
472
|
+
// cached) — return the env immediately.
|
|
473
|
+
// 2. Recovery from a failed refresh: refreshTempRscEnv() may
|
|
474
|
+
// have invalidated and nulled the registry, then thrown
|
|
475
|
+
// during importEntryAndRegistry. Without reuse, the next
|
|
476
|
+
// call would `createTempRscServer` and overwrite the
|
|
477
|
+
// handle, leaking the previous server. Try to re-import on
|
|
478
|
+
// the existing runner first; only if THAT fails do we
|
|
479
|
+
// close the orphan and create new.
|
|
480
|
+
if (prerenderTempServer) {
|
|
481
|
+
const existingEnv = (prerenderTempServer.environments as any)?.rsc;
|
|
482
|
+
if (existingEnv?.runner) {
|
|
483
|
+
if (prerenderNodeRegistry) {
|
|
484
|
+
debugDiscovery?.(
|
|
485
|
+
"getOrCreateTempServer: cached temp runner reused",
|
|
486
|
+
);
|
|
487
|
+
return existingEnv;
|
|
488
|
+
}
|
|
489
|
+
// Server alive but registry missing — likely after a prior
|
|
490
|
+
// refresh's invalidate + import threw. Try to re-import.
|
|
491
|
+
debugDiscovery?.(
|
|
492
|
+
"getOrCreateTempServer: server alive but registry missing — re-importing",
|
|
493
|
+
);
|
|
494
|
+
try {
|
|
495
|
+
await importEntryAndRegistry(existingEnv);
|
|
496
|
+
return existingEnv;
|
|
497
|
+
} catch (err: any) {
|
|
498
|
+
debugDiscovery?.(
|
|
499
|
+
"getOrCreateTempServer: reuse import failed (%s) — closing orphan and creating fresh",
|
|
500
|
+
err?.message ?? String(err),
|
|
501
|
+
);
|
|
502
|
+
await prerenderTempServer.close().catch(() => {});
|
|
503
|
+
prerenderTempServer = null;
|
|
504
|
+
prerenderNodeRegistry = null;
|
|
505
|
+
// Fall through to create-new path below.
|
|
506
|
+
}
|
|
507
|
+
} else {
|
|
508
|
+
// Server reference exists but its rsc env is unhealthy
|
|
509
|
+
// (no runner). Close and recreate.
|
|
510
|
+
debugDiscovery?.(
|
|
511
|
+
"getOrCreateTempServer: existing server has no rsc.runner — closing and recreating",
|
|
512
|
+
);
|
|
513
|
+
await prerenderTempServer.close().catch(() => {});
|
|
514
|
+
prerenderTempServer = null;
|
|
515
|
+
prerenderNodeRegistry = null;
|
|
516
|
+
}
|
|
323
517
|
}
|
|
518
|
+
|
|
519
|
+
// Create path: no existing temp server (or just nullified above).
|
|
520
|
+
debugDiscovery?.(
|
|
521
|
+
"getOrCreateTempServer: creating new temp server, entry=%s",
|
|
522
|
+
s.resolvedEntryPath ?? "(unset)",
|
|
523
|
+
);
|
|
324
524
|
try {
|
|
325
525
|
prerenderTempServer = await createTempRscServer(s, {
|
|
326
526
|
cacheDir: "node_modules/.vite_prerender",
|
|
@@ -328,64 +528,189 @@ export function createRouterDiscoveryPlugin(
|
|
|
328
528
|
|
|
329
529
|
const tempRscEnv = (prerenderTempServer.environments as any)?.rsc;
|
|
330
530
|
if (tempRscEnv?.runner) {
|
|
331
|
-
await tempRscEnv
|
|
332
|
-
const serverMod = await tempRscEnv.runner.import(
|
|
333
|
-
"@rangojs/router/server",
|
|
334
|
-
);
|
|
335
|
-
prerenderNodeRegistry = serverMod.RouterRegistry;
|
|
531
|
+
await importEntryAndRegistry(tempRscEnv);
|
|
336
532
|
return tempRscEnv;
|
|
337
533
|
}
|
|
534
|
+
debugDiscovery?.(
|
|
535
|
+
"getOrCreateTempServer: tempRscEnv.runner unavailable",
|
|
536
|
+
);
|
|
338
537
|
} catch (err: any) {
|
|
339
|
-
|
|
340
|
-
|
|
538
|
+
debugDiscovery?.(
|
|
539
|
+
"getOrCreateTempServer: FAILED message=%s",
|
|
540
|
+
err.message,
|
|
341
541
|
);
|
|
542
|
+
console.warn(`[rango] Failed to create temp runner: ${err.message}`);
|
|
342
543
|
}
|
|
343
544
|
return null;
|
|
344
545
|
}
|
|
345
546
|
|
|
547
|
+
// Clear the package-level singleton registries that survive a Vite
|
|
548
|
+
// moduleGraph.invalidateAll(). createRouter() / createHostRouter()
|
|
549
|
+
// call .set(id, ...) on these Maps; for "router removed" or
|
|
550
|
+
// "router id changed" edits, the OLD entry would persist after
|
|
551
|
+
// re-import without an explicit .clear(), leaving ghost routes
|
|
552
|
+
// in discoverRouters' output.
|
|
553
|
+
//
|
|
554
|
+
// We import the same module the runner imports, so the .clear()
|
|
555
|
+
// here mutates the same Map the freshly re-imported entry will
|
|
556
|
+
// populate.
|
|
557
|
+
async function clearTempRegistries(tempRscEnv: any): Promise<void> {
|
|
558
|
+
try {
|
|
559
|
+
const serverMod = await tempRscEnv.runner.import(
|
|
560
|
+
"@rangojs/router/server",
|
|
561
|
+
);
|
|
562
|
+
if (typeof serverMod?.RouterRegistry?.clear === "function") {
|
|
563
|
+
serverMod.RouterRegistry.clear();
|
|
564
|
+
}
|
|
565
|
+
if (typeof serverMod?.HostRouterRegistry?.clear === "function") {
|
|
566
|
+
serverMod.HostRouterRegistry.clear();
|
|
567
|
+
}
|
|
568
|
+
debugDiscovery?.(
|
|
569
|
+
"clearTempRegistries: cleared RouterRegistry + HostRouterRegistry",
|
|
570
|
+
);
|
|
571
|
+
} catch (err: any) {
|
|
572
|
+
// Non-fatal: if the import fails here, importEntryAndRegistry
|
|
573
|
+
// below will fail loudly with the same root cause and the
|
|
574
|
+
// caller will surface it.
|
|
575
|
+
debugDiscovery?.(
|
|
576
|
+
"clearTempRegistries: import @rangojs/router/server failed (%s)",
|
|
577
|
+
err?.message ?? String(err),
|
|
578
|
+
);
|
|
579
|
+
}
|
|
580
|
+
}
|
|
581
|
+
|
|
582
|
+
// HMR refresh: keep the temp Vite server alive across HMR cycles and
|
|
583
|
+
// invalidate its module graph instead of close+recreate. Closing the
|
|
584
|
+
// temp server during workerd's first post-cold-start module-fetch
|
|
585
|
+
// window disrupted the main dev server's transport — the user-visible
|
|
586
|
+
// symptom was a `transport was disconnected, cannot call "fetchModule"`
|
|
587
|
+
// error on the first urls.tsx edit (workerd's cache was cold, so its
|
|
588
|
+
// eval was still in flight when our close() ran). Module-graph
|
|
589
|
+
// invalidation is the architecturally cleaner refresh: same Vite
|
|
590
|
+
// instance, same transport, fresh source.
|
|
591
|
+
//
|
|
592
|
+
// Falls back to close+recreate when neither the env-level nor
|
|
593
|
+
// server-level moduleGraph exposes invalidateAll() (defensive — Vite
|
|
594
|
+
// versions / preset configurations may differ in which graph carries
|
|
595
|
+
// the module-runner cache).
|
|
596
|
+
async function refreshTempRscEnv(): Promise<any | null> {
|
|
597
|
+
let tempRscEnv = await getOrCreateTempServer();
|
|
598
|
+
if (!tempRscEnv) return null;
|
|
599
|
+
|
|
600
|
+
// Module-runner cache is on the per-environment graph in Vite 6+;
|
|
601
|
+
// older / non-environments setups carry it on the server graph.
|
|
602
|
+
// Try env first, server second.
|
|
603
|
+
const envGraph = (tempRscEnv as any).moduleGraph;
|
|
604
|
+
const serverGraph = (prerenderTempServer as any)?.moduleGraph;
|
|
605
|
+
const target = envGraph?.invalidateAll
|
|
606
|
+
? envGraph
|
|
607
|
+
: serverGraph?.invalidateAll
|
|
608
|
+
? serverGraph
|
|
609
|
+
: null;
|
|
610
|
+
|
|
611
|
+
if (!target) {
|
|
612
|
+
// No invalidate method available — fall back to close+recreate.
|
|
613
|
+
// This preserves the previous behavior in case a Vite version
|
|
614
|
+
// doesn't expose invalidateAll on either graph.
|
|
615
|
+
debugDiscovery?.(
|
|
616
|
+
"refreshTempRscEnv: invalidateAll unavailable on env+server graphs, falling back to close+recreate",
|
|
617
|
+
);
|
|
618
|
+
if (prerenderTempServer) {
|
|
619
|
+
await prerenderTempServer.close().catch(() => {});
|
|
620
|
+
prerenderTempServer = null;
|
|
621
|
+
prerenderNodeRegistry = null;
|
|
622
|
+
}
|
|
623
|
+
return await getOrCreateTempServer();
|
|
624
|
+
}
|
|
625
|
+
|
|
626
|
+
debugDiscovery?.(
|
|
627
|
+
"refreshTempRscEnv: invalidating module graph (%s)",
|
|
628
|
+
envGraph?.invalidateAll ? "env" : "server",
|
|
629
|
+
);
|
|
630
|
+
target.invalidateAll();
|
|
631
|
+
// Drop the cached registry so importEntryAndRegistry re-reads it
|
|
632
|
+
// through the now-invalidated module runner.
|
|
633
|
+
prerenderNodeRegistry = null;
|
|
634
|
+
// Clear singleton Maps that Vite's moduleGraph invalidation can't
|
|
635
|
+
// reach (RouterRegistry / HostRouterRegistry). Without this, an
|
|
636
|
+
// edit that REMOVES a createRouter() call or CHANGES a router id
|
|
637
|
+
// would leave the old entry in the registry, and discoverRouters
|
|
638
|
+
// would still emit its routes alongside whatever the new source
|
|
639
|
+
// declares.
|
|
640
|
+
await clearTempRegistries(tempRscEnv);
|
|
641
|
+
await importEntryAndRegistry(tempRscEnv);
|
|
642
|
+
return tempRscEnv;
|
|
643
|
+
}
|
|
644
|
+
|
|
346
645
|
const discover = async () => {
|
|
646
|
+
const discoverStart = performance.now();
|
|
347
647
|
const rscEnv = (server.environments as any)?.rsc;
|
|
348
648
|
if (!rscEnv?.runner) {
|
|
349
649
|
// Cloudflare dev: no module runner available (workerd-based RSC env).
|
|
350
650
|
// Set devServerOrigin so the virtual module can inject __PRERENDER_DEV_URL
|
|
351
651
|
// for on-demand prerender via the /__rsc_prerender endpoint.
|
|
652
|
+
debugDiscovery?.(
|
|
653
|
+
"dev: cloudflare path start, __rscRouterDiscoveryActive=%s",
|
|
654
|
+
(globalThis as any).__rscRouterDiscoveryActive ?? false,
|
|
655
|
+
);
|
|
352
656
|
s.devServerOrigin = getDevServerOrigin();
|
|
353
657
|
|
|
354
658
|
// Create a temp Node.js server to run runtime discovery and generate
|
|
355
659
|
// named route types (static parser can't resolve factory calls).
|
|
356
660
|
try {
|
|
357
661
|
// Acquire build-time env bindings for dev prerender
|
|
358
|
-
await
|
|
662
|
+
await timed(debugDiscovery, "acquireBuildEnv", () =>
|
|
663
|
+
acquireBuildEnv(s, viteCommand, viteMode),
|
|
664
|
+
);
|
|
359
665
|
|
|
360
|
-
const tempRscEnv = await
|
|
666
|
+
const tempRscEnv = await timed(
|
|
667
|
+
debugDiscovery,
|
|
668
|
+
"getOrCreateTempServer",
|
|
669
|
+
() => getOrCreateTempServer(),
|
|
670
|
+
);
|
|
361
671
|
if (tempRscEnv) {
|
|
362
|
-
await discoverRouters(
|
|
363
|
-
|
|
672
|
+
await timed(debugDiscovery, "discoverRouters (cloudflare)", () =>
|
|
673
|
+
discoverRouters(s, tempRscEnv),
|
|
674
|
+
);
|
|
675
|
+
timedSync(debugDiscovery, "writeRouteTypesFiles", () =>
|
|
676
|
+
writeRouteTypesFiles(s),
|
|
677
|
+
);
|
|
364
678
|
}
|
|
365
679
|
} catch (err: any) {
|
|
366
680
|
console.warn(
|
|
367
|
-
`[
|
|
681
|
+
`[rango] Cloudflare dev discovery failed: ${err.message}\n${err.stack}`,
|
|
368
682
|
);
|
|
369
683
|
}
|
|
370
684
|
|
|
685
|
+
debugDiscovery?.(
|
|
686
|
+
"dev discovery done (%sms)",
|
|
687
|
+
(performance.now() - discoverStart).toFixed(1),
|
|
688
|
+
);
|
|
371
689
|
resolveDiscovery!();
|
|
372
690
|
return;
|
|
373
691
|
}
|
|
374
692
|
|
|
375
693
|
try {
|
|
376
694
|
// Acquire build-time env bindings for dev prerender (Node.js path)
|
|
377
|
-
|
|
695
|
+
debugDiscovery?.("dev: node path start");
|
|
696
|
+
await timed(debugDiscovery, "acquireBuildEnv", () =>
|
|
697
|
+
acquireBuildEnv(s, viteCommand, viteMode),
|
|
698
|
+
);
|
|
378
699
|
|
|
379
700
|
// Set the readiness gate BEFORE discovery so early requests
|
|
380
701
|
// block until manifest is populated
|
|
381
|
-
const serverMod = await
|
|
382
|
-
|
|
702
|
+
const serverMod = await timed(
|
|
703
|
+
debugDiscovery,
|
|
704
|
+
"import @rangojs/router/server",
|
|
705
|
+
() => rscEnv.runner.import("@rangojs/router/server"),
|
|
383
706
|
);
|
|
384
707
|
if (serverMod?.setManifestReadyPromise) {
|
|
385
708
|
serverMod.setManifestReadyPromise(discoveryPromise);
|
|
386
709
|
}
|
|
387
710
|
|
|
388
|
-
await
|
|
711
|
+
await timed(debugDiscovery, "discoverRouters", () =>
|
|
712
|
+
discoverRouters(s, rscEnv),
|
|
713
|
+
);
|
|
389
714
|
|
|
390
715
|
// Store server origin for dev prerender endpoint (virtual module injection)
|
|
391
716
|
s.devServerOrigin = getDevServerOrigin();
|
|
@@ -395,24 +720,36 @@ export function createRouterDiscoveryPlugin(
|
|
|
395
720
|
// routes (e.g. Array.from loops) that the static parser cannot see.
|
|
396
721
|
// writeRouteTypesFiles() only writes when content changes, so this
|
|
397
722
|
// won't cause unnecessary HMR triggers.
|
|
398
|
-
writeRouteTypesFiles(
|
|
723
|
+
timedSync(debugDiscovery, "writeRouteTypesFiles", () =>
|
|
724
|
+
writeRouteTypesFiles(s),
|
|
725
|
+
);
|
|
399
726
|
|
|
400
727
|
// Populate the route map and per-router data in the RSC env
|
|
401
|
-
await propagateDiscoveryState(
|
|
728
|
+
await timed(debugDiscovery, "propagateDiscoveryState", () =>
|
|
729
|
+
propagateDiscoveryState(rscEnv),
|
|
730
|
+
);
|
|
402
731
|
} catch (err: any) {
|
|
403
732
|
console.warn(
|
|
404
|
-
`[
|
|
733
|
+
`[rango] Router discovery failed: ${err.message}\n${err.stack}`,
|
|
405
734
|
);
|
|
406
735
|
} finally {
|
|
736
|
+
debugDiscovery?.(
|
|
737
|
+
"dev discovery done (%sms)",
|
|
738
|
+
(performance.now() - discoverStart).toFixed(1),
|
|
739
|
+
);
|
|
407
740
|
resolveDiscovery!();
|
|
408
741
|
}
|
|
409
742
|
};
|
|
410
743
|
|
|
411
744
|
// Schedule after all plugins have finished configureServer.
|
|
412
|
-
//
|
|
413
|
-
|
|
414
|
-
|
|
415
|
-
|
|
745
|
+
// The gate (s.discoveryDone) is reset via beginDiscoveryGate() and
|
|
746
|
+
// resolved when discover() finishes, so the virtual manifest module's
|
|
747
|
+
// load() awaits the populated state.
|
|
748
|
+
beginDiscoveryGate();
|
|
749
|
+
setTimeout(
|
|
750
|
+
() => discover().then(resolveDiscoveryGate, resolveDiscoveryGate),
|
|
751
|
+
0,
|
|
752
|
+
);
|
|
416
753
|
|
|
417
754
|
// Dev-mode on-demand prerender endpoint.
|
|
418
755
|
// When workerd hits a prerender route, it fetches this endpoint instead of
|
|
@@ -452,24 +789,30 @@ export function createRouterDiscoveryPlugin(
|
|
|
452
789
|
if (s.mergedRouteTrie && serverMod.setRouteTrie) {
|
|
453
790
|
serverMod.setRouteTrie(s.mergedRouteTrie);
|
|
454
791
|
}
|
|
455
|
-
|
|
456
|
-
|
|
457
|
-
|
|
458
|
-
|
|
459
|
-
|
|
460
|
-
|
|
461
|
-
|
|
462
|
-
|
|
463
|
-
|
|
464
|
-
}
|
|
465
|
-
if (serverMod.setRouterPrecomputedEntries) {
|
|
466
|
-
for (const [routerId, entries] of s.perRouterPrecomputedMap) {
|
|
467
|
-
serverMod.setRouterPrecomputedEntries(routerId, entries);
|
|
468
|
-
}
|
|
792
|
+
const perRouterSetters: Array<[Map<string, any>, string]> = [
|
|
793
|
+
[s.perRouterManifestDataMap, "setRouterManifest"],
|
|
794
|
+
[s.perRouterTrieMap, "setRouterTrie"],
|
|
795
|
+
[s.perRouterPrecomputedMap, "setRouterPrecomputedEntries"],
|
|
796
|
+
];
|
|
797
|
+
for (const [map, fn] of perRouterSetters) {
|
|
798
|
+
const setter = serverMod[fn];
|
|
799
|
+
if (typeof setter !== "function") continue;
|
|
800
|
+
for (const [routerId, value] of map) setter(routerId, value);
|
|
469
801
|
}
|
|
470
802
|
};
|
|
471
803
|
|
|
472
804
|
server.middlewares.use("/__rsc_prerender", async (req: any, res: any) => {
|
|
805
|
+
const reqStart = debugDev ? performance.now() : 0;
|
|
806
|
+
const logResult = (status: number, note: string) => {
|
|
807
|
+
debugDev?.(
|
|
808
|
+
"/__rsc_prerender %s -> %d %s (%sms)",
|
|
809
|
+
req.url,
|
|
810
|
+
status,
|
|
811
|
+
note,
|
|
812
|
+
(performance.now() - reqStart).toFixed(1),
|
|
813
|
+
);
|
|
814
|
+
};
|
|
815
|
+
|
|
473
816
|
if (s.discoveryDone) await s.discoveryDone;
|
|
474
817
|
|
|
475
818
|
const url = new URL(req.url || "/", "http://localhost");
|
|
@@ -477,12 +820,36 @@ export function createRouterDiscoveryPlugin(
|
|
|
477
820
|
if (!pathname) {
|
|
478
821
|
res.statusCode = 400;
|
|
479
822
|
res.end("Missing pathname");
|
|
823
|
+
logResult(400, "missing pathname");
|
|
480
824
|
return;
|
|
481
825
|
}
|
|
482
826
|
|
|
483
|
-
//
|
|
484
|
-
//
|
|
485
|
-
|
|
827
|
+
// Import the user's entry module to force re-evaluation of any
|
|
828
|
+
// HMR-invalidated modules in the chain (entry → router → urls → handlers).
|
|
829
|
+
// This ensures createRouter() re-runs with updated handler code before
|
|
830
|
+
// we read RouterRegistry. Without this, edits to prerender handler files
|
|
831
|
+
// produce stale content because the old router instance remains registered.
|
|
832
|
+
const rscEnv = (server.environments as any)?.rsc;
|
|
833
|
+
let registry: Map<string, any> | null = null;
|
|
834
|
+
if (rscEnv?.runner && s.resolvedEntryPath) {
|
|
835
|
+
try {
|
|
836
|
+
await rscEnv.runner.import(s.resolvedEntryPath);
|
|
837
|
+
const serverMod = await rscEnv.runner.import(
|
|
838
|
+
"@rangojs/router/server",
|
|
839
|
+
);
|
|
840
|
+
registry = serverMod.RouterRegistry ?? null;
|
|
841
|
+
} catch (err: any) {
|
|
842
|
+
console.warn(
|
|
843
|
+
`[rango] Dev prerender module refresh failed: ${err.message}`,
|
|
844
|
+
);
|
|
845
|
+
res.statusCode = 500;
|
|
846
|
+
res.end(`Prerender handler error: ${err.message}`);
|
|
847
|
+
logResult(500, "module refresh failed");
|
|
848
|
+
return;
|
|
849
|
+
}
|
|
850
|
+
} else {
|
|
851
|
+
registry = mainRegistry;
|
|
852
|
+
}
|
|
486
853
|
|
|
487
854
|
if (!registry) {
|
|
488
855
|
// No main registry: the RSC env has no module runner (Cloudflare dev).
|
|
@@ -496,6 +863,7 @@ export function createRouterDiscoveryPlugin(
|
|
|
496
863
|
if (!registry || registry.size === 0) {
|
|
497
864
|
res.statusCode = 503;
|
|
498
865
|
res.end("Prerender runner not available");
|
|
866
|
+
logResult(503, "no registry");
|
|
499
867
|
return;
|
|
500
868
|
}
|
|
501
869
|
|
|
@@ -534,16 +902,18 @@ export function createRouterDiscoveryPlugin(
|
|
|
534
902
|
payload = { segments: result.segments, handles: result.handles };
|
|
535
903
|
}
|
|
536
904
|
res.end(JSON.stringify(payload));
|
|
905
|
+
logResult(200, `match ${result.routeName}`);
|
|
537
906
|
return;
|
|
538
907
|
} catch (err: any) {
|
|
539
908
|
console.warn(
|
|
540
|
-
`[
|
|
909
|
+
`[rango] Dev prerender failed for ${pathname}: ${err.message}`,
|
|
541
910
|
);
|
|
542
911
|
}
|
|
543
912
|
}
|
|
544
913
|
|
|
545
914
|
res.statusCode = 404;
|
|
546
915
|
res.end("No prerender match");
|
|
916
|
+
logResult(404, "no match");
|
|
547
917
|
});
|
|
548
918
|
|
|
549
919
|
// Watch url module and router files for changes and regenerate named-routes.gen.ts.
|
|
@@ -586,21 +956,135 @@ export function createRouterDiscoveryPlugin(
|
|
|
586
956
|
|
|
587
957
|
// Re-run runtime discovery so factory-generated routes that the
|
|
588
958
|
// static parser cannot see are refreshed after source changes.
|
|
589
|
-
|
|
959
|
+
// The state-machine concerns (queued/pending/gatePending) are
|
|
960
|
+
// owned by the gate created above (./discovery/gate-state.ts).
|
|
961
|
+
// Here we provide just the env-specific work.
|
|
590
962
|
const refreshRuntimeDiscovery = async () => {
|
|
591
963
|
const rscEnv = (server.environments as any)?.rsc;
|
|
592
|
-
|
|
593
|
-
|
|
964
|
+
const hasMainRunner = !!rscEnv?.runner;
|
|
965
|
+
// Cloudflare HMR has no main RSC runner (workerd is a separate
|
|
966
|
+
// runtime). When we have a populated runtime manifest from cold
|
|
967
|
+
// start, we can re-discover via the temp Node runner — the same
|
|
968
|
+
// mechanism getOrCreateTempServer() uses at startup. Without a
|
|
969
|
+
// populated manifest there's nothing useful to do, so bail
|
|
970
|
+
// before involving the gate machine at all.
|
|
971
|
+
if (!hasMainRunner && s.perRouterManifests.length === 0) return;
|
|
972
|
+
await gate.runRefreshCycle(async () => {
|
|
973
|
+
const hmrStart = performance.now();
|
|
974
|
+
try {
|
|
975
|
+
if (hasMainRunner) {
|
|
976
|
+
await timed(debugDiscovery, "hmr discoverRouters", () =>
|
|
977
|
+
discoverRouters(s, rscEnv),
|
|
978
|
+
);
|
|
979
|
+
timedSync(debugDiscovery, "hmr writeRouteTypesFiles", () =>
|
|
980
|
+
writeRouteTypesFiles(s),
|
|
981
|
+
);
|
|
982
|
+
await timed(debugDiscovery, "hmr propagateDiscoveryState", () =>
|
|
983
|
+
propagateDiscoveryState(rscEnv),
|
|
984
|
+
);
|
|
985
|
+
} else {
|
|
986
|
+
// Cloudflare HMR: invalidate the temp server's RSC module
|
|
987
|
+
// graph (or close+recreate as a fallback) so the runner
|
|
988
|
+
// re-reads the freshly edited source. Keeping the same
|
|
989
|
+
// Vite instance alive avoids disrupting workerd's transport
|
|
990
|
+
// during the first post-cold-start module-fetch window.
|
|
991
|
+
const tempRscEnv = await timed(
|
|
992
|
+
debugDiscovery,
|
|
993
|
+
"hmr refreshTempRscEnv (cloudflare)",
|
|
994
|
+
() => refreshTempRscEnv(),
|
|
995
|
+
);
|
|
996
|
+
if (!tempRscEnv) {
|
|
997
|
+
throw new Error(
|
|
998
|
+
"temp runner unavailable for cloudflare HMR rediscovery",
|
|
999
|
+
);
|
|
1000
|
+
}
|
|
1001
|
+
await timed(
|
|
1002
|
+
debugDiscovery,
|
|
1003
|
+
"hmr discoverRouters (cloudflare)",
|
|
1004
|
+
() => discoverRouters(s, tempRscEnv),
|
|
1005
|
+
);
|
|
1006
|
+
timedSync(debugDiscovery, "hmr writeRouteTypesFiles", () =>
|
|
1007
|
+
writeRouteTypesFiles(s),
|
|
1008
|
+
);
|
|
1009
|
+
}
|
|
1010
|
+
if (s.lastDiscoveryError) {
|
|
1011
|
+
debugDiscovery?.(
|
|
1012
|
+
"hmr: cleared lastDiscoveryError (%s) after successful rediscovery",
|
|
1013
|
+
s.lastDiscoveryError.message,
|
|
1014
|
+
);
|
|
1015
|
+
s.lastDiscoveryError = null;
|
|
1016
|
+
}
|
|
1017
|
+
// Cloudflare dev: on a successful cycle drop the workerd runner's
|
|
1018
|
+
// cached worker-entry chain so the next request re-evaluates
|
|
1019
|
+
// createRouter() with the new routes. Fired here in the work path
|
|
1020
|
+
// (not the caller's .then()) so a queued follow-up cycle that
|
|
1021
|
+
// succeeds after an earlier failed cycle still reloads:
|
|
1022
|
+
// runRefreshCycle recurses queued work without awaiting it, so the
|
|
1023
|
+
// original call already resolved on the failed cycle. A failed
|
|
1024
|
+
// cycle throws above and never reaches here, so a broken edit
|
|
1025
|
+
// never reloads the worker onto bad source.
|
|
1026
|
+
if (rscEnv && !rscEnv.runner) forceCloudflareWorkerReload(rscEnv);
|
|
1027
|
+
} catch (err: any) {
|
|
1028
|
+
s.lastDiscoveryError = {
|
|
1029
|
+
message: err?.message ?? String(err),
|
|
1030
|
+
at: Date.now(),
|
|
1031
|
+
};
|
|
1032
|
+
console.warn(
|
|
1033
|
+
`[rango] Runtime re-discovery failed: ${err.message}`,
|
|
1034
|
+
);
|
|
1035
|
+
debugDiscovery?.(
|
|
1036
|
+
"hmr: lastDiscoveryError set (%s) — manifest preserved at last-good; recovery mode active (any in-scan source change will trigger rediscovery)",
|
|
1037
|
+
err?.message,
|
|
1038
|
+
);
|
|
1039
|
+
} finally {
|
|
1040
|
+
debugDiscovery?.(
|
|
1041
|
+
"hmr re-discovery done (%sms)",
|
|
1042
|
+
(performance.now() - hmrStart).toFixed(1),
|
|
1043
|
+
);
|
|
1044
|
+
}
|
|
1045
|
+
});
|
|
1046
|
+
};
|
|
1047
|
+
|
|
1048
|
+
// Cloudflare dev only. workerd serves every request through the
|
|
1049
|
+
// runner-worker singleton, which re-resolves the worker entry per
|
|
1050
|
+
// request via runner.import("virtual:cloudflare/worker-entry"). The
|
|
1051
|
+
// route table lives in the user's createRouter() instance, captured
|
|
1052
|
+
// when that entry chain (entry -> router -> urls) was last evaluated
|
|
1053
|
+
// and then cached in the runner's evaluatedModules. The route-file
|
|
1054
|
+
// watcher refreshes discovery + types on the Node side, but the worker
|
|
1055
|
+
// keeps serving the cached (stale) router: route-definition modules
|
|
1056
|
+
// have no import.meta.hot boundary, so Vite never sends the worker an
|
|
1057
|
+
// HMR update for them and the entry chain is never evicted.
|
|
1058
|
+
//
|
|
1059
|
+
// Fix: after discovery completes, (1) invalidate the worker env's
|
|
1060
|
+
// Node-side module graph, then (2) send a full-reload to the worker.
|
|
1061
|
+
// Step (2) alone is insufficient: the full-reload handler clears the
|
|
1062
|
+
// runner's evaluatedModules and re-imports entrypoints, but each
|
|
1063
|
+
// re-import fetches the module back through this Node-side graph, which
|
|
1064
|
+
// still holds the pre-edit transform of urls.tsx — so createRouter()
|
|
1065
|
+
// rebuilds the stale route table and the new route 404s/hits the
|
|
1066
|
+
// catch-all. Invalidating the graph forces a fresh transform on
|
|
1067
|
+
// re-fetch (the same mechanism refreshTempRscEnv uses for discovery),
|
|
1068
|
+
// so the re-import re-runs createRouter() with the new routes. This is
|
|
1069
|
+
// the programmatic equivalent of the dev-server "r + enter" restart,
|
|
1070
|
+
// scoped to the worker environment instead of tearing down the server.
|
|
1071
|
+
const forceCloudflareWorkerReload = (rscEnv: any) => {
|
|
1072
|
+
if (!rscEnv?.hot) return;
|
|
594
1073
|
try {
|
|
595
|
-
|
|
596
|
-
|
|
597
|
-
|
|
1074
|
+
const graph = rscEnv.moduleGraph;
|
|
1075
|
+
if (graph?.invalidateAll) {
|
|
1076
|
+
graph.invalidateAll();
|
|
1077
|
+
debugDiscovery?.("hmr: invalidated workerd rsc module graph");
|
|
1078
|
+
}
|
|
1079
|
+
rscEnv.hot.send({ type: "full-reload" });
|
|
1080
|
+
debugDiscovery?.(
|
|
1081
|
+
"hmr: forced workerd rsc env reload (full-reload)",
|
|
1082
|
+
);
|
|
598
1083
|
} catch (err: any) {
|
|
599
|
-
|
|
600
|
-
|
|
1084
|
+
debugDiscovery?.(
|
|
1085
|
+
"hmr: workerd reload failed: %s",
|
|
1086
|
+
err?.message ?? err,
|
|
601
1087
|
);
|
|
602
|
-
} finally {
|
|
603
|
-
runtimeRediscoveryInProgress = false;
|
|
604
1088
|
}
|
|
605
1089
|
};
|
|
606
1090
|
|
|
@@ -608,23 +1092,50 @@ export function createRouterDiscoveryPlugin(
|
|
|
608
1092
|
clearTimeout(routeChangeTimer);
|
|
609
1093
|
routeChangeTimer = setTimeout(() => {
|
|
610
1094
|
routeChangeTimer = undefined;
|
|
1095
|
+
const regenStart = debugDiscovery ? performance.now() : 0;
|
|
1096
|
+
const rscEnv = (server.environments as any)?.rsc;
|
|
1097
|
+
const skipStaticWrite =
|
|
1098
|
+
!rscEnv?.runner && s.perRouterManifests.length > 0;
|
|
611
1099
|
try {
|
|
612
|
-
|
|
613
|
-
|
|
614
|
-
|
|
1100
|
+
// In cloudflare dev with a populated runtime manifest, the
|
|
1101
|
+
// static parser produces a strictly smaller (and actively
|
|
1102
|
+
// wrong) gen file — supplementGenFilesWithRuntimeRoutes can
|
|
1103
|
+
// only restore factory-only prefixes, and apps with mixed
|
|
1104
|
+
// static+factory routes under shared prefixes (cf-stress)
|
|
1105
|
+
// collapse to the 19-route static view. Skip the static
|
|
1106
|
+
// write entirely; runtime rediscovery below will overwrite
|
|
1107
|
+
// the gen file with the authoritative manifest.
|
|
1108
|
+
if (skipStaticWrite) {
|
|
1109
|
+
debugDiscovery?.(
|
|
1110
|
+
"watcher: skipping static write (cloudflare HMR — runtime rediscovery owns gen file)",
|
|
1111
|
+
);
|
|
1112
|
+
} else {
|
|
1113
|
+
writeCombinedRouteTypesWithTracking(s);
|
|
1114
|
+
if (s.perRouterManifests.length > 0) {
|
|
1115
|
+
supplementGenFilesWithRuntimeRoutes(s);
|
|
1116
|
+
}
|
|
615
1117
|
}
|
|
616
1118
|
} catch (err: any) {
|
|
617
|
-
console.error(
|
|
618
|
-
`[rsc-router] Route regeneration error: ${err.message}`,
|
|
619
|
-
);
|
|
1119
|
+
console.error(`[rango] Route regeneration error: ${err.message}`);
|
|
620
1120
|
}
|
|
1121
|
+
debugDiscovery?.(
|
|
1122
|
+
"watcher: regenerated gen files (%sms)",
|
|
1123
|
+
(performance.now() - regenStart).toFixed(1),
|
|
1124
|
+
);
|
|
621
1125
|
// Async: re-run runtime discovery to refresh factory-generated
|
|
622
|
-
// routes that the static parser cannot resolve.
|
|
1126
|
+
// routes that the static parser cannot resolve. Resolves the
|
|
1127
|
+
// discovery gate when complete.
|
|
623
1128
|
if (s.perRouterManifests.length > 0) {
|
|
1129
|
+
// The cloudflare workerd reload fires inside refreshRuntimeDiscovery
|
|
1130
|
+
// on the successful cycle (see forceCloudflareWorkerReload call
|
|
1131
|
+
// there) so queued follow-up cycles also trigger it.
|
|
624
1132
|
refreshRuntimeDiscovery().catch((err: any) => {
|
|
625
1133
|
console.warn(
|
|
626
|
-
`[
|
|
1134
|
+
`[rango] Runtime re-discovery error: ${err.message}`,
|
|
627
1135
|
);
|
|
1136
|
+
// Even on error, unblock the gate so workerd's reload doesn't
|
|
1137
|
+
// hang indefinitely against the previous manifest.
|
|
1138
|
+
resolveDiscoveryGate();
|
|
628
1139
|
});
|
|
629
1140
|
}
|
|
630
1141
|
}, 100);
|
|
@@ -637,21 +1148,74 @@ export function createRouterDiscoveryPlugin(
|
|
|
637
1148
|
!filePath.endsWith(".tsx") &&
|
|
638
1149
|
!filePath.endsWith(".js") &&
|
|
639
1150
|
!filePath.endsWith(".jsx")
|
|
640
|
-
)
|
|
1151
|
+
) {
|
|
1152
|
+
if (s.lastDiscoveryError) {
|
|
1153
|
+
debugDiscovery?.(
|
|
1154
|
+
"watcher: skip non-source %s [LASTERR %s]",
|
|
1155
|
+
filePath,
|
|
1156
|
+
s.lastDiscoveryError.message,
|
|
1157
|
+
);
|
|
1158
|
+
}
|
|
641
1159
|
return;
|
|
1160
|
+
}
|
|
642
1161
|
// Apply scan filter as early-exit before reading file
|
|
643
|
-
if (s.scanFilter && !s.scanFilter(filePath))
|
|
1162
|
+
if (s.scanFilter && !s.scanFilter(filePath)) {
|
|
1163
|
+
if (s.lastDiscoveryError) {
|
|
1164
|
+
debugDiscovery?.(
|
|
1165
|
+
"watcher: skip scan-filter %s [LASTERR %s]",
|
|
1166
|
+
filePath,
|
|
1167
|
+
s.lastDiscoveryError.message,
|
|
1168
|
+
);
|
|
1169
|
+
}
|
|
1170
|
+
return;
|
|
1171
|
+
}
|
|
1172
|
+
// Recovery mode: when the previous HMR re-discovery failed, the
|
|
1173
|
+
// import graph is incomplete and the manifest is stuck at the
|
|
1174
|
+
// last-good state. The fix may land in a non-route file (e.g. a
|
|
1175
|
+
// helper imported by the router, a missing module being created,
|
|
1176
|
+
// or a "use client" component) that the narrow content sniff
|
|
1177
|
+
// would otherwise filter out. While in recovery, treat any
|
|
1178
|
+
// in-scan source change as a candidate for rediscovery; the
|
|
1179
|
+
// tighter filter resumes once discovery succeeds again.
|
|
1180
|
+
const inRecoveryMode = !!s.lastDiscoveryError;
|
|
644
1181
|
try {
|
|
645
1182
|
const source = readFileSync(filePath, "utf-8");
|
|
646
1183
|
const trimmed = source.trimStart();
|
|
647
|
-
|
|
1184
|
+
const isUseClient =
|
|
648
1185
|
trimmed.startsWith('"use client"') ||
|
|
649
|
-
trimmed.startsWith("'use client'")
|
|
650
|
-
)
|
|
651
|
-
|
|
652
|
-
|
|
653
|
-
|
|
654
|
-
|
|
1186
|
+
trimmed.startsWith("'use client'");
|
|
1187
|
+
if (!inRecoveryMode && isUseClient) return;
|
|
1188
|
+
// Cheap raw pre-check first; only when a candidate token is present
|
|
1189
|
+
// do we confirm it occurs in real code (not a comment/string) via a
|
|
1190
|
+
// single allocation-free code-region scan. Most saved files contain
|
|
1191
|
+
// neither token and skip the scan entirely. This avoids a comment or
|
|
1192
|
+
// string mention spuriously marking a file relevant and triggering an
|
|
1193
|
+
// unnecessary re-discovery on save.
|
|
1194
|
+
let hasUrls = source.includes("urls(");
|
|
1195
|
+
let hasCreateRouter = /\bcreateRouter\s*[<(]/.test(source);
|
|
1196
|
+
if (hasUrls) hasUrls = firstCodeMatchIndex(source, /urls\(/g) >= 0;
|
|
1197
|
+
if (hasCreateRouter) {
|
|
1198
|
+
hasCreateRouter =
|
|
1199
|
+
firstCodeMatchIndex(source, /\bcreateRouter\s*[<(]/g) >= 0;
|
|
1200
|
+
}
|
|
1201
|
+
if (!inRecoveryMode && !hasUrls && !hasCreateRouter) return;
|
|
1202
|
+
if (inRecoveryMode) {
|
|
1203
|
+
debugDiscovery?.(
|
|
1204
|
+
"watcher: recovery rediscovery for %s (urls=%s, router=%s, useClient=%s) [LASTERR %s]",
|
|
1205
|
+
filePath,
|
|
1206
|
+
hasUrls,
|
|
1207
|
+
hasCreateRouter,
|
|
1208
|
+
isUseClient,
|
|
1209
|
+
s.lastDiscoveryError!.message,
|
|
1210
|
+
);
|
|
1211
|
+
} else {
|
|
1212
|
+
debugDiscovery?.(
|
|
1213
|
+
"watcher: %s matches (urls=%s, router=%s)",
|
|
1214
|
+
filePath,
|
|
1215
|
+
hasUrls,
|
|
1216
|
+
hasCreateRouter,
|
|
1217
|
+
);
|
|
1218
|
+
}
|
|
655
1219
|
// Invalidate cache when a router file changes (new router added/removed)
|
|
656
1220
|
if (hasCreateRouter) {
|
|
657
1221
|
const nestedRouterConflict = findNestedRouterConflict([
|
|
@@ -666,8 +1230,27 @@ export function createRouterDiscoveryPlugin(
|
|
|
666
1230
|
}
|
|
667
1231
|
s.cachedRouterFiles = undefined;
|
|
668
1232
|
}
|
|
1233
|
+
// Note the event in the gate machine IMMEDIATELY (before the
|
|
1234
|
+
// 100ms debounce and any downstream HMR fanout). This sets
|
|
1235
|
+
// both `pendingEvents` (so refresh's finally holds the gate
|
|
1236
|
+
// through the tail window even if no rediscovery is queued)
|
|
1237
|
+
// and resets `discoveryDone` to a fresh pending promise (so
|
|
1238
|
+
// workerd reloads triggered by the same source change can't
|
|
1239
|
+
// observe a stale resolved gate from cold-start). Resolved
|
|
1240
|
+
// by the trailing refreshRuntimeDiscovery() cycle.
|
|
1241
|
+
if (s.perRouterManifests.length > 0) {
|
|
1242
|
+
gate.noteRouteEvent();
|
|
1243
|
+
}
|
|
669
1244
|
scheduleRouteRegeneration();
|
|
670
|
-
} catch {
|
|
1245
|
+
} catch (readErr: any) {
|
|
1246
|
+
if (s.lastDiscoveryError) {
|
|
1247
|
+
debugDiscovery?.(
|
|
1248
|
+
"watcher: read error %s: %s [LASTERR %s]",
|
|
1249
|
+
filePath,
|
|
1250
|
+
readErr?.message,
|
|
1251
|
+
s.lastDiscoveryError.message,
|
|
1252
|
+
);
|
|
1253
|
+
}
|
|
671
1254
|
// Ignore read errors for deleted/moved files
|
|
672
1255
|
}
|
|
673
1256
|
};
|
|
@@ -696,13 +1279,23 @@ export function createRouterDiscoveryPlugin(
|
|
|
696
1279
|
async buildStart() {
|
|
697
1280
|
if (!s.isBuildMode) return;
|
|
698
1281
|
// Only run once across environment builds
|
|
699
|
-
if (s.mergedRouteManifest !== null)
|
|
1282
|
+
if (s.mergedRouteManifest !== null) {
|
|
1283
|
+
debugDiscovery?.(
|
|
1284
|
+
"build: skip (already discovered, env=%s)",
|
|
1285
|
+
this.environment?.name ?? "?",
|
|
1286
|
+
);
|
|
1287
|
+
return;
|
|
1288
|
+
}
|
|
1289
|
+
const buildStartTime = performance.now();
|
|
1290
|
+
debugDiscovery?.("build: start (env=%s)", this.environment?.name ?? "?");
|
|
700
1291
|
resetStagedBuildAssets(s.projectRoot);
|
|
701
1292
|
s.prerenderManifestEntries = null;
|
|
702
1293
|
s.staticManifestEntries = null;
|
|
703
1294
|
|
|
704
1295
|
// Acquire build-time env bindings if configured
|
|
705
|
-
await
|
|
1296
|
+
await timed(debugDiscovery, "build acquireBuildEnv", () =>
|
|
1297
|
+
acquireBuildEnv(s, viteCommand, viteMode),
|
|
1298
|
+
);
|
|
706
1299
|
|
|
707
1300
|
let tempServer: any = null;
|
|
708
1301
|
// Signal to user-space code (e.g. reverse.ts) that build-time discovery
|
|
@@ -711,12 +1304,16 @@ export function createRouterDiscoveryPlugin(
|
|
|
711
1304
|
// between the vite plugin and user code loaded via runner.import().
|
|
712
1305
|
(globalThis as any).__rscRouterDiscoveryActive = true;
|
|
713
1306
|
try {
|
|
714
|
-
tempServer = await
|
|
1307
|
+
tempServer = await timed(
|
|
1308
|
+
debugDiscovery,
|
|
1309
|
+
"build createTempRscServer",
|
|
1310
|
+
() => createTempRscServer(s, { forceBuild: true }),
|
|
1311
|
+
);
|
|
715
1312
|
|
|
716
1313
|
const rscEnv = (tempServer.environments as any)?.rsc;
|
|
717
1314
|
if (!rscEnv?.runner) {
|
|
718
1315
|
console.warn(
|
|
719
|
-
"[
|
|
1316
|
+
"[rango] RSC environment runner not available during build, skipping manifest generation",
|
|
720
1317
|
);
|
|
721
1318
|
return;
|
|
722
1319
|
}
|
|
@@ -731,11 +1328,15 @@ export function createRouterDiscoveryPlugin(
|
|
|
731
1328
|
s.resolvedStaticModules = tempIdsPlugin.api.staticHandlerModules;
|
|
732
1329
|
}
|
|
733
1330
|
|
|
734
|
-
await
|
|
1331
|
+
await timed(debugDiscovery, "build discoverRouters", () =>
|
|
1332
|
+
discoverRouters(s, rscEnv),
|
|
1333
|
+
);
|
|
735
1334
|
// Update named-routes.gen.ts from runtime discovery.
|
|
736
1335
|
// The runtime manifest includes dynamically generated routes
|
|
737
1336
|
// that the static parser cannot extract from source code.
|
|
738
|
-
writeRouteTypesFiles(
|
|
1337
|
+
timedSync(debugDiscovery, "build writeRouteTypesFiles", () =>
|
|
1338
|
+
writeRouteTypesFiles(s),
|
|
1339
|
+
);
|
|
739
1340
|
} catch (err: any) {
|
|
740
1341
|
// Extract the user source file from the stack trace (skip internal frames)
|
|
741
1342
|
const sourceFile = err.stack
|
|
@@ -755,14 +1356,50 @@ export function createRouterDiscoveryPlugin(
|
|
|
755
1356
|
.filter(Boolean)
|
|
756
1357
|
.join("\n");
|
|
757
1358
|
throw new Error(
|
|
758
|
-
`[
|
|
1359
|
+
`[rango] Build-time router discovery failed:\n${details}`,
|
|
1360
|
+
{ cause: err },
|
|
759
1361
|
);
|
|
760
1362
|
} finally {
|
|
761
1363
|
delete (globalThis as any).__rscRouterDiscoveryActive;
|
|
762
1364
|
if (tempServer) {
|
|
763
|
-
await tempServer.close()
|
|
1365
|
+
await timed(debugDiscovery, "build tempServer.close", () =>
|
|
1366
|
+
tempServer.close(),
|
|
1367
|
+
);
|
|
764
1368
|
}
|
|
765
1369
|
await releaseBuildEnv(s);
|
|
1370
|
+
debugDiscovery?.(
|
|
1371
|
+
"build discovery done (%sms)",
|
|
1372
|
+
(performance.now() - buildStartTime).toFixed(1),
|
|
1373
|
+
);
|
|
1374
|
+
}
|
|
1375
|
+
},
|
|
1376
|
+
|
|
1377
|
+
// Suppress vite's HMR cascade for our own gen-file writes.
|
|
1378
|
+
//
|
|
1379
|
+
// After every cf HMR cycle, refreshTempRscEnv → writeRouteTypesFiles
|
|
1380
|
+
// writes the configured gen files (default `router.named-routes.gen.ts`,
|
|
1381
|
+
// but the source filenames and gen suffix are user-configurable). The
|
|
1382
|
+
// chokidar watcher then fires twice independently: our
|
|
1383
|
+
// `handleRouteFileChange` (already short-circuited by
|
|
1384
|
+
// `consumeSelfGenWrite` inside `maybeHandleGeneratedRouteFileMutation`),
|
|
1385
|
+
// AND vite's own HMR pipeline (which invalidates the gen file's
|
|
1386
|
+
// importers and triggers a second workerd full reload — visible to the
|
|
1387
|
+
// user as a duplicate "[Rango] HMR: version changed" on the client).
|
|
1388
|
+
//
|
|
1389
|
+
// `peekSelfGenWrite` is the authoritative filter: its map only contains
|
|
1390
|
+
// paths that `markSelfGenWrite` has registered, so it natively works
|
|
1391
|
+
// for any configured gen-file name. It is non-consuming so the chokidar
|
|
1392
|
+
// handler that fires later can still consume the same entry. Returning
|
|
1393
|
+
// [] tells vite "no modules invalidated by this change" — safe because
|
|
1394
|
+
// `s.perRouterManifests` is already up-to-date (the write that just
|
|
1395
|
+
// happened is the consequence of our just-completed rediscovery).
|
|
1396
|
+
handleHotUpdate(ctx) {
|
|
1397
|
+
if (peekSelfGenWrite(s, ctx.file)) {
|
|
1398
|
+
debugDiscovery?.(
|
|
1399
|
+
"handleHotUpdate: suppressing self-write HMR cascade for %s",
|
|
1400
|
+
ctx.file,
|
|
1401
|
+
);
|
|
1402
|
+
return [];
|
|
766
1403
|
}
|
|
767
1404
|
},
|
|
768
1405
|
|
|
@@ -786,19 +1423,38 @@ export function createRouterDiscoveryPlugin(
|
|
|
786
1423
|
// This is critical for Cloudflare dev where the worker runs in a separate
|
|
787
1424
|
// Miniflare process and can only receive manifest data via the virtual module.
|
|
788
1425
|
if (s.discoveryDone) {
|
|
789
|
-
await
|
|
1426
|
+
await timed(
|
|
1427
|
+
debugRoutes,
|
|
1428
|
+
"await discoveryDone (manifest)",
|
|
1429
|
+
() => s.discoveryDone,
|
|
1430
|
+
);
|
|
790
1431
|
}
|
|
791
|
-
|
|
1432
|
+
const code = await timed(
|
|
1433
|
+
debugRoutes,
|
|
1434
|
+
"generateRoutesManifestModule",
|
|
1435
|
+
() => generateRoutesManifestModule(s),
|
|
1436
|
+
);
|
|
1437
|
+
debugRoutes?.("manifest module emitted (%d bytes)", code?.length ?? 0);
|
|
1438
|
+
return code;
|
|
792
1439
|
}
|
|
793
1440
|
// Per-router virtual modules: pure data exports (no side effects).
|
|
794
1441
|
// ensureRouterManifest() imports the module and stores the data.
|
|
795
1442
|
const perRouterPrefix = "\0" + VIRTUAL_ROUTES_MANIFEST_ID + "/";
|
|
796
1443
|
if (id.startsWith(perRouterPrefix)) {
|
|
797
1444
|
if (s.discoveryDone) {
|
|
798
|
-
await
|
|
1445
|
+
await timed(
|
|
1446
|
+
debugRoutes,
|
|
1447
|
+
"await discoveryDone (per-router)",
|
|
1448
|
+
() => s.discoveryDone,
|
|
1449
|
+
);
|
|
799
1450
|
}
|
|
800
1451
|
const routerId = id.slice(perRouterPrefix.length);
|
|
801
|
-
|
|
1452
|
+
const code = await timed(
|
|
1453
|
+
debugRoutes,
|
|
1454
|
+
`generatePerRouterModule ${routerId}`,
|
|
1455
|
+
() => generatePerRouterModule(s, routerId),
|
|
1456
|
+
);
|
|
1457
|
+
return code;
|
|
802
1458
|
}
|
|
803
1459
|
// virtual:rsc-router/prerender-paths load handler removed
|
|
804
1460
|
return null;
|
|
@@ -808,6 +1464,7 @@ export function createRouterDiscoveryPlugin(
|
|
|
808
1464
|
// Used by closeBundle for handler code eviction and prerender data injection.
|
|
809
1465
|
generateBundle(_options: any, bundle: any) {
|
|
810
1466
|
if (this.environment?.name !== "rsc") return;
|
|
1467
|
+
const genStart = debugBuild ? performance.now() : 0;
|
|
811
1468
|
|
|
812
1469
|
// Record RSC entry chunk filename for closeBundle injection
|
|
813
1470
|
for (const [fileName, chunk] of Object.entries(bundle) as [
|
|
@@ -820,8 +1477,13 @@ export function createRouterDiscoveryPlugin(
|
|
|
820
1477
|
}
|
|
821
1478
|
}
|
|
822
1479
|
|
|
823
|
-
if (!s.resolvedPrerenderModules?.size && !s.resolvedStaticModules?.size)
|
|
1480
|
+
if (!s.resolvedPrerenderModules?.size && !s.resolvedStaticModules?.size) {
|
|
1481
|
+
debugBuild?.(
|
|
1482
|
+
"generateBundle (rsc): no handlers to scan (%sms)",
|
|
1483
|
+
(performance.now() - genStart).toFixed(1),
|
|
1484
|
+
);
|
|
824
1485
|
return;
|
|
1486
|
+
}
|
|
825
1487
|
|
|
826
1488
|
// Clear maps at the start of each RSC generateBundle pass.
|
|
827
1489
|
// Vite 6 multi-environment builds run RSC twice (analysis + production);
|
|
@@ -876,6 +1538,14 @@ export function createRouterDiscoveryPlugin(
|
|
|
876
1538
|
}
|
|
877
1539
|
}
|
|
878
1540
|
}
|
|
1541
|
+
|
|
1542
|
+
debugBuild?.(
|
|
1543
|
+
"generateBundle (rsc): scanned %d chunks, %d prerender chunk(s), %d static chunk(s) (%sms)",
|
|
1544
|
+
Object.keys(bundle).length,
|
|
1545
|
+
s.handlerChunkInfoMap.size,
|
|
1546
|
+
s.staticHandlerChunkInfoMap.size,
|
|
1547
|
+
(performance.now() - genStart).toFixed(1),
|
|
1548
|
+
);
|
|
879
1549
|
},
|
|
880
1550
|
|
|
881
1551
|
// Build-time pre-rendering: evict handler code and inject collected prerender data.
|
|
@@ -889,7 +1559,9 @@ export function createRouterDiscoveryPlugin(
|
|
|
889
1559
|
// Only run for the RSC environment — other environments (client, ssr) have
|
|
890
1560
|
// no prerender/static data to process and would just do redundant file I/O.
|
|
891
1561
|
if (this.environment && this.environment.name !== "rsc") return;
|
|
892
|
-
postprocessBundle(
|
|
1562
|
+
timedSync(debugBuild, "closeBundle postprocessBundle", () =>
|
|
1563
|
+
postprocessBundle(s),
|
|
1564
|
+
);
|
|
893
1565
|
},
|
|
894
1566
|
},
|
|
895
1567
|
};
|