@rangojs/router 0.0.0-experimental.114 → 0.0.0-experimental.116

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.
Files changed (844) hide show
  1. package/dist/vite/index.js +205 -95
  2. package/package.json +17 -18
  3. package/skills/api-client/SKILL.md +211 -0
  4. package/skills/mime-routes/SKILL.md +1 -1
  5. package/skills/rango/SKILL.md +1 -0
  6. package/skills/response-routes/SKILL.md +61 -43
  7. package/skills/typesafety/SKILL.md +3 -3
  8. package/src/__augment-tests__/augmented.check.ts +2 -3
  9. package/src/build/collect-fallback-refs.ts +107 -0
  10. package/src/build/generate-manifest.ts +28 -1
  11. package/src/build/index.ts +8 -1
  12. package/src/build/prefix-tree-utils.ts +123 -0
  13. package/src/build/route-trie.ts +43 -0
  14. package/src/client.tsx +4 -23
  15. package/src/errors.ts +0 -3
  16. package/src/href-client.ts +7 -8
  17. package/src/index.rsc.ts +1 -2
  18. package/src/index.ts +1 -2
  19. package/src/router/find-match.ts +54 -6
  20. package/src/router/lazy-includes.ts +33 -14
  21. package/src/router/manifest.ts +19 -6
  22. package/src/router/pattern-matching.ts +15 -2
  23. package/src/router/router-interfaces.ts +11 -0
  24. package/src/router/trie-matching.ts +22 -3
  25. package/src/router.ts +21 -7
  26. package/src/rsc/manifest-init.ts +28 -41
  27. package/src/rsc/response-error.ts +79 -12
  28. package/src/rsc/response-route-handler.ts +16 -13
  29. package/src/urls/index.ts +1 -2
  30. package/src/urls/type-extraction.ts +33 -24
  31. package/src/vite/debug.ts +1 -0
  32. package/src/vite/discovery/discover-routers.ts +46 -29
  33. package/src/vite/discovery/state.ts +7 -0
  34. package/src/vite/index.ts +2 -0
  35. package/src/vite/plugin-types.ts +67 -0
  36. package/src/vite/plugins/client-ref-hashing.ts +12 -1
  37. package/src/vite/rango.ts +40 -0
  38. package/src/vite/utils/client-chunks.ts +190 -0
  39. package/src/vite/utils/manifest-utils.ts +8 -75
  40. package/src/vite/utils/shared-utils.ts +68 -3
  41. package/dist/__internal.d.ts +0 -83
  42. package/dist/__internal.d.ts.map +0 -1
  43. package/dist/__internal.js +0 -19
  44. package/dist/__internal.js.map +0 -1
  45. package/dist/__mocks__/version.d.ts +0 -7
  46. package/dist/__mocks__/version.d.ts.map +0 -1
  47. package/dist/__mocks__/version.js +0 -7
  48. package/dist/__mocks__/version.js.map +0 -1
  49. package/dist/__tests__/client-href.test.d.ts +0 -2
  50. package/dist/__tests__/client-href.test.d.ts.map +0 -1
  51. package/dist/__tests__/client-href.test.js +0 -74
  52. package/dist/__tests__/client-href.test.js.map +0 -1
  53. package/dist/__tests__/component-utils.test.d.ts +0 -2
  54. package/dist/__tests__/component-utils.test.d.ts.map +0 -1
  55. package/dist/__tests__/component-utils.test.js +0 -51
  56. package/dist/__tests__/component-utils.test.js.map +0 -1
  57. package/dist/__tests__/event-controller.test.d.ts +0 -2
  58. package/dist/__tests__/event-controller.test.d.ts.map +0 -1
  59. package/dist/__tests__/event-controller.test.js +0 -538
  60. package/dist/__tests__/event-controller.test.js.map +0 -1
  61. package/dist/__tests__/helpers/route-tree.d.ts +0 -118
  62. package/dist/__tests__/helpers/route-tree.d.ts.map +0 -1
  63. package/dist/__tests__/helpers/route-tree.js +0 -374
  64. package/dist/__tests__/helpers/route-tree.js.map +0 -1
  65. package/dist/__tests__/match-result.test.d.ts +0 -2
  66. package/dist/__tests__/match-result.test.d.ts.map +0 -1
  67. package/dist/__tests__/match-result.test.js +0 -154
  68. package/dist/__tests__/match-result.test.js.map +0 -1
  69. package/dist/__tests__/navigation-store.test.d.ts +0 -2
  70. package/dist/__tests__/navigation-store.test.d.ts.map +0 -1
  71. package/dist/__tests__/navigation-store.test.js +0 -440
  72. package/dist/__tests__/navigation-store.test.js.map +0 -1
  73. package/dist/__tests__/partial-update.test.d.ts +0 -2
  74. package/dist/__tests__/partial-update.test.d.ts.map +0 -1
  75. package/dist/__tests__/partial-update.test.js +0 -1009
  76. package/dist/__tests__/partial-update.test.js.map +0 -1
  77. package/dist/__tests__/reverse-types.test.d.ts +0 -8
  78. package/dist/__tests__/reverse-types.test.d.ts.map +0 -1
  79. package/dist/__tests__/reverse-types.test.js +0 -656
  80. package/dist/__tests__/reverse-types.test.js.map +0 -1
  81. package/dist/__tests__/route-definition.test.d.ts +0 -2
  82. package/dist/__tests__/route-definition.test.d.ts.map +0 -1
  83. package/dist/__tests__/route-definition.test.js +0 -55
  84. package/dist/__tests__/route-definition.test.js.map +0 -1
  85. package/dist/__tests__/router-helpers.test.d.ts +0 -2
  86. package/dist/__tests__/router-helpers.test.d.ts.map +0 -1
  87. package/dist/__tests__/router-helpers.test.js +0 -377
  88. package/dist/__tests__/router-helpers.test.js.map +0 -1
  89. package/dist/__tests__/router-integration-2.test.d.ts +0 -2
  90. package/dist/__tests__/router-integration-2.test.d.ts.map +0 -1
  91. package/dist/__tests__/router-integration-2.test.js +0 -426
  92. package/dist/__tests__/router-integration-2.test.js.map +0 -1
  93. package/dist/__tests__/router-integration.test.d.ts +0 -2
  94. package/dist/__tests__/router-integration.test.d.ts.map +0 -1
  95. package/dist/__tests__/router-integration.test.js +0 -1051
  96. package/dist/__tests__/router-integration.test.js.map +0 -1
  97. package/dist/__tests__/search-params.test.d.ts +0 -5
  98. package/dist/__tests__/search-params.test.d.ts.map +0 -1
  99. package/dist/__tests__/search-params.test.js +0 -306
  100. package/dist/__tests__/search-params.test.js.map +0 -1
  101. package/dist/__tests__/segment-system.test.d.ts +0 -2
  102. package/dist/__tests__/segment-system.test.d.ts.map +0 -1
  103. package/dist/__tests__/segment-system.test.js +0 -627
  104. package/dist/__tests__/segment-system.test.js.map +0 -1
  105. package/dist/__tests__/static-handler-types.test.d.ts +0 -8
  106. package/dist/__tests__/static-handler-types.test.d.ts.map +0 -1
  107. package/dist/__tests__/static-handler-types.test.js +0 -63
  108. package/dist/__tests__/static-handler-types.test.js.map +0 -1
  109. package/dist/__tests__/urls.test.d.ts +0 -2
  110. package/dist/__tests__/urls.test.d.ts.map +0 -1
  111. package/dist/__tests__/urls.test.js +0 -421
  112. package/dist/__tests__/urls.test.js.map +0 -1
  113. package/dist/__tests__/use-mount.test.d.ts +0 -2
  114. package/dist/__tests__/use-mount.test.d.ts.map +0 -1
  115. package/dist/__tests__/use-mount.test.js +0 -35
  116. package/dist/__tests__/use-mount.test.js.map +0 -1
  117. package/dist/bin/rango.d.ts +0 -2
  118. package/dist/bin/rango.d.ts.map +0 -1
  119. package/dist/bin/rango.js.map +0 -1
  120. package/dist/browser/event-controller.d.ts +0 -191
  121. package/dist/browser/event-controller.d.ts.map +0 -1
  122. package/dist/browser/event-controller.js +0 -559
  123. package/dist/browser/event-controller.js.map +0 -1
  124. package/dist/browser/index.d.ts +0 -2
  125. package/dist/browser/index.d.ts.map +0 -1
  126. package/dist/browser/index.js +0 -14
  127. package/dist/browser/index.js.map +0 -1
  128. package/dist/browser/link-interceptor.d.ts +0 -38
  129. package/dist/browser/link-interceptor.d.ts.map +0 -1
  130. package/dist/browser/link-interceptor.js +0 -99
  131. package/dist/browser/link-interceptor.js.map +0 -1
  132. package/dist/browser/logging.d.ts +0 -10
  133. package/dist/browser/logging.d.ts.map +0 -1
  134. package/dist/browser/logging.js +0 -29
  135. package/dist/browser/logging.js.map +0 -1
  136. package/dist/browser/lru-cache.d.ts +0 -17
  137. package/dist/browser/lru-cache.d.ts.map +0 -1
  138. package/dist/browser/lru-cache.js +0 -50
  139. package/dist/browser/lru-cache.js.map +0 -1
  140. package/dist/browser/merge-segment-loaders.d.ts +0 -39
  141. package/dist/browser/merge-segment-loaders.d.ts.map +0 -1
  142. package/dist/browser/merge-segment-loaders.js +0 -102
  143. package/dist/browser/merge-segment-loaders.js.map +0 -1
  144. package/dist/browser/navigation-bridge.d.ts +0 -102
  145. package/dist/browser/navigation-bridge.d.ts.map +0 -1
  146. package/dist/browser/navigation-bridge.js +0 -708
  147. package/dist/browser/navigation-bridge.js.map +0 -1
  148. package/dist/browser/navigation-client.d.ts +0 -25
  149. package/dist/browser/navigation-client.d.ts.map +0 -1
  150. package/dist/browser/navigation-client.js +0 -157
  151. package/dist/browser/navigation-client.js.map +0 -1
  152. package/dist/browser/navigation-store.d.ts +0 -101
  153. package/dist/browser/navigation-store.d.ts.map +0 -1
  154. package/dist/browser/navigation-store.js +0 -625
  155. package/dist/browser/navigation-store.js.map +0 -1
  156. package/dist/browser/partial-update.d.ts +0 -75
  157. package/dist/browser/partial-update.d.ts.map +0 -1
  158. package/dist/browser/partial-update.js +0 -426
  159. package/dist/browser/partial-update.js.map +0 -1
  160. package/dist/browser/react/Link.d.ts +0 -86
  161. package/dist/browser/react/Link.d.ts.map +0 -1
  162. package/dist/browser/react/Link.js +0 -128
  163. package/dist/browser/react/Link.js.map +0 -1
  164. package/dist/browser/react/NavigationProvider.d.ts +0 -63
  165. package/dist/browser/react/NavigationProvider.d.ts.map +0 -1
  166. package/dist/browser/react/NavigationProvider.js +0 -216
  167. package/dist/browser/react/NavigationProvider.js.map +0 -1
  168. package/dist/browser/react/ScrollRestoration.d.ts +0 -75
  169. package/dist/browser/react/ScrollRestoration.d.ts.map +0 -1
  170. package/dist/browser/react/ScrollRestoration.js +0 -57
  171. package/dist/browser/react/ScrollRestoration.js.map +0 -1
  172. package/dist/browser/react/context.d.ts +0 -46
  173. package/dist/browser/react/context.d.ts.map +0 -1
  174. package/dist/browser/react/context.js +0 -10
  175. package/dist/browser/react/context.js.map +0 -1
  176. package/dist/browser/react/index.d.ts +0 -11
  177. package/dist/browser/react/index.d.ts.map +0 -1
  178. package/dist/browser/react/index.js +0 -22
  179. package/dist/browser/react/index.js.map +0 -1
  180. package/dist/browser/react/location-state-shared.d.ts +0 -63
  181. package/dist/browser/react/location-state-shared.d.ts.map +0 -1
  182. package/dist/browser/react/location-state-shared.js +0 -81
  183. package/dist/browser/react/location-state-shared.js.map +0 -1
  184. package/dist/browser/react/location-state.d.ts +0 -23
  185. package/dist/browser/react/location-state.d.ts.map +0 -1
  186. package/dist/browser/react/location-state.js +0 -29
  187. package/dist/browser/react/location-state.js.map +0 -1
  188. package/dist/browser/react/mount-context.d.ts +0 -24
  189. package/dist/browser/react/mount-context.d.ts.map +0 -1
  190. package/dist/browser/react/mount-context.js +0 -24
  191. package/dist/browser/react/mount-context.js.map +0 -1
  192. package/dist/browser/react/use-action.d.ts +0 -64
  193. package/dist/browser/react/use-action.d.ts.map +0 -1
  194. package/dist/browser/react/use-action.js +0 -134
  195. package/dist/browser/react/use-action.js.map +0 -1
  196. package/dist/browser/react/use-client-cache.d.ts +0 -41
  197. package/dist/browser/react/use-client-cache.d.ts.map +0 -1
  198. package/dist/browser/react/use-client-cache.js +0 -39
  199. package/dist/browser/react/use-client-cache.js.map +0 -1
  200. package/dist/browser/react/use-handle.d.ts +0 -31
  201. package/dist/browser/react/use-handle.d.ts.map +0 -1
  202. package/dist/browser/react/use-handle.js +0 -144
  203. package/dist/browser/react/use-handle.js.map +0 -1
  204. package/dist/browser/react/use-href.d.ts +0 -33
  205. package/dist/browser/react/use-href.d.ts.map +0 -1
  206. package/dist/browser/react/use-href.js +0 -39
  207. package/dist/browser/react/use-href.js.map +0 -1
  208. package/dist/browser/react/use-link-status.d.ts +0 -37
  209. package/dist/browser/react/use-link-status.d.ts.map +0 -1
  210. package/dist/browser/react/use-link-status.js +0 -99
  211. package/dist/browser/react/use-link-status.js.map +0 -1
  212. package/dist/browser/react/use-mount.d.ts +0 -25
  213. package/dist/browser/react/use-mount.d.ts.map +0 -1
  214. package/dist/browser/react/use-mount.js +0 -30
  215. package/dist/browser/react/use-mount.js.map +0 -1
  216. package/dist/browser/react/use-navigation.d.ts +0 -27
  217. package/dist/browser/react/use-navigation.d.ts.map +0 -1
  218. package/dist/browser/react/use-navigation.js +0 -87
  219. package/dist/browser/react/use-navigation.js.map +0 -1
  220. package/dist/browser/react/use-segments.d.ts +0 -38
  221. package/dist/browser/react/use-segments.d.ts.map +0 -1
  222. package/dist/browser/react/use-segments.js +0 -130
  223. package/dist/browser/react/use-segments.js.map +0 -1
  224. package/dist/browser/request-controller.d.ts +0 -26
  225. package/dist/browser/request-controller.d.ts.map +0 -1
  226. package/dist/browser/request-controller.js +0 -147
  227. package/dist/browser/request-controller.js.map +0 -1
  228. package/dist/browser/rsc-router.d.ts +0 -129
  229. package/dist/browser/rsc-router.d.ts.map +0 -1
  230. package/dist/browser/rsc-router.js +0 -195
  231. package/dist/browser/rsc-router.js.map +0 -1
  232. package/dist/browser/scroll-restoration.d.ts +0 -93
  233. package/dist/browser/scroll-restoration.d.ts.map +0 -1
  234. package/dist/browser/scroll-restoration.js +0 -321
  235. package/dist/browser/scroll-restoration.js.map +0 -1
  236. package/dist/browser/segment-structure-assert.d.ts +0 -17
  237. package/dist/browser/segment-structure-assert.d.ts.map +0 -1
  238. package/dist/browser/segment-structure-assert.js +0 -59
  239. package/dist/browser/segment-structure-assert.js.map +0 -1
  240. package/dist/browser/server-action-bridge.d.ts +0 -26
  241. package/dist/browser/server-action-bridge.d.ts.map +0 -1
  242. package/dist/browser/server-action-bridge.js +0 -668
  243. package/dist/browser/server-action-bridge.js.map +0 -1
  244. package/dist/browser/shallow.d.ts +0 -12
  245. package/dist/browser/shallow.d.ts.map +0 -1
  246. package/dist/browser/shallow.js +0 -34
  247. package/dist/browser/shallow.js.map +0 -1
  248. package/dist/browser/types.d.ts +0 -369
  249. package/dist/browser/types.d.ts.map +0 -1
  250. package/dist/browser/types.js +0 -2
  251. package/dist/browser/types.js.map +0 -1
  252. package/dist/build/__tests__/generate-cli.test.d.ts +0 -2
  253. package/dist/build/__tests__/generate-cli.test.d.ts.map +0 -1
  254. package/dist/build/__tests__/generate-cli.test.js +0 -237
  255. package/dist/build/__tests__/generate-cli.test.js.map +0 -1
  256. package/dist/build/__tests__/generate-manifest.test.d.ts +0 -2
  257. package/dist/build/__tests__/generate-manifest.test.d.ts.map +0 -1
  258. package/dist/build/__tests__/generate-manifest.test.js +0 -119
  259. package/dist/build/__tests__/generate-manifest.test.js.map +0 -1
  260. package/dist/build/__tests__/generate-route-types.test.d.ts +0 -2
  261. package/dist/build/__tests__/generate-route-types.test.d.ts.map +0 -1
  262. package/dist/build/__tests__/generate-route-types.test.js +0 -620
  263. package/dist/build/__tests__/generate-route-types.test.js.map +0 -1
  264. package/dist/build/__tests__/per-router-manifest.test.d.ts +0 -2
  265. package/dist/build/__tests__/per-router-manifest.test.d.ts.map +0 -1
  266. package/dist/build/__tests__/per-router-manifest.test.js +0 -308
  267. package/dist/build/__tests__/per-router-manifest.test.js.map +0 -1
  268. package/dist/build/generate-manifest.d.ts +0 -81
  269. package/dist/build/generate-manifest.d.ts.map +0 -1
  270. package/dist/build/generate-manifest.js +0 -276
  271. package/dist/build/generate-manifest.js.map +0 -1
  272. package/dist/build/generate-route-types.d.ts +0 -115
  273. package/dist/build/generate-route-types.d.ts.map +0 -1
  274. package/dist/build/generate-route-types.js +0 -740
  275. package/dist/build/generate-route-types.js.map +0 -1
  276. package/dist/build/index.d.ts +0 -21
  277. package/dist/build/index.d.ts.map +0 -1
  278. package/dist/build/index.js +0 -21
  279. package/dist/build/index.js.map +0 -1
  280. package/dist/build/route-trie.d.ts +0 -71
  281. package/dist/build/route-trie.d.ts.map +0 -1
  282. package/dist/build/route-trie.js +0 -175
  283. package/dist/build/route-trie.js.map +0 -1
  284. package/dist/cache/__tests__/cache-scope.test.d.ts +0 -2
  285. package/dist/cache/__tests__/cache-scope.test.d.ts.map +0 -1
  286. package/dist/cache/__tests__/cache-scope.test.js +0 -208
  287. package/dist/cache/__tests__/cache-scope.test.js.map +0 -1
  288. package/dist/cache/__tests__/document-cache.test.d.ts +0 -2
  289. package/dist/cache/__tests__/document-cache.test.d.ts.map +0 -1
  290. package/dist/cache/__tests__/document-cache.test.js +0 -345
  291. package/dist/cache/__tests__/document-cache.test.js.map +0 -1
  292. package/dist/cache/__tests__/memory-segment-store.test.d.ts +0 -2
  293. package/dist/cache/__tests__/memory-segment-store.test.d.ts.map +0 -1
  294. package/dist/cache/__tests__/memory-segment-store.test.js +0 -425
  295. package/dist/cache/__tests__/memory-segment-store.test.js.map +0 -1
  296. package/dist/cache/__tests__/memory-store.test.d.ts +0 -2
  297. package/dist/cache/__tests__/memory-store.test.d.ts.map +0 -1
  298. package/dist/cache/__tests__/memory-store.test.js +0 -367
  299. package/dist/cache/__tests__/memory-store.test.js.map +0 -1
  300. package/dist/cache/cache-scope.d.ts +0 -102
  301. package/dist/cache/cache-scope.d.ts.map +0 -1
  302. package/dist/cache/cache-scope.js +0 -440
  303. package/dist/cache/cache-scope.js.map +0 -1
  304. package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts +0 -2
  305. package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts.map +0 -1
  306. package/dist/cache/cf/__tests__/cf-cache-store.test.js +0 -330
  307. package/dist/cache/cf/__tests__/cf-cache-store.test.js.map +0 -1
  308. package/dist/cache/cf/cf-cache-store.d.ts +0 -165
  309. package/dist/cache/cf/cf-cache-store.d.ts.map +0 -1
  310. package/dist/cache/cf/cf-cache-store.js +0 -242
  311. package/dist/cache/cf/cf-cache-store.js.map +0 -1
  312. package/dist/cache/cf/index.d.ts +0 -14
  313. package/dist/cache/cf/index.d.ts.map +0 -1
  314. package/dist/cache/cf/index.js +0 -17
  315. package/dist/cache/cf/index.js.map +0 -1
  316. package/dist/cache/document-cache.d.ts +0 -64
  317. package/dist/cache/document-cache.d.ts.map +0 -1
  318. package/dist/cache/document-cache.js +0 -228
  319. package/dist/cache/document-cache.js.map +0 -1
  320. package/dist/cache/index.d.ts +0 -19
  321. package/dist/cache/index.d.ts.map +0 -1
  322. package/dist/cache/index.js +0 -21
  323. package/dist/cache/index.js.map +0 -1
  324. package/dist/cache/memory-segment-store.d.ts +0 -110
  325. package/dist/cache/memory-segment-store.d.ts.map +0 -1
  326. package/dist/cache/memory-segment-store.js +0 -117
  327. package/dist/cache/memory-segment-store.js.map +0 -1
  328. package/dist/cache/memory-store.d.ts +0 -41
  329. package/dist/cache/memory-store.d.ts.map +0 -1
  330. package/dist/cache/memory-store.js +0 -191
  331. package/dist/cache/memory-store.js.map +0 -1
  332. package/dist/cache/types.d.ts +0 -317
  333. package/dist/cache/types.d.ts.map +0 -1
  334. package/dist/cache/types.js +0 -12
  335. package/dist/cache/types.js.map +0 -1
  336. package/dist/client.d.ts +0 -248
  337. package/dist/client.d.ts.map +0 -1
  338. package/dist/client.js +0 -367
  339. package/dist/client.js.map +0 -1
  340. package/dist/client.rsc.d.ts +0 -26
  341. package/dist/client.rsc.d.ts.map +0 -1
  342. package/dist/client.rsc.js +0 -46
  343. package/dist/client.rsc.js.map +0 -1
  344. package/dist/component-utils.d.ts +0 -36
  345. package/dist/component-utils.d.ts.map +0 -1
  346. package/dist/component-utils.js +0 -61
  347. package/dist/component-utils.js.map +0 -1
  348. package/dist/components/DefaultDocument.d.ts +0 -13
  349. package/dist/components/DefaultDocument.d.ts.map +0 -1
  350. package/dist/components/DefaultDocument.js +0 -15
  351. package/dist/components/DefaultDocument.js.map +0 -1
  352. package/dist/debug.d.ts +0 -58
  353. package/dist/debug.d.ts.map +0 -1
  354. package/dist/debug.js +0 -157
  355. package/dist/debug.js.map +0 -1
  356. package/dist/default-error-boundary.d.ts +0 -11
  357. package/dist/default-error-boundary.d.ts.map +0 -1
  358. package/dist/default-error-boundary.js +0 -45
  359. package/dist/default-error-boundary.js.map +0 -1
  360. package/dist/deps/browser.d.ts +0 -2
  361. package/dist/deps/browser.d.ts.map +0 -1
  362. package/dist/deps/browser.js +0 -3
  363. package/dist/deps/browser.js.map +0 -1
  364. package/dist/deps/html-stream-client.d.ts +0 -2
  365. package/dist/deps/html-stream-client.d.ts.map +0 -1
  366. package/dist/deps/html-stream-client.js +0 -3
  367. package/dist/deps/html-stream-client.js.map +0 -1
  368. package/dist/deps/html-stream-server.d.ts +0 -2
  369. package/dist/deps/html-stream-server.d.ts.map +0 -1
  370. package/dist/deps/html-stream-server.js +0 -3
  371. package/dist/deps/html-stream-server.js.map +0 -1
  372. package/dist/deps/rsc.d.ts +0 -2
  373. package/dist/deps/rsc.d.ts.map +0 -1
  374. package/dist/deps/rsc.js +0 -4
  375. package/dist/deps/rsc.js.map +0 -1
  376. package/dist/deps/ssr.d.ts +0 -2
  377. package/dist/deps/ssr.d.ts.map +0 -1
  378. package/dist/deps/ssr.js +0 -3
  379. package/dist/deps/ssr.js.map +0 -1
  380. package/dist/errors.d.ts +0 -174
  381. package/dist/errors.d.ts.map +0 -1
  382. package/dist/errors.js +0 -241
  383. package/dist/errors.js.map +0 -1
  384. package/dist/handle.d.ts +0 -78
  385. package/dist/handle.d.ts.map +0 -1
  386. package/dist/handle.js +0 -82
  387. package/dist/handle.js.map +0 -1
  388. package/dist/handles/MetaTags.d.ts +0 -14
  389. package/dist/handles/MetaTags.d.ts.map +0 -1
  390. package/dist/handles/MetaTags.js +0 -136
  391. package/dist/handles/MetaTags.js.map +0 -1
  392. package/dist/handles/index.d.ts +0 -6
  393. package/dist/handles/index.d.ts.map +0 -1
  394. package/dist/handles/index.js +0 -6
  395. package/dist/handles/index.js.map +0 -1
  396. package/dist/handles/meta.d.ts +0 -39
  397. package/dist/handles/meta.d.ts.map +0 -1
  398. package/dist/handles/meta.js +0 -202
  399. package/dist/handles/meta.js.map +0 -1
  400. package/dist/host/__tests__/errors.test.d.ts +0 -2
  401. package/dist/host/__tests__/errors.test.d.ts.map +0 -1
  402. package/dist/host/__tests__/errors.test.js +0 -76
  403. package/dist/host/__tests__/errors.test.js.map +0 -1
  404. package/dist/host/__tests__/pattern-comprehensive.test.d.ts +0 -2
  405. package/dist/host/__tests__/pattern-comprehensive.test.d.ts.map +0 -1
  406. package/dist/host/__tests__/pattern-comprehensive.test.js +0 -732
  407. package/dist/host/__tests__/pattern-comprehensive.test.js.map +0 -1
  408. package/dist/host/__tests__/pattern-matcher.test.d.ts +0 -2
  409. package/dist/host/__tests__/pattern-matcher.test.d.ts.map +0 -1
  410. package/dist/host/__tests__/pattern-matcher.test.js +0 -251
  411. package/dist/host/__tests__/pattern-matcher.test.js.map +0 -1
  412. package/dist/host/__tests__/router.test.d.ts +0 -2
  413. package/dist/host/__tests__/router.test.d.ts.map +0 -1
  414. package/dist/host/__tests__/router.test.js +0 -241
  415. package/dist/host/__tests__/router.test.js.map +0 -1
  416. package/dist/host/__tests__/testing.test.d.ts +0 -2
  417. package/dist/host/__tests__/testing.test.d.ts.map +0 -1
  418. package/dist/host/__tests__/testing.test.js +0 -64
  419. package/dist/host/__tests__/testing.test.js.map +0 -1
  420. package/dist/host/__tests__/utils.test.d.ts +0 -2
  421. package/dist/host/__tests__/utils.test.d.ts.map +0 -1
  422. package/dist/host/__tests__/utils.test.js +0 -29
  423. package/dist/host/__tests__/utils.test.js.map +0 -1
  424. package/dist/host/cookie-handler.d.ts +0 -34
  425. package/dist/host/cookie-handler.d.ts.map +0 -1
  426. package/dist/host/cookie-handler.js +0 -124
  427. package/dist/host/cookie-handler.js.map +0 -1
  428. package/dist/host/errors.d.ts +0 -56
  429. package/dist/host/errors.d.ts.map +0 -1
  430. package/dist/host/errors.js +0 -79
  431. package/dist/host/errors.js.map +0 -1
  432. package/dist/host/index.d.ts +0 -29
  433. package/dist/host/index.d.ts.map +0 -1
  434. package/dist/host/index.js +0 -32
  435. package/dist/host/index.js.map +0 -1
  436. package/dist/host/pattern-matcher.d.ts +0 -36
  437. package/dist/host/pattern-matcher.d.ts.map +0 -1
  438. package/dist/host/pattern-matcher.js +0 -172
  439. package/dist/host/pattern-matcher.js.map +0 -1
  440. package/dist/host/router.d.ts +0 -26
  441. package/dist/host/router.d.ts.map +0 -1
  442. package/dist/host/router.js +0 -218
  443. package/dist/host/router.js.map +0 -1
  444. package/dist/host/testing.d.ts +0 -36
  445. package/dist/host/testing.d.ts.map +0 -1
  446. package/dist/host/testing.js +0 -55
  447. package/dist/host/testing.js.map +0 -1
  448. package/dist/host/types.d.ts +0 -115
  449. package/dist/host/types.d.ts.map +0 -1
  450. package/dist/host/types.js +0 -7
  451. package/dist/host/types.js.map +0 -1
  452. package/dist/host/utils.d.ts +0 -21
  453. package/dist/host/utils.d.ts.map +0 -1
  454. package/dist/host/utils.js +0 -23
  455. package/dist/host/utils.js.map +0 -1
  456. package/dist/href-client.d.ts +0 -131
  457. package/dist/href-client.d.ts.map +0 -1
  458. package/dist/href-client.js +0 -64
  459. package/dist/href-client.js.map +0 -1
  460. package/dist/href-context.d.ts +0 -29
  461. package/dist/href-context.d.ts.map +0 -1
  462. package/dist/href-context.js +0 -21
  463. package/dist/href-context.js.map +0 -1
  464. package/dist/index.d.ts +0 -73
  465. package/dist/index.d.ts.map +0 -1
  466. package/dist/index.js +0 -91
  467. package/dist/index.js.map +0 -1
  468. package/dist/index.rsc.d.ts +0 -32
  469. package/dist/index.rsc.d.ts.map +0 -1
  470. package/dist/index.rsc.js +0 -40
  471. package/dist/index.rsc.js.map +0 -1
  472. package/dist/internal-debug.d.ts +0 -2
  473. package/dist/internal-debug.d.ts.map +0 -1
  474. package/dist/internal-debug.js +0 -5
  475. package/dist/internal-debug.js.map +0 -1
  476. package/dist/loader.d.ts +0 -14
  477. package/dist/loader.d.ts.map +0 -1
  478. package/dist/loader.js +0 -20
  479. package/dist/loader.js.map +0 -1
  480. package/dist/loader.rsc.d.ts +0 -19
  481. package/dist/loader.rsc.d.ts.map +0 -1
  482. package/dist/loader.rsc.js +0 -99
  483. package/dist/loader.rsc.js.map +0 -1
  484. package/dist/network-error-thrower.d.ts +0 -17
  485. package/dist/network-error-thrower.d.ts.map +0 -1
  486. package/dist/network-error-thrower.js +0 -14
  487. package/dist/network-error-thrower.js.map +0 -1
  488. package/dist/outlet-context.d.ts +0 -13
  489. package/dist/outlet-context.d.ts.map +0 -1
  490. package/dist/outlet-context.js +0 -3
  491. package/dist/outlet-context.js.map +0 -1
  492. package/dist/prerender/__tests__/param-hash.test.d.ts +0 -2
  493. package/dist/prerender/__tests__/param-hash.test.d.ts.map +0 -1
  494. package/dist/prerender/__tests__/param-hash.test.js +0 -148
  495. package/dist/prerender/__tests__/param-hash.test.js.map +0 -1
  496. package/dist/prerender/param-hash.d.ts +0 -16
  497. package/dist/prerender/param-hash.d.ts.map +0 -1
  498. package/dist/prerender/param-hash.js +0 -36
  499. package/dist/prerender/param-hash.js.map +0 -1
  500. package/dist/prerender/store.d.ts +0 -38
  501. package/dist/prerender/store.d.ts.map +0 -1
  502. package/dist/prerender/store.js +0 -61
  503. package/dist/prerender/store.js.map +0 -1
  504. package/dist/prerender.d.ts +0 -66
  505. package/dist/prerender.d.ts.map +0 -1
  506. package/dist/prerender.js +0 -57
  507. package/dist/prerender.js.map +0 -1
  508. package/dist/reverse.d.ts +0 -196
  509. package/dist/reverse.d.ts.map +0 -1
  510. package/dist/reverse.js +0 -78
  511. package/dist/reverse.js.map +0 -1
  512. package/dist/root-error-boundary.d.ts +0 -33
  513. package/dist/root-error-boundary.d.ts.map +0 -1
  514. package/dist/root-error-boundary.js +0 -165
  515. package/dist/root-error-boundary.js.map +0 -1
  516. package/dist/route-content-wrapper.d.ts +0 -46
  517. package/dist/route-content-wrapper.d.ts.map +0 -1
  518. package/dist/route-content-wrapper.js +0 -77
  519. package/dist/route-content-wrapper.js.map +0 -1
  520. package/dist/route-definition.d.ts +0 -421
  521. package/dist/route-definition.d.ts.map +0 -1
  522. package/dist/route-definition.js +0 -868
  523. package/dist/route-definition.js.map +0 -1
  524. package/dist/route-map-builder.d.ts +0 -155
  525. package/dist/route-map-builder.d.ts.map +0 -1
  526. package/dist/route-map-builder.js +0 -237
  527. package/dist/route-map-builder.js.map +0 -1
  528. package/dist/route-types.d.ts +0 -165
  529. package/dist/route-types.d.ts.map +0 -1
  530. package/dist/route-types.js +0 -7
  531. package/dist/route-types.js.map +0 -1
  532. package/dist/router/__tests__/handler-context.test.d.ts +0 -2
  533. package/dist/router/__tests__/handler-context.test.d.ts.map +0 -1
  534. package/dist/router/__tests__/handler-context.test.js +0 -65
  535. package/dist/router/__tests__/handler-context.test.js.map +0 -1
  536. package/dist/router/__tests__/loader-cycle-detection.test.d.ts +0 -2
  537. package/dist/router/__tests__/loader-cycle-detection.test.d.ts.map +0 -1
  538. package/dist/router/__tests__/loader-cycle-detection.test.js +0 -221
  539. package/dist/router/__tests__/loader-cycle-detection.test.js.map +0 -1
  540. package/dist/router/__tests__/match-context.test.d.ts +0 -2
  541. package/dist/router/__tests__/match-context.test.d.ts.map +0 -1
  542. package/dist/router/__tests__/match-context.test.js +0 -92
  543. package/dist/router/__tests__/match-context.test.js.map +0 -1
  544. package/dist/router/__tests__/match-pipelines.test.d.ts +0 -2
  545. package/dist/router/__tests__/match-pipelines.test.d.ts.map +0 -1
  546. package/dist/router/__tests__/match-pipelines.test.js +0 -417
  547. package/dist/router/__tests__/match-pipelines.test.js.map +0 -1
  548. package/dist/router/__tests__/match-result.test.d.ts +0 -2
  549. package/dist/router/__tests__/match-result.test.d.ts.map +0 -1
  550. package/dist/router/__tests__/match-result.test.js +0 -457
  551. package/dist/router/__tests__/match-result.test.js.map +0 -1
  552. package/dist/router/__tests__/on-error.test.d.ts +0 -2
  553. package/dist/router/__tests__/on-error.test.d.ts.map +0 -1
  554. package/dist/router/__tests__/on-error.test.js +0 -678
  555. package/dist/router/__tests__/on-error.test.js.map +0 -1
  556. package/dist/router/__tests__/pattern-matching.test.d.ts +0 -2
  557. package/dist/router/__tests__/pattern-matching.test.d.ts.map +0 -1
  558. package/dist/router/__tests__/pattern-matching.test.js +0 -629
  559. package/dist/router/__tests__/pattern-matching.test.js.map +0 -1
  560. package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts +0 -2
  561. package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts.map +0 -1
  562. package/dist/router/__tests__/segment-resolution-parallel-loading.test.js +0 -155
  563. package/dist/router/__tests__/segment-resolution-parallel-loading.test.js.map +0 -1
  564. package/dist/router/error-handling.d.ts +0 -77
  565. package/dist/router/error-handling.d.ts.map +0 -1
  566. package/dist/router/error-handling.js +0 -202
  567. package/dist/router/error-handling.js.map +0 -1
  568. package/dist/router/handler-context.d.ts +0 -20
  569. package/dist/router/handler-context.d.ts.map +0 -1
  570. package/dist/router/handler-context.js +0 -198
  571. package/dist/router/handler-context.js.map +0 -1
  572. package/dist/router/intercept-resolution.d.ts +0 -66
  573. package/dist/router/intercept-resolution.d.ts.map +0 -1
  574. package/dist/router/intercept-resolution.js +0 -246
  575. package/dist/router/intercept-resolution.js.map +0 -1
  576. package/dist/router/loader-resolution.d.ts +0 -64
  577. package/dist/router/loader-resolution.d.ts.map +0 -1
  578. package/dist/router/loader-resolution.js +0 -284
  579. package/dist/router/loader-resolution.js.map +0 -1
  580. package/dist/router/logging.d.ts +0 -15
  581. package/dist/router/logging.d.ts.map +0 -1
  582. package/dist/router/logging.js +0 -99
  583. package/dist/router/logging.js.map +0 -1
  584. package/dist/router/manifest.d.ts +0 -22
  585. package/dist/router/manifest.d.ts.map +0 -1
  586. package/dist/router/manifest.js +0 -181
  587. package/dist/router/manifest.js.map +0 -1
  588. package/dist/router/match-api.d.ts +0 -35
  589. package/dist/router/match-api.d.ts.map +0 -1
  590. package/dist/router/match-api.js +0 -406
  591. package/dist/router/match-api.js.map +0 -1
  592. package/dist/router/match-context.d.ts +0 -206
  593. package/dist/router/match-context.d.ts.map +0 -1
  594. package/dist/router/match-context.js +0 -17
  595. package/dist/router/match-context.js.map +0 -1
  596. package/dist/router/match-middleware/background-revalidation.d.ts +0 -127
  597. package/dist/router/match-middleware/background-revalidation.d.ts.map +0 -1
  598. package/dist/router/match-middleware/background-revalidation.js +0 -75
  599. package/dist/router/match-middleware/background-revalidation.js.map +0 -1
  600. package/dist/router/match-middleware/cache-lookup.d.ts +0 -112
  601. package/dist/router/match-middleware/cache-lookup.d.ts.map +0 -1
  602. package/dist/router/match-middleware/cache-lookup.js +0 -257
  603. package/dist/router/match-middleware/cache-lookup.js.map +0 -1
  604. package/dist/router/match-middleware/cache-store.d.ts +0 -113
  605. package/dist/router/match-middleware/cache-store.d.ts.map +0 -1
  606. package/dist/router/match-middleware/cache-store.js +0 -108
  607. package/dist/router/match-middleware/cache-store.js.map +0 -1
  608. package/dist/router/match-middleware/index.d.ts +0 -81
  609. package/dist/router/match-middleware/index.d.ts.map +0 -1
  610. package/dist/router/match-middleware/index.js +0 -80
  611. package/dist/router/match-middleware/index.js.map +0 -1
  612. package/dist/router/match-middleware/intercept-resolution.d.ts +0 -117
  613. package/dist/router/match-middleware/intercept-resolution.d.ts.map +0 -1
  614. package/dist/router/match-middleware/intercept-resolution.js +0 -134
  615. package/dist/router/match-middleware/intercept-resolution.js.map +0 -1
  616. package/dist/router/match-middleware/segment-resolution.d.ts +0 -99
  617. package/dist/router/match-middleware/segment-resolution.d.ts.map +0 -1
  618. package/dist/router/match-middleware/segment-resolution.js +0 -53
  619. package/dist/router/match-middleware/segment-resolution.js.map +0 -1
  620. package/dist/router/match-pipelines.d.ts +0 -147
  621. package/dist/router/match-pipelines.d.ts.map +0 -1
  622. package/dist/router/match-pipelines.js +0 -82
  623. package/dist/router/match-pipelines.js.map +0 -1
  624. package/dist/router/match-result.d.ts +0 -126
  625. package/dist/router/match-result.d.ts.map +0 -1
  626. package/dist/router/match-result.js +0 -93
  627. package/dist/router/match-result.js.map +0 -1
  628. package/dist/router/metrics.d.ts +0 -20
  629. package/dist/router/metrics.d.ts.map +0 -1
  630. package/dist/router/metrics.js +0 -47
  631. package/dist/router/metrics.js.map +0 -1
  632. package/dist/router/middleware.d.ts +0 -249
  633. package/dist/router/middleware.d.ts.map +0 -1
  634. package/dist/router/middleware.js +0 -434
  635. package/dist/router/middleware.js.map +0 -1
  636. package/dist/router/middleware.test.d.ts +0 -2
  637. package/dist/router/middleware.test.d.ts.map +0 -1
  638. package/dist/router/middleware.test.js +0 -816
  639. package/dist/router/middleware.test.js.map +0 -1
  640. package/dist/router/pattern-matching.d.ts +0 -149
  641. package/dist/router/pattern-matching.d.ts.map +0 -1
  642. package/dist/router/pattern-matching.js +0 -349
  643. package/dist/router/pattern-matching.js.map +0 -1
  644. package/dist/router/revalidation.d.ts +0 -44
  645. package/dist/router/revalidation.d.ts.map +0 -1
  646. package/dist/router/revalidation.js +0 -147
  647. package/dist/router/revalidation.js.map +0 -1
  648. package/dist/router/router-context.d.ts +0 -135
  649. package/dist/router/router-context.d.ts.map +0 -1
  650. package/dist/router/router-context.js +0 -36
  651. package/dist/router/router-context.js.map +0 -1
  652. package/dist/router/segment-resolution.d.ts +0 -127
  653. package/dist/router/segment-resolution.d.ts.map +0 -1
  654. package/dist/router/segment-resolution.js +0 -919
  655. package/dist/router/segment-resolution.js.map +0 -1
  656. package/dist/router/trie-matching.d.ts +0 -40
  657. package/dist/router/trie-matching.d.ts.map +0 -1
  658. package/dist/router/trie-matching.js +0 -127
  659. package/dist/router/trie-matching.js.map +0 -1
  660. package/dist/router/types.d.ts +0 -136
  661. package/dist/router/types.d.ts.map +0 -1
  662. package/dist/router/types.js +0 -7
  663. package/dist/router/types.js.map +0 -1
  664. package/dist/router.d.ts +0 -753
  665. package/dist/router.d.ts.map +0 -1
  666. package/dist/router.gen.d.ts +0 -6
  667. package/dist/router.gen.d.ts.map +0 -1
  668. package/dist/router.gen.js +0 -6
  669. package/dist/router.gen.js.map +0 -1
  670. package/dist/router.js +0 -1304
  671. package/dist/router.js.map +0 -1
  672. package/dist/rsc/__tests__/helpers.test.d.ts +0 -2
  673. package/dist/rsc/__tests__/helpers.test.d.ts.map +0 -1
  674. package/dist/rsc/__tests__/helpers.test.js +0 -140
  675. package/dist/rsc/__tests__/helpers.test.js.map +0 -1
  676. package/dist/rsc/handler.d.ts +0 -45
  677. package/dist/rsc/handler.d.ts.map +0 -1
  678. package/dist/rsc/handler.js +0 -1172
  679. package/dist/rsc/handler.js.map +0 -1
  680. package/dist/rsc/helpers.d.ts +0 -16
  681. package/dist/rsc/helpers.d.ts.map +0 -1
  682. package/dist/rsc/helpers.js +0 -55
  683. package/dist/rsc/helpers.js.map +0 -1
  684. package/dist/rsc/index.d.ts +0 -22
  685. package/dist/rsc/index.d.ts.map +0 -1
  686. package/dist/rsc/index.js +0 -23
  687. package/dist/rsc/index.js.map +0 -1
  688. package/dist/rsc/nonce.d.ts +0 -9
  689. package/dist/rsc/nonce.d.ts.map +0 -1
  690. package/dist/rsc/nonce.js +0 -18
  691. package/dist/rsc/nonce.js.map +0 -1
  692. package/dist/rsc/types.d.ts +0 -206
  693. package/dist/rsc/types.d.ts.map +0 -1
  694. package/dist/rsc/types.js +0 -8
  695. package/dist/rsc/types.js.map +0 -1
  696. package/dist/search-params.d.ts +0 -103
  697. package/dist/search-params.d.ts.map +0 -1
  698. package/dist/search-params.js +0 -74
  699. package/dist/search-params.js.map +0 -1
  700. package/dist/segment-system.d.ts +0 -75
  701. package/dist/segment-system.d.ts.map +0 -1
  702. package/dist/segment-system.js +0 -336
  703. package/dist/segment-system.js.map +0 -1
  704. package/dist/server/context.d.ts +0 -245
  705. package/dist/server/context.d.ts.map +0 -1
  706. package/dist/server/context.js +0 -197
  707. package/dist/server/context.js.map +0 -1
  708. package/dist/server/fetchable-loader-store.d.ts +0 -18
  709. package/dist/server/fetchable-loader-store.d.ts.map +0 -1
  710. package/dist/server/fetchable-loader-store.js +0 -18
  711. package/dist/server/fetchable-loader-store.js.map +0 -1
  712. package/dist/server/handle-store.d.ts +0 -85
  713. package/dist/server/handle-store.d.ts.map +0 -1
  714. package/dist/server/handle-store.js +0 -142
  715. package/dist/server/handle-store.js.map +0 -1
  716. package/dist/server/loader-registry.d.ts +0 -55
  717. package/dist/server/loader-registry.d.ts.map +0 -1
  718. package/dist/server/loader-registry.js +0 -132
  719. package/dist/server/loader-registry.js.map +0 -1
  720. package/dist/server/request-context.d.ts +0 -226
  721. package/dist/server/request-context.d.ts.map +0 -1
  722. package/dist/server/request-context.js +0 -290
  723. package/dist/server/request-context.js.map +0 -1
  724. package/dist/server/root-layout.d.ts +0 -4
  725. package/dist/server/root-layout.d.ts.map +0 -1
  726. package/dist/server/root-layout.js +0 -5
  727. package/dist/server/root-layout.js.map +0 -1
  728. package/dist/server.d.ts +0 -15
  729. package/dist/server.d.ts.map +0 -1
  730. package/dist/server.js +0 -20
  731. package/dist/server.js.map +0 -1
  732. package/dist/ssr/__tests__/ssr-handler.test.d.ts +0 -2
  733. package/dist/ssr/__tests__/ssr-handler.test.d.ts.map +0 -1
  734. package/dist/ssr/__tests__/ssr-handler.test.js +0 -132
  735. package/dist/ssr/__tests__/ssr-handler.test.js.map +0 -1
  736. package/dist/ssr/index.d.ts +0 -98
  737. package/dist/ssr/index.d.ts.map +0 -1
  738. package/dist/ssr/index.js +0 -158
  739. package/dist/ssr/index.js.map +0 -1
  740. package/dist/static-handler.d.ts +0 -50
  741. package/dist/static-handler.d.ts.map +0 -1
  742. package/dist/static-handler.gen.d.ts +0 -5
  743. package/dist/static-handler.gen.d.ts.map +0 -1
  744. package/dist/static-handler.gen.js +0 -5
  745. package/dist/static-handler.gen.js.map +0 -1
  746. package/dist/static-handler.js +0 -29
  747. package/dist/static-handler.js.map +0 -1
  748. package/dist/theme/ThemeProvider.d.ts +0 -20
  749. package/dist/theme/ThemeProvider.d.ts.map +0 -1
  750. package/dist/theme/ThemeProvider.js +0 -240
  751. package/dist/theme/ThemeProvider.js.map +0 -1
  752. package/dist/theme/ThemeScript.d.ts +0 -48
  753. package/dist/theme/ThemeScript.d.ts.map +0 -1
  754. package/dist/theme/ThemeScript.js +0 -13
  755. package/dist/theme/ThemeScript.js.map +0 -1
  756. package/dist/theme/__tests__/theme.test.d.ts +0 -2
  757. package/dist/theme/__tests__/theme.test.d.ts.map +0 -1
  758. package/dist/theme/__tests__/theme.test.js +0 -103
  759. package/dist/theme/__tests__/theme.test.js.map +0 -1
  760. package/dist/theme/constants.d.ts +0 -29
  761. package/dist/theme/constants.d.ts.map +0 -1
  762. package/dist/theme/constants.js +0 -48
  763. package/dist/theme/constants.js.map +0 -1
  764. package/dist/theme/index.d.ts +0 -31
  765. package/dist/theme/index.d.ts.map +0 -1
  766. package/dist/theme/index.js +0 -36
  767. package/dist/theme/index.js.map +0 -1
  768. package/dist/theme/theme-context.d.ts +0 -40
  769. package/dist/theme/theme-context.d.ts.map +0 -1
  770. package/dist/theme/theme-context.js +0 -60
  771. package/dist/theme/theme-context.js.map +0 -1
  772. package/dist/theme/theme-script.d.ts +0 -27
  773. package/dist/theme/theme-script.d.ts.map +0 -1
  774. package/dist/theme/theme-script.js +0 -147
  775. package/dist/theme/theme-script.js.map +0 -1
  776. package/dist/theme/types.d.ts +0 -163
  777. package/dist/theme/types.d.ts.map +0 -1
  778. package/dist/theme/types.js +0 -11
  779. package/dist/theme/types.js.map +0 -1
  780. package/dist/theme/use-theme.d.ts +0 -12
  781. package/dist/theme/use-theme.d.ts.map +0 -1
  782. package/dist/theme/use-theme.js +0 -40
  783. package/dist/theme/use-theme.js.map +0 -1
  784. package/dist/types.d.ts +0 -1479
  785. package/dist/types.d.ts.map +0 -1
  786. package/dist/types.js +0 -10
  787. package/dist/types.js.map +0 -1
  788. package/dist/urls.d.ts +0 -441
  789. package/dist/urls.d.ts.map +0 -1
  790. package/dist/urls.gen.d.ts +0 -8
  791. package/dist/urls.gen.d.ts.map +0 -1
  792. package/dist/urls.gen.js +0 -8
  793. package/dist/urls.gen.js.map +0 -1
  794. package/dist/urls.js +0 -443
  795. package/dist/urls.js.map +0 -1
  796. package/dist/use-loader.d.ts +0 -127
  797. package/dist/use-loader.d.ts.map +0 -1
  798. package/dist/use-loader.js +0 -237
  799. package/dist/use-loader.js.map +0 -1
  800. package/dist/vite/__tests__/ast-handler-extract.test.d.ts +0 -2
  801. package/dist/vite/__tests__/ast-handler-extract.test.d.ts.map +0 -1
  802. package/dist/vite/__tests__/ast-handler-extract.test.js +0 -294
  803. package/dist/vite/__tests__/ast-handler-extract.test.js.map +0 -1
  804. package/dist/vite/__tests__/expose-id-utils.test.d.ts +0 -2
  805. package/dist/vite/__tests__/expose-id-utils.test.d.ts.map +0 -1
  806. package/dist/vite/__tests__/expose-id-utils.test.js +0 -224
  807. package/dist/vite/__tests__/expose-id-utils.test.js.map +0 -1
  808. package/dist/vite/__tests__/expose-internal-ids.test.d.ts +0 -2
  809. package/dist/vite/__tests__/expose-internal-ids.test.d.ts.map +0 -1
  810. package/dist/vite/__tests__/expose-internal-ids.test.js +0 -647
  811. package/dist/vite/__tests__/expose-internal-ids.test.js.map +0 -1
  812. package/dist/vite/__tests__/expose-router-id.test.d.ts +0 -2
  813. package/dist/vite/__tests__/expose-router-id.test.d.ts.map +0 -1
  814. package/dist/vite/__tests__/expose-router-id.test.js +0 -39
  815. package/dist/vite/__tests__/expose-router-id.test.js.map +0 -1
  816. package/dist/vite/ast-handler-extract.d.ts +0 -49
  817. package/dist/vite/ast-handler-extract.d.ts.map +0 -1
  818. package/dist/vite/ast-handler-extract.js +0 -249
  819. package/dist/vite/ast-handler-extract.js.map +0 -1
  820. package/dist/vite/expose-action-id.d.ts +0 -19
  821. package/dist/vite/expose-action-id.d.ts.map +0 -1
  822. package/dist/vite/expose-action-id.js +0 -250
  823. package/dist/vite/expose-action-id.js.map +0 -1
  824. package/dist/vite/expose-id-utils.d.ts +0 -69
  825. package/dist/vite/expose-id-utils.d.ts.map +0 -1
  826. package/dist/vite/expose-id-utils.js +0 -289
  827. package/dist/vite/expose-id-utils.js.map +0 -1
  828. package/dist/vite/expose-internal-ids.d.ts +0 -22
  829. package/dist/vite/expose-internal-ids.d.ts.map +0 -1
  830. package/dist/vite/expose-internal-ids.js +0 -886
  831. package/dist/vite/expose-internal-ids.js.map +0 -1
  832. package/dist/vite/index.d.ts +0 -149
  833. package/dist/vite/index.d.ts.map +0 -1
  834. package/dist/vite/index.js.bak +0 -5448
  835. package/dist/vite/index.js.map +0 -1
  836. package/dist/vite/index.named-routes.gen.ts +0 -103
  837. package/dist/vite/package-resolution.d.ts +0 -43
  838. package/dist/vite/package-resolution.d.ts.map +0 -1
  839. package/dist/vite/package-resolution.js +0 -112
  840. package/dist/vite/package-resolution.js.map +0 -1
  841. package/dist/vite/virtual-entries.d.ts +0 -25
  842. package/dist/vite/virtual-entries.d.ts.map +0 -1
  843. package/dist/vite/virtual-entries.js +0 -110
  844. package/dist/vite/virtual-entries.js.map +0 -1
@@ -0,0 +1,123 @@
1
+ /**
2
+ * Pure prefix-tree walks shared by the build/discovery layer and the runtime
3
+ * trie builder. Kept in `build/` (not `vite/utils`) so runtime code
4
+ * (rsc/manifest-init via build/route-trie) can consume them without importing
5
+ * from the vite layer. `vite/utils/manifest-utils` re-exports them so existing
6
+ * vite-side imports stay unchanged.
7
+ */
8
+
9
+ /**
10
+ * Flatten prefix tree leaf nodes into precomputed route entries.
11
+ * Leaf nodes have no children (no nested includes), so their routes can be
12
+ * used directly by evaluateLazyEntry() without running the handler.
13
+ * Non-leaf nodes are skipped because they have nested lazy includes that
14
+ * require the handler to run for discovery.
15
+ *
16
+ * A leaf is also skipped when its staticPrefix collides with an ancestor
17
+ * include node's staticPrefix. That happens when a dynamic param collapses the
18
+ * staticPrefix of nested includes onto the parent's (e.g. `/m/:id/edit` -> sp
19
+ * `/m`): precomputing such a leaf under the collapsed prefix would let the
20
+ * ancestor's lazy entry claim a route it cannot register (the route is behind
21
+ * further nested lazy includes), producing a RouteNotFoundError at request time
22
+ * (issue #506). Those routes are resolved via the handler chain instead.
23
+ */
24
+ export function flattenLeafEntries(
25
+ prefixTree: Record<string, any>,
26
+ routeManifest: Record<string, string>,
27
+ result: Array<{ staticPrefix: string; routes: Record<string, string> }>,
28
+ ): void {
29
+ function visit(node: any, ancestorStaticPrefixes: Set<string>): void {
30
+ const children = node.children || {};
31
+ if (
32
+ Object.keys(children).length === 0 &&
33
+ node.routes &&
34
+ node.routes.length > 0
35
+ ) {
36
+ // Leaf node. Skip if its staticPrefix collides with an ancestor include
37
+ // node's staticPrefix (dynamic-param collapse) — see doc comment above.
38
+ if (ancestorStaticPrefixes.has(node.staticPrefix)) {
39
+ return;
40
+ }
41
+ // Collect its routes from the manifest
42
+ const routes: Record<string, string> = {};
43
+ for (const name of node.routes) {
44
+ if (name in routeManifest) {
45
+ routes[name] = routeManifest[name];
46
+ }
47
+ }
48
+ result.push({ staticPrefix: node.staticPrefix, routes });
49
+ } else {
50
+ // Non-leaf: recurse into children, tracking this node's staticPrefix as
51
+ // an ancestor so a collapsed nested leaf below it is not over-claimed.
52
+ const nextAncestors = new Set(ancestorStaticPrefixes);
53
+ nextAncestors.add(node.staticPrefix);
54
+ for (const child of Object.values(children)) {
55
+ visit(child, nextAncestors);
56
+ }
57
+ }
58
+ }
59
+ for (const node of Object.values(prefixTree)) {
60
+ visit(node, new Set());
61
+ }
62
+ }
63
+
64
+ /**
65
+ * Build the staticPrefix -> routes lookup the runtime shortcut consumes from a
66
+ * flat precomputed-entry array.
67
+ *
68
+ * A staticPrefix owned by MORE THAN ONE leaf include cannot be collapsed to a
69
+ * single routes object: `new Map(entries.map(e => [e.staticPrefix, e.routes]))`
70
+ * is last-wins, so one include's routes are silently dropped and mis-assigned
71
+ * to whichever entry evaluates first. Two distinct includes legitimately share a
72
+ * staticPrefix when a dynamic param collapses their literal prefixes onto the
73
+ * same value (e.g. `include("/shop/:cat", ...)` and a nested
74
+ * `include("/shop/:brand", ...)` both extract "/shop/"). Merging them is also
75
+ * wrong — assigning the merged set to the first matching entry makes findMatch
76
+ * pick the wrong handler for routes belonging to the other include, which then
77
+ * fails its `Store.manifest.has(routeKey)` invariant at render (500 on a valid
78
+ * route, dev/prod identical).
79
+ *
80
+ * So any shared staticPrefix is OMITTED from the shortcut entirely. Those
81
+ * includes fall through to the handler path in evaluateLazyEntry(), which is the
82
+ * ground truth (identical to pre-precomputed behavior). The shortcut is purely an
83
+ * optimization, so dropping a prefix can only cost a handler run, never change a
84
+ * result.
85
+ */
86
+ export function buildPrecomputedByPrefix(
87
+ entries: Array<{ staticPrefix: string; routes: Record<string, string> }>,
88
+ ): Map<string, Record<string, string>> {
89
+ const byPrefix = new Map<string, Record<string, string>>();
90
+ const shared = new Set<string>();
91
+ for (const e of entries) {
92
+ if (byPrefix.has(e.staticPrefix)) {
93
+ shared.add(e.staticPrefix);
94
+ } else {
95
+ byPrefix.set(e.staticPrefix, e.routes);
96
+ }
97
+ }
98
+ for (const sp of shared) {
99
+ byPrefix.delete(sp);
100
+ }
101
+ return byPrefix;
102
+ }
103
+
104
+ /**
105
+ * Walk prefix tree to map each route name to its scope's staticPrefix.
106
+ */
107
+ export function buildRouteToStaticPrefix(
108
+ prefixTree: Record<string, any>,
109
+ result: Record<string, string>,
110
+ ): void {
111
+ function visit(node: any): void {
112
+ const sp = node.staticPrefix || "";
113
+ for (const name of node.routes || []) {
114
+ result[name] = sp;
115
+ }
116
+ for (const child of Object.values(node.children || {})) {
117
+ visit(child);
118
+ }
119
+ }
120
+ for (const node of Object.values(prefixTree)) {
121
+ visit(node);
122
+ }
123
+ }
@@ -10,6 +10,8 @@ import {
10
10
  parsePattern,
11
11
  type ParsedSegment,
12
12
  } from "../router/pattern-matching.js";
13
+ import { buildRouteToStaticPrefix } from "./prefix-tree-utils.js";
14
+ import type { FullManifest } from "./generate-manifest.js";
13
15
 
14
16
  // -- Trie data structures (compact keys for JSON serialization) --
15
17
 
@@ -98,6 +100,47 @@ export function buildRouteTrie(
98
100
  return root;
99
101
  }
100
102
 
103
+ /**
104
+ * Build a per-router trie from a generated manifest. This is the single
105
+ * construction path shared by build/discovery (discover-routers.ts, serialized
106
+ * into the production chunk) and the dev/HMR runtime rebuild
107
+ * (rsc/manifest-init.ts). Keeping one code path is what guarantees the dev
108
+ * runtime trie and the production serialized trie are byte-for-byte identical
109
+ * (modulo `leaf.a` ancestry, which embeds the mount index and is debug-only).
110
+ *
111
+ * Returns null when the manifest has no route ancestry (no routes), matching
112
+ * the prior guard at both call sites.
113
+ */
114
+ export function buildPerRouterTrie(manifest: FullManifest): TrieNode | null {
115
+ const ancestry = manifest._routeAncestry;
116
+ if (!ancestry || Object.keys(ancestry).length === 0) {
117
+ return null;
118
+ }
119
+
120
+ // Seed every route to the root static prefix (""), then override with each
121
+ // route's include() scope prefix from the prefix tree so the trie returns the
122
+ // correct `sp` for lazy-entry lookup in find-match.
123
+ const routeToStaticPrefix: Record<string, string> = {};
124
+ for (const name of Object.keys(manifest.routeManifest)) {
125
+ routeToStaticPrefix[name] = "";
126
+ }
127
+ if (manifest.prefixTree) {
128
+ buildRouteToStaticPrefix(manifest.prefixTree, routeToStaticPrefix);
129
+ }
130
+
131
+ return buildRouteTrie(
132
+ manifest.routeManifest,
133
+ ancestry,
134
+ routeToStaticPrefix,
135
+ manifest.routeTrailingSlash,
136
+ manifest.prerenderRoutes ? new Set(manifest.prerenderRoutes) : undefined,
137
+ manifest.passthroughRoutes
138
+ ? new Set(manifest.passthroughRoutes)
139
+ : undefined,
140
+ manifest.responseTypeRoutes,
141
+ );
142
+ }
143
+
101
144
  /**
102
145
  * Insert a route into the trie. Optional params expand into two branches at
103
146
  * registration time (skip-first, then present), so each terminal lives at the
package/src/client.tsx CHANGED
@@ -415,29 +415,10 @@ export {
415
415
  // href-client.ts) — no import needed.
416
416
  export { href, type PatternToPath } from "./href-client.js";
417
417
 
418
- // Response envelope types for consuming JSON response routes
419
- export type { ResponseEnvelope, ResponseError } from "./urls.js";
420
-
421
- /**
422
- * Type guard for checking if a response envelope contains an error.
423
- *
424
- * @example
425
- * ```typescript
426
- * const result: ResponseEnvelope<Product> = await fetch(url).then(r => r.json());
427
- * if (isResponseError(result)) {
428
- * console.log(result.error.message, result.error.code);
429
- * return;
430
- * }
431
- * result.data // fully typed as Product
432
- * ```
433
- */
434
- export function isResponseError<T>(
435
- result: import("./urls.js").ResponseEnvelope<T>,
436
- ): result is import("./urls.js").ResponseEnvelope<T> & {
437
- error: import("./urls.js").ResponseError;
438
- } {
439
- return result.error !== undefined;
440
- }
418
+ // Problem Details (RFC 9457) error body type for consuming JSON response routes.
419
+ // On a non-2xx response, `await res.json()` yields this shape; on success the
420
+ // body is the bare value (no envelope). Discriminate on `res.ok` / status.
421
+ export type { ProblemDetails } from "./urls.js";
441
422
 
442
423
  // Mount context for include() scoped components
443
424
  export { useMount } from "./browser/react/use-mount.js";
package/src/errors.ts CHANGED
@@ -225,7 +225,6 @@ export function isNetworkError(error: unknown): boolean {
225
225
  export class RouterError extends Error {
226
226
  name = "RouterError" as const;
227
227
  code: string;
228
- type?: string;
229
228
  status: number;
230
229
  cause?: unknown;
231
230
 
@@ -234,7 +233,6 @@ export class RouterError extends Error {
234
233
  message: string,
235
234
  options?: {
236
235
  status?: number;
237
- type?: string;
238
236
  cause?: unknown;
239
237
  },
240
238
  ) {
@@ -242,7 +240,6 @@ export class RouterError extends Error {
242
240
  Object.setPrototypeOf(this, RouterError.prototype);
243
241
  this.code = code;
244
242
  this.status = options?.status ?? 500;
245
- this.type = options?.type;
246
243
  this.cause = options?.cause;
247
244
  }
248
245
  }
@@ -16,7 +16,6 @@
16
16
 
17
17
  import type { GetRegisteredRoutes } from "./types.js";
18
18
  import type { JsonSerialize } from "./serialize.js";
19
- import type { ResponseEnvelope } from "./urls.js";
20
19
 
21
20
  /**
22
21
  * Parse constraint values into a union type for paths
@@ -163,16 +162,16 @@ type ResponsePayloadForKey<
163
162
  }[keyof TRoutes];
164
163
 
165
164
  /**
166
- * Public response type for a route, keyed by pattern or concrete path. The
167
- * payload is wrapped in `JsonSerialize` so it describes the JSON **wire** value a
168
- * consumer receives from `fetch().then(r => r.json())`, not the handler's raw
169
- * return type — e.g. a handler returning `{ createdAt: Date }` resolves here to
170
- * `ResponseEnvelope<{ createdAt: string }>`.
165
+ * Public response type for a route, keyed by pattern or concrete path. JSON
166
+ * response routes send the handler's return value verbatim (bare), so the
167
+ * payload is wrapped only in `JsonSerialize` to describe the JSON **wire** value
168
+ * a consumer receives from `fetch().then(r => r.json())` — e.g. a handler
169
+ * returning `{ createdAt: Date }` resolves here to `{ createdAt: string }`.
171
170
  */
172
171
  export type PathResponse<
173
172
  TPath extends string,
174
173
  TRoutes = GetRegisteredRoutes,
175
- > = ResponseEnvelope<JsonSerialize<ResponsePayloadFor<TPath, TRoutes>>>;
174
+ > = JsonSerialize<ResponsePayloadFor<TPath, TRoutes>>;
176
175
 
177
176
  /**
178
177
  * Strip trailing slash from a path (e.g., "/blog/" -> "/blog" | "/blog/")
@@ -256,7 +255,7 @@ declare global {
256
255
  *
257
256
  * The payload is the JSON **wire** shape (via `Rango.JsonSerialize`), not the
258
257
  * handler's raw return — a handler returning `{ createdAt: Date }` resolves
259
- * here to `ResponseEnvelope<{ createdAt: string }>`, matching what
258
+ * here to `{ createdAt: string }` (bare, no envelope), matching what
260
259
  * `fetch().then(r => r.json())` actually yields.
261
260
  *
262
261
  * Only resolves once `Rango.RegisteredRoutes` carries response metadata (the
package/src/index.rsc.ts CHANGED
@@ -138,8 +138,7 @@ export {
138
138
  type IncludeOptions,
139
139
  type IncludeItem,
140
140
  type RouteResponse,
141
- type ResponseError,
142
- type ResponseEnvelope,
141
+ type ProblemDetails,
143
142
  type ResponseHandler,
144
143
  type ResponseHandlerContext,
145
144
  type JsonResponseHandler,
package/src/index.ts CHANGED
@@ -104,8 +104,7 @@ export type {
104
104
  JsonResponsePathFn,
105
105
  TextResponsePathFn,
106
106
  RouteResponse,
107
- ResponseError,
108
- ResponseEnvelope,
107
+ ProblemDetails,
109
108
  } from "./urls.js";
110
109
 
111
110
  // Middleware context types
@@ -1,5 +1,5 @@
1
1
  import { tryTrieMatch } from "./trie-matching.js";
2
- import { getRouteTrie, getRouterTrie } from "../route-map-builder.js";
2
+ import { getRouterTrie } from "../route-map-builder.js";
3
3
  import {
4
4
  findMatch as findRouteMatch,
5
5
  isLazyEvaluationNeeded,
@@ -8,6 +8,19 @@ import {
8
8
  import type { MetricsStore } from "../server/context";
9
9
  import type { RouteEntry } from "../types";
10
10
 
11
+ // Return a shallow copy with an independent `params` object. The single-entry
12
+ // cache below is module-lifetime and keyed only on pathname, so the same result
13
+ // object is handed to every same-pathname request in the isolate. ctx.params
14
+ // aliases this `params` (see request-context), so without an own copy a handler
15
+ // that mutates ctx.params would corrupt the cached entry for later requests.
16
+ // `entry` and the flags are intentionally shared by reference: they are
17
+ // read-only, and entry identity is compared in match-api (prevMatch.entry).
18
+ function cloneMatchResult<TEnv>(
19
+ r: RouteMatchResult<TEnv> | null,
20
+ ): RouteMatchResult<TEnv> | null {
21
+ return r ? { ...r, params: { ...r.params } } : null;
22
+ }
23
+
11
24
  export interface FindMatchDeps<TEnv = any> {
12
25
  routesEntries: RouteEntry<TEnv>[];
13
26
  evaluateLazyEntry: (entry: RouteEntry<TEnv>) => void;
@@ -35,9 +48,10 @@ export function createFindMatch<TEnv = any>(
35
48
  pathname: string,
36
49
  ms?: MetricsStore,
37
50
  ): RouteMatchResult<TEnv> | null {
38
- // Return cached result if same pathname (avoids double-match per request)
51
+ // Return cached result if same pathname (avoids double-match per request).
52
+ // Clone so a caller mutating ctx.params cannot corrupt the shared cache.
39
53
  if (lastFindMatchPathname === pathname) {
40
- return lastFindMatchResult;
54
+ return cloneMatchResult(lastFindMatchResult);
41
55
  }
42
56
 
43
57
  // Helper to push sub-metrics
@@ -56,12 +70,19 @@ export function createFindMatch<TEnv = any>(
56
70
  // routers and must not be used — in multi-router setups (host routing)
57
71
  // overlapping paths like "/" would match the wrong app's route.
58
72
  const routeTrie = getRouterTrie(deps.routerId);
73
+ // Whether the trie produced a match for this pathname (independent of
74
+ // whether the owning RouteEntry was resolvable yet). Used to suppress the
75
+ // R3 dev warning below: if the trie DID match but we fell through to the
76
+ // regex fallback only because a lazy entry was not spliced in yet, that is
77
+ // not a trie gap.
78
+ let trieMatched = false;
59
79
  if (routeTrie) {
60
80
  const trieStart = performance.now();
61
81
  const trieResult = tryTrieMatch(routeTrie, pathname);
62
82
  pushMetric?.("match:trie", trieStart);
63
83
 
64
84
  if (trieResult) {
85
+ trieMatched = true;
65
86
  // Find the RouteEntry that contains this route.
66
87
  // Multiple entries can share the same staticPrefix (e.g., several
67
88
  // include("/", patterns) calls all produce staticPrefix=""). Evaluate
@@ -114,7 +135,6 @@ export function createFindMatch<TEnv = any>(
114
135
  params: trieResult.params,
115
136
  optionalParams: new Set(trieResult.optionalParams || []),
116
137
  redirectTo: trieResult.redirectTo,
117
- ancestry: trieResult.ancestry,
118
138
  ...(trieResult.pr ? { pr: true } : {}),
119
139
  ...(trieResult.pt ? { pt: true } : {}),
120
140
  ...(trieResult.responseType
@@ -125,7 +145,7 @@ export function createFindMatch<TEnv = any>(
125
145
  : {}),
126
146
  ...(trieResult.rscFirst ? { rscFirst: true } : {}),
127
147
  };
128
- return lastFindMatchResult;
148
+ return cloneMatchResult(lastFindMatchResult);
129
149
  }
130
150
  }
131
151
  }
@@ -153,8 +173,36 @@ export function createFindMatch<TEnv = any>(
153
173
  }
154
174
  pushMetric?.("match:regex-fallback", regexStart);
155
175
 
176
+ // The trie is the single source of truth and is built before findMatch in
177
+ // both dev (handler rebuild) and production (ensureRouterManifest). If the
178
+ // trie was present yet the regex fallback resolved a real match, the trie
179
+ // has a gap (e.g. a route shape it cannot represent) and dev/prod could
180
+ // diverge if the trie were ever absent. Surface it in dev; folded out in
181
+ // production builds.
182
+ //
183
+ // Suppress when the trie DID match (`trieMatched`): that path falls through
184
+ // to the regex fallback only on the first request to a not-yet-spliced lazy
185
+ // entry (e.g. a 2+-level nested include whose deeper parent has not been
186
+ // evaluated). The trie knew the route; runtime lazy discovery simply lagged.
187
+ // That is the supported lazy-include flow, not a trie gap, so warning on it
188
+ // is a false positive (it manufactures bug reports and erodes the signal).
189
+ if (
190
+ process.env.NODE_ENV !== "production" &&
191
+ routeTrie &&
192
+ !trieMatched &&
193
+ result &&
194
+ !isLazyEvaluationNeeded(result)
195
+ ) {
196
+ console.warn(
197
+ `[@rangojs/router] Route "${pathname}" resolved via the regex fallback ` +
198
+ `even though the route trie was present. The trie should be the single ` +
199
+ `matching source of truth; this indicates a trie gap. Please report this ` +
200
+ `with your route configuration.`,
201
+ );
202
+ }
203
+
156
204
  lastFindMatchPathname = pathname;
157
205
  lastFindMatchResult = result;
158
- return result;
206
+ return cloneMatchResult(result);
159
207
  };
160
208
  }
@@ -1,5 +1,5 @@
1
1
  import { registerRouteMap } from "../route-map-builder.js";
2
- import { extractStaticPrefix } from "./pattern-matching.js";
2
+ import { extractStaticPrefix, joinPrefix } from "./pattern-matching.js";
3
3
  import {
4
4
  type EntryData,
5
5
  RangoContext,
@@ -81,11 +81,16 @@ export function evaluateLazyEntry<TEnv = any>(
81
81
  // Check for pre-computed routes from build-time data.
82
82
  // Only leaf nodes (no nested includes) are precomputed, so entries with
83
83
  // nested lazy includes fall through to the handler below.
84
- // When multiple entries share the same staticPrefix (e.g., several
85
- // include("/", ...) calls), the precomputed data merges all their routes
86
- // into one entry. Assigning that merged set to the first matching entry
87
- // causes findMatch to pick the wrong handler for routes belonging to a
88
- // different include. Skip the shortcut when the prefix is shared.
84
+ //
85
+ // The load-bearing protection against two includes sharing a staticPrefix
86
+ // lives UPSTREAM in buildPrecomputedByPrefix (build/prefix-tree-utils): a
87
+ // shared staticPrefix is omitted from the map entirely, so currentPrecomputed
88
+ // never returns routes for it and the shortcut is skipped. The live-count
89
+ // check below is a secondary guard only — it is TIMING-BLIND (it counts
90
+ // routesEntries, which cannot see a nested sibling that has not been spliced
91
+ // in yet), so it must NOT be relied on alone. Kept as defense-in-depth for the
92
+ // all-siblings-live case (e.g. several include("/", ...) placeholders created
93
+ // up front).
89
94
  const currentPrecomputed = deps.getPrecomputedByPrefix();
90
95
  if (currentPrecomputed) {
91
96
  const routes = currentPrecomputed.get(entry.staticPrefix);
@@ -113,7 +118,15 @@ export function evaluateLazyEntry<TEnv = any>(
113
118
  const lazyPatterns = entry.lazyPatterns as UrlPatterns<TEnv>;
114
119
  const lazyContext = entry.lazyContext;
115
120
 
116
- // Create a new context for evaluating the lazy patterns
121
+ // Create a new context for evaluating the lazy patterns.
122
+ // KNOWN REDUNDANCY (LP3, docs/internal/matching-stability-review.md): this
123
+ // runs lazyPatterns.handler() purely to extract `patterns` (route name ->
124
+ // pattern) for matching, and DISCARDS the EntryData `manifest` it builds.
125
+ // loadManifest() then runs the SAME handler again on the first request to
126
+ // build the EntryData tree for rendering. Unifying the two runs is deferred
127
+ // (the two run in different contexts — see the LP3 todo in
128
+ // lazy-include-perf.test.ts). The precomputed-entries shortcut above avoids
129
+ // THIS run entirely for leaf includes.
117
130
  const manifest = new Map<string, EntryData>();
118
131
  const patterns = new Map<string, string>();
119
132
  const patternsByPrefix = new Map<string, Map<string, string>>();
@@ -145,10 +158,13 @@ export function evaluateLazyEntry<TEnv = any>(
145
158
  includeScope: lazyContext?.includeScope,
146
159
  },
147
160
  () => {
148
- // Run the lazy patterns handler with the original context prefixes
149
- // The prefix comes from the IncludeItem stored in lazyPatterns
161
+ // Run the lazy patterns handler with the original context prefixes.
162
+ // The prefix comes from the IncludeItem stored in lazyPatterns. Use the
163
+ // slash-collapsing join so a trailing-slash parent prefix does not bake a
164
+ // double slash into the registered route patterns (entry.routes,
165
+ // reverse(), EntryData.pattern, mountPath) when the handler runs.
150
166
  const includePrefix = (entry as any)._lazyPrefix || "";
151
- const fullPrefix = (lazyContext?.urlPrefix || "") + includePrefix;
167
+ const fullPrefix = joinPrefix(lazyContext?.urlPrefix, includePrefix);
152
168
 
153
169
  if (fullPrefix || lazyContext?.namePrefix) {
154
170
  runWithPrefixes(fullPrefix, lazyContext?.namePrefix, () => {
@@ -190,10 +206,13 @@ export function evaluateLazyEntry<TEnv = any>(
190
206
  // Detect nested lazy includes and register them as new entries
191
207
  const nestedLazyIncludes = findLazyIncludes(handlerResult);
192
208
  for (const lazyInclude of nestedLazyIncludes) {
193
- // Compute the full URL prefix (combining parent prefix if any)
194
- const fullPrefix = lazyInclude.context.urlPrefix
195
- ? lazyInclude.context.urlPrefix + lazyInclude.prefix
196
- : lazyInclude.prefix;
209
+ // Compute the full URL prefix (combining parent prefix if any). Use the
210
+ // slash-collapsing join so a trailing-slash parent prefix does not produce
211
+ // a double-slash staticPrefix the trie's sp can never match.
212
+ const fullPrefix = joinPrefix(
213
+ lazyInclude.context.urlPrefix,
214
+ lazyInclude.prefix,
215
+ );
197
216
 
198
217
  const nestedEntry: RouteEntry<TEnv> & { _lazyPrefix?: string } = {
199
218
  prefix: "",
@@ -14,6 +14,7 @@ import {
14
14
  type MetricsStore,
15
15
  } from "../server/context";
16
16
  import MapRootLayout from "../server/root-layout";
17
+ import { joinPrefix } from "./pattern-matching.js";
17
18
  import type { RouteEntry } from "../types";
18
19
  import type { UrlPatterns } from "../urls";
19
20
  import { VERSION } from "@rangojs/router:version";
@@ -23,10 +24,17 @@ import { VERSION } from "@rangojs/router:version";
23
24
  // stable references), so the resulting EntryData tree can be safely cached and reused
24
25
  // across requests within the same isolate.
25
26
  //
26
- // Cache is keyed by (VERSION, mountIndex, routeKey, isSSR). VERSION comes from the
27
+ // Cache is keyed by (VERSION, routerId, mountIndex, routeKey, isSSR). routeKey is
28
+ // REQUIRED in the key: loadManifest() runs the handler with forRoute=routeKey, and
29
+ // path-helper.ts prunes (skips registering) every route except forRoute, so the
30
+ // resulting Store.manifest is pruned to the requested route — NOT the full include.
31
+ // Dropping routeKey would make a sibling route miss and overwrite this entry with its
32
+ // own pruned manifest, so alternating sibling requests would thrash (re-run the
33
+ // handler every time). Running the include handler once per isolate instead of once
34
+ // per route is possible but needs an unpruned manifest cache with prune-on-read — see
35
+ // LP1 in docs/internal/matching-stability-review.md. VERSION comes from the
27
36
  // @rangojs/router:version virtual module which Vite invalidates on RSC module HMR.
28
37
  // When VERSION changes, this module re-evaluates and the cache is recreated empty.
29
- // Including VERSION in the key is additional defense against stale entries.
30
38
  const manifestModuleCache = new Map<string, Map<string, EntryData>>();
31
39
 
32
40
  /**
@@ -34,8 +42,8 @@ const manifestModuleCache = new Map<string, Map<string, EntryData>>();
34
42
  * Handles lazy imports, unwrapping, and validation
35
43
  *
36
44
  * Results are cached at module level after first execution. Subsequent calls
37
- * for the same (routeKey, isSSR) within the same isolate return cached data
38
- * without re-executing the DSL handler.
45
+ * for the same (routerId, mountIndex, routeKey, isSSR) within the same isolate
46
+ * return cached data without re-executing the DSL handler.
39
47
  */
40
48
  /**
41
49
  * Clear the module-level manifest cache.
@@ -65,9 +73,11 @@ export async function loadManifest(
65
73
 
66
74
  const mountIndex = entry.mountIndex;
67
75
 
68
- // Check module-level cache (persists across requests within same isolate)
76
+ // Check module-level cache (persists across requests within same isolate).
69
77
  // Include routerId so multi-router setups (host routing) don't share cached
70
78
  // EntryData across routers with overlapping mountIndex + routeKey combinations.
79
+ // routeKey is in the key because loadManifest() builds a manifest pruned to
80
+ // forRoute=routeKey (see path-helper.ts) — see the cache comment above.
71
81
  const cacheKey = `${VERSION}:${entry.routerId ?? ""}:${mountIndex ?? ""}:${routeKey}:${isSSR ? 1 : 0}`;
72
82
  const cached = manifestModuleCache.get(cacheKey);
73
83
  if (cached) {
@@ -176,7 +186,10 @@ export async function loadManifest(
176
186
  if (entry.lazy && entry.lazyPatterns) {
177
187
  const lazyPatterns = entry.lazyPatterns as UrlPatterns<any>;
178
188
  const includePrefix = (entry as any)._lazyPrefix || "";
179
- const fullPrefix = (lazyContext?.urlPrefix || "") + includePrefix;
189
+ // Slash-collapsing join so a trailing-slash parent prefix does not
190
+ // bake a double slash into the registered route patterns (must match
191
+ // the same join in evaluateLazyEntry / the build-time runWithPrefixes).
192
+ const fullPrefix = joinPrefix(lazyContext?.urlPrefix, includePrefix);
180
193
 
181
194
  if (fullPrefix || lazyContext?.namePrefix) {
182
195
  return runWithPrefixes(fullPrefix, lazyContext?.namePrefix, () =>
@@ -317,6 +317,21 @@ export function extractStaticPrefix(pattern: string): string {
317
317
  return pattern.slice(0, lastSlash);
318
318
  }
319
319
 
320
+ /**
321
+ * Join a URL prefix to a sub-prefix, collapsing the duplicate slash when the
322
+ * base ends with "/" and the sub-prefix starts with "/". This mirrors the
323
+ * canonical join in `include()` (urls/include-helper.ts) and `runWithPrefixes`
324
+ * (server/context.ts) so a nested lazy include's runtime staticPrefix matches
325
+ * the build-time trie's `sp` (e.g. `include("/parent/", …)` containing
326
+ * `include("/child", …)` resolves to `/parent/child`, not `/parent//child`).
327
+ */
328
+ export function joinPrefix(base: string | undefined, prefix: string): string {
329
+ if (!base) return prefix;
330
+ return base.endsWith("/") && prefix.startsWith("/")
331
+ ? base + prefix.slice(1)
332
+ : base + prefix;
333
+ }
334
+
320
335
  /**
321
336
  * Match a pathname against registered routes
322
337
  *
@@ -343,8 +358,6 @@ export interface RouteMatchResult<TEnv = any> {
343
358
  params: Record<string, string>;
344
359
  optionalParams: Set<string>;
345
360
  redirectTo?: string;
346
- /** Ancestry shortCodes for layout pruning (from trie match) */
347
- ancestry?: string[];
348
361
  /** Route has pre-rendered data available (from trie) */
349
362
  pr?: true;
350
363
  /** Passthrough: handler kept for live fallback on unknown params (from trie) */
@@ -365,6 +365,17 @@ export interface RangoInternal<
365
365
  /** @internal basename for runtime manifest generation */
366
366
  readonly __basename?: string;
367
367
 
368
+ /**
369
+ * @internal Router-level error/notFound fallbacks (`createRouter` options),
370
+ * exposed for the build-time clientChunks discovery so a `"use client"`
371
+ * default boundary is routed into the dedicated `app-fallback` chunk. Unlike
372
+ * the route-tree `errorBoundary()`/`notFoundBoundary()` helpers these never
373
+ * land in `EntryData`, so they are read directly off the router instance.
374
+ */
375
+ readonly __defaultErrorBoundary?: RangoOptions<TEnv>["defaultErrorBoundary"];
376
+ readonly __defaultNotFoundBoundary?: RangoOptions<TEnv>["defaultNotFoundBoundary"];
377
+ readonly __notFound?: RangoOptions<TEnv>["notFound"];
378
+
368
379
  match(
369
380
  request: Request,
370
381
  input?: RouterRequestInput<TEnv>,
@@ -19,8 +19,6 @@ export interface TrieMatchResult {
19
19
  * from `params` (read as `undefined`), matching the
20
20
  * `ExtractParams<"/:locale?/...">` type. */
21
21
  optionalParams?: string[];
22
- /** Ancestry shortCodes for layout pruning */
23
- ancestry: string[];
24
22
  /** Redirect target if trailing slash requires it */
25
23
  redirectTo?: string;
26
24
  /** Route has pre-rendered data available */
@@ -63,6 +61,19 @@ export function tryTrieMatch(
63
61
  pathnameHasTrailingSlash,
64
62
  );
65
63
  }
64
+ // A root-level wildcard ("/*") matches "/" with an empty remainder, the
65
+ // same value the regex matcher produces for the bare prefix. Without this
66
+ // the trie misses, the regex fallback runs, and its no-config branch emits
67
+ // a corrupt slice-off redirect. The static terminal still wins above.
68
+ if (trie.w) {
69
+ return validateAndBuild(
70
+ trie.w,
71
+ [],
72
+ "",
73
+ pathname,
74
+ pathnameHasTrailingSlash,
75
+ );
76
+ }
66
77
  return null;
67
78
  }
68
79
 
@@ -105,6 +116,15 @@ function walkTrie(
105
116
  if (node.r) {
106
117
  return { leaf: node.r, paramValues: [...paramValues] };
107
118
  }
119
+ // A wildcard at this node matches the bare prefix with an empty remainder
120
+ // (e.g. "/files" against "/files/*"), mirroring the regex matcher's `*=""`.
121
+ // walkTrie otherwise only reaches node.w in the index<length branch below,
122
+ // so without this a request to the wildcard's own prefix misses the trie
123
+ // and the regex fallback emits a corrupt redirect. A static terminal
124
+ // (node.r) still wins.
125
+ if (node.w) {
126
+ return { leaf: node.w, paramValues: [...paramValues], wildcardValue: "" };
127
+ }
108
128
  return null;
109
129
  }
110
130
 
@@ -229,7 +249,6 @@ function validateAndBuild(
229
249
  routeKey: leaf.n,
230
250
  sp: leaf.sp,
231
251
  params,
232
- ancestry: leaf.a,
233
252
  };
234
253
 
235
254
  if (leaf.op) result.optionalParams = leaf.op;