@rangojs/router 0.0.0-experimental.fa8a383a → 0.0.0-experimental.fb6e2f40

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 (916) hide show
  1. package/README.md +76 -18
  2. package/dist/bin/rango.js +130 -47
  3. package/dist/vite/index.js +421 -121
  4. package/package.json +2 -2
  5. package/skills/cache-guide/SKILL.md +32 -0
  6. package/skills/caching/SKILL.md +8 -0
  7. package/skills/links/SKILL.md +3 -1
  8. package/skills/loader/SKILL.md +53 -43
  9. package/skills/middleware/SKILL.md +2 -0
  10. package/skills/parallel/SKILL.md +67 -0
  11. package/skills/prerender/SKILL.md +110 -68
  12. package/skills/route/SKILL.md +31 -0
  13. package/skills/router-setup/SKILL.md +87 -2
  14. package/skills/typesafety/SKILL.md +10 -0
  15. package/src/__internal.ts +1 -1
  16. package/src/browser/app-version.ts +14 -0
  17. package/src/browser/navigation-bridge.ts +16 -3
  18. package/src/browser/navigation-client.ts +64 -40
  19. package/src/browser/navigation-store.ts +43 -8
  20. package/src/browser/partial-update.ts +37 -4
  21. package/src/browser/prefetch/fetch.ts +8 -2
  22. package/src/browser/prefetch/queue.ts +61 -29
  23. package/src/browser/prefetch/resource-ready.ts +77 -0
  24. package/src/browser/react/Link.tsx +44 -8
  25. package/src/browser/react/NavigationProvider.tsx +13 -4
  26. package/src/browser/react/context.ts +7 -2
  27. package/src/browser/react/use-handle.ts +9 -58
  28. package/src/browser/react/use-router.ts +21 -8
  29. package/src/browser/rsc-router.tsx +26 -3
  30. package/src/browser/scroll-restoration.ts +10 -8
  31. package/src/browser/server-action-bridge.ts +8 -6
  32. package/src/browser/types.ts +27 -5
  33. package/src/build/generate-manifest.ts +6 -6
  34. package/src/build/generate-route-types.ts +3 -0
  35. package/src/build/route-types/include-resolution.ts +8 -1
  36. package/src/build/route-types/router-processing.ts +211 -72
  37. package/src/build/route-types/scan-filter.ts +8 -1
  38. package/src/cache/cache-runtime.ts +15 -11
  39. package/src/cache/cache-scope.ts +46 -5
  40. package/src/cache/taint.ts +55 -0
  41. package/src/client.tsx +2 -56
  42. package/src/context-var.ts +72 -2
  43. package/src/handle.ts +40 -0
  44. package/src/index.rsc.ts +3 -1
  45. package/src/index.ts +8 -0
  46. package/src/prerender/store.ts +5 -4
  47. package/src/prerender.ts +138 -77
  48. package/src/reverse.ts +22 -1
  49. package/src/route-definition/dsl-helpers.ts +42 -19
  50. package/src/route-definition/helpers-types.ts +10 -6
  51. package/src/route-definition/index.ts +3 -0
  52. package/src/route-definition/redirect.ts +9 -1
  53. package/src/route-definition/resolve-handler-use.ts +149 -0
  54. package/src/route-types.ts +11 -0
  55. package/src/router/content-negotiation.ts +100 -1
  56. package/src/router/handler-context.ts +79 -23
  57. package/src/router/intercept-resolution.ts +9 -4
  58. package/src/router/loader-resolution.ts +122 -10
  59. package/src/router/match-api.ts +124 -189
  60. package/src/router/match-middleware/background-revalidation.ts +12 -1
  61. package/src/router/match-middleware/cache-lookup.ts +68 -13
  62. package/src/router/match-middleware/cache-store.ts +21 -4
  63. package/src/router/match-middleware/segment-resolution.ts +53 -0
  64. package/src/router/match-result.ts +11 -5
  65. package/src/router/metrics.ts +6 -1
  66. package/src/router/middleware-types.ts +6 -8
  67. package/src/router/middleware.ts +2 -5
  68. package/src/router/navigation-snapshot.ts +182 -0
  69. package/src/router/prerender-match.ts +110 -10
  70. package/src/router/preview-match.ts +30 -102
  71. package/src/router/request-classification.ts +310 -0
  72. package/src/router/route-snapshot.ts +245 -0
  73. package/src/router/router-context.ts +1 -0
  74. package/src/router/router-interfaces.ts +36 -4
  75. package/src/router/router-options.ts +37 -11
  76. package/src/router/segment-resolution/fresh.ts +101 -18
  77. package/src/router/segment-resolution/helpers.ts +29 -24
  78. package/src/router/segment-resolution/revalidation.ts +122 -26
  79. package/src/router/types.ts +1 -0
  80. package/src/router.ts +54 -5
  81. package/src/rsc/handler.ts +460 -377
  82. package/src/rsc/manifest-init.ts +5 -1
  83. package/src/rsc/progressive-enhancement.ts +4 -0
  84. package/src/rsc/rsc-rendering.ts +5 -0
  85. package/src/rsc/server-action.ts +2 -0
  86. package/src/rsc/ssr-setup.ts +2 -2
  87. package/src/rsc/types.ts +8 -1
  88. package/src/server/context.ts +50 -1
  89. package/src/server/loader-registry.ts +9 -8
  90. package/src/server/request-context.ts +146 -14
  91. package/src/ssr/index.tsx +3 -0
  92. package/src/static-handler.ts +18 -6
  93. package/src/types/cache-types.ts +4 -4
  94. package/src/types/handler-context.ts +137 -33
  95. package/src/types/loader-types.ts +36 -9
  96. package/src/types/route-entry.ts +1 -1
  97. package/src/urls/path-helper-types.ts +9 -2
  98. package/src/urls/path-helper.ts +47 -12
  99. package/src/urls/pattern-types.ts +12 -0
  100. package/src/urls/response-types.ts +16 -6
  101. package/src/use-loader.tsx +73 -4
  102. package/src/vite/discovery/bundle-postprocess.ts +30 -33
  103. package/src/vite/discovery/discover-routers.ts +5 -1
  104. package/src/vite/discovery/prerender-collection.ts +14 -1
  105. package/src/vite/discovery/state.ts +13 -4
  106. package/src/vite/index.ts +4 -0
  107. package/src/vite/plugin-types.ts +60 -5
  108. package/src/vite/plugins/performance-tracks.ts +88 -0
  109. package/src/vite/plugins/refresh-cmd.ts +88 -26
  110. package/src/vite/rango.ts +19 -2
  111. package/src/vite/router-discovery.ts +153 -34
  112. package/src/vite/utils/prerender-utils.ts +18 -0
  113. package/src/vite/utils/shared-utils.ts +3 -2
  114. package/dist/__internal.d.ts +0 -83
  115. package/dist/__internal.d.ts.map +0 -1
  116. package/dist/__internal.js +0 -19
  117. package/dist/__internal.js.map +0 -1
  118. package/dist/__mocks__/version.d.ts +0 -7
  119. package/dist/__mocks__/version.d.ts.map +0 -1
  120. package/dist/__mocks__/version.js +0 -7
  121. package/dist/__mocks__/version.js.map +0 -1
  122. package/dist/__tests__/client-href.test.d.ts +0 -2
  123. package/dist/__tests__/client-href.test.d.ts.map +0 -1
  124. package/dist/__tests__/client-href.test.js +0 -74
  125. package/dist/__tests__/client-href.test.js.map +0 -1
  126. package/dist/__tests__/component-utils.test.d.ts +0 -2
  127. package/dist/__tests__/component-utils.test.d.ts.map +0 -1
  128. package/dist/__tests__/component-utils.test.js +0 -51
  129. package/dist/__tests__/component-utils.test.js.map +0 -1
  130. package/dist/__tests__/event-controller.test.d.ts +0 -2
  131. package/dist/__tests__/event-controller.test.d.ts.map +0 -1
  132. package/dist/__tests__/event-controller.test.js +0 -538
  133. package/dist/__tests__/event-controller.test.js.map +0 -1
  134. package/dist/__tests__/helpers/route-tree.d.ts +0 -118
  135. package/dist/__tests__/helpers/route-tree.d.ts.map +0 -1
  136. package/dist/__tests__/helpers/route-tree.js +0 -374
  137. package/dist/__tests__/helpers/route-tree.js.map +0 -1
  138. package/dist/__tests__/match-result.test.d.ts +0 -2
  139. package/dist/__tests__/match-result.test.d.ts.map +0 -1
  140. package/dist/__tests__/match-result.test.js +0 -154
  141. package/dist/__tests__/match-result.test.js.map +0 -1
  142. package/dist/__tests__/navigation-store.test.d.ts +0 -2
  143. package/dist/__tests__/navigation-store.test.d.ts.map +0 -1
  144. package/dist/__tests__/navigation-store.test.js +0 -440
  145. package/dist/__tests__/navigation-store.test.js.map +0 -1
  146. package/dist/__tests__/partial-update.test.d.ts +0 -2
  147. package/dist/__tests__/partial-update.test.d.ts.map +0 -1
  148. package/dist/__tests__/partial-update.test.js +0 -1009
  149. package/dist/__tests__/partial-update.test.js.map +0 -1
  150. package/dist/__tests__/reverse-types.test.d.ts +0 -8
  151. package/dist/__tests__/reverse-types.test.d.ts.map +0 -1
  152. package/dist/__tests__/reverse-types.test.js +0 -656
  153. package/dist/__tests__/reverse-types.test.js.map +0 -1
  154. package/dist/__tests__/route-definition.test.d.ts +0 -2
  155. package/dist/__tests__/route-definition.test.d.ts.map +0 -1
  156. package/dist/__tests__/route-definition.test.js +0 -55
  157. package/dist/__tests__/route-definition.test.js.map +0 -1
  158. package/dist/__tests__/router-helpers.test.d.ts +0 -2
  159. package/dist/__tests__/router-helpers.test.d.ts.map +0 -1
  160. package/dist/__tests__/router-helpers.test.js +0 -377
  161. package/dist/__tests__/router-helpers.test.js.map +0 -1
  162. package/dist/__tests__/router-integration-2.test.d.ts +0 -2
  163. package/dist/__tests__/router-integration-2.test.d.ts.map +0 -1
  164. package/dist/__tests__/router-integration-2.test.js +0 -426
  165. package/dist/__tests__/router-integration-2.test.js.map +0 -1
  166. package/dist/__tests__/router-integration.test.d.ts +0 -2
  167. package/dist/__tests__/router-integration.test.d.ts.map +0 -1
  168. package/dist/__tests__/router-integration.test.js +0 -1051
  169. package/dist/__tests__/router-integration.test.js.map +0 -1
  170. package/dist/__tests__/search-params.test.d.ts +0 -5
  171. package/dist/__tests__/search-params.test.d.ts.map +0 -1
  172. package/dist/__tests__/search-params.test.js +0 -306
  173. package/dist/__tests__/search-params.test.js.map +0 -1
  174. package/dist/__tests__/segment-system.test.d.ts +0 -2
  175. package/dist/__tests__/segment-system.test.d.ts.map +0 -1
  176. package/dist/__tests__/segment-system.test.js +0 -627
  177. package/dist/__tests__/segment-system.test.js.map +0 -1
  178. package/dist/__tests__/static-handler-types.test.d.ts +0 -8
  179. package/dist/__tests__/static-handler-types.test.d.ts.map +0 -1
  180. package/dist/__tests__/static-handler-types.test.js +0 -63
  181. package/dist/__tests__/static-handler-types.test.js.map +0 -1
  182. package/dist/__tests__/urls.test.d.ts +0 -2
  183. package/dist/__tests__/urls.test.d.ts.map +0 -1
  184. package/dist/__tests__/urls.test.js +0 -421
  185. package/dist/__tests__/urls.test.js.map +0 -1
  186. package/dist/__tests__/use-mount.test.d.ts +0 -2
  187. package/dist/__tests__/use-mount.test.d.ts.map +0 -1
  188. package/dist/__tests__/use-mount.test.js +0 -35
  189. package/dist/__tests__/use-mount.test.js.map +0 -1
  190. package/dist/bin/rango.d.ts +0 -2
  191. package/dist/bin/rango.d.ts.map +0 -1
  192. package/dist/bin/rango.js.map +0 -1
  193. package/dist/browser/event-controller.d.ts +0 -191
  194. package/dist/browser/event-controller.d.ts.map +0 -1
  195. package/dist/browser/event-controller.js +0 -559
  196. package/dist/browser/event-controller.js.map +0 -1
  197. package/dist/browser/index.d.ts +0 -2
  198. package/dist/browser/index.d.ts.map +0 -1
  199. package/dist/browser/index.js +0 -14
  200. package/dist/browser/index.js.map +0 -1
  201. package/dist/browser/link-interceptor.d.ts +0 -38
  202. package/dist/browser/link-interceptor.d.ts.map +0 -1
  203. package/dist/browser/link-interceptor.js +0 -99
  204. package/dist/browser/link-interceptor.js.map +0 -1
  205. package/dist/browser/logging.d.ts +0 -10
  206. package/dist/browser/logging.d.ts.map +0 -1
  207. package/dist/browser/logging.js +0 -29
  208. package/dist/browser/logging.js.map +0 -1
  209. package/dist/browser/lru-cache.d.ts +0 -17
  210. package/dist/browser/lru-cache.d.ts.map +0 -1
  211. package/dist/browser/lru-cache.js +0 -50
  212. package/dist/browser/lru-cache.js.map +0 -1
  213. package/dist/browser/merge-segment-loaders.d.ts +0 -39
  214. package/dist/browser/merge-segment-loaders.d.ts.map +0 -1
  215. package/dist/browser/merge-segment-loaders.js +0 -102
  216. package/dist/browser/merge-segment-loaders.js.map +0 -1
  217. package/dist/browser/navigation-bridge.d.ts +0 -102
  218. package/dist/browser/navigation-bridge.d.ts.map +0 -1
  219. package/dist/browser/navigation-bridge.js +0 -708
  220. package/dist/browser/navigation-bridge.js.map +0 -1
  221. package/dist/browser/navigation-client.d.ts +0 -25
  222. package/dist/browser/navigation-client.d.ts.map +0 -1
  223. package/dist/browser/navigation-client.js +0 -157
  224. package/dist/browser/navigation-client.js.map +0 -1
  225. package/dist/browser/navigation-store.d.ts +0 -101
  226. package/dist/browser/navigation-store.d.ts.map +0 -1
  227. package/dist/browser/navigation-store.js +0 -625
  228. package/dist/browser/navigation-store.js.map +0 -1
  229. package/dist/browser/partial-update.d.ts +0 -75
  230. package/dist/browser/partial-update.d.ts.map +0 -1
  231. package/dist/browser/partial-update.js +0 -426
  232. package/dist/browser/partial-update.js.map +0 -1
  233. package/dist/browser/react/Link.d.ts +0 -86
  234. package/dist/browser/react/Link.d.ts.map +0 -1
  235. package/dist/browser/react/Link.js +0 -128
  236. package/dist/browser/react/Link.js.map +0 -1
  237. package/dist/browser/react/NavigationProvider.d.ts +0 -63
  238. package/dist/browser/react/NavigationProvider.d.ts.map +0 -1
  239. package/dist/browser/react/NavigationProvider.js +0 -216
  240. package/dist/browser/react/NavigationProvider.js.map +0 -1
  241. package/dist/browser/react/ScrollRestoration.d.ts +0 -75
  242. package/dist/browser/react/ScrollRestoration.d.ts.map +0 -1
  243. package/dist/browser/react/ScrollRestoration.js +0 -57
  244. package/dist/browser/react/ScrollRestoration.js.map +0 -1
  245. package/dist/browser/react/context.d.ts +0 -46
  246. package/dist/browser/react/context.d.ts.map +0 -1
  247. package/dist/browser/react/context.js +0 -10
  248. package/dist/browser/react/context.js.map +0 -1
  249. package/dist/browser/react/index.d.ts +0 -11
  250. package/dist/browser/react/index.d.ts.map +0 -1
  251. package/dist/browser/react/index.js +0 -22
  252. package/dist/browser/react/index.js.map +0 -1
  253. package/dist/browser/react/location-state-shared.d.ts +0 -63
  254. package/dist/browser/react/location-state-shared.d.ts.map +0 -1
  255. package/dist/browser/react/location-state-shared.js +0 -81
  256. package/dist/browser/react/location-state-shared.js.map +0 -1
  257. package/dist/browser/react/location-state.d.ts +0 -23
  258. package/dist/browser/react/location-state.d.ts.map +0 -1
  259. package/dist/browser/react/location-state.js +0 -29
  260. package/dist/browser/react/location-state.js.map +0 -1
  261. package/dist/browser/react/mount-context.d.ts +0 -24
  262. package/dist/browser/react/mount-context.d.ts.map +0 -1
  263. package/dist/browser/react/mount-context.js +0 -24
  264. package/dist/browser/react/mount-context.js.map +0 -1
  265. package/dist/browser/react/use-action.d.ts +0 -64
  266. package/dist/browser/react/use-action.d.ts.map +0 -1
  267. package/dist/browser/react/use-action.js +0 -134
  268. package/dist/browser/react/use-action.js.map +0 -1
  269. package/dist/browser/react/use-client-cache.d.ts +0 -41
  270. package/dist/browser/react/use-client-cache.d.ts.map +0 -1
  271. package/dist/browser/react/use-client-cache.js +0 -39
  272. package/dist/browser/react/use-client-cache.js.map +0 -1
  273. package/dist/browser/react/use-handle.d.ts +0 -31
  274. package/dist/browser/react/use-handle.d.ts.map +0 -1
  275. package/dist/browser/react/use-handle.js +0 -144
  276. package/dist/browser/react/use-handle.js.map +0 -1
  277. package/dist/browser/react/use-href.d.ts +0 -33
  278. package/dist/browser/react/use-href.d.ts.map +0 -1
  279. package/dist/browser/react/use-href.js +0 -39
  280. package/dist/browser/react/use-href.js.map +0 -1
  281. package/dist/browser/react/use-link-status.d.ts +0 -37
  282. package/dist/browser/react/use-link-status.d.ts.map +0 -1
  283. package/dist/browser/react/use-link-status.js +0 -99
  284. package/dist/browser/react/use-link-status.js.map +0 -1
  285. package/dist/browser/react/use-mount.d.ts +0 -25
  286. package/dist/browser/react/use-mount.d.ts.map +0 -1
  287. package/dist/browser/react/use-mount.js +0 -30
  288. package/dist/browser/react/use-mount.js.map +0 -1
  289. package/dist/browser/react/use-navigation.d.ts +0 -27
  290. package/dist/browser/react/use-navigation.d.ts.map +0 -1
  291. package/dist/browser/react/use-navigation.js +0 -87
  292. package/dist/browser/react/use-navigation.js.map +0 -1
  293. package/dist/browser/react/use-segments.d.ts +0 -38
  294. package/dist/browser/react/use-segments.d.ts.map +0 -1
  295. package/dist/browser/react/use-segments.js +0 -130
  296. package/dist/browser/react/use-segments.js.map +0 -1
  297. package/dist/browser/request-controller.d.ts +0 -26
  298. package/dist/browser/request-controller.d.ts.map +0 -1
  299. package/dist/browser/request-controller.js +0 -147
  300. package/dist/browser/request-controller.js.map +0 -1
  301. package/dist/browser/rsc-router.d.ts +0 -129
  302. package/dist/browser/rsc-router.d.ts.map +0 -1
  303. package/dist/browser/rsc-router.js +0 -195
  304. package/dist/browser/rsc-router.js.map +0 -1
  305. package/dist/browser/scroll-restoration.d.ts +0 -93
  306. package/dist/browser/scroll-restoration.d.ts.map +0 -1
  307. package/dist/browser/scroll-restoration.js +0 -321
  308. package/dist/browser/scroll-restoration.js.map +0 -1
  309. package/dist/browser/segment-structure-assert.d.ts +0 -17
  310. package/dist/browser/segment-structure-assert.d.ts.map +0 -1
  311. package/dist/browser/segment-structure-assert.js +0 -59
  312. package/dist/browser/segment-structure-assert.js.map +0 -1
  313. package/dist/browser/server-action-bridge.d.ts +0 -26
  314. package/dist/browser/server-action-bridge.d.ts.map +0 -1
  315. package/dist/browser/server-action-bridge.js +0 -668
  316. package/dist/browser/server-action-bridge.js.map +0 -1
  317. package/dist/browser/shallow.d.ts +0 -12
  318. package/dist/browser/shallow.d.ts.map +0 -1
  319. package/dist/browser/shallow.js +0 -34
  320. package/dist/browser/shallow.js.map +0 -1
  321. package/dist/browser/types.d.ts +0 -369
  322. package/dist/browser/types.d.ts.map +0 -1
  323. package/dist/browser/types.js +0 -2
  324. package/dist/browser/types.js.map +0 -1
  325. package/dist/build/__tests__/generate-cli.test.d.ts +0 -2
  326. package/dist/build/__tests__/generate-cli.test.d.ts.map +0 -1
  327. package/dist/build/__tests__/generate-cli.test.js +0 -237
  328. package/dist/build/__tests__/generate-cli.test.js.map +0 -1
  329. package/dist/build/__tests__/generate-manifest.test.d.ts +0 -2
  330. package/dist/build/__tests__/generate-manifest.test.d.ts.map +0 -1
  331. package/dist/build/__tests__/generate-manifest.test.js +0 -119
  332. package/dist/build/__tests__/generate-manifest.test.js.map +0 -1
  333. package/dist/build/__tests__/generate-route-types.test.d.ts +0 -2
  334. package/dist/build/__tests__/generate-route-types.test.d.ts.map +0 -1
  335. package/dist/build/__tests__/generate-route-types.test.js +0 -620
  336. package/dist/build/__tests__/generate-route-types.test.js.map +0 -1
  337. package/dist/build/__tests__/per-router-manifest.test.d.ts +0 -2
  338. package/dist/build/__tests__/per-router-manifest.test.d.ts.map +0 -1
  339. package/dist/build/__tests__/per-router-manifest.test.js +0 -308
  340. package/dist/build/__tests__/per-router-manifest.test.js.map +0 -1
  341. package/dist/build/generate-manifest.d.ts +0 -81
  342. package/dist/build/generate-manifest.d.ts.map +0 -1
  343. package/dist/build/generate-manifest.js +0 -276
  344. package/dist/build/generate-manifest.js.map +0 -1
  345. package/dist/build/generate-route-types.d.ts +0 -115
  346. package/dist/build/generate-route-types.d.ts.map +0 -1
  347. package/dist/build/generate-route-types.js +0 -740
  348. package/dist/build/generate-route-types.js.map +0 -1
  349. package/dist/build/index.d.ts +0 -21
  350. package/dist/build/index.d.ts.map +0 -1
  351. package/dist/build/index.js +0 -21
  352. package/dist/build/index.js.map +0 -1
  353. package/dist/build/route-trie.d.ts +0 -71
  354. package/dist/build/route-trie.d.ts.map +0 -1
  355. package/dist/build/route-trie.js +0 -175
  356. package/dist/build/route-trie.js.map +0 -1
  357. package/dist/cache/__tests__/cache-scope.test.d.ts +0 -2
  358. package/dist/cache/__tests__/cache-scope.test.d.ts.map +0 -1
  359. package/dist/cache/__tests__/cache-scope.test.js +0 -208
  360. package/dist/cache/__tests__/cache-scope.test.js.map +0 -1
  361. package/dist/cache/__tests__/document-cache.test.d.ts +0 -2
  362. package/dist/cache/__tests__/document-cache.test.d.ts.map +0 -1
  363. package/dist/cache/__tests__/document-cache.test.js +0 -345
  364. package/dist/cache/__tests__/document-cache.test.js.map +0 -1
  365. package/dist/cache/__tests__/memory-segment-store.test.d.ts +0 -2
  366. package/dist/cache/__tests__/memory-segment-store.test.d.ts.map +0 -1
  367. package/dist/cache/__tests__/memory-segment-store.test.js +0 -425
  368. package/dist/cache/__tests__/memory-segment-store.test.js.map +0 -1
  369. package/dist/cache/__tests__/memory-store.test.d.ts +0 -2
  370. package/dist/cache/__tests__/memory-store.test.d.ts.map +0 -1
  371. package/dist/cache/__tests__/memory-store.test.js +0 -367
  372. package/dist/cache/__tests__/memory-store.test.js.map +0 -1
  373. package/dist/cache/cache-scope.d.ts +0 -102
  374. package/dist/cache/cache-scope.d.ts.map +0 -1
  375. package/dist/cache/cache-scope.js +0 -440
  376. package/dist/cache/cache-scope.js.map +0 -1
  377. package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts +0 -2
  378. package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts.map +0 -1
  379. package/dist/cache/cf/__tests__/cf-cache-store.test.js +0 -330
  380. package/dist/cache/cf/__tests__/cf-cache-store.test.js.map +0 -1
  381. package/dist/cache/cf/cf-cache-store.d.ts +0 -165
  382. package/dist/cache/cf/cf-cache-store.d.ts.map +0 -1
  383. package/dist/cache/cf/cf-cache-store.js +0 -242
  384. package/dist/cache/cf/cf-cache-store.js.map +0 -1
  385. package/dist/cache/cf/index.d.ts +0 -14
  386. package/dist/cache/cf/index.d.ts.map +0 -1
  387. package/dist/cache/cf/index.js +0 -17
  388. package/dist/cache/cf/index.js.map +0 -1
  389. package/dist/cache/document-cache.d.ts +0 -64
  390. package/dist/cache/document-cache.d.ts.map +0 -1
  391. package/dist/cache/document-cache.js +0 -228
  392. package/dist/cache/document-cache.js.map +0 -1
  393. package/dist/cache/index.d.ts +0 -19
  394. package/dist/cache/index.d.ts.map +0 -1
  395. package/dist/cache/index.js +0 -21
  396. package/dist/cache/index.js.map +0 -1
  397. package/dist/cache/memory-segment-store.d.ts +0 -110
  398. package/dist/cache/memory-segment-store.d.ts.map +0 -1
  399. package/dist/cache/memory-segment-store.js +0 -117
  400. package/dist/cache/memory-segment-store.js.map +0 -1
  401. package/dist/cache/memory-store.d.ts +0 -41
  402. package/dist/cache/memory-store.d.ts.map +0 -1
  403. package/dist/cache/memory-store.js +0 -191
  404. package/dist/cache/memory-store.js.map +0 -1
  405. package/dist/cache/types.d.ts +0 -317
  406. package/dist/cache/types.d.ts.map +0 -1
  407. package/dist/cache/types.js +0 -12
  408. package/dist/cache/types.js.map +0 -1
  409. package/dist/client.d.ts +0 -248
  410. package/dist/client.d.ts.map +0 -1
  411. package/dist/client.js +0 -367
  412. package/dist/client.js.map +0 -1
  413. package/dist/client.rsc.d.ts +0 -26
  414. package/dist/client.rsc.d.ts.map +0 -1
  415. package/dist/client.rsc.js +0 -46
  416. package/dist/client.rsc.js.map +0 -1
  417. package/dist/component-utils.d.ts +0 -36
  418. package/dist/component-utils.d.ts.map +0 -1
  419. package/dist/component-utils.js +0 -61
  420. package/dist/component-utils.js.map +0 -1
  421. package/dist/components/DefaultDocument.d.ts +0 -13
  422. package/dist/components/DefaultDocument.d.ts.map +0 -1
  423. package/dist/components/DefaultDocument.js +0 -15
  424. package/dist/components/DefaultDocument.js.map +0 -1
  425. package/dist/debug.d.ts +0 -58
  426. package/dist/debug.d.ts.map +0 -1
  427. package/dist/debug.js +0 -157
  428. package/dist/debug.js.map +0 -1
  429. package/dist/default-error-boundary.d.ts +0 -11
  430. package/dist/default-error-boundary.d.ts.map +0 -1
  431. package/dist/default-error-boundary.js +0 -45
  432. package/dist/default-error-boundary.js.map +0 -1
  433. package/dist/deps/browser.d.ts +0 -2
  434. package/dist/deps/browser.d.ts.map +0 -1
  435. package/dist/deps/browser.js +0 -3
  436. package/dist/deps/browser.js.map +0 -1
  437. package/dist/deps/html-stream-client.d.ts +0 -2
  438. package/dist/deps/html-stream-client.d.ts.map +0 -1
  439. package/dist/deps/html-stream-client.js +0 -3
  440. package/dist/deps/html-stream-client.js.map +0 -1
  441. package/dist/deps/html-stream-server.d.ts +0 -2
  442. package/dist/deps/html-stream-server.d.ts.map +0 -1
  443. package/dist/deps/html-stream-server.js +0 -3
  444. package/dist/deps/html-stream-server.js.map +0 -1
  445. package/dist/deps/rsc.d.ts +0 -2
  446. package/dist/deps/rsc.d.ts.map +0 -1
  447. package/dist/deps/rsc.js +0 -4
  448. package/dist/deps/rsc.js.map +0 -1
  449. package/dist/deps/ssr.d.ts +0 -2
  450. package/dist/deps/ssr.d.ts.map +0 -1
  451. package/dist/deps/ssr.js +0 -3
  452. package/dist/deps/ssr.js.map +0 -1
  453. package/dist/errors.d.ts +0 -174
  454. package/dist/errors.d.ts.map +0 -1
  455. package/dist/errors.js +0 -241
  456. package/dist/errors.js.map +0 -1
  457. package/dist/handle.d.ts +0 -78
  458. package/dist/handle.d.ts.map +0 -1
  459. package/dist/handle.js +0 -82
  460. package/dist/handle.js.map +0 -1
  461. package/dist/handles/MetaTags.d.ts +0 -14
  462. package/dist/handles/MetaTags.d.ts.map +0 -1
  463. package/dist/handles/MetaTags.js +0 -136
  464. package/dist/handles/MetaTags.js.map +0 -1
  465. package/dist/handles/index.d.ts +0 -6
  466. package/dist/handles/index.d.ts.map +0 -1
  467. package/dist/handles/index.js +0 -6
  468. package/dist/handles/index.js.map +0 -1
  469. package/dist/handles/meta.d.ts +0 -39
  470. package/dist/handles/meta.d.ts.map +0 -1
  471. package/dist/handles/meta.js +0 -202
  472. package/dist/handles/meta.js.map +0 -1
  473. package/dist/host/__tests__/errors.test.d.ts +0 -2
  474. package/dist/host/__tests__/errors.test.d.ts.map +0 -1
  475. package/dist/host/__tests__/errors.test.js +0 -76
  476. package/dist/host/__tests__/errors.test.js.map +0 -1
  477. package/dist/host/__tests__/pattern-comprehensive.test.d.ts +0 -2
  478. package/dist/host/__tests__/pattern-comprehensive.test.d.ts.map +0 -1
  479. package/dist/host/__tests__/pattern-comprehensive.test.js +0 -732
  480. package/dist/host/__tests__/pattern-comprehensive.test.js.map +0 -1
  481. package/dist/host/__tests__/pattern-matcher.test.d.ts +0 -2
  482. package/dist/host/__tests__/pattern-matcher.test.d.ts.map +0 -1
  483. package/dist/host/__tests__/pattern-matcher.test.js +0 -251
  484. package/dist/host/__tests__/pattern-matcher.test.js.map +0 -1
  485. package/dist/host/__tests__/router.test.d.ts +0 -2
  486. package/dist/host/__tests__/router.test.d.ts.map +0 -1
  487. package/dist/host/__tests__/router.test.js +0 -241
  488. package/dist/host/__tests__/router.test.js.map +0 -1
  489. package/dist/host/__tests__/testing.test.d.ts +0 -2
  490. package/dist/host/__tests__/testing.test.d.ts.map +0 -1
  491. package/dist/host/__tests__/testing.test.js +0 -64
  492. package/dist/host/__tests__/testing.test.js.map +0 -1
  493. package/dist/host/__tests__/utils.test.d.ts +0 -2
  494. package/dist/host/__tests__/utils.test.d.ts.map +0 -1
  495. package/dist/host/__tests__/utils.test.js +0 -29
  496. package/dist/host/__tests__/utils.test.js.map +0 -1
  497. package/dist/host/cookie-handler.d.ts +0 -34
  498. package/dist/host/cookie-handler.d.ts.map +0 -1
  499. package/dist/host/cookie-handler.js +0 -124
  500. package/dist/host/cookie-handler.js.map +0 -1
  501. package/dist/host/errors.d.ts +0 -56
  502. package/dist/host/errors.d.ts.map +0 -1
  503. package/dist/host/errors.js +0 -79
  504. package/dist/host/errors.js.map +0 -1
  505. package/dist/host/index.d.ts +0 -29
  506. package/dist/host/index.d.ts.map +0 -1
  507. package/dist/host/index.js +0 -32
  508. package/dist/host/index.js.map +0 -1
  509. package/dist/host/pattern-matcher.d.ts +0 -36
  510. package/dist/host/pattern-matcher.d.ts.map +0 -1
  511. package/dist/host/pattern-matcher.js +0 -172
  512. package/dist/host/pattern-matcher.js.map +0 -1
  513. package/dist/host/router.d.ts +0 -26
  514. package/dist/host/router.d.ts.map +0 -1
  515. package/dist/host/router.js +0 -218
  516. package/dist/host/router.js.map +0 -1
  517. package/dist/host/testing.d.ts +0 -36
  518. package/dist/host/testing.d.ts.map +0 -1
  519. package/dist/host/testing.js +0 -55
  520. package/dist/host/testing.js.map +0 -1
  521. package/dist/host/types.d.ts +0 -115
  522. package/dist/host/types.d.ts.map +0 -1
  523. package/dist/host/types.js +0 -7
  524. package/dist/host/types.js.map +0 -1
  525. package/dist/host/utils.d.ts +0 -21
  526. package/dist/host/utils.d.ts.map +0 -1
  527. package/dist/host/utils.js +0 -23
  528. package/dist/host/utils.js.map +0 -1
  529. package/dist/href-client.d.ts +0 -131
  530. package/dist/href-client.d.ts.map +0 -1
  531. package/dist/href-client.js +0 -64
  532. package/dist/href-client.js.map +0 -1
  533. package/dist/href-context.d.ts +0 -29
  534. package/dist/href-context.d.ts.map +0 -1
  535. package/dist/href-context.js +0 -21
  536. package/dist/href-context.js.map +0 -1
  537. package/dist/index.d.ts +0 -73
  538. package/dist/index.d.ts.map +0 -1
  539. package/dist/index.js +0 -91
  540. package/dist/index.js.map +0 -1
  541. package/dist/index.rsc.d.ts +0 -32
  542. package/dist/index.rsc.d.ts.map +0 -1
  543. package/dist/index.rsc.js +0 -40
  544. package/dist/index.rsc.js.map +0 -1
  545. package/dist/internal-debug.d.ts +0 -2
  546. package/dist/internal-debug.d.ts.map +0 -1
  547. package/dist/internal-debug.js +0 -5
  548. package/dist/internal-debug.js.map +0 -1
  549. package/dist/loader.d.ts +0 -14
  550. package/dist/loader.d.ts.map +0 -1
  551. package/dist/loader.js +0 -20
  552. package/dist/loader.js.map +0 -1
  553. package/dist/loader.rsc.d.ts +0 -19
  554. package/dist/loader.rsc.d.ts.map +0 -1
  555. package/dist/loader.rsc.js +0 -99
  556. package/dist/loader.rsc.js.map +0 -1
  557. package/dist/network-error-thrower.d.ts +0 -17
  558. package/dist/network-error-thrower.d.ts.map +0 -1
  559. package/dist/network-error-thrower.js +0 -14
  560. package/dist/network-error-thrower.js.map +0 -1
  561. package/dist/outlet-context.d.ts +0 -13
  562. package/dist/outlet-context.d.ts.map +0 -1
  563. package/dist/outlet-context.js +0 -3
  564. package/dist/outlet-context.js.map +0 -1
  565. package/dist/prerender/__tests__/param-hash.test.d.ts +0 -2
  566. package/dist/prerender/__tests__/param-hash.test.d.ts.map +0 -1
  567. package/dist/prerender/__tests__/param-hash.test.js +0 -148
  568. package/dist/prerender/__tests__/param-hash.test.js.map +0 -1
  569. package/dist/prerender/param-hash.d.ts +0 -16
  570. package/dist/prerender/param-hash.d.ts.map +0 -1
  571. package/dist/prerender/param-hash.js +0 -36
  572. package/dist/prerender/param-hash.js.map +0 -1
  573. package/dist/prerender/store.d.ts +0 -38
  574. package/dist/prerender/store.d.ts.map +0 -1
  575. package/dist/prerender/store.js +0 -61
  576. package/dist/prerender/store.js.map +0 -1
  577. package/dist/prerender.d.ts +0 -66
  578. package/dist/prerender.d.ts.map +0 -1
  579. package/dist/prerender.js +0 -57
  580. package/dist/prerender.js.map +0 -1
  581. package/dist/reverse.d.ts +0 -196
  582. package/dist/reverse.d.ts.map +0 -1
  583. package/dist/reverse.js +0 -78
  584. package/dist/reverse.js.map +0 -1
  585. package/dist/root-error-boundary.d.ts +0 -33
  586. package/dist/root-error-boundary.d.ts.map +0 -1
  587. package/dist/root-error-boundary.js +0 -165
  588. package/dist/root-error-boundary.js.map +0 -1
  589. package/dist/route-content-wrapper.d.ts +0 -46
  590. package/dist/route-content-wrapper.d.ts.map +0 -1
  591. package/dist/route-content-wrapper.js +0 -77
  592. package/dist/route-content-wrapper.js.map +0 -1
  593. package/dist/route-definition.d.ts +0 -421
  594. package/dist/route-definition.d.ts.map +0 -1
  595. package/dist/route-definition.js +0 -868
  596. package/dist/route-definition.js.map +0 -1
  597. package/dist/route-map-builder.d.ts +0 -155
  598. package/dist/route-map-builder.d.ts.map +0 -1
  599. package/dist/route-map-builder.js +0 -237
  600. package/dist/route-map-builder.js.map +0 -1
  601. package/dist/route-types.d.ts +0 -165
  602. package/dist/route-types.d.ts.map +0 -1
  603. package/dist/route-types.js +0 -7
  604. package/dist/route-types.js.map +0 -1
  605. package/dist/router/__tests__/handler-context.test.d.ts +0 -2
  606. package/dist/router/__tests__/handler-context.test.d.ts.map +0 -1
  607. package/dist/router/__tests__/handler-context.test.js +0 -65
  608. package/dist/router/__tests__/handler-context.test.js.map +0 -1
  609. package/dist/router/__tests__/loader-cycle-detection.test.d.ts +0 -2
  610. package/dist/router/__tests__/loader-cycle-detection.test.d.ts.map +0 -1
  611. package/dist/router/__tests__/loader-cycle-detection.test.js +0 -221
  612. package/dist/router/__tests__/loader-cycle-detection.test.js.map +0 -1
  613. package/dist/router/__tests__/match-context.test.d.ts +0 -2
  614. package/dist/router/__tests__/match-context.test.d.ts.map +0 -1
  615. package/dist/router/__tests__/match-context.test.js +0 -92
  616. package/dist/router/__tests__/match-context.test.js.map +0 -1
  617. package/dist/router/__tests__/match-pipelines.test.d.ts +0 -2
  618. package/dist/router/__tests__/match-pipelines.test.d.ts.map +0 -1
  619. package/dist/router/__tests__/match-pipelines.test.js +0 -417
  620. package/dist/router/__tests__/match-pipelines.test.js.map +0 -1
  621. package/dist/router/__tests__/match-result.test.d.ts +0 -2
  622. package/dist/router/__tests__/match-result.test.d.ts.map +0 -1
  623. package/dist/router/__tests__/match-result.test.js +0 -457
  624. package/dist/router/__tests__/match-result.test.js.map +0 -1
  625. package/dist/router/__tests__/on-error.test.d.ts +0 -2
  626. package/dist/router/__tests__/on-error.test.d.ts.map +0 -1
  627. package/dist/router/__tests__/on-error.test.js +0 -678
  628. package/dist/router/__tests__/on-error.test.js.map +0 -1
  629. package/dist/router/__tests__/pattern-matching.test.d.ts +0 -2
  630. package/dist/router/__tests__/pattern-matching.test.d.ts.map +0 -1
  631. package/dist/router/__tests__/pattern-matching.test.js +0 -629
  632. package/dist/router/__tests__/pattern-matching.test.js.map +0 -1
  633. package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts +0 -2
  634. package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts.map +0 -1
  635. package/dist/router/__tests__/segment-resolution-parallel-loading.test.js +0 -155
  636. package/dist/router/__tests__/segment-resolution-parallel-loading.test.js.map +0 -1
  637. package/dist/router/error-handling.d.ts +0 -77
  638. package/dist/router/error-handling.d.ts.map +0 -1
  639. package/dist/router/error-handling.js +0 -202
  640. package/dist/router/error-handling.js.map +0 -1
  641. package/dist/router/handler-context.d.ts +0 -20
  642. package/dist/router/handler-context.d.ts.map +0 -1
  643. package/dist/router/handler-context.js +0 -198
  644. package/dist/router/handler-context.js.map +0 -1
  645. package/dist/router/intercept-resolution.d.ts +0 -66
  646. package/dist/router/intercept-resolution.d.ts.map +0 -1
  647. package/dist/router/intercept-resolution.js +0 -246
  648. package/dist/router/intercept-resolution.js.map +0 -1
  649. package/dist/router/loader-resolution.d.ts +0 -64
  650. package/dist/router/loader-resolution.d.ts.map +0 -1
  651. package/dist/router/loader-resolution.js +0 -284
  652. package/dist/router/loader-resolution.js.map +0 -1
  653. package/dist/router/logging.d.ts +0 -15
  654. package/dist/router/logging.d.ts.map +0 -1
  655. package/dist/router/logging.js +0 -99
  656. package/dist/router/logging.js.map +0 -1
  657. package/dist/router/manifest.d.ts +0 -22
  658. package/dist/router/manifest.d.ts.map +0 -1
  659. package/dist/router/manifest.js +0 -181
  660. package/dist/router/manifest.js.map +0 -1
  661. package/dist/router/match-api.d.ts +0 -35
  662. package/dist/router/match-api.d.ts.map +0 -1
  663. package/dist/router/match-api.js +0 -406
  664. package/dist/router/match-api.js.map +0 -1
  665. package/dist/router/match-context.d.ts +0 -206
  666. package/dist/router/match-context.d.ts.map +0 -1
  667. package/dist/router/match-context.js +0 -17
  668. package/dist/router/match-context.js.map +0 -1
  669. package/dist/router/match-middleware/background-revalidation.d.ts +0 -127
  670. package/dist/router/match-middleware/background-revalidation.d.ts.map +0 -1
  671. package/dist/router/match-middleware/background-revalidation.js +0 -75
  672. package/dist/router/match-middleware/background-revalidation.js.map +0 -1
  673. package/dist/router/match-middleware/cache-lookup.d.ts +0 -112
  674. package/dist/router/match-middleware/cache-lookup.d.ts.map +0 -1
  675. package/dist/router/match-middleware/cache-lookup.js +0 -257
  676. package/dist/router/match-middleware/cache-lookup.js.map +0 -1
  677. package/dist/router/match-middleware/cache-store.d.ts +0 -113
  678. package/dist/router/match-middleware/cache-store.d.ts.map +0 -1
  679. package/dist/router/match-middleware/cache-store.js +0 -108
  680. package/dist/router/match-middleware/cache-store.js.map +0 -1
  681. package/dist/router/match-middleware/index.d.ts +0 -81
  682. package/dist/router/match-middleware/index.d.ts.map +0 -1
  683. package/dist/router/match-middleware/index.js +0 -80
  684. package/dist/router/match-middleware/index.js.map +0 -1
  685. package/dist/router/match-middleware/intercept-resolution.d.ts +0 -117
  686. package/dist/router/match-middleware/intercept-resolution.d.ts.map +0 -1
  687. package/dist/router/match-middleware/intercept-resolution.js +0 -134
  688. package/dist/router/match-middleware/intercept-resolution.js.map +0 -1
  689. package/dist/router/match-middleware/segment-resolution.d.ts +0 -99
  690. package/dist/router/match-middleware/segment-resolution.d.ts.map +0 -1
  691. package/dist/router/match-middleware/segment-resolution.js +0 -53
  692. package/dist/router/match-middleware/segment-resolution.js.map +0 -1
  693. package/dist/router/match-pipelines.d.ts +0 -147
  694. package/dist/router/match-pipelines.d.ts.map +0 -1
  695. package/dist/router/match-pipelines.js +0 -82
  696. package/dist/router/match-pipelines.js.map +0 -1
  697. package/dist/router/match-result.d.ts +0 -126
  698. package/dist/router/match-result.d.ts.map +0 -1
  699. package/dist/router/match-result.js +0 -93
  700. package/dist/router/match-result.js.map +0 -1
  701. package/dist/router/metrics.d.ts +0 -20
  702. package/dist/router/metrics.d.ts.map +0 -1
  703. package/dist/router/metrics.js +0 -47
  704. package/dist/router/metrics.js.map +0 -1
  705. package/dist/router/middleware.d.ts +0 -249
  706. package/dist/router/middleware.d.ts.map +0 -1
  707. package/dist/router/middleware.js +0 -434
  708. package/dist/router/middleware.js.map +0 -1
  709. package/dist/router/middleware.test.d.ts +0 -2
  710. package/dist/router/middleware.test.d.ts.map +0 -1
  711. package/dist/router/middleware.test.js +0 -816
  712. package/dist/router/middleware.test.js.map +0 -1
  713. package/dist/router/pattern-matching.d.ts +0 -149
  714. package/dist/router/pattern-matching.d.ts.map +0 -1
  715. package/dist/router/pattern-matching.js +0 -349
  716. package/dist/router/pattern-matching.js.map +0 -1
  717. package/dist/router/revalidation.d.ts +0 -44
  718. package/dist/router/revalidation.d.ts.map +0 -1
  719. package/dist/router/revalidation.js +0 -147
  720. package/dist/router/revalidation.js.map +0 -1
  721. package/dist/router/router-context.d.ts +0 -135
  722. package/dist/router/router-context.d.ts.map +0 -1
  723. package/dist/router/router-context.js +0 -36
  724. package/dist/router/router-context.js.map +0 -1
  725. package/dist/router/segment-resolution.d.ts +0 -127
  726. package/dist/router/segment-resolution.d.ts.map +0 -1
  727. package/dist/router/segment-resolution.js +0 -919
  728. package/dist/router/segment-resolution.js.map +0 -1
  729. package/dist/router/trie-matching.d.ts +0 -40
  730. package/dist/router/trie-matching.d.ts.map +0 -1
  731. package/dist/router/trie-matching.js +0 -127
  732. package/dist/router/trie-matching.js.map +0 -1
  733. package/dist/router/types.d.ts +0 -136
  734. package/dist/router/types.d.ts.map +0 -1
  735. package/dist/router/types.js +0 -7
  736. package/dist/router/types.js.map +0 -1
  737. package/dist/router.d.ts +0 -753
  738. package/dist/router.d.ts.map +0 -1
  739. package/dist/router.gen.d.ts +0 -6
  740. package/dist/router.gen.d.ts.map +0 -1
  741. package/dist/router.gen.js +0 -6
  742. package/dist/router.gen.js.map +0 -1
  743. package/dist/router.js +0 -1304
  744. package/dist/router.js.map +0 -1
  745. package/dist/rsc/__tests__/helpers.test.d.ts +0 -2
  746. package/dist/rsc/__tests__/helpers.test.d.ts.map +0 -1
  747. package/dist/rsc/__tests__/helpers.test.js +0 -140
  748. package/dist/rsc/__tests__/helpers.test.js.map +0 -1
  749. package/dist/rsc/handler.d.ts +0 -45
  750. package/dist/rsc/handler.d.ts.map +0 -1
  751. package/dist/rsc/handler.js +0 -1172
  752. package/dist/rsc/handler.js.map +0 -1
  753. package/dist/rsc/helpers.d.ts +0 -16
  754. package/dist/rsc/helpers.d.ts.map +0 -1
  755. package/dist/rsc/helpers.js +0 -55
  756. package/dist/rsc/helpers.js.map +0 -1
  757. package/dist/rsc/index.d.ts +0 -22
  758. package/dist/rsc/index.d.ts.map +0 -1
  759. package/dist/rsc/index.js +0 -23
  760. package/dist/rsc/index.js.map +0 -1
  761. package/dist/rsc/nonce.d.ts +0 -9
  762. package/dist/rsc/nonce.d.ts.map +0 -1
  763. package/dist/rsc/nonce.js +0 -18
  764. package/dist/rsc/nonce.js.map +0 -1
  765. package/dist/rsc/types.d.ts +0 -206
  766. package/dist/rsc/types.d.ts.map +0 -1
  767. package/dist/rsc/types.js +0 -8
  768. package/dist/rsc/types.js.map +0 -1
  769. package/dist/search-params.d.ts +0 -103
  770. package/dist/search-params.d.ts.map +0 -1
  771. package/dist/search-params.js +0 -74
  772. package/dist/search-params.js.map +0 -1
  773. package/dist/segment-system.d.ts +0 -75
  774. package/dist/segment-system.d.ts.map +0 -1
  775. package/dist/segment-system.js +0 -336
  776. package/dist/segment-system.js.map +0 -1
  777. package/dist/server/context.d.ts +0 -245
  778. package/dist/server/context.d.ts.map +0 -1
  779. package/dist/server/context.js +0 -197
  780. package/dist/server/context.js.map +0 -1
  781. package/dist/server/fetchable-loader-store.d.ts +0 -18
  782. package/dist/server/fetchable-loader-store.d.ts.map +0 -1
  783. package/dist/server/fetchable-loader-store.js +0 -18
  784. package/dist/server/fetchable-loader-store.js.map +0 -1
  785. package/dist/server/handle-store.d.ts +0 -85
  786. package/dist/server/handle-store.d.ts.map +0 -1
  787. package/dist/server/handle-store.js +0 -142
  788. package/dist/server/handle-store.js.map +0 -1
  789. package/dist/server/loader-registry.d.ts +0 -55
  790. package/dist/server/loader-registry.d.ts.map +0 -1
  791. package/dist/server/loader-registry.js +0 -132
  792. package/dist/server/loader-registry.js.map +0 -1
  793. package/dist/server/request-context.d.ts +0 -226
  794. package/dist/server/request-context.d.ts.map +0 -1
  795. package/dist/server/request-context.js +0 -290
  796. package/dist/server/request-context.js.map +0 -1
  797. package/dist/server/root-layout.d.ts +0 -4
  798. package/dist/server/root-layout.d.ts.map +0 -1
  799. package/dist/server/root-layout.js +0 -5
  800. package/dist/server/root-layout.js.map +0 -1
  801. package/dist/server.d.ts +0 -15
  802. package/dist/server.d.ts.map +0 -1
  803. package/dist/server.js +0 -20
  804. package/dist/server.js.map +0 -1
  805. package/dist/ssr/__tests__/ssr-handler.test.d.ts +0 -2
  806. package/dist/ssr/__tests__/ssr-handler.test.d.ts.map +0 -1
  807. package/dist/ssr/__tests__/ssr-handler.test.js +0 -132
  808. package/dist/ssr/__tests__/ssr-handler.test.js.map +0 -1
  809. package/dist/ssr/index.d.ts +0 -98
  810. package/dist/ssr/index.d.ts.map +0 -1
  811. package/dist/ssr/index.js +0 -158
  812. package/dist/ssr/index.js.map +0 -1
  813. package/dist/static-handler.d.ts +0 -50
  814. package/dist/static-handler.d.ts.map +0 -1
  815. package/dist/static-handler.gen.d.ts +0 -5
  816. package/dist/static-handler.gen.d.ts.map +0 -1
  817. package/dist/static-handler.gen.js +0 -5
  818. package/dist/static-handler.gen.js.map +0 -1
  819. package/dist/static-handler.js +0 -29
  820. package/dist/static-handler.js.map +0 -1
  821. package/dist/theme/ThemeProvider.d.ts +0 -20
  822. package/dist/theme/ThemeProvider.d.ts.map +0 -1
  823. package/dist/theme/ThemeProvider.js +0 -240
  824. package/dist/theme/ThemeProvider.js.map +0 -1
  825. package/dist/theme/ThemeScript.d.ts +0 -48
  826. package/dist/theme/ThemeScript.d.ts.map +0 -1
  827. package/dist/theme/ThemeScript.js +0 -13
  828. package/dist/theme/ThemeScript.js.map +0 -1
  829. package/dist/theme/__tests__/theme.test.d.ts +0 -2
  830. package/dist/theme/__tests__/theme.test.d.ts.map +0 -1
  831. package/dist/theme/__tests__/theme.test.js +0 -103
  832. package/dist/theme/__tests__/theme.test.js.map +0 -1
  833. package/dist/theme/constants.d.ts +0 -29
  834. package/dist/theme/constants.d.ts.map +0 -1
  835. package/dist/theme/constants.js +0 -48
  836. package/dist/theme/constants.js.map +0 -1
  837. package/dist/theme/index.d.ts +0 -31
  838. package/dist/theme/index.d.ts.map +0 -1
  839. package/dist/theme/index.js +0 -36
  840. package/dist/theme/index.js.map +0 -1
  841. package/dist/theme/theme-context.d.ts +0 -40
  842. package/dist/theme/theme-context.d.ts.map +0 -1
  843. package/dist/theme/theme-context.js +0 -60
  844. package/dist/theme/theme-context.js.map +0 -1
  845. package/dist/theme/theme-script.d.ts +0 -27
  846. package/dist/theme/theme-script.d.ts.map +0 -1
  847. package/dist/theme/theme-script.js +0 -147
  848. package/dist/theme/theme-script.js.map +0 -1
  849. package/dist/theme/types.d.ts +0 -163
  850. package/dist/theme/types.d.ts.map +0 -1
  851. package/dist/theme/types.js +0 -11
  852. package/dist/theme/types.js.map +0 -1
  853. package/dist/theme/use-theme.d.ts +0 -12
  854. package/dist/theme/use-theme.d.ts.map +0 -1
  855. package/dist/theme/use-theme.js +0 -40
  856. package/dist/theme/use-theme.js.map +0 -1
  857. package/dist/types.d.ts +0 -1479
  858. package/dist/types.d.ts.map +0 -1
  859. package/dist/types.js +0 -10
  860. package/dist/types.js.map +0 -1
  861. package/dist/urls.d.ts +0 -441
  862. package/dist/urls.d.ts.map +0 -1
  863. package/dist/urls.gen.d.ts +0 -8
  864. package/dist/urls.gen.d.ts.map +0 -1
  865. package/dist/urls.gen.js +0 -8
  866. package/dist/urls.gen.js.map +0 -1
  867. package/dist/urls.js +0 -443
  868. package/dist/urls.js.map +0 -1
  869. package/dist/use-loader.d.ts +0 -127
  870. package/dist/use-loader.d.ts.map +0 -1
  871. package/dist/use-loader.js +0 -237
  872. package/dist/use-loader.js.map +0 -1
  873. package/dist/vite/__tests__/ast-handler-extract.test.d.ts +0 -2
  874. package/dist/vite/__tests__/ast-handler-extract.test.d.ts.map +0 -1
  875. package/dist/vite/__tests__/ast-handler-extract.test.js +0 -294
  876. package/dist/vite/__tests__/ast-handler-extract.test.js.map +0 -1
  877. package/dist/vite/__tests__/expose-id-utils.test.d.ts +0 -2
  878. package/dist/vite/__tests__/expose-id-utils.test.d.ts.map +0 -1
  879. package/dist/vite/__tests__/expose-id-utils.test.js +0 -224
  880. package/dist/vite/__tests__/expose-id-utils.test.js.map +0 -1
  881. package/dist/vite/__tests__/expose-internal-ids.test.d.ts +0 -2
  882. package/dist/vite/__tests__/expose-internal-ids.test.d.ts.map +0 -1
  883. package/dist/vite/__tests__/expose-internal-ids.test.js +0 -647
  884. package/dist/vite/__tests__/expose-internal-ids.test.js.map +0 -1
  885. package/dist/vite/__tests__/expose-router-id.test.d.ts +0 -2
  886. package/dist/vite/__tests__/expose-router-id.test.d.ts.map +0 -1
  887. package/dist/vite/__tests__/expose-router-id.test.js +0 -39
  888. package/dist/vite/__tests__/expose-router-id.test.js.map +0 -1
  889. package/dist/vite/ast-handler-extract.d.ts +0 -49
  890. package/dist/vite/ast-handler-extract.d.ts.map +0 -1
  891. package/dist/vite/ast-handler-extract.js +0 -249
  892. package/dist/vite/ast-handler-extract.js.map +0 -1
  893. package/dist/vite/expose-action-id.d.ts +0 -19
  894. package/dist/vite/expose-action-id.d.ts.map +0 -1
  895. package/dist/vite/expose-action-id.js +0 -250
  896. package/dist/vite/expose-action-id.js.map +0 -1
  897. package/dist/vite/expose-id-utils.d.ts +0 -69
  898. package/dist/vite/expose-id-utils.d.ts.map +0 -1
  899. package/dist/vite/expose-id-utils.js +0 -289
  900. package/dist/vite/expose-id-utils.js.map +0 -1
  901. package/dist/vite/expose-internal-ids.d.ts +0 -22
  902. package/dist/vite/expose-internal-ids.d.ts.map +0 -1
  903. package/dist/vite/expose-internal-ids.js +0 -886
  904. package/dist/vite/expose-internal-ids.js.map +0 -1
  905. package/dist/vite/index.d.ts +0 -149
  906. package/dist/vite/index.d.ts.map +0 -1
  907. package/dist/vite/index.js.map +0 -1
  908. package/dist/vite/index.named-routes.gen.ts +0 -103
  909. package/dist/vite/package-resolution.d.ts +0 -43
  910. package/dist/vite/package-resolution.d.ts.map +0 -1
  911. package/dist/vite/package-resolution.js +0 -112
  912. package/dist/vite/package-resolution.js.map +0 -1
  913. package/dist/vite/virtual-entries.d.ts +0 -25
  914. package/dist/vite/virtual-entries.d.ts.map +0 -1
  915. package/dist/vite/virtual-entries.js +0 -110
  916. package/dist/vite/virtual-entries.js.map +0 -1
@@ -8,7 +8,13 @@ import type { HandlerContext, InternalHandlerContext } from "../types";
8
8
  import { _getRequestContext } from "../server/request-context.js";
9
9
  import { getSearchSchema, isRouteRootScoped } from "../route-map-builder.js";
10
10
  import { parseSearchParams, serializeSearchParams } from "../search-params.js";
11
- import { contextGet, contextSet } from "../context-var.js";
11
+ import {
12
+ contextGet,
13
+ contextSet,
14
+ isNonCacheable,
15
+ type ContextSetOptions,
16
+ } from "../context-var.js";
17
+ import { isInsideCacheScope } from "../server/context.js";
12
18
  import { NOCACHE_SYMBOL, assertNotInsideCacheExec } from "../cache/taint.js";
13
19
  import { isAutoGeneratedRouteName } from "../route-name.js";
14
20
  import { PRERENDER_PASSTHROUGH } from "../prerender.js";
@@ -108,9 +114,9 @@ function createPrerenderPassthroughFn(
108
114
  }
109
115
  if (!isPassthroughRoute) {
110
116
  throw new Error(
111
- "ctx.passthrough() is only available on routes declared with " +
112
- "{ passthrough: true }. Remove the passthrough() call or add " +
113
- "{ passthrough: true } to the Prerender options.",
117
+ "ctx.passthrough() is only available on routes wrapped with " +
118
+ "Passthrough(). Remove the passthrough() call or wrap the " +
119
+ "Prerender definition with Passthrough(prerenderDef, liveHandler).",
114
120
  );
115
121
  }
116
122
  return PRERENDER_PASSTHROUGH;
@@ -160,9 +166,24 @@ export function createReverseFunction(
160
166
  : hrefParams;
161
167
 
162
168
  // Substitute params (strip constraint and optional syntax: :param(a|b)? -> value)
169
+ // Optional params (:param?) are omitted when not provided
163
170
  if (effectiveParams) {
171
+ let hadOmittedOptional = false;
172
+ // First pass: optional params (trailing ?)
164
173
  result = result.replace(
165
- /:([a-zA-Z_][a-zA-Z0-9_]*)(\([^)]*\))?\??/g,
174
+ /:([a-zA-Z_][a-zA-Z0-9_]*)(\([^)]*\))?(\?)/g,
175
+ (_, key) => {
176
+ const value = effectiveParams[key];
177
+ if (value === undefined) {
178
+ hadOmittedOptional = true;
179
+ return "";
180
+ }
181
+ return encodeURIComponent(value);
182
+ },
183
+ );
184
+ // Second pass: required params (no trailing ?)
185
+ result = result.replace(
186
+ /:([a-zA-Z_][a-zA-Z0-9_]*)(\([^)]*\))?(?!\?)/g,
166
187
  (_, key) => {
167
188
  const value = effectiveParams[key];
168
189
  if (value === undefined) {
@@ -171,6 +192,13 @@ export function createReverseFunction(
171
192
  return encodeURIComponent(value);
172
193
  },
173
194
  );
195
+ // Clean up slashes only when an optional param was actually omitted,
196
+ // so intentional trailing-slash patterns like "/blog/" are preserved.
197
+ if (hadOmittedOptional) {
198
+ const hadTrailingSlash = pattern.length > 1 && pattern.endsWith("/");
199
+ result = result.replace(/\/\/+/g, "/").replace(/\/+$/, "") || "/";
200
+ if (hadTrailingSlash && !result.endsWith("/")) result += "/";
201
+ }
174
202
  }
175
203
 
176
204
  // Append search params as query string
@@ -201,7 +229,7 @@ export function createHandlerContext<TEnv>(
201
229
  // Get variables from request context - this is the unified context
202
230
  // shared between middleware and route handlers
203
231
  const requestContext = _getRequestContext();
204
- const variables: any = requestContext?.var ?? {};
232
+ const variables: any = requestContext?._variables ?? {};
205
233
 
206
234
  // If route has a search schema, parse URLSearchParams into typed object
207
235
  const searchSchema = routeName ? getSearchSchema(routeName) : undefined;
@@ -213,7 +241,7 @@ export function createHandlerContext<TEnv>(
213
241
  const stubResponse =
214
242
  requestContext?.res ?? new Response(null, { status: 200 });
215
243
 
216
- // Guard mutating Headers methods so they throw inside "use cache" functions.
244
+ // Guard mutating Headers methods so they throw inside "use cache" or cache() scope.
217
245
  // Uses lazy `ctx` reference (assigned below) — only the specific handler ctx
218
246
  // is stamped by cache-runtime, not the shared request context.
219
247
  const MUTATING_HEADERS_METHODS = new Set(["set", "append", "delete"]);
@@ -225,6 +253,13 @@ export function createHandlerContext<TEnv>(
225
253
  if (MUTATING_HEADERS_METHODS.has(prop as string)) {
226
254
  return (...args: any[]) => {
227
255
  assertNotInsideCacheExec(ctx, "headers");
256
+ if (isInsideCacheScope()) {
257
+ throw new Error(
258
+ `ctx.headers.${String(prop)}() cannot be called inside a cache() boundary. ` +
259
+ `On cache hit the handler is skipped, so this side effect would be lost. ` +
260
+ `Move header mutations to a middleware or layout outside the cache() scope.`,
261
+ );
262
+ }
228
263
  return value.apply(target, args);
229
264
  };
230
265
  }
@@ -237,6 +272,7 @@ export function createHandlerContext<TEnv>(
237
272
  ctx = {
238
273
  params,
239
274
  build: false,
275
+ dev: false,
240
276
  request,
241
277
  searchParams,
242
278
  search: searchSchema ? resolvedSearchParams : {},
@@ -244,14 +280,24 @@ export function createHandlerContext<TEnv>(
244
280
  url,
245
281
  originalUrl: new URL(request.url),
246
282
  env: bindings,
247
- var: variables,
248
- get: ((keyOrVar: any) => contextGet(variables, keyOrVar)) as HandlerContext<
249
- any,
250
- TEnv
251
- >["get"],
252
- set: ((keyOrVar: any, value: any) => {
283
+ _variables: variables,
284
+ get: ((keyOrVar: any) => {
285
+ // Read-time guard: non-cacheable var inside cache() → throw.
286
+ // Works for both ContextVar tokens and string keys.
287
+ if (isNonCacheable(variables, keyOrVar) && isInsideCacheScope()) {
288
+ throw new Error(
289
+ `ctx.get() for a non-cacheable variable cannot be called inside a cache() boundary. ` +
290
+ `The variable was created with { cache: false } or set with { cache: false }, ` +
291
+ `and its value would be stale on cache hit. Move the read outside the cached scope.`,
292
+ );
293
+ }
294
+ return contextGet(variables, keyOrVar);
295
+ }) as HandlerContext<any, TEnv>["get"],
296
+ set: ((keyOrVar: any, value: any, options?: ContextSetOptions) => {
253
297
  assertNotInsideCacheExec(ctx, "set");
254
- contextSet(variables, keyOrVar, value);
298
+ // Write is dumb: store value + non-cacheable metadata.
299
+ // Enforcement happens at read time via ctx.get().
300
+ contextSet(variables, keyOrVar, value, options);
255
301
  }) as HandlerContext<any, TEnv>["set"],
256
302
  res: stubResponse, // Stub response for setting headers
257
303
  headers: guardedHeaders, // Guarded shorthand for res.headers
@@ -297,7 +343,7 @@ export function createHandlerContext<TEnv>(
297
343
  *
298
344
  * Returns an InternalHandlerContext where params, pathname, url, searchParams,
299
345
  * search, reverse, and use(handle) work. Request-time properties
300
- * (request, env, headers, cookies, var, get, set, res) throw with a clear error.
346
+ * (request, env, headers, cookies, get, set, res) throw with a clear error.
301
347
  */
302
348
  export function createPrerenderContext<TEnv>(
303
349
  params: Record<string, string>,
@@ -306,6 +352,8 @@ export function createPrerenderContext<TEnv>(
306
352
  routeName?: string,
307
353
  buildVars?: Record<string, any>,
308
354
  isPassthroughRoute?: boolean,
355
+ buildEnv?: TEnv,
356
+ devMode?: boolean,
309
357
  ): InternalHandlerContext<any, TEnv> {
310
358
  const syntheticUrl = new URL(`http://prerender${pathname}`);
311
359
  const variables = buildVars ?? {};
@@ -320,6 +368,7 @@ export function createPrerenderContext<TEnv>(
320
368
  return {
321
369
  params,
322
370
  build: true,
371
+ dev: devMode ?? false,
323
372
  get request(): Request {
324
373
  return throwUnavailable("request");
325
374
  },
@@ -329,11 +378,13 @@ export function createPrerenderContext<TEnv>(
329
378
  url: syntheticUrl,
330
379
  originalUrl: syntheticUrl,
331
380
  get env(): TEnv {
332
- return throwUnavailable("env");
333
- },
334
- get var(): any {
335
- return throwUnavailable("var");
381
+ if (buildEnv !== undefined) return buildEnv;
382
+ throw new Error(
383
+ "ctx.env is not available during pre-rendering. " +
384
+ "Configure buildEnv in your rango() plugin options to enable build-time env access.",
385
+ );
336
386
  },
387
+ _variables: variables,
337
388
  get: ((keyOrVar: any) => contextGet(variables, keyOrVar)) as any,
338
389
  set: ((keyOrVar: any, value: any) => {
339
390
  contextSet(variables, keyOrVar, value);
@@ -379,6 +430,8 @@ export function createPrerenderContext<TEnv>(
379
430
  export function createStaticContext<TEnv>(
380
431
  routeMap: Record<string, string>,
381
432
  routeName?: string,
433
+ buildEnv?: TEnv,
434
+ devMode?: boolean,
382
435
  ): InternalHandlerContext<any, TEnv> {
383
436
  const variables: Record<string, any> = {};
384
437
 
@@ -394,6 +447,7 @@ export function createStaticContext<TEnv>(
394
447
  return throwUnavailable("params");
395
448
  },
396
449
  build: true,
450
+ dev: devMode ?? false,
397
451
  get request(): Request {
398
452
  return throwUnavailable("request");
399
453
  },
@@ -413,11 +467,13 @@ export function createStaticContext<TEnv>(
413
467
  return throwUnavailable("originalUrl");
414
468
  },
415
469
  get env(): TEnv {
416
- return throwUnavailable("env");
417
- },
418
- get var(): any {
419
- return throwUnavailable("var");
470
+ if (buildEnv !== undefined) return buildEnv;
471
+ throw new Error(
472
+ "ctx.env is not available in Static() handlers. " +
473
+ "Configure buildEnv in your rango() plugin options to enable build-time env access.",
474
+ );
420
475
  },
476
+ _variables: variables,
421
477
  get: ((keyOrVar: any) => contextGet(variables, keyOrVar)) as any,
422
478
  set: ((keyOrVar: any, value: any) => {
423
479
  contextSet(variables, keyOrVar, value);
@@ -11,7 +11,11 @@ import type {
11
11
  InterceptEntry,
12
12
  InterceptSelectorContext,
13
13
  } from "../server/context";
14
- import type { HandlerContext, ResolvedSegment } from "../types";
14
+ import type {
15
+ HandlerContext,
16
+ InternalHandlerContext,
17
+ ResolvedSegment,
18
+ } from "../types";
15
19
  import { evaluateRevalidation } from "./revalidation.js";
16
20
  import { getRequestContext } from "../server/request-context.js";
17
21
  import { executeInterceptMiddleware } from "./middleware.js";
@@ -20,6 +24,7 @@ import { getGlobalRouteMap } from "../route-map-builder.js";
20
24
  import { handleHandlerResult } from "./segment-resolution.js";
21
25
  import type { SegmentResolutionDeps } from "./types.js";
22
26
  import { debugLog } from "./logging.js";
27
+ import { runInsideLoaderScope } from "../server/context.js";
23
28
 
24
29
  /**
25
30
  * Check if an intercept's when conditions are satisfied.
@@ -133,7 +138,7 @@ export async function resolveInterceptEntry<TEnv>(
133
138
  context.request,
134
139
  context.env,
135
140
  params,
136
- context.var as Record<string, any>,
141
+ (context as InternalHandlerContext<any, TEnv>)._variables,
137
142
  requestCtx.res,
138
143
  createReverseFunction(getGlobalRouteMap()),
139
144
  );
@@ -207,7 +212,7 @@ export async function resolveInterceptEntry<TEnv>(
207
212
  loaderIds.push(loader.$$id);
208
213
  loaderPromises.push(
209
214
  deps.wrapLoaderPromise(
210
- context.use(loader),
215
+ runInsideLoaderScope(() => context.use(loader)),
211
216
  parentEntry,
212
217
  segmentId,
213
218
  context.pathname,
@@ -374,7 +379,7 @@ export async function resolveInterceptLoadersOnly<TEnv>(
374
379
  loaderIds.push(loader.$$id);
375
380
  loaderPromises.push(
376
381
  deps.wrapLoaderPromise(
377
- context.use(loader),
382
+ runInsideLoaderScope(() => context.use(loader)),
378
383
  parentEntry,
379
384
  segmentId,
380
385
  context.pathname,
@@ -7,6 +7,7 @@
7
7
  import type { ReactNode } from "react";
8
8
  import { track } from "../server/context";
9
9
  import type { EntryData } from "../server/context";
10
+ import { contextGet } from "../context-var.js";
10
11
  import type {
11
12
  ResolvedSegment,
12
13
  HandlerContext,
@@ -19,10 +20,11 @@ import type {
19
20
  ErrorInfo,
20
21
  } from "../types";
21
22
  import type { LoaderRevalidationResult, ActionContext } from "./types";
22
- import { isHandle, type Handle } from "../handle.js";
23
- import type { HandleStore } from "../server/handle-store.js";
23
+ import { isHandle, collectHandleData, type Handle } from "../handle.js";
24
+ import type { HandleStore, HandleData } from "../server/handle-store.js";
24
25
  import { getFetchableLoader } from "../server/fetchable-loader-store.js";
25
26
  import { _getRequestContext } from "../server/request-context.js";
27
+ import { isInsideLoaderScope } from "../server/context.js";
26
28
  import { debugLog } from "./logging.js";
27
29
 
28
30
  /**
@@ -241,6 +243,21 @@ function createLoaderExecutor<TEnv>(
241
243
  pendingLoaders.add(loader.$$id);
242
244
 
243
245
  const currentLoaderId = loader.$$id;
246
+ const variables = (ctx as InternalHandlerContext<any, TEnv>)._variables;
247
+
248
+ // Capture whether this loader is being started from a DSL loader scope
249
+ // (runInsideLoaderScope in fresh.ts). Handler-invoked loaders are NOT
250
+ // inside loader scope. This determines whether rendered() is allowed.
251
+ const isDslLoader = isInsideLoaderScope();
252
+
253
+ let renderedResolved = false;
254
+ let renderedPromise: Promise<void> | null = null;
255
+
256
+ // Loader functions are always fresh (never cached), so they get an
257
+ // unguarded get that bypasses non-cacheable read guards. This applies
258
+ // to ALL loaders — DSL and handler-called — because the loader
259
+ // function itself always re-executes. Also handles nested deps
260
+ // (loaderA → use(loaderB)) since all share this unguarded get.
244
261
  const loaderCtx: LoaderContext<Record<string, string | undefined>, TEnv> = {
245
262
  params: ctx.params,
246
263
  routeParams: (ctx.params ?? {}) as Record<string, string>,
@@ -250,16 +267,76 @@ function createLoaderExecutor<TEnv>(
250
267
  pathname: ctx.pathname,
251
268
  url: ctx.url,
252
269
  env: ctx.env,
253
- var: ctx.var,
254
- get: ctx.get,
255
- use: <TDep, TDepParams = any>(
256
- dep: LoaderDefinition<TDep, TDepParams>,
257
- ): Promise<TDep> => {
258
- return useLoader(dep, currentLoaderId);
259
- },
270
+ get: ((keyOrVar: any) =>
271
+ contextGet(variables, keyOrVar)) as typeof ctx.get,
272
+ use: ((item: LoaderDefinition<any, any> | Handle<any, any>) => {
273
+ if (isHandle(item)) {
274
+ if (!renderedResolved) {
275
+ throw new Error(
276
+ `ctx.use(handle) in a loader requires "await ctx.rendered()" first. ` +
277
+ `Handle "${item.$$id}" cannot be read until the render tree has settled.`,
278
+ );
279
+ }
280
+ const reqCtx = reqCtxRef ?? _getRequestContext();
281
+ if (!reqCtx) {
282
+ throw new Error(
283
+ `ctx.use(handle) failed: request context not available.`,
284
+ );
285
+ }
286
+ const segmentOrder = reqCtx._renderBarrierSegmentOrder ?? [];
287
+ const snapshot = buildHandleSnapshot(
288
+ reqCtx._handleStore,
289
+ segmentOrder,
290
+ );
291
+ return collectHandleData(item, snapshot, segmentOrder);
292
+ }
293
+
294
+ // Loader case
295
+ return useLoader(item as LoaderDefinition<any, any>, currentLoaderId);
296
+ }) as LoaderContext["use"],
260
297
  method: "GET",
261
298
  body: undefined,
262
299
  reverse: ctx.reverse as LoaderContext["reverse"],
300
+ rendered: (): Promise<void> => {
301
+ // Guard: only DSL loaders may use rendered()
302
+ if (!isDslLoader) {
303
+ throw new Error(
304
+ `ctx.rendered() is only available in DSL loaders (registered via loader() in urls()). ` +
305
+ `Handler-invoked loaders (ctx.use(Loader) inside a handler) cannot use rendered().`,
306
+ );
307
+ }
308
+
309
+ // Guard: reject streaming trees
310
+ const reqCtx = reqCtxRef ?? _getRequestContext();
311
+ if (reqCtx?._treeHasStreaming) {
312
+ throw new Error(
313
+ `ctx.rendered() is not supported when the matched route tree uses loading(). ` +
314
+ `Streaming handlers may not have settled when rendered() resolves. ` +
315
+ `Remove loading() from the route tree or restructure to avoid rendered().`,
316
+ );
317
+ }
318
+
319
+ if (renderedPromise) return renderedPromise;
320
+
321
+ if (!reqCtx) {
322
+ throw new Error(
323
+ `ctx.rendered() failed: request context not available.`,
324
+ );
325
+ }
326
+
327
+ // Register this loader as waiting for the barrier so that
328
+ // setupLoaderAccess can detect deadlocks when a handler
329
+ // tries to await the same loader via ctx.use().
330
+ if (!reqCtx._renderBarrierWaiters) {
331
+ reqCtx._renderBarrierWaiters = new Set();
332
+ }
333
+ reqCtx._renderBarrierWaiters.add(currentLoaderId);
334
+
335
+ renderedPromise = reqCtx._renderBarrier.then(() => {
336
+ renderedResolved = true;
337
+ });
338
+ return renderedPromise;
339
+ },
263
340
  };
264
341
 
265
342
  const doneLoader = track(`loader:${loader.$$id}`, 2);
@@ -277,6 +354,25 @@ function createLoaderExecutor<TEnv>(
277
354
  return useLoader;
278
355
  }
279
356
 
357
+ /**
358
+ * Build a HandleData snapshot from the HandleStore using segment ordering.
359
+ * Reads data directly from the store for each segment in order.
360
+ */
361
+ function buildHandleSnapshot(
362
+ handleStore: HandleStore,
363
+ segmentOrder: string[],
364
+ ): HandleData {
365
+ const data: HandleData = {};
366
+ for (const segmentId of segmentOrder) {
367
+ const segData = handleStore.getDataForSegment(segmentId);
368
+ for (const handleName in segData) {
369
+ if (!data[handleName]) data[handleName] = {};
370
+ data[handleName][segmentId] = segData[handleName];
371
+ }
372
+ }
373
+ return data;
374
+ }
375
+
280
376
  /**
281
377
  * Set up the use() method on handler context to access loaders and handles.
282
378
  *
@@ -327,7 +423,23 @@ export function setupLoaderAccess<TEnv>(
327
423
  };
328
424
  }
329
425
 
330
- return useLoader(item as LoaderDefinition<any, any>, null);
426
+ // Deadlock guard: if a HANDLER awaits a loader that called rendered(),
427
+ // the handler blocks segment resolution which blocks the barrier.
428
+ // Skip this check when inside a DSL loader scope (resolveLoaderData
429
+ // also calls ctx.use() but that's DSL-to-DSL, not handler-to-loader).
430
+ const loader = item as LoaderDefinition<any, any>;
431
+ if (loaderPromises.has(loader.$$id) && !isInsideLoaderScope()) {
432
+ const reqCtx = _getRequestContext();
433
+ if (reqCtx?._renderBarrierWaiters?.has(loader.$$id)) {
434
+ throw new Error(
435
+ `Deadlock: handler is awaiting loader "${loader.$$id}" which called ctx.rendered(). ` +
436
+ `The loader is waiting for segment resolution, but the handler blocks resolution. ` +
437
+ `Move the data dependency to a loader-to-loader pattern instead.`,
438
+ );
439
+ }
440
+ }
441
+
442
+ return useLoader(loader, null);
331
443
  }) as typeof ctx.use;
332
444
  }
333
445