@rocicorp/zero 1.6.0-canary.1 → 1.6.0-canary.10

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 (1772) hide show
  1. package/README.md +28 -3
  2. package/out/_virtual/_@oxc-project_runtime@0.130.0/helpers/usingCtx.js +57 -0
  3. package/out/_virtual/__vite-optional-peer-dep_pg-native_pg.js +13 -0
  4. package/out/_virtual/__vite-optional-peer-dep_pg-native_pg.js.map +1 -0
  5. package/out/_virtual/_rolldown/runtime.js +12 -1
  6. package/out/node_modules/.pnpm/@opentelemetry_semantic-conventions@1.41.1/node_modules/@opentelemetry/semantic-conventions/build/esm/stable_attributes.js +12 -0
  7. package/out/node_modules/.pnpm/@opentelemetry_semantic-conventions@1.41.1/node_modules/@opentelemetry/semantic-conventions/build/esm/stable_attributes.js.map +1 -0
  8. package/out/node_modules/.pnpm/pg-cloudflare@1.3.0/node_modules/pg-cloudflare/dist/empty.js +11 -0
  9. package/out/node_modules/.pnpm/pg-cloudflare@1.3.0/node_modules/pg-cloudflare/dist/empty.js.map +1 -0
  10. package/out/node_modules/.pnpm/pg-connection-string@2.12.0/node_modules/pg-connection-string/index.js +130 -0
  11. package/out/node_modules/.pnpm/pg-connection-string@2.12.0/node_modules/pg-connection-string/index.js.map +1 -0
  12. package/out/node_modules/.pnpm/pg-int8@1.0.1/node_modules/pg-int8/index.js +62 -0
  13. package/out/node_modules/.pnpm/pg-int8@1.0.1/node_modules/pg-int8/index.js.map +1 -0
  14. package/out/node_modules/.pnpm/pg-pool@3.13.0_pg@8.20.0/node_modules/pg-pool/index.js +353 -0
  15. package/out/node_modules/.pnpm/pg-pool@3.13.0_pg@8.20.0/node_modules/pg-pool/index.js.map +1 -0
  16. package/out/node_modules/.pnpm/pg-protocol@1.13.0/node_modules/pg-protocol/dist/buffer-reader.js +60 -0
  17. package/out/node_modules/.pnpm/pg-protocol@1.13.0/node_modules/pg-protocol/dist/buffer-reader.js.map +1 -0
  18. package/out/node_modules/.pnpm/pg-protocol@1.13.0/node_modules/pg-protocol/dist/buffer-writer.js +81 -0
  19. package/out/node_modules/.pnpm/pg-protocol@1.13.0/node_modules/pg-protocol/dist/buffer-writer.js.map +1 -0
  20. package/out/node_modules/.pnpm/pg-protocol@1.13.0/node_modules/pg-protocol/dist/index.js +35 -0
  21. package/out/node_modules/.pnpm/pg-protocol@1.13.0/node_modules/pg-protocol/dist/index.js.map +1 -0
  22. package/out/node_modules/.pnpm/pg-protocol@1.13.0/node_modules/pg-protocol/dist/messages.js +167 -0
  23. package/out/node_modules/.pnpm/pg-protocol@1.13.0/node_modules/pg-protocol/dist/messages.js.map +1 -0
  24. package/out/node_modules/.pnpm/pg-protocol@1.13.0/node_modules/pg-protocol/dist/parser.js +288 -0
  25. package/out/node_modules/.pnpm/pg-protocol@1.13.0/node_modules/pg-protocol/dist/parser.js.map +1 -0
  26. package/out/node_modules/.pnpm/pg-protocol@1.13.0/node_modules/pg-protocol/dist/serializer.js +177 -0
  27. package/out/node_modules/.pnpm/pg-protocol@1.13.0/node_modules/pg-protocol/dist/serializer.js.map +1 -0
  28. package/out/node_modules/.pnpm/pg-types@2.2.0/node_modules/pg-types/index.js +46 -0
  29. package/out/node_modules/.pnpm/pg-types@2.2.0/node_modules/pg-types/index.js.map +1 -0
  30. package/out/node_modules/.pnpm/pg-types@2.2.0/node_modules/pg-types/lib/arrayParser.js +16 -0
  31. package/out/node_modules/.pnpm/pg-types@2.2.0/node_modules/pg-types/lib/arrayParser.js.map +1 -0
  32. package/out/node_modules/.pnpm/pg-types@2.2.0/node_modules/pg-types/lib/binaryParsers.js +165 -0
  33. package/out/node_modules/.pnpm/pg-types@2.2.0/node_modules/pg-types/lib/binaryParsers.js.map +1 -0
  34. package/out/node_modules/.pnpm/pg-types@2.2.0/node_modules/pg-types/lib/builtins.js +81 -0
  35. package/out/node_modules/.pnpm/pg-types@2.2.0/node_modules/pg-types/lib/builtins.js.map +1 -0
  36. package/out/node_modules/.pnpm/pg-types@2.2.0/node_modules/pg-types/lib/textParsers.js +167 -0
  37. package/out/node_modules/.pnpm/pg-types@2.2.0/node_modules/pg-types/lib/textParsers.js.map +1 -0
  38. package/out/node_modules/.pnpm/pg@8.20.0/node_modules/pg/esm/index.js +19 -0
  39. package/out/node_modules/.pnpm/pg@8.20.0/node_modules/pg/esm/index.js.map +1 -0
  40. package/out/node_modules/.pnpm/pg@8.20.0/node_modules/pg/lib/client.js +508 -0
  41. package/out/node_modules/.pnpm/pg@8.20.0/node_modules/pg/lib/client.js.map +1 -0
  42. package/out/node_modules/.pnpm/pg@8.20.0/node_modules/pg/lib/connection-parameters.js +104 -0
  43. package/out/node_modules/.pnpm/pg@8.20.0/node_modules/pg/lib/connection-parameters.js.map +1 -0
  44. package/out/node_modules/.pnpm/pg@8.20.0/node_modules/pg/lib/connection.js +160 -0
  45. package/out/node_modules/.pnpm/pg@8.20.0/node_modules/pg/lib/connection.js.map +1 -0
  46. package/out/node_modules/.pnpm/pg@8.20.0/node_modules/pg/lib/crypto/cert-signatures.js +97 -0
  47. package/out/node_modules/.pnpm/pg@8.20.0/node_modules/pg/lib/crypto/cert-signatures.js.map +1 -0
  48. package/out/node_modules/.pnpm/pg@8.20.0/node_modules/pg/lib/crypto/sasl.js +131 -0
  49. package/out/node_modules/.pnpm/pg@8.20.0/node_modules/pg/lib/crypto/sasl.js.map +1 -0
  50. package/out/node_modules/.pnpm/pg@8.20.0/node_modules/pg/lib/crypto/utils-legacy.js +39 -0
  51. package/out/node_modules/.pnpm/pg@8.20.0/node_modules/pg/lib/crypto/utils-legacy.js.map +1 -0
  52. package/out/node_modules/.pnpm/pg@8.20.0/node_modules/pg/lib/crypto/utils-webcrypto.js +89 -0
  53. package/out/node_modules/.pnpm/pg@8.20.0/node_modules/pg/lib/crypto/utils-webcrypto.js.map +1 -0
  54. package/out/node_modules/.pnpm/pg@8.20.0/node_modules/pg/lib/crypto/utils.js +13 -0
  55. package/out/node_modules/.pnpm/pg@8.20.0/node_modules/pg/lib/crypto/utils.js.map +1 -0
  56. package/out/node_modules/.pnpm/pg@8.20.0/node_modules/pg/lib/defaults.js +46 -0
  57. package/out/node_modules/.pnpm/pg@8.20.0/node_modules/pg/lib/defaults.js.map +1 -0
  58. package/out/node_modules/.pnpm/pg@8.20.0/node_modules/pg/lib/index.js +71 -0
  59. package/out/node_modules/.pnpm/pg@8.20.0/node_modules/pg/lib/index.js.map +1 -0
  60. package/out/node_modules/.pnpm/pg@8.20.0/node_modules/pg/lib/native/client.js +226 -0
  61. package/out/node_modules/.pnpm/pg@8.20.0/node_modules/pg/lib/native/client.js.map +1 -0
  62. package/out/node_modules/.pnpm/pg@8.20.0/node_modules/pg/lib/native/index.js +11 -0
  63. package/out/node_modules/.pnpm/pg@8.20.0/node_modules/pg/lib/native/index.js.map +1 -0
  64. package/out/node_modules/.pnpm/pg@8.20.0/node_modules/pg/lib/native/query.js +117 -0
  65. package/out/node_modules/.pnpm/pg@8.20.0/node_modules/pg/lib/native/query.js.map +1 -0
  66. package/out/node_modules/.pnpm/pg@8.20.0/node_modules/pg/lib/query.js +151 -0
  67. package/out/node_modules/.pnpm/pg@8.20.0/node_modules/pg/lib/query.js.map +1 -0
  68. package/out/node_modules/.pnpm/pg@8.20.0/node_modules/pg/lib/result.js +76 -0
  69. package/out/node_modules/.pnpm/pg@8.20.0/node_modules/pg/lib/result.js.map +1 -0
  70. package/out/node_modules/.pnpm/pg@8.20.0/node_modules/pg/lib/stream.js +73 -0
  71. package/out/node_modules/.pnpm/pg@8.20.0/node_modules/pg/lib/stream.js.map +1 -0
  72. package/out/node_modules/.pnpm/pg@8.20.0/node_modules/pg/lib/type-overrides.js +35 -0
  73. package/out/node_modules/.pnpm/pg@8.20.0/node_modules/pg/lib/type-overrides.js.map +1 -0
  74. package/out/node_modules/.pnpm/pg@8.20.0/node_modules/pg/lib/utils.js +118 -0
  75. package/out/node_modules/.pnpm/pg@8.20.0/node_modules/pg/lib/utils.js.map +1 -0
  76. package/out/node_modules/.pnpm/pgpass@1.0.5/node_modules/pgpass/lib/helper.js +147 -0
  77. package/out/node_modules/.pnpm/pgpass@1.0.5/node_modules/pgpass/lib/helper.js.map +1 -0
  78. package/out/node_modules/.pnpm/pgpass@1.0.5/node_modules/pgpass/lib/index.js +21 -0
  79. package/out/node_modules/.pnpm/pgpass@1.0.5/node_modules/pgpass/lib/index.js.map +1 -0
  80. package/out/node_modules/.pnpm/postgres-array@2.0.0/node_modules/postgres-array/index.js +84 -0
  81. package/out/node_modules/.pnpm/postgres-array@2.0.0/node_modules/postgres-array/index.js.map +1 -0
  82. package/out/node_modules/.pnpm/postgres-bytea@1.0.1/node_modules/postgres-bytea/index.js +28 -0
  83. package/out/node_modules/.pnpm/postgres-bytea@1.0.1/node_modules/postgres-bytea/index.js.map +1 -0
  84. package/out/node_modules/.pnpm/postgres-date@1.0.7/node_modules/postgres-date/index.js +65 -0
  85. package/out/node_modules/.pnpm/postgres-date@1.0.7/node_modules/postgres-date/index.js.map +1 -0
  86. package/out/node_modules/.pnpm/postgres-interval@1.2.0/node_modules/postgres-interval/index.js +107 -0
  87. package/out/node_modules/.pnpm/postgres-interval@1.2.0/node_modules/postgres-interval/index.js.map +1 -0
  88. package/out/node_modules/.pnpm/react@18.3.1/node_modules/react/cjs/react-jsx-runtime.development.js +696 -0
  89. package/out/node_modules/.pnpm/react@18.3.1/node_modules/react/cjs/react-jsx-runtime.development.js.map +1 -0
  90. package/out/node_modules/.pnpm/react@18.3.1/node_modules/react/cjs/react-jsx-runtime.production.min.js +44 -0
  91. package/out/node_modules/.pnpm/react@18.3.1/node_modules/react/cjs/react-jsx-runtime.production.min.js.map +1 -0
  92. package/out/node_modules/.pnpm/react@18.3.1/node_modules/react/cjs/react.development.js +1585 -0
  93. package/out/node_modules/.pnpm/react@18.3.1/node_modules/react/cjs/react.development.js.map +1 -0
  94. package/out/node_modules/.pnpm/react@18.3.1/node_modules/react/cjs/react.production.min.js +329 -0
  95. package/out/node_modules/.pnpm/react@18.3.1/node_modules/react/cjs/react.production.min.js.map +1 -0
  96. package/out/node_modules/.pnpm/react@18.3.1/node_modules/react/index.js +13 -0
  97. package/out/node_modules/.pnpm/react@18.3.1/node_modules/react/index.js.map +1 -0
  98. package/out/node_modules/.pnpm/react@18.3.1/node_modules/react/jsx-runtime.js +13 -0
  99. package/out/node_modules/.pnpm/react@18.3.1/node_modules/react/jsx-runtime.js.map +1 -0
  100. package/out/node_modules/.pnpm/solid-js@1.9.13/node_modules/solid-js/dist/server.js +131 -0
  101. package/out/node_modules/.pnpm/solid-js@1.9.13/node_modules/solid-js/dist/server.js.map +1 -0
  102. package/out/node_modules/.pnpm/solid-js@1.9.13/node_modules/solid-js/store/dist/server.js +96 -0
  103. package/out/node_modules/.pnpm/solid-js@1.9.13/node_modules/solid-js/store/dist/server.js.map +1 -0
  104. package/out/node_modules/.pnpm/split2@4.2.0/node_modules/split2/index.js +95 -0
  105. package/out/node_modules/.pnpm/split2@4.2.0/node_modules/split2/index.js.map +1 -0
  106. package/out/node_modules/.pnpm/xtend@4.0.2/node_modules/xtend/mutable.js +18 -0
  107. package/out/node_modules/.pnpm/xtend@4.0.2/node_modules/xtend/mutable.js.map +1 -0
  108. package/out/packages/analyze-query/src/analyze-cli.js.map +1 -0
  109. package/out/packages/analyze-query/src/bin-analyze.js +282 -0
  110. package/out/packages/analyze-query/src/bin-analyze.js.map +1 -0
  111. package/out/packages/analyze-query/src/bin-transform.js.map +1 -0
  112. package/out/packages/ast-to-zql/src/ast-to-zql.js.map +1 -0
  113. package/out/packages/ast-to-zql/src/bin.js.map +1 -0
  114. package/out/packages/ast-to-zql/src/format.js.map +1 -0
  115. package/out/packages/datadog/src/datadog-log-sink.js.map +1 -0
  116. package/out/packages/otel/src/enabled.js.map +1 -0
  117. package/out/packages/otel/src/log-options.js.map +1 -0
  118. package/out/packages/otel/src/maybe-time.js.map +1 -0
  119. package/out/packages/otel/src/span.js.map +1 -0
  120. package/out/packages/otel/src/version.js.map +1 -0
  121. package/out/packages/replicache/src/async-iterable-to-array.js.map +1 -0
  122. package/out/packages/replicache/src/bg-interval.js.map +1 -0
  123. package/out/packages/replicache/src/btree/diff.js.map +1 -0
  124. package/out/packages/replicache/src/btree/node.js.map +1 -0
  125. package/out/packages/replicache/src/btree/read.js.map +1 -0
  126. package/out/packages/replicache/src/btree/splice.js.map +1 -0
  127. package/out/packages/replicache/src/btree/write.js +191 -0
  128. package/out/packages/replicache/src/btree/write.js.map +1 -0
  129. package/out/packages/replicache/src/call-default-fetch.js.map +1 -0
  130. package/out/packages/replicache/src/connection-loop-delegates.js.map +1 -0
  131. package/out/packages/replicache/src/connection-loop.js.map +1 -0
  132. package/out/packages/replicache/src/cookies.js.map +1 -0
  133. package/out/packages/replicache/src/dag/chunk.js.map +1 -0
  134. package/out/packages/replicache/src/dag/gc.js.map +1 -0
  135. package/out/packages/replicache/src/dag/key.js.map +1 -0
  136. package/out/packages/replicache/src/dag/lazy-store.js.map +1 -0
  137. package/out/packages/replicache/src/dag/store-impl.js +157 -0
  138. package/out/packages/replicache/src/dag/store-impl.js.map +1 -0
  139. package/out/packages/replicache/src/dag/store.js.map +1 -0
  140. package/out/packages/replicache/src/dag/visitor.js.map +1 -0
  141. package/out/packages/replicache/src/db/commit.js.map +1 -0
  142. package/out/packages/replicache/src/db/index.js.map +1 -0
  143. package/out/packages/replicache/src/db/read.js.map +1 -0
  144. package/out/packages/replicache/src/db/rebase.js.map +1 -0
  145. package/out/packages/replicache/src/db/write.js.map +1 -0
  146. package/out/packages/replicache/src/deleted-clients.js.map +1 -0
  147. package/out/packages/replicache/src/error-responses.js.map +1 -0
  148. package/out/packages/replicache/src/frozen-json.js.map +1 -0
  149. package/out/packages/replicache/src/get-default-puller.js.map +1 -0
  150. package/out/packages/replicache/src/get-default-pusher.js.map +1 -0
  151. package/out/packages/replicache/src/get-kv-store-provider.js.map +1 -0
  152. package/out/packages/replicache/src/hash.js.map +1 -0
  153. package/out/packages/replicache/src/http-request-info.js.map +1 -0
  154. package/out/packages/replicache/src/index-defs.js.map +1 -0
  155. package/out/packages/replicache/src/kv/expo-sqlite/store.js +57 -0
  156. package/out/packages/replicache/src/kv/expo-sqlite/store.js.map +1 -0
  157. package/out/packages/replicache/src/kv/idb-store-with-mem-fallback.js.map +1 -0
  158. package/out/packages/replicache/src/kv/idb-store.js.map +1 -0
  159. package/out/packages/replicache/src/kv/mem-store.js.map +1 -0
  160. package/out/packages/replicache/src/kv/op-sqlite/store.js +63 -0
  161. package/out/packages/replicache/src/kv/op-sqlite/store.js.map +1 -0
  162. package/out/packages/replicache/src/kv/op-sqlite/types.js.map +1 -0
  163. package/out/packages/replicache/src/kv/read-impl.js.map +1 -0
  164. package/out/packages/replicache/src/kv/sqlite-store.js +301 -0
  165. package/out/packages/replicache/src/kv/sqlite-store.js.map +1 -0
  166. package/out/packages/replicache/src/kv/throw-if-closed.js +23 -0
  167. package/out/packages/replicache/src/kv/throw-if-closed.js.map +1 -0
  168. package/out/packages/replicache/src/kv/write-impl-base.js.map +1 -0
  169. package/out/packages/replicache/src/kv/write-impl.js.map +1 -0
  170. package/out/packages/replicache/src/lazy.js.map +1 -0
  171. package/out/packages/replicache/src/log-options.js.map +1 -0
  172. package/out/packages/replicache/src/make-idb-name.js.map +1 -0
  173. package/out/packages/replicache/src/new-client-channel.js.map +1 -0
  174. package/out/packages/replicache/src/on-persist-channel.js.map +1 -0
  175. package/out/packages/replicache/src/patch-operation.js.map +1 -0
  176. package/out/packages/replicache/src/pending-mutations.js.map +1 -0
  177. package/out/packages/replicache/src/persist/client-gc.js.map +1 -0
  178. package/out/packages/replicache/src/persist/client-group-gc.js.map +1 -0
  179. package/out/packages/replicache/src/persist/client-groups.js +150 -0
  180. package/out/packages/replicache/src/persist/client-groups.js.map +1 -0
  181. package/out/packages/replicache/src/persist/clients.js +289 -0
  182. package/out/packages/replicache/src/persist/clients.js.map +1 -0
  183. package/out/packages/replicache/src/persist/collect-idb-databases.js.map +1 -0
  184. package/out/packages/replicache/src/persist/gather-mem-only-visitor.js.map +1 -0
  185. package/out/packages/replicache/src/persist/gather-not-cached-visitor.js.map +1 -0
  186. package/out/packages/replicache/src/persist/heartbeat.js.map +1 -0
  187. package/out/packages/replicache/src/persist/idb-databases-store-db-name.js.map +1 -0
  188. package/out/packages/replicache/src/persist/idb-databases-store.js.map +1 -0
  189. package/out/packages/replicache/src/persist/make-client-id.js.map +1 -0
  190. package/out/packages/replicache/src/persist/persist.js +124 -0
  191. package/out/packages/replicache/src/persist/persist.js.map +1 -0
  192. package/out/packages/replicache/src/persist/refresh.js.map +1 -0
  193. package/out/packages/replicache/src/process-scheduler.js.map +1 -0
  194. package/out/packages/replicache/src/pusher.js.map +1 -0
  195. package/out/packages/replicache/src/replicache-impl.js.map +1 -0
  196. package/out/packages/replicache/src/report-error.js.map +1 -0
  197. package/out/packages/replicache/src/request-idle.js.map +1 -0
  198. package/out/packages/replicache/src/scan-iterator.js.map +1 -0
  199. package/out/packages/replicache/src/scan-options.js.map +1 -0
  200. package/out/packages/replicache/src/set-interval-with-signal.js.map +1 -0
  201. package/out/packages/replicache/src/subscriptions.js.map +1 -0
  202. package/out/packages/replicache/src/sync/diff.js.map +1 -0
  203. package/out/packages/replicache/src/sync/ids.js.map +1 -0
  204. package/out/packages/replicache/src/sync/patch.js.map +1 -0
  205. package/out/packages/replicache/src/sync/pull-error.js.map +1 -0
  206. package/out/packages/replicache/src/sync/pull.js +169 -0
  207. package/out/packages/replicache/src/sync/pull.js.map +1 -0
  208. package/out/packages/replicache/src/sync/push.js.map +1 -0
  209. package/out/packages/replicache/src/sync/request-id.js.map +1 -0
  210. package/out/packages/replicache/src/sync/sync-head-name.js.map +1 -0
  211. package/out/packages/replicache/src/to-error.js.map +1 -0
  212. package/out/packages/replicache/src/transaction-closed-error.js.map +1 -0
  213. package/out/packages/replicache/src/transactions.js.map +1 -0
  214. package/out/packages/replicache/src/version.js.map +1 -0
  215. package/out/packages/replicache/src/with-transactions.js.map +1 -0
  216. package/out/packages/shared/src/abort-error.js.map +1 -0
  217. package/out/packages/shared/src/arrays.js.map +1 -0
  218. package/out/packages/shared/src/asserts.js.map +1 -0
  219. package/out/packages/shared/src/bigint-json.js.map +1 -0
  220. package/out/packages/shared/src/binary-search.js.map +1 -0
  221. package/out/packages/shared/src/broadcast-channel.js.map +1 -0
  222. package/out/packages/shared/src/browser-env.js.map +1 -0
  223. package/out/packages/shared/src/btree-set.js.map +1 -0
  224. package/out/packages/shared/src/cache.js.map +1 -0
  225. package/out/packages/shared/src/centroid.js.map +1 -0
  226. package/out/packages/shared/src/config.js.map +1 -0
  227. package/out/packages/shared/src/custom-key-map.js.map +1 -0
  228. package/out/packages/shared/src/custom-key-set.js.map +1 -0
  229. package/out/packages/shared/src/deep-clone.js.map +1 -0
  230. package/out/packages/shared/src/deep-merge.js.map +1 -0
  231. package/out/packages/shared/src/document-visible.js.map +1 -0
  232. package/out/packages/shared/src/dotenv.js.map +1 -0
  233. package/out/packages/shared/src/error.js.map +1 -0
  234. package/out/packages/shared/src/has-own.js.map +1 -0
  235. package/out/packages/shared/src/hash.js.map +1 -0
  236. package/out/packages/shared/src/iterables.js.map +1 -0
  237. package/out/packages/shared/src/json-schema.js.map +1 -0
  238. package/out/packages/shared/src/json.js.map +1 -0
  239. package/out/packages/shared/src/logging-test-utils.js.map +1 -0
  240. package/out/packages/shared/src/logging.js.map +1 -0
  241. package/out/packages/shared/src/map.js +39 -0
  242. package/out/packages/shared/src/map.js.map +1 -0
  243. package/out/packages/shared/src/must.js.map +1 -0
  244. package/out/packages/shared/src/navigator.js.map +1 -0
  245. package/out/packages/shared/src/object-traversal.js.map +1 -0
  246. package/out/packages/shared/src/objects.js.map +1 -0
  247. package/out/packages/shared/src/options.js.map +1 -0
  248. package/out/packages/shared/src/parse-big-int.js.map +1 -0
  249. package/out/packages/shared/src/promise-race.js.map +1 -0
  250. package/out/packages/shared/src/queue.js +120 -0
  251. package/out/packages/shared/src/queue.js.map +1 -0
  252. package/out/packages/shared/src/rand.js.map +1 -0
  253. package/out/packages/shared/src/random-uint64.js.map +1 -0
  254. package/out/packages/shared/src/random-values.js.map +1 -0
  255. package/out/packages/shared/src/record-proxy.js.map +1 -0
  256. package/out/packages/shared/src/resolved-promises.js.map +1 -0
  257. package/out/packages/shared/src/ring-buffer.js +109 -0
  258. package/out/packages/shared/src/ring-buffer.js.map +1 -0
  259. package/out/packages/shared/src/sentinels.js.map +1 -0
  260. package/out/packages/shared/src/set-utils.js.map +1 -0
  261. package/out/packages/shared/src/size-of-value.js.map +1 -0
  262. package/out/packages/shared/src/sleep.js.map +1 -0
  263. package/out/packages/shared/src/sorted-entries.js.map +1 -0
  264. package/out/packages/shared/src/string-compare.js.map +1 -0
  265. package/out/packages/shared/src/subscribable.js.map +1 -0
  266. package/out/packages/shared/src/tdigest-schema.js.map +1 -0
  267. package/out/packages/shared/src/tdigest.js.map +1 -0
  268. package/out/packages/shared/src/valita.js +172 -0
  269. package/out/packages/shared/src/valita.js.map +1 -0
  270. package/out/packages/z2s/src/compiler.js.map +1 -0
  271. package/out/packages/z2s/src/sql.js.map +1 -0
  272. package/out/packages/zero/package.js +205 -0
  273. package/out/packages/zero/package.js.map +1 -0
  274. package/out/packages/zero-cache/src/auth/auth.js.map +1 -0
  275. package/out/packages/zero-cache/src/auth/jwt.js.map +1 -0
  276. package/out/packages/zero-cache/src/auth/load-permissions.js.map +1 -0
  277. package/out/packages/zero-cache/src/auth/read-authorizer.js.map +1 -0
  278. package/out/packages/zero-cache/src/auth/write-authorizer.js.map +1 -0
  279. package/out/packages/zero-cache/src/config/network.js.map +1 -0
  280. package/out/packages/zero-cache/src/config/normalize.js.map +1 -0
  281. package/out/packages/zero-cache/src/config/server-context.js.map +1 -0
  282. package/out/packages/zero-cache/src/config/zero-config.js +921 -0
  283. package/out/packages/zero-cache/src/config/zero-config.js.map +1 -0
  284. package/out/packages/zero-cache/src/custom/fetch.js.map +1 -0
  285. package/out/packages/zero-cache/src/custom-queries/transform-query.js.map +1 -0
  286. package/out/packages/zero-cache/src/db/create.js.map +1 -0
  287. package/out/packages/zero-cache/src/db/delete-lite-db.js.map +1 -0
  288. package/out/packages/zero-cache/src/db/lite-tables.js.map +1 -0
  289. package/out/packages/zero-cache/src/db/migration-lite.js +166 -0
  290. package/out/packages/zero-cache/src/db/migration-lite.js.map +1 -0
  291. package/out/packages/zero-cache/src/db/migration.js +139 -0
  292. package/out/packages/zero-cache/src/db/migration.js.map +1 -0
  293. package/out/packages/zero-cache/src/db/mode-enum.js.map +1 -0
  294. package/out/packages/zero-cache/src/db/pg-copy-binary.js.map +1 -0
  295. package/out/packages/zero-cache/src/db/pg-copy.js.map +1 -0
  296. package/out/packages/zero-cache/src/db/pg-to-lite.js.map +1 -0
  297. package/out/packages/zero-cache/src/db/pg-type-parser.js.map +1 -0
  298. package/out/packages/zero-cache/src/db/run-transaction.js.map +1 -0
  299. package/out/packages/zero-cache/src/db/specs.js.map +1 -0
  300. package/out/packages/zero-cache/src/db/statements.js.map +1 -0
  301. package/out/packages/zero-cache/src/db/transaction-pool.js.map +1 -0
  302. package/out/packages/zero-cache/src/db/warmup.js.map +1 -0
  303. package/out/packages/zero-cache/src/observability/events.js.map +1 -0
  304. package/out/packages/zero-cache/src/observability/metrics.js.map +1 -0
  305. package/out/packages/zero-cache/src/scripts/decommission.js.map +1 -0
  306. package/out/packages/zero-cache/src/scripts/deploy-permissions.js.map +1 -0
  307. package/out/packages/zero-cache/src/scripts/permissions.js.map +1 -0
  308. package/out/packages/zero-cache/src/server/anonymous-otel-start.js +306 -0
  309. package/out/packages/zero-cache/src/server/anonymous-otel-start.js.map +1 -0
  310. package/out/packages/zero-cache/src/server/inspector-delegate.js.map +1 -0
  311. package/out/packages/zero-cache/src/server/logging.js.map +1 -0
  312. package/out/packages/zero-cache/src/server/otel-diag-logger.js.map +1 -0
  313. package/out/packages/zero-cache/src/server/otel-log-sink.js.map +1 -0
  314. package/out/packages/zero-cache/src/server/otel-start.js +53 -0
  315. package/out/packages/zero-cache/src/server/otel-start.js.map +1 -0
  316. package/out/packages/zero-cache/src/server/priority-op.js.map +1 -0
  317. package/out/packages/zero-cache/src/server/runner/main.js +11 -0
  318. package/out/packages/zero-cache/src/server/runner/main.js.map +1 -0
  319. package/out/packages/zero-cache/src/server/runner/run-worker.js.map +1 -0
  320. package/out/packages/zero-cache/src/server/runner/runtime.js.map +1 -0
  321. package/out/packages/zero-cache/src/server/runner/zero-dispatcher.js.map +1 -0
  322. package/out/packages/zero-cache/src/server/worker-dispatcher.js.map +1 -0
  323. package/out/packages/zero-cache/src/server/worker-urls.js.map +1 -0
  324. package/out/packages/zero-cache/src/services/analyze.js +72 -0
  325. package/out/packages/zero-cache/src/services/analyze.js.map +1 -0
  326. package/out/packages/zero-cache/src/services/change-source/common/backfill-manager.js.map +1 -0
  327. package/out/packages/zero-cache/src/services/change-source/common/change-stream-multiplexer.js.map +1 -0
  328. package/out/packages/zero-cache/src/services/change-source/common/replica-schema.js.map +1 -0
  329. package/out/packages/zero-cache/src/services/change-source/custom/change-source.js.map +1 -0
  330. package/out/packages/zero-cache/src/services/change-source/pg/backfill-metadata.js.map +1 -0
  331. package/out/packages/zero-cache/src/services/change-source/pg/backfill-stream.js +197 -0
  332. package/out/packages/zero-cache/src/services/change-source/pg/backfill-stream.js.map +1 -0
  333. package/out/packages/zero-cache/src/services/change-source/pg/change-source.js +929 -0
  334. package/out/packages/zero-cache/src/services/change-source/pg/change-source.js.map +1 -0
  335. package/out/packages/zero-cache/src/services/change-source/pg/decommission.js.map +1 -0
  336. package/out/packages/zero-cache/src/services/change-source/pg/initial-sync.js +553 -0
  337. package/out/packages/zero-cache/src/services/change-source/pg/initial-sync.js.map +1 -0
  338. package/out/packages/zero-cache/src/services/change-source/pg/logical-replication/binary-reader.js.map +1 -0
  339. package/out/packages/zero-cache/src/services/change-source/pg/logical-replication/pgoutput-parser.js.map +1 -0
  340. package/out/packages/zero-cache/src/services/change-source/pg/logical-replication/stream.js.map +1 -0
  341. package/out/packages/zero-cache/src/services/change-source/pg/lsn.js.map +1 -0
  342. package/out/packages/zero-cache/src/services/change-source/pg/replication-slots.js +162 -0
  343. package/out/packages/zero-cache/src/services/change-source/pg/replication-slots.js.map +1 -0
  344. package/out/packages/zero-cache/src/services/change-source/pg/schema/ddl.js.map +1 -0
  345. package/out/packages/zero-cache/src/services/change-source/pg/schema/init.js.map +1 -0
  346. package/out/packages/zero-cache/src/services/change-source/pg/schema/published.js.map +1 -0
  347. package/out/packages/zero-cache/src/services/change-source/pg/schema/shard.js +330 -0
  348. package/out/packages/zero-cache/src/services/change-source/pg/schema/shard.js.map +1 -0
  349. package/out/packages/zero-cache/src/services/change-source/pg/schema/validation.js.map +1 -0
  350. package/out/packages/zero-cache/src/services/change-source/protocol/current/control.js.map +1 -0
  351. package/out/packages/zero-cache/src/services/change-source/protocol/current/data.js +194 -0
  352. package/out/packages/zero-cache/src/services/change-source/protocol/current/data.js.map +1 -0
  353. package/out/packages/zero-cache/src/services/change-source/protocol/current/downstream.js.map +1 -0
  354. package/out/packages/zero-cache/src/services/change-source/protocol/current/json.js.map +1 -0
  355. package/out/packages/zero-cache/src/services/change-source/protocol/current/path.js.map +1 -0
  356. package/out/packages/zero-cache/src/services/change-source/protocol/current/status.js.map +1 -0
  357. package/out/packages/zero-cache/src/services/change-source/protocol/current/upstream.js.map +1 -0
  358. package/out/packages/zero-cache/src/services/change-source/protocol/current.js +56 -0
  359. package/out/packages/zero-cache/src/services/change-source/protocol/current.js.map +1 -0
  360. package/out/packages/zero-cache/src/services/change-streamer/backup-monitor.js.map +1 -0
  361. package/out/packages/zero-cache/src/services/change-streamer/broadcast.js.map +1 -0
  362. package/out/packages/zero-cache/src/services/change-streamer/change-streamer-http.js.map +1 -0
  363. package/out/packages/zero-cache/src/services/change-streamer/change-streamer-service.js.map +1 -0
  364. package/out/packages/zero-cache/src/services/change-streamer/change-streamer.js.map +1 -0
  365. package/out/packages/zero-cache/src/services/change-streamer/forwarder.js.map +1 -0
  366. package/out/packages/zero-cache/src/services/change-streamer/replica-monitor.js.map +1 -0
  367. package/out/packages/zero-cache/src/services/change-streamer/schema/init.js +70 -0
  368. package/out/packages/zero-cache/src/services/change-streamer/schema/init.js.map +1 -0
  369. package/out/packages/zero-cache/src/services/change-streamer/schema/tables.js +191 -0
  370. package/out/packages/zero-cache/src/services/change-streamer/schema/tables.js.map +1 -0
  371. package/out/packages/zero-cache/src/services/change-streamer/snapshot.js +42 -0
  372. package/out/packages/zero-cache/src/services/change-streamer/snapshot.js.map +1 -0
  373. package/out/packages/zero-cache/src/services/change-streamer/storer.js.map +1 -0
  374. package/out/packages/zero-cache/src/services/change-streamer/subscriber.js.map +1 -0
  375. package/out/packages/zero-cache/src/services/heapz.js.map +1 -0
  376. package/out/packages/zero-cache/src/services/http-service.js.map +1 -0
  377. package/out/packages/zero-cache/src/services/life-cycle.js +200 -0
  378. package/out/packages/zero-cache/src/services/life-cycle.js.map +1 -0
  379. package/out/packages/zero-cache/src/services/limiter/sliding-window-limiter.js.map +1 -0
  380. package/out/packages/zero-cache/src/services/litestream/commands.js.map +1 -0
  381. package/out/packages/zero-cache/src/services/mutagen/error.js.map +1 -0
  382. package/out/packages/zero-cache/src/services/mutagen/mutagen.js.map +1 -0
  383. package/out/packages/zero-cache/src/services/mutagen/pusher.js.map +1 -0
  384. package/out/packages/zero-cache/src/services/replicator/change-processor.js.map +1 -0
  385. package/out/packages/zero-cache/src/services/replicator/incremental-sync.js.map +1 -0
  386. package/out/packages/zero-cache/src/services/replicator/notifier.js.map +1 -0
  387. package/out/packages/zero-cache/src/services/replicator/replication-status.js.map +1 -0
  388. package/out/packages/zero-cache/src/services/replicator/replicator.js.map +1 -0
  389. package/out/packages/zero-cache/src/services/replicator/reporter/recorder.js.map +1 -0
  390. package/out/packages/zero-cache/src/services/replicator/reporter/report-schema.js.map +1 -0
  391. package/out/packages/zero-cache/src/services/replicator/schema/change-log.js.map +1 -0
  392. package/out/packages/zero-cache/src/services/replicator/schema/column-metadata.js.map +1 -0
  393. package/out/packages/zero-cache/src/services/replicator/schema/constants.js.map +1 -0
  394. package/out/packages/zero-cache/src/services/replicator/schema/replication-state.js.map +1 -0
  395. package/out/packages/zero-cache/src/services/replicator/schema/table-metadata.js.map +1 -0
  396. package/out/packages/zero-cache/src/services/replicator/write-worker-client.js.map +1 -0
  397. package/out/packages/zero-cache/src/services/replicator/write-worker.js.map +1 -0
  398. package/out/packages/zero-cache/src/services/run-ast.js +88 -0
  399. package/out/packages/zero-cache/src/services/run-ast.js.map +1 -0
  400. package/out/packages/zero-cache/src/services/runner.js.map +1 -0
  401. package/out/packages/zero-cache/src/services/running-state.js +139 -0
  402. package/out/packages/zero-cache/src/services/running-state.js.map +1 -0
  403. package/out/packages/zero-cache/src/services/shadow-sync/shadow-sync-service.js.map +1 -0
  404. package/out/packages/zero-cache/src/services/statz.js.map +1 -0
  405. package/out/packages/zero-cache/src/services/view-syncer/active-users-gauge.js.map +1 -0
  406. package/out/packages/zero-cache/src/services/view-syncer/client-handler.js +270 -0
  407. package/out/packages/zero-cache/src/services/view-syncer/client-handler.js.map +1 -0
  408. package/out/packages/zero-cache/src/services/view-syncer/client-schema.js.map +1 -0
  409. package/out/packages/zero-cache/src/services/view-syncer/connection-context-manager.js.map +1 -0
  410. package/out/packages/zero-cache/src/services/view-syncer/cvr-purger.js +110 -0
  411. package/out/packages/zero-cache/src/services/view-syncer/cvr-purger.js.map +1 -0
  412. package/out/packages/zero-cache/src/services/view-syncer/cvr-store.js.map +1 -0
  413. package/out/packages/zero-cache/src/services/view-syncer/cvr.js.map +1 -0
  414. package/out/packages/zero-cache/src/services/view-syncer/drain-coordinator.js.map +1 -0
  415. package/out/packages/zero-cache/src/services/view-syncer/inspect-handler.js +102 -0
  416. package/out/packages/zero-cache/src/services/view-syncer/inspect-handler.js.map +1 -0
  417. package/out/packages/zero-cache/src/services/view-syncer/pipeline-driver.js +628 -0
  418. package/out/packages/zero-cache/src/services/view-syncer/pipeline-driver.js.map +1 -0
  419. package/out/packages/zero-cache/src/services/view-syncer/row-record-cache.js.map +1 -0
  420. package/out/packages/zero-cache/src/services/view-syncer/row-set-signature.js.map +1 -0
  421. package/out/packages/zero-cache/src/services/view-syncer/schema/cvr.js.map +1 -0
  422. package/out/packages/zero-cache/src/services/view-syncer/schema/init.js +142 -0
  423. package/out/packages/zero-cache/src/services/view-syncer/schema/init.js.map +1 -0
  424. package/out/packages/zero-cache/src/services/view-syncer/schema/types.js +278 -0
  425. package/out/packages/zero-cache/src/services/view-syncer/schema/types.js.map +1 -0
  426. package/out/packages/zero-cache/src/services/view-syncer/snapshotter.js.map +1 -0
  427. package/out/packages/zero-cache/src/services/view-syncer/tracer.js.map +1 -0
  428. package/out/packages/zero-cache/src/services/view-syncer/ttl-clock.js.map +1 -0
  429. package/out/packages/zero-cache/src/services/view-syncer/view-syncer.js +1245 -0
  430. package/out/packages/zero-cache/src/services/view-syncer/view-syncer.js.map +1 -0
  431. package/out/packages/zero-cache/src/types/configuration-error.js +11 -0
  432. package/out/packages/zero-cache/src/types/configuration-error.js.map +1 -0
  433. package/out/packages/zero-cache/src/types/error-with-level.js.map +1 -0
  434. package/out/packages/zero-cache/src/types/http.js.map +1 -0
  435. package/out/packages/zero-cache/src/types/lexi-version.js.map +1 -0
  436. package/out/packages/zero-cache/src/types/lite.js.map +1 -0
  437. package/out/packages/zero-cache/src/types/names.js.map +1 -0
  438. package/out/packages/zero-cache/src/types/pg-data-type.js.map +1 -0
  439. package/out/packages/zero-cache/src/types/pg-types.js.map +1 -0
  440. package/out/packages/zero-cache/src/types/pg-versions.js.map +1 -0
  441. package/out/packages/zero-cache/src/types/pg.js +222 -0
  442. package/out/packages/zero-cache/src/types/pg.js.map +1 -0
  443. package/out/packages/zero-cache/src/types/processes.js.map +1 -0
  444. package/out/packages/zero-cache/src/types/profiler.js.map +1 -0
  445. package/out/packages/zero-cache/src/types/row-key.js.map +1 -0
  446. package/out/packages/zero-cache/src/types/shards.js.map +1 -0
  447. package/out/packages/zero-cache/src/types/sql.js.map +1 -0
  448. package/out/packages/zero-cache/src/types/state-version.js.map +1 -0
  449. package/out/packages/zero-cache/src/types/streams.js.map +1 -0
  450. package/out/packages/zero-cache/src/types/strings.js.map +1 -0
  451. package/out/packages/zero-cache/src/types/subscription.js.map +1 -0
  452. package/out/packages/zero-cache/src/types/timeout.js.map +1 -0
  453. package/out/packages/zero-cache/src/types/url-params.js.map +1 -0
  454. package/out/packages/zero-cache/src/types/websocket-handoff.js.map +1 -0
  455. package/out/packages/zero-cache/src/types/ws.js.map +1 -0
  456. package/out/packages/zero-cache/src/workers/connect-params.js.map +1 -0
  457. package/out/packages/zero-cache/src/workers/connection.js.map +1 -0
  458. package/out/packages/zero-cache/src/workers/mutator.js.map +1 -0
  459. package/out/packages/zero-cache/src/workers/replicator.js.map +1 -0
  460. package/out/packages/zero-cache/src/workers/syncer-ws-message-handler.js.map +1 -0
  461. package/out/packages/zero-cache/src/workers/syncer.js.map +1 -0
  462. package/out/packages/zero-client/src/client/active-clients-manager.js.map +1 -0
  463. package/out/packages/zero-client/src/client/client-error-kind-enum.js.map +1 -0
  464. package/out/packages/zero-client/src/client/connection-manager.js +296 -0
  465. package/out/packages/zero-client/src/client/connection-manager.js.map +1 -0
  466. package/out/packages/zero-client/src/client/connection-status-enum.js +20 -0
  467. package/out/packages/zero-client/src/client/connection-status-enum.js.map +1 -0
  468. package/out/packages/zero-client/src/client/connection.js.map +1 -0
  469. package/out/packages/zero-client/src/client/context.js.map +1 -0
  470. package/out/packages/zero-client/src/client/crud-impl.js +61 -0
  471. package/out/packages/zero-client/src/client/crud-impl.js.map +1 -0
  472. package/out/packages/zero-client/src/client/crud.js.map +1 -0
  473. package/out/packages/zero-client/src/client/custom.js +64 -0
  474. package/out/packages/zero-client/src/client/custom.js.map +1 -0
  475. package/out/packages/zero-client/src/client/delete-clients-manager.js.map +1 -0
  476. package/out/packages/zero-client/src/client/enable-analytics.js.map +1 -0
  477. package/out/packages/zero-client/src/client/error.js.map +1 -0
  478. package/out/packages/zero-client/src/client/http-string.js.map +1 -0
  479. package/out/packages/zero-client/src/client/inspector/client-group.js.map +1 -0
  480. package/out/packages/zero-client/src/client/inspector/client.js.map +1 -0
  481. package/out/packages/zero-client/src/client/inspector/html-dialog-prompt.js.map +1 -0
  482. package/out/packages/zero-client/src/client/inspector/inspector.js.map +1 -0
  483. package/out/packages/zero-client/src/client/inspector/lazy-inspector.js.map +1 -0
  484. package/out/packages/zero-client/src/client/inspector/query.js.map +1 -0
  485. package/out/packages/zero-client/src/client/ivm-branch.js.map +1 -0
  486. package/out/packages/zero-client/src/client/keys.js.map +1 -0
  487. package/out/packages/zero-client/src/client/log-options.js.map +1 -0
  488. package/out/packages/zero-client/src/client/make-mutate-property.js.map +1 -0
  489. package/out/packages/zero-client/src/client/make-replicache-mutators.js.map +1 -0
  490. package/out/packages/zero-client/src/client/metric-name-enum.js.map +1 -0
  491. package/out/packages/zero-client/src/client/metrics.js.map +1 -0
  492. package/out/packages/zero-client/src/client/mutation-tracker.js.map +1 -0
  493. package/out/packages/zero-client/src/client/mutator-proxy.js.map +1 -0
  494. package/out/packages/zero-client/src/client/options.js.map +1 -0
  495. package/out/packages/zero-client/src/client/query-manager.js.map +1 -0
  496. package/out/packages/zero-client/src/client/reload-error-handler.js.map +1 -0
  497. package/out/packages/zero-client/src/client/server-option.js.map +1 -0
  498. package/out/packages/zero-client/src/client/update-needed-reason-type-enum.js +27 -0
  499. package/out/packages/zero-client/src/client/update-needed-reason-type-enum.js.map +1 -0
  500. package/out/packages/zero-client/src/client/version.js +9 -0
  501. package/out/packages/zero-client/src/client/version.js.map +1 -0
  502. package/out/packages/zero-client/src/client/zero-poke-handler.js.map +1 -0
  503. package/out/packages/zero-client/src/client/zero-rep.js.map +1 -0
  504. package/out/packages/zero-client/src/client/zero.js +1469 -0
  505. package/out/packages/zero-client/src/client/zero.js.map +1 -0
  506. package/out/packages/zero-client/src/util/nanoid.js.map +1 -0
  507. package/out/packages/zero-protocol/src/analyze-query-result.js +123 -0
  508. package/out/packages/zero-protocol/src/analyze-query-result.js.map +1 -0
  509. package/out/packages/zero-protocol/src/application-error.js.map +1 -0
  510. package/out/packages/zero-protocol/src/ast.js.map +1 -0
  511. package/out/packages/zero-protocol/src/change-desired-queries.js +13 -0
  512. package/out/packages/zero-protocol/src/change-desired-queries.js.map +1 -0
  513. package/out/packages/zero-protocol/src/client-schema.js.map +1 -0
  514. package/out/packages/zero-protocol/src/close-connection.js.map +1 -0
  515. package/out/packages/zero-protocol/src/connect.js +54 -0
  516. package/out/packages/zero-protocol/src/connect.js.map +1 -0
  517. package/out/packages/zero-protocol/src/custom-queries.js.map +1 -0
  518. package/out/packages/zero-protocol/src/data.js.map +1 -0
  519. package/out/packages/zero-protocol/src/delete-clients.js.map +1 -0
  520. package/out/packages/zero-protocol/src/down.js.map +1 -0
  521. package/out/packages/zero-protocol/src/error-kind-enum.js.map +1 -0
  522. package/out/packages/zero-protocol/src/error-origin-enum.js.map +1 -0
  523. package/out/packages/zero-protocol/src/error-reason-enum.js.map +1 -0
  524. package/out/packages/zero-protocol/src/error.js +91 -0
  525. package/out/packages/zero-protocol/src/error.js.map +1 -0
  526. package/out/packages/zero-protocol/src/inspect-down.js.map +1 -0
  527. package/out/packages/zero-protocol/src/inspect-up.js +35 -0
  528. package/out/packages/zero-protocol/src/inspect-up.js.map +1 -0
  529. package/out/packages/zero-protocol/src/mutate-server.js.map +1 -0
  530. package/out/packages/zero-protocol/src/mutation-id.js.map +1 -0
  531. package/out/packages/zero-protocol/src/mutation-type-enum.js.map +1 -0
  532. package/out/packages/zero-protocol/src/mutation.js.map +1 -0
  533. package/out/packages/zero-protocol/src/mutations-patch.js.map +1 -0
  534. package/out/packages/zero-protocol/src/ping.js.map +1 -0
  535. package/out/packages/zero-protocol/src/poke.js +63 -0
  536. package/out/packages/zero-protocol/src/poke.js.map +1 -0
  537. package/out/packages/zero-protocol/src/pong.js.map +1 -0
  538. package/out/packages/zero-protocol/src/primary-key.js.map +1 -0
  539. package/out/packages/zero-protocol/src/protocol-version.js.map +1 -0
  540. package/out/packages/zero-protocol/src/pull.js.map +1 -0
  541. package/out/packages/zero-protocol/src/push.js +76 -0
  542. package/out/packages/zero-protocol/src/push.js.map +1 -0
  543. package/out/packages/zero-protocol/src/queries-patch.js.map +1 -0
  544. package/out/packages/zero-protocol/src/query-hash.js.map +1 -0
  545. package/out/packages/zero-protocol/src/query-server.js.map +1 -0
  546. package/out/packages/zero-protocol/src/row-patch.js.map +1 -0
  547. package/out/packages/zero-protocol/src/up.js.map +1 -0
  548. package/out/packages/zero-protocol/src/update-auth.js.map +1 -0
  549. package/out/packages/zero-protocol/src/version.js.map +1 -0
  550. package/out/packages/zero-react/src/use-connection-state.js +19 -0
  551. package/out/packages/zero-react/src/use-connection-state.js.map +1 -0
  552. package/out/packages/zero-react/src/use-query.js +301 -0
  553. package/out/packages/zero-react/src/use-query.js.map +1 -0
  554. package/out/packages/zero-react/src/use-zero-online.js +22 -0
  555. package/out/packages/zero-react/src/use-zero-online.js.map +1 -0
  556. package/out/packages/zero-react/src/zero-provider.js +90 -0
  557. package/out/packages/zero-react/src/zero-provider.js.map +1 -0
  558. package/out/packages/zero-schema/src/builder/relationship-builder.js.map +1 -0
  559. package/out/packages/zero-schema/src/builder/schema-builder.js.map +1 -0
  560. package/out/packages/zero-schema/src/builder/table-builder.js.map +1 -0
  561. package/out/packages/zero-schema/src/compiled-permissions.js.map +1 -0
  562. package/out/packages/zero-schema/src/name-mapper.js.map +1 -0
  563. package/out/packages/zero-schema/src/permissions.js.map +1 -0
  564. package/out/packages/zero-schema/src/schema-config.js.map +1 -0
  565. package/out/packages/zero-server/src/adapters/drizzle.js.map +1 -0
  566. package/out/packages/zero-server/src/adapters/kysely.js.map +1 -0
  567. package/out/packages/zero-server/src/adapters/pg.js +83 -0
  568. package/out/packages/zero-server/src/adapters/pg.js.map +1 -0
  569. package/out/packages/zero-server/src/adapters/postgresjs.js.map +1 -0
  570. package/out/packages/zero-server/src/adapters/prisma.js.map +1 -0
  571. package/out/packages/zero-server/src/custom.js +215 -0
  572. package/out/packages/zero-server/src/custom.js.map +1 -0
  573. package/out/packages/zero-server/src/logging.js.map +1 -0
  574. package/out/packages/zero-server/src/pg-query-executor.js.map +1 -0
  575. package/out/packages/zero-server/src/process-mutations.js.map +1 -0
  576. package/out/packages/zero-server/src/push-processor.js.map +1 -0
  577. package/out/packages/zero-server/src/queries/process-queries.js.map +1 -0
  578. package/out/packages/zero-server/src/schema.js.map +1 -0
  579. package/out/packages/zero-server/src/zql-database.js.map +1 -0
  580. package/out/packages/zero-solid/src/solid-view.js +145 -0
  581. package/out/packages/zero-solid/src/solid-view.js.map +1 -0
  582. package/out/packages/zero-solid/src/use-connection-state.js +21 -0
  583. package/out/packages/zero-solid/src/use-connection-state.js.map +1 -0
  584. package/out/packages/zero-solid/src/use-query.js +64 -0
  585. package/out/packages/zero-solid/src/use-query.js.map +1 -0
  586. package/out/packages/zero-solid/src/use-zero-online.js +21 -0
  587. package/out/packages/zero-solid/src/use-zero-online.js.map +1 -0
  588. package/out/packages/zero-solid/src/use-zero.js +93 -0
  589. package/out/packages/zero-solid/src/use-zero.js.map +1 -0
  590. package/out/packages/zero-types/src/format.js.map +1 -0
  591. package/out/packages/zero-types/src/name-mapper.js.map +1 -0
  592. package/out/packages/zql/src/builder/builder.js +381 -0
  593. package/out/packages/zql/src/builder/builder.js.map +1 -0
  594. package/out/packages/zql/src/builder/debug-delegate.js +81 -0
  595. package/out/packages/zql/src/builder/debug-delegate.js.map +1 -0
  596. package/out/packages/zql/src/builder/filter.js.map +1 -0
  597. package/out/packages/zql/src/builder/like.js.map +1 -0
  598. package/out/packages/zql/src/error.js.map +1 -0
  599. package/out/packages/zql/src/ivm/array-view.js.map +1 -0
  600. package/out/packages/zql/src/ivm/cap.js +205 -0
  601. package/out/packages/zql/src/ivm/cap.js.map +1 -0
  602. package/out/packages/zql/src/ivm/change.js.map +1 -0
  603. package/out/packages/zql/src/ivm/constraint.js +82 -0
  604. package/out/packages/zql/src/ivm/constraint.js.map +1 -0
  605. package/out/packages/zql/src/ivm/data.js.map +1 -0
  606. package/out/packages/zql/src/ivm/exists.js.map +1 -0
  607. package/out/packages/zql/src/ivm/fan-in.js.map +1 -0
  608. package/out/packages/zql/src/ivm/fan-out.js.map +1 -0
  609. package/out/packages/zql/src/ivm/filter-operators.js.map +1 -0
  610. package/out/packages/zql/src/ivm/filter-push.js.map +1 -0
  611. package/out/packages/zql/src/ivm/filter.js.map +1 -0
  612. package/out/packages/zql/src/ivm/flipped-join.js +307 -0
  613. package/out/packages/zql/src/ivm/flipped-join.js.map +1 -0
  614. package/out/packages/zql/src/ivm/join-utils.js.map +1 -0
  615. package/out/packages/zql/src/ivm/join.js.map +1 -0
  616. package/out/packages/zql/src/ivm/maybe-split-and-push-edit-change.js.map +1 -0
  617. package/out/packages/zql/src/ivm/memory-source.js +612 -0
  618. package/out/packages/zql/src/ivm/memory-source.js.map +1 -0
  619. package/out/packages/zql/src/ivm/memory-storage.js.map +1 -0
  620. package/out/packages/zql/src/ivm/operator.js.map +1 -0
  621. package/out/packages/zql/src/ivm/push-accumulated.js.map +1 -0
  622. package/out/packages/zql/src/ivm/skip-yields.js.map +1 -0
  623. package/out/packages/zql/src/ivm/skip.js.map +1 -0
  624. package/out/packages/zql/src/ivm/source.js.map +1 -0
  625. package/out/packages/zql/src/ivm/stream.js.map +1 -0
  626. package/out/packages/zql/src/ivm/take.js +410 -0
  627. package/out/packages/zql/src/ivm/take.js.map +1 -0
  628. package/out/packages/zql/src/ivm/union-fan-in.js +165 -0
  629. package/out/packages/zql/src/ivm/union-fan-in.js.map +1 -0
  630. package/out/packages/zql/src/ivm/union-fan-out.js.map +1 -0
  631. package/out/packages/zql/src/ivm/view-apply-change.js.map +1 -0
  632. package/out/packages/zql/src/mutate/crud.js.map +1 -0
  633. package/out/packages/zql/src/mutate/custom.js.map +1 -0
  634. package/out/packages/zql/src/mutate/mutator-registry.js.map +1 -0
  635. package/out/packages/zql/src/mutate/mutator.js.map +1 -0
  636. package/out/packages/zql/src/planner/planner-builder.js.map +1 -0
  637. package/out/packages/zql/src/planner/planner-connection.js.map +1 -0
  638. package/out/packages/zql/src/planner/planner-constraint.js.map +1 -0
  639. package/out/packages/zql/src/planner/planner-debug.js.map +1 -0
  640. package/out/packages/zql/src/planner/planner-fan-in.js.map +1 -0
  641. package/out/packages/zql/src/planner/planner-fan-out.js.map +1 -0
  642. package/out/packages/zql/src/planner/planner-graph.js.map +1 -0
  643. package/out/packages/zql/src/planner/planner-join.js +262 -0
  644. package/out/packages/zql/src/planner/planner-join.js.map +1 -0
  645. package/out/packages/zql/src/planner/planner-node.js.map +1 -0
  646. package/out/packages/zql/src/planner/planner-source.js.map +1 -0
  647. package/out/packages/zql/src/planner/planner-terminus.js.map +1 -0
  648. package/out/packages/zql/src/query/complete-ordering.js.map +1 -0
  649. package/out/packages/zql/src/query/create-builder.js.map +1 -0
  650. package/out/packages/zql/src/query/error.js.map +1 -0
  651. package/out/packages/zql/src/query/escape-like.js.map +1 -0
  652. package/out/packages/zql/src/query/expression.js.map +1 -0
  653. package/out/packages/zql/src/query/measure-push-operator.js.map +1 -0
  654. package/out/packages/zql/src/query/metrics-delegate.js.map +1 -0
  655. package/out/packages/zql/src/query/named.js.map +1 -0
  656. package/out/packages/zql/src/query/query-delegate-base.js.map +1 -0
  657. package/out/packages/zql/src/query/query-impl.js +290 -0
  658. package/out/packages/zql/src/query/query-impl.js.map +1 -0
  659. package/out/packages/zql/src/query/query-internals.js.map +1 -0
  660. package/out/packages/zql/src/query/query-registry.js.map +1 -0
  661. package/out/packages/zql/src/query/runnable-query-impl.js.map +1 -0
  662. package/out/packages/zql/src/query/static-query.js.map +1 -0
  663. package/out/packages/zql/src/query/ttl.js.map +1 -0
  664. package/out/packages/zql/src/query/validate-input.js.map +1 -0
  665. package/out/packages/zqlite/src/database-storage.js.map +1 -0
  666. package/out/packages/zqlite/src/db.js.map +1 -0
  667. package/out/packages/zqlite/src/explain-queries.js.map +1 -0
  668. package/out/packages/zqlite/src/internal/sql-inline.js.map +1 -0
  669. package/out/packages/zqlite/src/internal/sql.js.map +1 -0
  670. package/out/packages/zqlite/src/internal/statement-cache.js.map +1 -0
  671. package/out/packages/zqlite/src/query-builder.js.map +1 -0
  672. package/out/packages/zqlite/src/query-delegate.js.map +1 -0
  673. package/out/packages/zqlite/src/resolve-scalar-subqueries.js.map +1 -0
  674. package/out/packages/zqlite/src/sqlite-cost-model.js.map +1 -0
  675. package/out/packages/zqlite/src/sqlite-stat-fanout.js.map +1 -0
  676. package/out/packages/zqlite/src/table-source.js +313 -0
  677. package/out/packages/zqlite/src/table-source.js.map +1 -0
  678. package/out/replicache/src/dag/store-impl.d.ts.map +1 -1
  679. package/out/replicache/src/kv/expo-sqlite/store.d.ts +1 -1
  680. package/out/replicache/src/kv/expo-sqlite/store.d.ts.map +1 -1
  681. package/out/replicache/src/kv/op-sqlite/store.d.ts.map +1 -1
  682. package/out/replicache/src/kv/sqlite-store.d.ts +6 -6
  683. package/out/replicache/src/kv/sqlite-store.d.ts.map +1 -1
  684. package/out/replicache/src/kv/throw-if-closed.d.ts +1 -0
  685. package/out/replicache/src/kv/throw-if-closed.d.ts.map +1 -1
  686. package/out/replicache/src/persist/persist.d.ts.map +1 -1
  687. package/out/replicache/src/sync/pull.d.ts.map +1 -1
  688. package/out/shared/src/map.d.ts +6 -0
  689. package/out/shared/src/map.d.ts.map +1 -0
  690. package/out/shared/src/queue.d.ts.map +1 -1
  691. package/out/shared/src/ring-buffer.d.ts +32 -0
  692. package/out/shared/src/ring-buffer.d.ts.map +1 -0
  693. package/out/zero/src/adapters/drizzle.js +1 -1
  694. package/out/zero/src/adapters/kysely.js +1 -1
  695. package/out/zero/src/adapters/pg.js +1 -1
  696. package/out/zero/src/adapters/postgresjs.js +1 -1
  697. package/out/zero/src/adapters/prisma.js +1 -1
  698. package/out/zero/src/analyze-query.js +1 -1
  699. package/out/zero/src/analyze.js +1 -1
  700. package/out/zero/src/ast-to-zql.js +1 -1
  701. package/out/zero/src/bindings.js +11 -11
  702. package/out/zero/src/build-schema.js.map +1 -1
  703. package/out/zero/src/change-protocol/v0.js +2 -2
  704. package/out/zero/src/cli.js +1 -1
  705. package/out/zero/src/deploy-permissions.js +1 -1
  706. package/out/zero/src/expo-sqlite.js +2 -2
  707. package/out/zero/src/op-sqlite.js +2 -2
  708. package/out/zero/src/pg.js +9 -9
  709. package/out/zero/src/react-native.js +2 -2
  710. package/out/zero/src/react.js +5 -5
  711. package/out/zero/src/server.js +8 -8
  712. package/out/zero/src/solid.js +5 -5
  713. package/out/zero/src/sqlite.js +2 -2
  714. package/out/zero/src/transform-query.js +1 -1
  715. package/out/zero/src/zero-cache-dev.js +6 -6
  716. package/out/zero/src/zero-cache-dev.js.map +1 -1
  717. package/out/zero/src/zero-out.js +5 -5
  718. package/out/zero/src/zero-out.js.map +1 -1
  719. package/out/zero/src/zero.js +22 -22
  720. package/out/zero/src/zqlite.js +5 -5
  721. package/out/zero-cache/src/server/change-streamer.d.ts.map +1 -1
  722. package/out/zero-cache/src/server/change-streamer.js +38 -32
  723. package/out/zero-cache/src/server/change-streamer.js.map +1 -1
  724. package/out/zero-cache/src/server/main.d.ts.map +1 -1
  725. package/out/zero-cache/src/server/main.js +15 -13
  726. package/out/zero-cache/src/server/main.js.map +1 -1
  727. package/out/zero-cache/src/server/mutator.js +12 -10
  728. package/out/zero-cache/src/server/mutator.js.map +1 -1
  729. package/out/zero-cache/src/server/reaper.d.ts.map +1 -1
  730. package/out/zero-cache/src/server/reaper.js +18 -16
  731. package/out/zero-cache/src/server/reaper.js.map +1 -1
  732. package/out/zero-cache/src/server/replicator.d.ts.map +1 -1
  733. package/out/zero-cache/src/server/replicator.js +20 -18
  734. package/out/zero-cache/src/server/replicator.js.map +1 -1
  735. package/out/zero-cache/src/server/runner/main.d.ts.map +1 -1
  736. package/out/zero-cache/src/server/shadow-syncer.js +16 -13
  737. package/out/zero-cache/src/server/shadow-syncer.js.map +1 -1
  738. package/out/zero-cache/src/server/syncer.d.ts.map +1 -1
  739. package/out/zero-cache/src/server/syncer.js +36 -34
  740. package/out/zero-cache/src/server/syncer.js.map +1 -1
  741. package/out/zero-cache/src/server/write-worker.js +1 -1
  742. package/out/zero-cache/src/services/analyze.d.ts.map +1 -1
  743. package/out/zero-cache/src/services/change-source/pg/change-source.d.ts.map +1 -1
  744. package/out/zero-cache/src/services/change-source/pg/initial-sync.d.ts +8 -2
  745. package/out/zero-cache/src/services/change-source/pg/initial-sync.d.ts.map +1 -1
  746. package/out/zero-cache/src/services/change-source/pg/replication-slots.d.ts +1 -1
  747. package/out/zero-cache/src/services/change-source/pg/replication-slots.d.ts.map +1 -1
  748. package/out/zero-cache/src/services/change-streamer/schema/tables.d.ts.map +1 -1
  749. package/out/zero-cache/src/services/life-cycle.d.ts +1 -1
  750. package/out/zero-cache/src/services/life-cycle.d.ts.map +1 -1
  751. package/out/zero-cache/src/services/run-ast.d.ts.map +1 -1
  752. package/out/zero-cache/src/services/running-state.d.ts.map +1 -1
  753. package/out/zero-cache/src/services/view-syncer/cvr-purger.d.ts.map +1 -1
  754. package/out/zero-cache/src/services/view-syncer/view-syncer.d.ts.map +1 -1
  755. package/out/zero-cache/src/types/configuration-error.d.ts +4 -0
  756. package/out/zero-cache/src/types/configuration-error.d.ts.map +1 -0
  757. package/out/zero-cache/src/types/pg.d.ts +2 -0
  758. package/out/zero-cache/src/types/pg.d.ts.map +1 -1
  759. package/out/zero-client/src/client/zero.d.ts.map +1 -1
  760. package/out/zql/src/builder/builder.d.ts.map +1 -1
  761. package/out/zql/src/builder/debug-delegate.d.ts +5 -0
  762. package/out/zql/src/builder/debug-delegate.d.ts.map +1 -1
  763. package/out/zql/src/ivm/cap.d.ts +32 -0
  764. package/out/zql/src/ivm/cap.d.ts.map +1 -0
  765. package/out/zql/src/ivm/flipped-join.d.ts +4 -8
  766. package/out/zql/src/ivm/flipped-join.d.ts.map +1 -1
  767. package/out/zql/src/ivm/operator.d.ts +1 -1
  768. package/out/zql/src/ivm/schema.d.ts +0 -8
  769. package/out/zql/src/ivm/schema.d.ts.map +1 -1
  770. package/out/zql/src/ivm/union-fan-in.d.ts.map +1 -1
  771. package/out/zql/src/mutate/mutator.d.ts +12 -3
  772. package/out/zql/src/mutate/mutator.d.ts.map +1 -1
  773. package/out/zql/src/planner/planner-join.d.ts.map +1 -1
  774. package/out/zql/src/query/query-registry.d.ts +10 -3
  775. package/out/zql/src/query/query-registry.d.ts.map +1 -1
  776. package/out/zqlite/src/table-source.d.ts.map +1 -1
  777. package/package.json +23 -23
  778. package/out/_virtual/_@oxc-project_runtime@0.122.0/helpers/usingCtx.js +0 -57
  779. package/out/analyze-query/src/analyze-cli.js.map +0 -1
  780. package/out/analyze-query/src/bin-analyze.js +0 -277
  781. package/out/analyze-query/src/bin-analyze.js.map +0 -1
  782. package/out/analyze-query/src/bin-transform.js.map +0 -1
  783. package/out/ast-to-zql/src/ast-to-zql.js.map +0 -1
  784. package/out/ast-to-zql/src/bin.js.map +0 -1
  785. package/out/ast-to-zql/src/format.js.map +0 -1
  786. package/out/datadog/src/datadog-log-sink.js.map +0 -1
  787. package/out/otel/src/enabled.js.map +0 -1
  788. package/out/otel/src/log-options.js.map +0 -1
  789. package/out/otel/src/maybe-time.js.map +0 -1
  790. package/out/otel/src/span.js.map +0 -1
  791. package/out/otel/src/version.js.map +0 -1
  792. package/out/replicache/src/async-iterable-to-array.js.map +0 -1
  793. package/out/replicache/src/bg-interval.js.map +0 -1
  794. package/out/replicache/src/btree/diff.js.map +0 -1
  795. package/out/replicache/src/btree/node.js.map +0 -1
  796. package/out/replicache/src/btree/read.js.map +0 -1
  797. package/out/replicache/src/btree/splice.js.map +0 -1
  798. package/out/replicache/src/btree/write.js +0 -188
  799. package/out/replicache/src/btree/write.js.map +0 -1
  800. package/out/replicache/src/call-default-fetch.js.map +0 -1
  801. package/out/replicache/src/connection-loop-delegates.js.map +0 -1
  802. package/out/replicache/src/connection-loop.js.map +0 -1
  803. package/out/replicache/src/cookies.js.map +0 -1
  804. package/out/replicache/src/dag/chunk.js.map +0 -1
  805. package/out/replicache/src/dag/gc.js.map +0 -1
  806. package/out/replicache/src/dag/key.js.map +0 -1
  807. package/out/replicache/src/dag/lazy-store.js.map +0 -1
  808. package/out/replicache/src/dag/store-impl.js +0 -152
  809. package/out/replicache/src/dag/store-impl.js.map +0 -1
  810. package/out/replicache/src/dag/store.js.map +0 -1
  811. package/out/replicache/src/dag/visitor.js.map +0 -1
  812. package/out/replicache/src/db/commit.js.map +0 -1
  813. package/out/replicache/src/db/index.js.map +0 -1
  814. package/out/replicache/src/db/read.js.map +0 -1
  815. package/out/replicache/src/db/rebase.js.map +0 -1
  816. package/out/replicache/src/db/write.js.map +0 -1
  817. package/out/replicache/src/deleted-clients.js.map +0 -1
  818. package/out/replicache/src/error-responses.js.map +0 -1
  819. package/out/replicache/src/frozen-json.js.map +0 -1
  820. package/out/replicache/src/get-default-puller.js.map +0 -1
  821. package/out/replicache/src/get-default-pusher.js.map +0 -1
  822. package/out/replicache/src/get-kv-store-provider.js.map +0 -1
  823. package/out/replicache/src/hash.js.map +0 -1
  824. package/out/replicache/src/http-request-info.js.map +0 -1
  825. package/out/replicache/src/index-defs.js.map +0 -1
  826. package/out/replicache/src/kv/expo-sqlite/store.js +0 -58
  827. package/out/replicache/src/kv/expo-sqlite/store.js.map +0 -1
  828. package/out/replicache/src/kv/idb-store-with-mem-fallback.js.map +0 -1
  829. package/out/replicache/src/kv/idb-store.js.map +0 -1
  830. package/out/replicache/src/kv/mem-store.js.map +0 -1
  831. package/out/replicache/src/kv/op-sqlite/store.js +0 -63
  832. package/out/replicache/src/kv/op-sqlite/store.js.map +0 -1
  833. package/out/replicache/src/kv/op-sqlite/types.js.map +0 -1
  834. package/out/replicache/src/kv/read-impl.js.map +0 -1
  835. package/out/replicache/src/kv/sqlite-store.js +0 -216
  836. package/out/replicache/src/kv/sqlite-store.js.map +0 -1
  837. package/out/replicache/src/kv/throw-if-closed.js +0 -26
  838. package/out/replicache/src/kv/throw-if-closed.js.map +0 -1
  839. package/out/replicache/src/kv/write-impl-base.js.map +0 -1
  840. package/out/replicache/src/kv/write-impl.js.map +0 -1
  841. package/out/replicache/src/lazy.js.map +0 -1
  842. package/out/replicache/src/log-options.js.map +0 -1
  843. package/out/replicache/src/make-idb-name.js.map +0 -1
  844. package/out/replicache/src/new-client-channel.js.map +0 -1
  845. package/out/replicache/src/on-persist-channel.js.map +0 -1
  846. package/out/replicache/src/patch-operation.js.map +0 -1
  847. package/out/replicache/src/pending-mutations.js.map +0 -1
  848. package/out/replicache/src/persist/client-gc.js.map +0 -1
  849. package/out/replicache/src/persist/client-group-gc.js.map +0 -1
  850. package/out/replicache/src/persist/client-groups.js +0 -110
  851. package/out/replicache/src/persist/client-groups.js.map +0 -1
  852. package/out/replicache/src/persist/clients.js +0 -261
  853. package/out/replicache/src/persist/clients.js.map +0 -1
  854. package/out/replicache/src/persist/collect-idb-databases.js.map +0 -1
  855. package/out/replicache/src/persist/gather-mem-only-visitor.js.map +0 -1
  856. package/out/replicache/src/persist/gather-not-cached-visitor.js.map +0 -1
  857. package/out/replicache/src/persist/heartbeat.js.map +0 -1
  858. package/out/replicache/src/persist/idb-databases-store-db-name.js.map +0 -1
  859. package/out/replicache/src/persist/idb-databases-store.js.map +0 -1
  860. package/out/replicache/src/persist/make-client-id.js.map +0 -1
  861. package/out/replicache/src/persist/persist.js +0 -122
  862. package/out/replicache/src/persist/persist.js.map +0 -1
  863. package/out/replicache/src/persist/refresh.js.map +0 -1
  864. package/out/replicache/src/process-scheduler.js.map +0 -1
  865. package/out/replicache/src/pusher.js.map +0 -1
  866. package/out/replicache/src/replicache-impl.js.map +0 -1
  867. package/out/replicache/src/report-error.js.map +0 -1
  868. package/out/replicache/src/request-idle.js.map +0 -1
  869. package/out/replicache/src/scan-iterator.js.map +0 -1
  870. package/out/replicache/src/scan-options.js.map +0 -1
  871. package/out/replicache/src/set-interval-with-signal.js.map +0 -1
  872. package/out/replicache/src/subscriptions.js.map +0 -1
  873. package/out/replicache/src/sync/diff.js.map +0 -1
  874. package/out/replicache/src/sync/ids.js.map +0 -1
  875. package/out/replicache/src/sync/patch.js.map +0 -1
  876. package/out/replicache/src/sync/pull-error.js.map +0 -1
  877. package/out/replicache/src/sync/pull.js +0 -166
  878. package/out/replicache/src/sync/pull.js.map +0 -1
  879. package/out/replicache/src/sync/push.js.map +0 -1
  880. package/out/replicache/src/sync/request-id.js.map +0 -1
  881. package/out/replicache/src/sync/sync-head-name.js.map +0 -1
  882. package/out/replicache/src/to-error.js.map +0 -1
  883. package/out/replicache/src/transaction-closed-error.js.map +0 -1
  884. package/out/replicache/src/transactions.js.map +0 -1
  885. package/out/replicache/src/version.js.map +0 -1
  886. package/out/replicache/src/with-transactions.js.map +0 -1
  887. package/out/shared/src/abort-error.js.map +0 -1
  888. package/out/shared/src/arrays.js.map +0 -1
  889. package/out/shared/src/asserts.js.map +0 -1
  890. package/out/shared/src/bigint-json.js.map +0 -1
  891. package/out/shared/src/binary-search.js.map +0 -1
  892. package/out/shared/src/broadcast-channel.js.map +0 -1
  893. package/out/shared/src/browser-env.js.map +0 -1
  894. package/out/shared/src/btree-set.js.map +0 -1
  895. package/out/shared/src/cache.js.map +0 -1
  896. package/out/shared/src/centroid.js.map +0 -1
  897. package/out/shared/src/config.js.map +0 -1
  898. package/out/shared/src/custom-key-map.js.map +0 -1
  899. package/out/shared/src/custom-key-set.js.map +0 -1
  900. package/out/shared/src/deep-clone.js.map +0 -1
  901. package/out/shared/src/deep-merge.js.map +0 -1
  902. package/out/shared/src/document-visible.js.map +0 -1
  903. package/out/shared/src/dotenv.js.map +0 -1
  904. package/out/shared/src/error.js.map +0 -1
  905. package/out/shared/src/has-own.js.map +0 -1
  906. package/out/shared/src/hash.js.map +0 -1
  907. package/out/shared/src/iterables.js.map +0 -1
  908. package/out/shared/src/json-schema.js.map +0 -1
  909. package/out/shared/src/json.js.map +0 -1
  910. package/out/shared/src/logging-test-utils.js.map +0 -1
  911. package/out/shared/src/logging.js.map +0 -1
  912. package/out/shared/src/must.js.map +0 -1
  913. package/out/shared/src/navigator.js.map +0 -1
  914. package/out/shared/src/object-traversal.js.map +0 -1
  915. package/out/shared/src/objects.js.map +0 -1
  916. package/out/shared/src/options.js.map +0 -1
  917. package/out/shared/src/parse-big-int.js.map +0 -1
  918. package/out/shared/src/promise-race.js.map +0 -1
  919. package/out/shared/src/queue.js +0 -126
  920. package/out/shared/src/queue.js.map +0 -1
  921. package/out/shared/src/rand.js.map +0 -1
  922. package/out/shared/src/random-uint64.js.map +0 -1
  923. package/out/shared/src/random-values.js.map +0 -1
  924. package/out/shared/src/record-proxy.js.map +0 -1
  925. package/out/shared/src/resolved-promises.js.map +0 -1
  926. package/out/shared/src/sentinels.js.map +0 -1
  927. package/out/shared/src/set-utils.js.map +0 -1
  928. package/out/shared/src/size-of-value.js.map +0 -1
  929. package/out/shared/src/sleep.js.map +0 -1
  930. package/out/shared/src/sorted-entries.js.map +0 -1
  931. package/out/shared/src/string-compare.js.map +0 -1
  932. package/out/shared/src/subscribable.js.map +0 -1
  933. package/out/shared/src/tdigest-schema.js.map +0 -1
  934. package/out/shared/src/tdigest.js.map +0 -1
  935. package/out/shared/src/valita.js +0 -172
  936. package/out/shared/src/valita.js.map +0 -1
  937. package/out/z2s/src/compiler.js.map +0 -1
  938. package/out/z2s/src/sql.js.map +0 -1
  939. package/out/zero/package.js +0 -205
  940. package/out/zero/package.js.map +0 -1
  941. package/out/zero-cache/src/auth/auth.js.map +0 -1
  942. package/out/zero-cache/src/auth/jwt.js.map +0 -1
  943. package/out/zero-cache/src/auth/load-permissions.js.map +0 -1
  944. package/out/zero-cache/src/auth/read-authorizer.js.map +0 -1
  945. package/out/zero-cache/src/auth/write-authorizer.js.map +0 -1
  946. package/out/zero-cache/src/config/network.js.map +0 -1
  947. package/out/zero-cache/src/config/normalize.js.map +0 -1
  948. package/out/zero-cache/src/config/server-context.js.map +0 -1
  949. package/out/zero-cache/src/config/zero-config.js +0 -916
  950. package/out/zero-cache/src/config/zero-config.js.map +0 -1
  951. package/out/zero-cache/src/custom/fetch.js.map +0 -1
  952. package/out/zero-cache/src/custom-queries/transform-query.js.map +0 -1
  953. package/out/zero-cache/src/db/create.js.map +0 -1
  954. package/out/zero-cache/src/db/delete-lite-db.js.map +0 -1
  955. package/out/zero-cache/src/db/lite-tables.js.map +0 -1
  956. package/out/zero-cache/src/db/migration-lite.js +0 -147
  957. package/out/zero-cache/src/db/migration-lite.js.map +0 -1
  958. package/out/zero-cache/src/db/migration.js +0 -120
  959. package/out/zero-cache/src/db/migration.js.map +0 -1
  960. package/out/zero-cache/src/db/mode-enum.js.map +0 -1
  961. package/out/zero-cache/src/db/pg-copy-binary.js.map +0 -1
  962. package/out/zero-cache/src/db/pg-copy.js.map +0 -1
  963. package/out/zero-cache/src/db/pg-to-lite.js.map +0 -1
  964. package/out/zero-cache/src/db/pg-type-parser.js.map +0 -1
  965. package/out/zero-cache/src/db/run-transaction.js.map +0 -1
  966. package/out/zero-cache/src/db/specs.js.map +0 -1
  967. package/out/zero-cache/src/db/statements.js.map +0 -1
  968. package/out/zero-cache/src/db/transaction-pool.js.map +0 -1
  969. package/out/zero-cache/src/db/warmup.js.map +0 -1
  970. package/out/zero-cache/src/observability/events.js.map +0 -1
  971. package/out/zero-cache/src/observability/metrics.js.map +0 -1
  972. package/out/zero-cache/src/scripts/decommission.js.map +0 -1
  973. package/out/zero-cache/src/scripts/deploy-permissions.js.map +0 -1
  974. package/out/zero-cache/src/scripts/permissions.js.map +0 -1
  975. package/out/zero-cache/src/server/anonymous-otel-start.js +0 -305
  976. package/out/zero-cache/src/server/anonymous-otel-start.js.map +0 -1
  977. package/out/zero-cache/src/server/inspector-delegate.js.map +0 -1
  978. package/out/zero-cache/src/server/logging.js.map +0 -1
  979. package/out/zero-cache/src/server/otel-diag-logger.js.map +0 -1
  980. package/out/zero-cache/src/server/otel-log-sink.js.map +0 -1
  981. package/out/zero-cache/src/server/otel-start.js +0 -53
  982. package/out/zero-cache/src/server/otel-start.js.map +0 -1
  983. package/out/zero-cache/src/server/priority-op.js.map +0 -1
  984. package/out/zero-cache/src/server/runner/main.js +0 -10
  985. package/out/zero-cache/src/server/runner/main.js.map +0 -1
  986. package/out/zero-cache/src/server/runner/run-worker.js.map +0 -1
  987. package/out/zero-cache/src/server/runner/runtime.js.map +0 -1
  988. package/out/zero-cache/src/server/runner/zero-dispatcher.js.map +0 -1
  989. package/out/zero-cache/src/server/worker-dispatcher.js.map +0 -1
  990. package/out/zero-cache/src/server/worker-urls.js.map +0 -1
  991. package/out/zero-cache/src/services/analyze.js +0 -69
  992. package/out/zero-cache/src/services/analyze.js.map +0 -1
  993. package/out/zero-cache/src/services/change-source/common/backfill-manager.js.map +0 -1
  994. package/out/zero-cache/src/services/change-source/common/change-stream-multiplexer.js.map +0 -1
  995. package/out/zero-cache/src/services/change-source/common/replica-schema.js.map +0 -1
  996. package/out/zero-cache/src/services/change-source/custom/change-source.js.map +0 -1
  997. package/out/zero-cache/src/services/change-source/pg/backfill-metadata.js.map +0 -1
  998. package/out/zero-cache/src/services/change-source/pg/backfill-stream.js +0 -197
  999. package/out/zero-cache/src/services/change-source/pg/backfill-stream.js.map +0 -1
  1000. package/out/zero-cache/src/services/change-source/pg/change-source.js +0 -929
  1001. package/out/zero-cache/src/services/change-source/pg/change-source.js.map +0 -1
  1002. package/out/zero-cache/src/services/change-source/pg/decommission.js.map +0 -1
  1003. package/out/zero-cache/src/services/change-source/pg/initial-sync.js +0 -552
  1004. package/out/zero-cache/src/services/change-source/pg/initial-sync.js.map +0 -1
  1005. package/out/zero-cache/src/services/change-source/pg/logical-replication/binary-reader.js.map +0 -1
  1006. package/out/zero-cache/src/services/change-source/pg/logical-replication/pgoutput-parser.js.map +0 -1
  1007. package/out/zero-cache/src/services/change-source/pg/logical-replication/stream.js.map +0 -1
  1008. package/out/zero-cache/src/services/change-source/pg/lsn.js.map +0 -1
  1009. package/out/zero-cache/src/services/change-source/pg/replication-slots.js +0 -162
  1010. package/out/zero-cache/src/services/change-source/pg/replication-slots.js.map +0 -1
  1011. package/out/zero-cache/src/services/change-source/pg/schema/ddl.js.map +0 -1
  1012. package/out/zero-cache/src/services/change-source/pg/schema/init.js.map +0 -1
  1013. package/out/zero-cache/src/services/change-source/pg/schema/published.js.map +0 -1
  1014. package/out/zero-cache/src/services/change-source/pg/schema/shard.js +0 -330
  1015. package/out/zero-cache/src/services/change-source/pg/schema/shard.js.map +0 -1
  1016. package/out/zero-cache/src/services/change-source/pg/schema/validation.js.map +0 -1
  1017. package/out/zero-cache/src/services/change-source/protocol/current/control.js.map +0 -1
  1018. package/out/zero-cache/src/services/change-source/protocol/current/data.js +0 -192
  1019. package/out/zero-cache/src/services/change-source/protocol/current/data.js.map +0 -1
  1020. package/out/zero-cache/src/services/change-source/protocol/current/downstream.js.map +0 -1
  1021. package/out/zero-cache/src/services/change-source/protocol/current/json.js.map +0 -1
  1022. package/out/zero-cache/src/services/change-source/protocol/current/path.js.map +0 -1
  1023. package/out/zero-cache/src/services/change-source/protocol/current/status.js.map +0 -1
  1024. package/out/zero-cache/src/services/change-source/protocol/current/upstream.js.map +0 -1
  1025. package/out/zero-cache/src/services/change-source/protocol/current.js +0 -56
  1026. package/out/zero-cache/src/services/change-source/protocol/current.js.map +0 -1
  1027. package/out/zero-cache/src/services/change-streamer/backup-monitor.js.map +0 -1
  1028. package/out/zero-cache/src/services/change-streamer/broadcast.js.map +0 -1
  1029. package/out/zero-cache/src/services/change-streamer/change-streamer-http.js.map +0 -1
  1030. package/out/zero-cache/src/services/change-streamer/change-streamer-service.js.map +0 -1
  1031. package/out/zero-cache/src/services/change-streamer/change-streamer.js.map +0 -1
  1032. package/out/zero-cache/src/services/change-streamer/forwarder.js.map +0 -1
  1033. package/out/zero-cache/src/services/change-streamer/replica-monitor.js.map +0 -1
  1034. package/out/zero-cache/src/services/change-streamer/schema/init.js +0 -74
  1035. package/out/zero-cache/src/services/change-streamer/schema/init.js.map +0 -1
  1036. package/out/zero-cache/src/services/change-streamer/schema/tables.js +0 -191
  1037. package/out/zero-cache/src/services/change-streamer/schema/tables.js.map +0 -1
  1038. package/out/zero-cache/src/services/change-streamer/snapshot.js +0 -27
  1039. package/out/zero-cache/src/services/change-streamer/snapshot.js.map +0 -1
  1040. package/out/zero-cache/src/services/change-streamer/storer.js.map +0 -1
  1041. package/out/zero-cache/src/services/change-streamer/subscriber.js.map +0 -1
  1042. package/out/zero-cache/src/services/heapz.js.map +0 -1
  1043. package/out/zero-cache/src/services/http-service.js.map +0 -1
  1044. package/out/zero-cache/src/services/life-cycle.js +0 -195
  1045. package/out/zero-cache/src/services/life-cycle.js.map +0 -1
  1046. package/out/zero-cache/src/services/limiter/sliding-window-limiter.js.map +0 -1
  1047. package/out/zero-cache/src/services/litestream/commands.js.map +0 -1
  1048. package/out/zero-cache/src/services/mutagen/error.js.map +0 -1
  1049. package/out/zero-cache/src/services/mutagen/mutagen.js.map +0 -1
  1050. package/out/zero-cache/src/services/mutagen/pusher.js.map +0 -1
  1051. package/out/zero-cache/src/services/replicator/change-processor.js.map +0 -1
  1052. package/out/zero-cache/src/services/replicator/incremental-sync.js.map +0 -1
  1053. package/out/zero-cache/src/services/replicator/notifier.js.map +0 -1
  1054. package/out/zero-cache/src/services/replicator/replication-status.js.map +0 -1
  1055. package/out/zero-cache/src/services/replicator/replicator.js.map +0 -1
  1056. package/out/zero-cache/src/services/replicator/reporter/recorder.js.map +0 -1
  1057. package/out/zero-cache/src/services/replicator/reporter/report-schema.js.map +0 -1
  1058. package/out/zero-cache/src/services/replicator/schema/change-log.js.map +0 -1
  1059. package/out/zero-cache/src/services/replicator/schema/column-metadata.js.map +0 -1
  1060. package/out/zero-cache/src/services/replicator/schema/constants.js.map +0 -1
  1061. package/out/zero-cache/src/services/replicator/schema/replication-state.js.map +0 -1
  1062. package/out/zero-cache/src/services/replicator/schema/table-metadata.js.map +0 -1
  1063. package/out/zero-cache/src/services/replicator/write-worker-client.js.map +0 -1
  1064. package/out/zero-cache/src/services/replicator/write-worker.js.map +0 -1
  1065. package/out/zero-cache/src/services/run-ast.js +0 -87
  1066. package/out/zero-cache/src/services/run-ast.js.map +0 -1
  1067. package/out/zero-cache/src/services/runner.js.map +0 -1
  1068. package/out/zero-cache/src/services/running-state.js +0 -136
  1069. package/out/zero-cache/src/services/running-state.js.map +0 -1
  1070. package/out/zero-cache/src/services/shadow-sync/shadow-sync-service.js.map +0 -1
  1071. package/out/zero-cache/src/services/statz.js.map +0 -1
  1072. package/out/zero-cache/src/services/view-syncer/active-users-gauge.js.map +0 -1
  1073. package/out/zero-cache/src/services/view-syncer/client-handler.js +0 -270
  1074. package/out/zero-cache/src/services/view-syncer/client-handler.js.map +0 -1
  1075. package/out/zero-cache/src/services/view-syncer/client-schema.js.map +0 -1
  1076. package/out/zero-cache/src/services/view-syncer/connection-context-manager.js.map +0 -1
  1077. package/out/zero-cache/src/services/view-syncer/cvr-purger.js +0 -109
  1078. package/out/zero-cache/src/services/view-syncer/cvr-purger.js.map +0 -1
  1079. package/out/zero-cache/src/services/view-syncer/cvr-store.js.map +0 -1
  1080. package/out/zero-cache/src/services/view-syncer/cvr.js.map +0 -1
  1081. package/out/zero-cache/src/services/view-syncer/drain-coordinator.js.map +0 -1
  1082. package/out/zero-cache/src/services/view-syncer/inspect-handler.js +0 -102
  1083. package/out/zero-cache/src/services/view-syncer/inspect-handler.js.map +0 -1
  1084. package/out/zero-cache/src/services/view-syncer/pipeline-driver.js +0 -628
  1085. package/out/zero-cache/src/services/view-syncer/pipeline-driver.js.map +0 -1
  1086. package/out/zero-cache/src/services/view-syncer/row-record-cache.js.map +0 -1
  1087. package/out/zero-cache/src/services/view-syncer/row-set-signature.js.map +0 -1
  1088. package/out/zero-cache/src/services/view-syncer/schema/cvr.js.map +0 -1
  1089. package/out/zero-cache/src/services/view-syncer/schema/init.js +0 -158
  1090. package/out/zero-cache/src/services/view-syncer/schema/init.js.map +0 -1
  1091. package/out/zero-cache/src/services/view-syncer/schema/types.js +0 -176
  1092. package/out/zero-cache/src/services/view-syncer/schema/types.js.map +0 -1
  1093. package/out/zero-cache/src/services/view-syncer/snapshotter.js.map +0 -1
  1094. package/out/zero-cache/src/services/view-syncer/tracer.js.map +0 -1
  1095. package/out/zero-cache/src/services/view-syncer/ttl-clock.js.map +0 -1
  1096. package/out/zero-cache/src/services/view-syncer/view-syncer.js +0 -1235
  1097. package/out/zero-cache/src/services/view-syncer/view-syncer.js.map +0 -1
  1098. package/out/zero-cache/src/types/error-with-level.js.map +0 -1
  1099. package/out/zero-cache/src/types/http.js.map +0 -1
  1100. package/out/zero-cache/src/types/lexi-version.js.map +0 -1
  1101. package/out/zero-cache/src/types/lite.js.map +0 -1
  1102. package/out/zero-cache/src/types/names.js.map +0 -1
  1103. package/out/zero-cache/src/types/pg-data-type.js.map +0 -1
  1104. package/out/zero-cache/src/types/pg-types.js.map +0 -1
  1105. package/out/zero-cache/src/types/pg-versions.js.map +0 -1
  1106. package/out/zero-cache/src/types/pg.js +0 -189
  1107. package/out/zero-cache/src/types/pg.js.map +0 -1
  1108. package/out/zero-cache/src/types/processes.js.map +0 -1
  1109. package/out/zero-cache/src/types/profiler.js.map +0 -1
  1110. package/out/zero-cache/src/types/row-key.js.map +0 -1
  1111. package/out/zero-cache/src/types/shards.js.map +0 -1
  1112. package/out/zero-cache/src/types/sql.js.map +0 -1
  1113. package/out/zero-cache/src/types/state-version.js.map +0 -1
  1114. package/out/zero-cache/src/types/streams.js.map +0 -1
  1115. package/out/zero-cache/src/types/strings.js.map +0 -1
  1116. package/out/zero-cache/src/types/subscription.js.map +0 -1
  1117. package/out/zero-cache/src/types/timeout.js.map +0 -1
  1118. package/out/zero-cache/src/types/url-params.js.map +0 -1
  1119. package/out/zero-cache/src/types/websocket-handoff.js.map +0 -1
  1120. package/out/zero-cache/src/types/ws.js.map +0 -1
  1121. package/out/zero-cache/src/workers/connect-params.js.map +0 -1
  1122. package/out/zero-cache/src/workers/connection.js.map +0 -1
  1123. package/out/zero-cache/src/workers/mutator.js.map +0 -1
  1124. package/out/zero-cache/src/workers/replicator.js.map +0 -1
  1125. package/out/zero-cache/src/workers/syncer-ws-message-handler.js.map +0 -1
  1126. package/out/zero-cache/src/workers/syncer.js.map +0 -1
  1127. package/out/zero-client/src/client/active-clients-manager.js.map +0 -1
  1128. package/out/zero-client/src/client/client-error-kind-enum.js.map +0 -1
  1129. package/out/zero-client/src/client/connection-manager.js +0 -295
  1130. package/out/zero-client/src/client/connection-manager.js.map +0 -1
  1131. package/out/zero-client/src/client/connection-status-enum.js +0 -20
  1132. package/out/zero-client/src/client/connection-status-enum.js.map +0 -1
  1133. package/out/zero-client/src/client/connection.js.map +0 -1
  1134. package/out/zero-client/src/client/context.js.map +0 -1
  1135. package/out/zero-client/src/client/crud-impl.js +0 -61
  1136. package/out/zero-client/src/client/crud-impl.js.map +0 -1
  1137. package/out/zero-client/src/client/crud.js.map +0 -1
  1138. package/out/zero-client/src/client/custom.js +0 -63
  1139. package/out/zero-client/src/client/custom.js.map +0 -1
  1140. package/out/zero-client/src/client/delete-clients-manager.js.map +0 -1
  1141. package/out/zero-client/src/client/enable-analytics.js.map +0 -1
  1142. package/out/zero-client/src/client/error.js.map +0 -1
  1143. package/out/zero-client/src/client/http-string.js.map +0 -1
  1144. package/out/zero-client/src/client/inspector/client-group.js.map +0 -1
  1145. package/out/zero-client/src/client/inspector/client.js.map +0 -1
  1146. package/out/zero-client/src/client/inspector/html-dialog-prompt.js.map +0 -1
  1147. package/out/zero-client/src/client/inspector/inspector.js.map +0 -1
  1148. package/out/zero-client/src/client/inspector/lazy-inspector.js.map +0 -1
  1149. package/out/zero-client/src/client/inspector/query.js.map +0 -1
  1150. package/out/zero-client/src/client/ivm-branch.js.map +0 -1
  1151. package/out/zero-client/src/client/keys.js.map +0 -1
  1152. package/out/zero-client/src/client/log-options.js.map +0 -1
  1153. package/out/zero-client/src/client/make-mutate-property.js.map +0 -1
  1154. package/out/zero-client/src/client/make-replicache-mutators.js.map +0 -1
  1155. package/out/zero-client/src/client/metric-name-enum.js.map +0 -1
  1156. package/out/zero-client/src/client/metrics.js.map +0 -1
  1157. package/out/zero-client/src/client/mutation-tracker.js.map +0 -1
  1158. package/out/zero-client/src/client/mutator-proxy.js.map +0 -1
  1159. package/out/zero-client/src/client/options.js.map +0 -1
  1160. package/out/zero-client/src/client/query-manager.js.map +0 -1
  1161. package/out/zero-client/src/client/reload-error-handler.js.map +0 -1
  1162. package/out/zero-client/src/client/server-option.js.map +0 -1
  1163. package/out/zero-client/src/client/update-needed-reason-type-enum.js +0 -27
  1164. package/out/zero-client/src/client/update-needed-reason-type-enum.js.map +0 -1
  1165. package/out/zero-client/src/client/version.js +0 -9
  1166. package/out/zero-client/src/client/version.js.map +0 -1
  1167. package/out/zero-client/src/client/zero-poke-handler.js.map +0 -1
  1168. package/out/zero-client/src/client/zero-rep.js.map +0 -1
  1169. package/out/zero-client/src/client/zero.js +0 -1443
  1170. package/out/zero-client/src/client/zero.js.map +0 -1
  1171. package/out/zero-client/src/util/nanoid.js.map +0 -1
  1172. package/out/zero-client/src/util/socket.d.ts +0 -3
  1173. package/out/zero-client/src/util/socket.d.ts.map +0 -1
  1174. package/out/zero-client/src/util/socket.js +0 -8
  1175. package/out/zero-client/src/util/socket.js.map +0 -1
  1176. package/out/zero-protocol/src/analyze-query-result.js +0 -120
  1177. package/out/zero-protocol/src/analyze-query-result.js.map +0 -1
  1178. package/out/zero-protocol/src/application-error.js.map +0 -1
  1179. package/out/zero-protocol/src/ast.js.map +0 -1
  1180. package/out/zero-protocol/src/change-desired-queries.js +0 -12
  1181. package/out/zero-protocol/src/change-desired-queries.js.map +0 -1
  1182. package/out/zero-protocol/src/client-schema.js.map +0 -1
  1183. package/out/zero-protocol/src/close-connection.js.map +0 -1
  1184. package/out/zero-protocol/src/connect.js +0 -47
  1185. package/out/zero-protocol/src/connect.js.map +0 -1
  1186. package/out/zero-protocol/src/custom-queries.js.map +0 -1
  1187. package/out/zero-protocol/src/data.js.map +0 -1
  1188. package/out/zero-protocol/src/delete-clients.js.map +0 -1
  1189. package/out/zero-protocol/src/down.js.map +0 -1
  1190. package/out/zero-protocol/src/error-kind-enum.js.map +0 -1
  1191. package/out/zero-protocol/src/error-origin-enum.js.map +0 -1
  1192. package/out/zero-protocol/src/error-reason-enum.js.map +0 -1
  1193. package/out/zero-protocol/src/error.js +0 -84
  1194. package/out/zero-protocol/src/error.js.map +0 -1
  1195. package/out/zero-protocol/src/inspect-down.js.map +0 -1
  1196. package/out/zero-protocol/src/inspect-up.js +0 -34
  1197. package/out/zero-protocol/src/inspect-up.js.map +0 -1
  1198. package/out/zero-protocol/src/mutate-server.js.map +0 -1
  1199. package/out/zero-protocol/src/mutation-id.js.map +0 -1
  1200. package/out/zero-protocol/src/mutation-type-enum.js.map +0 -1
  1201. package/out/zero-protocol/src/mutation.js.map +0 -1
  1202. package/out/zero-protocol/src/mutations-patch.js.map +0 -1
  1203. package/out/zero-protocol/src/ping.js.map +0 -1
  1204. package/out/zero-protocol/src/poke.js +0 -59
  1205. package/out/zero-protocol/src/poke.js.map +0 -1
  1206. package/out/zero-protocol/src/pong.js.map +0 -1
  1207. package/out/zero-protocol/src/primary-key.js.map +0 -1
  1208. package/out/zero-protocol/src/protocol-version.js.map +0 -1
  1209. package/out/zero-protocol/src/pull.js.map +0 -1
  1210. package/out/zero-protocol/src/push.js +0 -60
  1211. package/out/zero-protocol/src/push.js.map +0 -1
  1212. package/out/zero-protocol/src/queries-patch.js.map +0 -1
  1213. package/out/zero-protocol/src/query-hash.js.map +0 -1
  1214. package/out/zero-protocol/src/query-server.js.map +0 -1
  1215. package/out/zero-protocol/src/row-patch.js.map +0 -1
  1216. package/out/zero-protocol/src/up.js.map +0 -1
  1217. package/out/zero-protocol/src/update-auth.js.map +0 -1
  1218. package/out/zero-protocol/src/version.js.map +0 -1
  1219. package/out/zero-react/src/use-connection-state.js +0 -17
  1220. package/out/zero-react/src/use-connection-state.js.map +0 -1
  1221. package/out/zero-react/src/use-query.js +0 -299
  1222. package/out/zero-react/src/use-query.js.map +0 -1
  1223. package/out/zero-react/src/use-zero-online.js +0 -20
  1224. package/out/zero-react/src/use-zero-online.js.map +0 -1
  1225. package/out/zero-react/src/zero-provider.js +0 -87
  1226. package/out/zero-react/src/zero-provider.js.map +0 -1
  1227. package/out/zero-schema/src/builder/relationship-builder.js.map +0 -1
  1228. package/out/zero-schema/src/builder/schema-builder.js.map +0 -1
  1229. package/out/zero-schema/src/builder/table-builder.js.map +0 -1
  1230. package/out/zero-schema/src/compiled-permissions.js.map +0 -1
  1231. package/out/zero-schema/src/name-mapper.js.map +0 -1
  1232. package/out/zero-schema/src/permissions.js.map +0 -1
  1233. package/out/zero-schema/src/schema-config.js.map +0 -1
  1234. package/out/zero-server/src/adapters/drizzle.js.map +0 -1
  1235. package/out/zero-server/src/adapters/kysely.js.map +0 -1
  1236. package/out/zero-server/src/adapters/pg.js +0 -83
  1237. package/out/zero-server/src/adapters/pg.js.map +0 -1
  1238. package/out/zero-server/src/adapters/postgresjs.js.map +0 -1
  1239. package/out/zero-server/src/adapters/prisma.js.map +0 -1
  1240. package/out/zero-server/src/custom.js +0 -214
  1241. package/out/zero-server/src/custom.js.map +0 -1
  1242. package/out/zero-server/src/logging.js.map +0 -1
  1243. package/out/zero-server/src/pg-query-executor.js.map +0 -1
  1244. package/out/zero-server/src/process-mutations.js.map +0 -1
  1245. package/out/zero-server/src/push-processor.js.map +0 -1
  1246. package/out/zero-server/src/queries/process-queries.js.map +0 -1
  1247. package/out/zero-server/src/schema.js.map +0 -1
  1248. package/out/zero-server/src/zql-database.js.map +0 -1
  1249. package/out/zero-solid/src/solid-view.js +0 -145
  1250. package/out/zero-solid/src/solid-view.js.map +0 -1
  1251. package/out/zero-solid/src/use-connection-state.js +0 -21
  1252. package/out/zero-solid/src/use-connection-state.js.map +0 -1
  1253. package/out/zero-solid/src/use-query.js +0 -64
  1254. package/out/zero-solid/src/use-query.js.map +0 -1
  1255. package/out/zero-solid/src/use-zero-online.js +0 -21
  1256. package/out/zero-solid/src/use-zero-online.js.map +0 -1
  1257. package/out/zero-solid/src/use-zero.js +0 -93
  1258. package/out/zero-solid/src/use-zero.js.map +0 -1
  1259. package/out/zero-types/src/format.js.map +0 -1
  1260. package/out/zero-types/src/name-mapper.js.map +0 -1
  1261. package/out/zql/src/builder/builder.js +0 -370
  1262. package/out/zql/src/builder/builder.js.map +0 -1
  1263. package/out/zql/src/builder/debug-delegate.js +0 -72
  1264. package/out/zql/src/builder/debug-delegate.js.map +0 -1
  1265. package/out/zql/src/builder/filter.js.map +0 -1
  1266. package/out/zql/src/builder/like.js.map +0 -1
  1267. package/out/zql/src/error.js.map +0 -1
  1268. package/out/zql/src/ivm/array-view.js.map +0 -1
  1269. package/out/zql/src/ivm/change.js.map +0 -1
  1270. package/out/zql/src/ivm/constraint.js +0 -82
  1271. package/out/zql/src/ivm/constraint.js.map +0 -1
  1272. package/out/zql/src/ivm/data.js.map +0 -1
  1273. package/out/zql/src/ivm/exists.js.map +0 -1
  1274. package/out/zql/src/ivm/fan-in.js.map +0 -1
  1275. package/out/zql/src/ivm/fan-out.js.map +0 -1
  1276. package/out/zql/src/ivm/filter-operators.js.map +0 -1
  1277. package/out/zql/src/ivm/filter-push.js.map +0 -1
  1278. package/out/zql/src/ivm/filter.js.map +0 -1
  1279. package/out/zql/src/ivm/flipped-join.js +0 -311
  1280. package/out/zql/src/ivm/flipped-join.js.map +0 -1
  1281. package/out/zql/src/ivm/join-utils.js.map +0 -1
  1282. package/out/zql/src/ivm/join.js.map +0 -1
  1283. package/out/zql/src/ivm/maybe-split-and-push-edit-change.js.map +0 -1
  1284. package/out/zql/src/ivm/memory-source.js +0 -612
  1285. package/out/zql/src/ivm/memory-source.js.map +0 -1
  1286. package/out/zql/src/ivm/memory-storage.js.map +0 -1
  1287. package/out/zql/src/ivm/operator.js.map +0 -1
  1288. package/out/zql/src/ivm/push-accumulated.js.map +0 -1
  1289. package/out/zql/src/ivm/skip-yields.js.map +0 -1
  1290. package/out/zql/src/ivm/skip.js.map +0 -1
  1291. package/out/zql/src/ivm/source.js.map +0 -1
  1292. package/out/zql/src/ivm/stream.js.map +0 -1
  1293. package/out/zql/src/ivm/take.js +0 -410
  1294. package/out/zql/src/ivm/take.js.map +0 -1
  1295. package/out/zql/src/ivm/union-fan-in.js +0 -163
  1296. package/out/zql/src/ivm/union-fan-in.js.map +0 -1
  1297. package/out/zql/src/ivm/union-fan-out.js.map +0 -1
  1298. package/out/zql/src/ivm/view-apply-change.js.map +0 -1
  1299. package/out/zql/src/mutate/crud.js.map +0 -1
  1300. package/out/zql/src/mutate/custom.js.map +0 -1
  1301. package/out/zql/src/mutate/mutator-registry.js.map +0 -1
  1302. package/out/zql/src/mutate/mutator.js.map +0 -1
  1303. package/out/zql/src/planner/planner-builder.js.map +0 -1
  1304. package/out/zql/src/planner/planner-connection.js.map +0 -1
  1305. package/out/zql/src/planner/planner-constraint.js.map +0 -1
  1306. package/out/zql/src/planner/planner-debug.js.map +0 -1
  1307. package/out/zql/src/planner/planner-fan-in.js.map +0 -1
  1308. package/out/zql/src/planner/planner-fan-out.js.map +0 -1
  1309. package/out/zql/src/planner/planner-graph.js.map +0 -1
  1310. package/out/zql/src/planner/planner-join.js +0 -261
  1311. package/out/zql/src/planner/planner-join.js.map +0 -1
  1312. package/out/zql/src/planner/planner-node.js.map +0 -1
  1313. package/out/zql/src/planner/planner-source.js.map +0 -1
  1314. package/out/zql/src/planner/planner-terminus.js.map +0 -1
  1315. package/out/zql/src/query/complete-ordering.js.map +0 -1
  1316. package/out/zql/src/query/create-builder.js.map +0 -1
  1317. package/out/zql/src/query/error.js.map +0 -1
  1318. package/out/zql/src/query/escape-like.js.map +0 -1
  1319. package/out/zql/src/query/expression.js.map +0 -1
  1320. package/out/zql/src/query/measure-push-operator.js.map +0 -1
  1321. package/out/zql/src/query/metrics-delegate.js.map +0 -1
  1322. package/out/zql/src/query/named.js.map +0 -1
  1323. package/out/zql/src/query/query-delegate-base.js.map +0 -1
  1324. package/out/zql/src/query/query-impl.js +0 -290
  1325. package/out/zql/src/query/query-impl.js.map +0 -1
  1326. package/out/zql/src/query/query-internals.js.map +0 -1
  1327. package/out/zql/src/query/query-registry.js.map +0 -1
  1328. package/out/zql/src/query/runnable-query-impl.js.map +0 -1
  1329. package/out/zql/src/query/static-query.js.map +0 -1
  1330. package/out/zql/src/query/ttl.js.map +0 -1
  1331. package/out/zql/src/query/validate-input.js.map +0 -1
  1332. package/out/zqlite/src/database-storage.js.map +0 -1
  1333. package/out/zqlite/src/db.js.map +0 -1
  1334. package/out/zqlite/src/explain-queries.js.map +0 -1
  1335. package/out/zqlite/src/internal/sql-inline.js.map +0 -1
  1336. package/out/zqlite/src/internal/sql.js.map +0 -1
  1337. package/out/zqlite/src/internal/statement-cache.js.map +0 -1
  1338. package/out/zqlite/src/query-builder.js.map +0 -1
  1339. package/out/zqlite/src/query-delegate.js.map +0 -1
  1340. package/out/zqlite/src/resolve-scalar-subqueries.js.map +0 -1
  1341. package/out/zqlite/src/sqlite-cost-model.js.map +0 -1
  1342. package/out/zqlite/src/sqlite-stat-fanout.js.map +0 -1
  1343. package/out/zqlite/src/table-source.js +0 -313
  1344. package/out/zqlite/src/table-source.js.map +0 -1
  1345. /package/out/{analyze-query → packages/analyze-query}/src/analyze-cli.js +0 -0
  1346. /package/out/{analyze-query → packages/analyze-query}/src/bin-transform.js +0 -0
  1347. /package/out/{ast-to-zql → packages/ast-to-zql}/src/ast-to-zql.js +0 -0
  1348. /package/out/{ast-to-zql → packages/ast-to-zql}/src/bin.js +0 -0
  1349. /package/out/{ast-to-zql → packages/ast-to-zql}/src/format.js +0 -0
  1350. /package/out/{datadog → packages/datadog}/src/datadog-log-sink.js +0 -0
  1351. /package/out/{otel → packages/otel}/src/enabled.js +0 -0
  1352. /package/out/{otel → packages/otel}/src/log-options.js +0 -0
  1353. /package/out/{otel → packages/otel}/src/maybe-time.js +0 -0
  1354. /package/out/{otel → packages/otel}/src/span.js +0 -0
  1355. /package/out/{otel → packages/otel}/src/version.js +0 -0
  1356. /package/out/{replicache → packages/replicache}/src/async-iterable-to-array.js +0 -0
  1357. /package/out/{replicache → packages/replicache}/src/bg-interval.js +0 -0
  1358. /package/out/{replicache → packages/replicache}/src/btree/diff.js +0 -0
  1359. /package/out/{replicache → packages/replicache}/src/btree/node.js +0 -0
  1360. /package/out/{replicache → packages/replicache}/src/btree/read.js +0 -0
  1361. /package/out/{replicache → packages/replicache}/src/btree/splice.js +0 -0
  1362. /package/out/{replicache → packages/replicache}/src/call-default-fetch.js +0 -0
  1363. /package/out/{replicache → packages/replicache}/src/config.js +0 -0
  1364. /package/out/{replicache → packages/replicache}/src/connection-loop-delegates.js +0 -0
  1365. /package/out/{replicache → packages/replicache}/src/connection-loop.js +0 -0
  1366. /package/out/{replicache → packages/replicache}/src/cookies.js +0 -0
  1367. /package/out/{replicache → packages/replicache}/src/dag/chunk.js +0 -0
  1368. /package/out/{replicache → packages/replicache}/src/dag/gc.js +0 -0
  1369. /package/out/{replicache → packages/replicache}/src/dag/key.js +0 -0
  1370. /package/out/{replicache → packages/replicache}/src/dag/lazy-store.js +0 -0
  1371. /package/out/{replicache → packages/replicache}/src/dag/store.js +0 -0
  1372. /package/out/{replicache → packages/replicache}/src/dag/visitor.js +0 -0
  1373. /package/out/{replicache → packages/replicache}/src/db/commit.js +0 -0
  1374. /package/out/{replicache → packages/replicache}/src/db/index.js +0 -0
  1375. /package/out/{replicache → packages/replicache}/src/db/read.js +0 -0
  1376. /package/out/{replicache → packages/replicache}/src/db/rebase.js +0 -0
  1377. /package/out/{replicache → packages/replicache}/src/db/write.js +0 -0
  1378. /package/out/{replicache → packages/replicache}/src/deleted-clients.js +0 -0
  1379. /package/out/{replicache → packages/replicache}/src/error-responses.js +0 -0
  1380. /package/out/{replicache → packages/replicache}/src/expo-sqlite.js +0 -0
  1381. /package/out/{replicache → packages/replicache}/src/frozen-json.js +0 -0
  1382. /package/out/{replicache → packages/replicache}/src/get-default-puller.js +0 -0
  1383. /package/out/{replicache → packages/replicache}/src/get-default-pusher.js +0 -0
  1384. /package/out/{replicache → packages/replicache}/src/get-kv-store-provider.js +0 -0
  1385. /package/out/{replicache → packages/replicache}/src/hash.js +0 -0
  1386. /package/out/{replicache → packages/replicache}/src/http-request-info.js +0 -0
  1387. /package/out/{replicache → packages/replicache}/src/impl.js +0 -0
  1388. /package/out/{replicache → packages/replicache}/src/index-defs.js +0 -0
  1389. /package/out/{replicache → packages/replicache}/src/kv/idb-store-with-mem-fallback.js +0 -0
  1390. /package/out/{replicache → packages/replicache}/src/kv/idb-store.js +0 -0
  1391. /package/out/{replicache → packages/replicache}/src/kv/mem-store.js +0 -0
  1392. /package/out/{replicache → packages/replicache}/src/kv/op-sqlite/types.js +0 -0
  1393. /package/out/{replicache → packages/replicache}/src/kv/read-impl.js +0 -0
  1394. /package/out/{replicache → packages/replicache}/src/kv/write-impl-base.js +0 -0
  1395. /package/out/{replicache → packages/replicache}/src/kv/write-impl.js +0 -0
  1396. /package/out/{replicache → packages/replicache}/src/lazy.js +0 -0
  1397. /package/out/{replicache → packages/replicache}/src/log-options.js +0 -0
  1398. /package/out/{replicache → packages/replicache}/src/make-idb-name.js +0 -0
  1399. /package/out/{replicache → packages/replicache}/src/mutation-recovery.js +0 -0
  1400. /package/out/{replicache → packages/replicache}/src/new-client-channel.js +0 -0
  1401. /package/out/{replicache → packages/replicache}/src/on-persist-channel.js +0 -0
  1402. /package/out/{replicache → packages/replicache}/src/op-sqlite.js +0 -0
  1403. /package/out/{replicache → packages/replicache}/src/patch-operation.js +0 -0
  1404. /package/out/{replicache → packages/replicache}/src/pending-mutations.js +0 -0
  1405. /package/out/{replicache → packages/replicache}/src/persist/client-gc.js +0 -0
  1406. /package/out/{replicache → packages/replicache}/src/persist/client-group-gc.js +0 -0
  1407. /package/out/{replicache → packages/replicache}/src/persist/collect-idb-databases.js +0 -0
  1408. /package/out/{replicache → packages/replicache}/src/persist/gather-mem-only-visitor.js +0 -0
  1409. /package/out/{replicache → packages/replicache}/src/persist/gather-not-cached-visitor.js +0 -0
  1410. /package/out/{replicache → packages/replicache}/src/persist/heartbeat.js +0 -0
  1411. /package/out/{replicache → packages/replicache}/src/persist/idb-databases-store-db-name.js +0 -0
  1412. /package/out/{replicache → packages/replicache}/src/persist/idb-databases-store.js +0 -0
  1413. /package/out/{replicache → packages/replicache}/src/persist/make-client-id.js +0 -0
  1414. /package/out/{replicache → packages/replicache}/src/persist/refresh.js +0 -0
  1415. /package/out/{replicache → packages/replicache}/src/process-scheduler.js +0 -0
  1416. /package/out/{replicache → packages/replicache}/src/pusher.js +0 -0
  1417. /package/out/{replicache → packages/replicache}/src/replicache-impl.js +0 -0
  1418. /package/out/{replicache → packages/replicache}/src/report-error.js +0 -0
  1419. /package/out/{replicache → packages/replicache}/src/request-idle.js +0 -0
  1420. /package/out/{replicache → packages/replicache}/src/scan-iterator.js +0 -0
  1421. /package/out/{replicache → packages/replicache}/src/scan-options.js +0 -0
  1422. /package/out/{replicache → packages/replicache}/src/set-interval-with-signal.js +0 -0
  1423. /package/out/{replicache → packages/replicache}/src/sqlite.js +0 -0
  1424. /package/out/{replicache → packages/replicache}/src/subscriptions.js +0 -0
  1425. /package/out/{replicache → packages/replicache}/src/sync/diff.js +0 -0
  1426. /package/out/{replicache → packages/replicache}/src/sync/ids.js +0 -0
  1427. /package/out/{replicache → packages/replicache}/src/sync/patch.js +0 -0
  1428. /package/out/{replicache → packages/replicache}/src/sync/pull-error.js +0 -0
  1429. /package/out/{replicache → packages/replicache}/src/sync/push.js +0 -0
  1430. /package/out/{replicache → packages/replicache}/src/sync/request-id.js +0 -0
  1431. /package/out/{replicache → packages/replicache}/src/sync/sync-head-name.js +0 -0
  1432. /package/out/{replicache → packages/replicache}/src/to-error.js +0 -0
  1433. /package/out/{replicache → packages/replicache}/src/transaction-closed-error.js +0 -0
  1434. /package/out/{replicache → packages/replicache}/src/transactions.js +0 -0
  1435. /package/out/{replicache → packages/replicache}/src/version.js +0 -0
  1436. /package/out/{replicache → packages/replicache}/src/with-transactions.js +0 -0
  1437. /package/out/{shared → packages/shared}/src/abort-error.js +0 -0
  1438. /package/out/{shared → packages/shared}/src/arrays.js +0 -0
  1439. /package/out/{shared → packages/shared}/src/asserts.js +0 -0
  1440. /package/out/{shared → packages/shared}/src/bigint-json.js +0 -0
  1441. /package/out/{shared → packages/shared}/src/binary-search.js +0 -0
  1442. /package/out/{shared → packages/shared}/src/broadcast-channel.js +0 -0
  1443. /package/out/{shared → packages/shared}/src/browser-env.js +0 -0
  1444. /package/out/{shared → packages/shared}/src/btree-set.js +0 -0
  1445. /package/out/{shared → packages/shared}/src/cache.js +0 -0
  1446. /package/out/{shared → packages/shared}/src/centroid.js +0 -0
  1447. /package/out/{shared → packages/shared}/src/config.js +0 -0
  1448. /package/out/{shared → packages/shared}/src/custom-key-map.js +0 -0
  1449. /package/out/{shared → packages/shared}/src/custom-key-set.js +0 -0
  1450. /package/out/{shared → packages/shared}/src/deep-clone.js +0 -0
  1451. /package/out/{shared → packages/shared}/src/deep-merge.js +0 -0
  1452. /package/out/{shared → packages/shared}/src/document-visible.js +0 -0
  1453. /package/out/{shared → packages/shared}/src/dotenv.js +0 -0
  1454. /package/out/{shared → packages/shared}/src/error.js +0 -0
  1455. /package/out/{shared → packages/shared}/src/has-own.js +0 -0
  1456. /package/out/{shared → packages/shared}/src/hash.js +0 -0
  1457. /package/out/{shared → packages/shared}/src/iterables.js +0 -0
  1458. /package/out/{shared → packages/shared}/src/json-schema.js +0 -0
  1459. /package/out/{shared → packages/shared}/src/json.js +0 -0
  1460. /package/out/{shared → packages/shared}/src/logging-test-utils.js +0 -0
  1461. /package/out/{shared → packages/shared}/src/logging.js +0 -0
  1462. /package/out/{shared → packages/shared}/src/must.js +0 -0
  1463. /package/out/{shared → packages/shared}/src/navigator.js +0 -0
  1464. /package/out/{shared → packages/shared}/src/object-traversal.js +0 -0
  1465. /package/out/{shared → packages/shared}/src/objects.js +0 -0
  1466. /package/out/{shared → packages/shared}/src/options.js +0 -0
  1467. /package/out/{shared → packages/shared}/src/parse-big-int.js +0 -0
  1468. /package/out/{shared → packages/shared}/src/promise-race.js +0 -0
  1469. /package/out/{shared → packages/shared}/src/rand.js +0 -0
  1470. /package/out/{shared → packages/shared}/src/random-uint64.js +0 -0
  1471. /package/out/{shared → packages/shared}/src/random-values.js +0 -0
  1472. /package/out/{shared → packages/shared}/src/record-proxy.js +0 -0
  1473. /package/out/{shared → packages/shared}/src/resolved-promises.js +0 -0
  1474. /package/out/{shared → packages/shared}/src/sentinels.js +0 -0
  1475. /package/out/{shared → packages/shared}/src/set-utils.js +0 -0
  1476. /package/out/{shared → packages/shared}/src/size-of-value.js +0 -0
  1477. /package/out/{shared → packages/shared}/src/sleep.js +0 -0
  1478. /package/out/{shared → packages/shared}/src/sorted-entries.js +0 -0
  1479. /package/out/{shared → packages/shared}/src/string-compare.js +0 -0
  1480. /package/out/{shared → packages/shared}/src/subscribable.js +0 -0
  1481. /package/out/{shared → packages/shared}/src/tdigest-schema.js +0 -0
  1482. /package/out/{shared → packages/shared}/src/tdigest.js +0 -0
  1483. /package/out/{z2s → packages/z2s}/src/compiler.js +0 -0
  1484. /package/out/{z2s → packages/z2s}/src/sql.js +0 -0
  1485. /package/out/{zero → packages/zero}/src/server/runner/main.js +0 -0
  1486. /package/out/{zero-cache → packages/zero-cache}/src/auth/auth.js +0 -0
  1487. /package/out/{zero-cache → packages/zero-cache}/src/auth/jwt.js +0 -0
  1488. /package/out/{zero-cache → packages/zero-cache}/src/auth/load-permissions.js +0 -0
  1489. /package/out/{zero-cache → packages/zero-cache}/src/auth/read-authorizer.js +0 -0
  1490. /package/out/{zero-cache → packages/zero-cache}/src/auth/write-authorizer.js +0 -0
  1491. /package/out/{zero-cache → packages/zero-cache}/src/config/network.js +0 -0
  1492. /package/out/{zero-cache → packages/zero-cache}/src/config/normalize.js +0 -0
  1493. /package/out/{zero-cache → packages/zero-cache}/src/config/server-context.js +0 -0
  1494. /package/out/{zero-cache → packages/zero-cache}/src/custom/fetch.js +0 -0
  1495. /package/out/{zero-cache → packages/zero-cache}/src/custom-queries/transform-query.js +0 -0
  1496. /package/out/{zero-cache → packages/zero-cache}/src/db/create.js +0 -0
  1497. /package/out/{zero-cache → packages/zero-cache}/src/db/delete-lite-db.js +0 -0
  1498. /package/out/{zero-cache → packages/zero-cache}/src/db/lite-tables.js +0 -0
  1499. /package/out/{zero-cache → packages/zero-cache}/src/db/mode-enum.js +0 -0
  1500. /package/out/{zero-cache → packages/zero-cache}/src/db/pg-copy-binary.js +0 -0
  1501. /package/out/{zero-cache → packages/zero-cache}/src/db/pg-copy.js +0 -0
  1502. /package/out/{zero-cache → packages/zero-cache}/src/db/pg-to-lite.js +0 -0
  1503. /package/out/{zero-cache → packages/zero-cache}/src/db/pg-type-parser.js +0 -0
  1504. /package/out/{zero-cache → packages/zero-cache}/src/db/run-transaction.js +0 -0
  1505. /package/out/{zero-cache → packages/zero-cache}/src/db/specs.js +0 -0
  1506. /package/out/{zero-cache → packages/zero-cache}/src/db/statements.js +0 -0
  1507. /package/out/{zero-cache → packages/zero-cache}/src/db/transaction-pool.js +0 -0
  1508. /package/out/{zero-cache → packages/zero-cache}/src/db/warmup.js +0 -0
  1509. /package/out/{zero-cache → packages/zero-cache}/src/observability/events.js +0 -0
  1510. /package/out/{zero-cache → packages/zero-cache}/src/observability/metrics.js +0 -0
  1511. /package/out/{zero-cache → packages/zero-cache}/src/scripts/decommission.js +0 -0
  1512. /package/out/{zero-cache → packages/zero-cache}/src/scripts/deploy-permissions.js +0 -0
  1513. /package/out/{zero-cache → packages/zero-cache}/src/scripts/permissions.js +0 -0
  1514. /package/out/{zero-cache → packages/zero-cache}/src/server/inspector-delegate.js +0 -0
  1515. /package/out/{zero-cache → packages/zero-cache}/src/server/logging.js +0 -0
  1516. /package/out/{zero-cache → packages/zero-cache}/src/server/otel-diag-logger.js +0 -0
  1517. /package/out/{zero-cache → packages/zero-cache}/src/server/otel-log-sink.js +0 -0
  1518. /package/out/{zero-cache → packages/zero-cache}/src/server/priority-op.js +0 -0
  1519. /package/out/{zero-cache → packages/zero-cache}/src/server/runner/run-worker.js +0 -0
  1520. /package/out/{zero-cache → packages/zero-cache}/src/server/runner/runtime.js +0 -0
  1521. /package/out/{zero-cache → packages/zero-cache}/src/server/runner/zero-dispatcher.js +0 -0
  1522. /package/out/{zero-cache → packages/zero-cache}/src/server/worker-dispatcher.js +0 -0
  1523. /package/out/{zero-cache → packages/zero-cache}/src/server/worker-urls.js +0 -0
  1524. /package/out/{zero-cache → packages/zero-cache}/src/services/change-source/common/backfill-manager.js +0 -0
  1525. /package/out/{zero-cache → packages/zero-cache}/src/services/change-source/common/change-stream-multiplexer.js +0 -0
  1526. /package/out/{zero-cache → packages/zero-cache}/src/services/change-source/common/replica-schema.js +0 -0
  1527. /package/out/{zero-cache → packages/zero-cache}/src/services/change-source/custom/change-source.js +0 -0
  1528. /package/out/{zero-cache → packages/zero-cache}/src/services/change-source/pg/backfill-metadata.js +0 -0
  1529. /package/out/{zero-cache → packages/zero-cache}/src/services/change-source/pg/decommission.js +0 -0
  1530. /package/out/{zero-cache → packages/zero-cache}/src/services/change-source/pg/logical-replication/binary-reader.js +0 -0
  1531. /package/out/{zero-cache → packages/zero-cache}/src/services/change-source/pg/logical-replication/pgoutput-parser.js +0 -0
  1532. /package/out/{zero-cache → packages/zero-cache}/src/services/change-source/pg/logical-replication/stream.js +0 -0
  1533. /package/out/{zero-cache → packages/zero-cache}/src/services/change-source/pg/lsn.js +0 -0
  1534. /package/out/{zero-cache → packages/zero-cache}/src/services/change-source/pg/schema/ddl.js +0 -0
  1535. /package/out/{zero-cache → packages/zero-cache}/src/services/change-source/pg/schema/init.js +0 -0
  1536. /package/out/{zero-cache → packages/zero-cache}/src/services/change-source/pg/schema/published.js +0 -0
  1537. /package/out/{zero-cache → packages/zero-cache}/src/services/change-source/pg/schema/validation.js +0 -0
  1538. /package/out/{zero-cache → packages/zero-cache}/src/services/change-source/protocol/current/control.js +0 -0
  1539. /package/out/{zero-cache → packages/zero-cache}/src/services/change-source/protocol/current/downstream.js +0 -0
  1540. /package/out/{zero-cache → packages/zero-cache}/src/services/change-source/protocol/current/json.js +0 -0
  1541. /package/out/{zero-cache → packages/zero-cache}/src/services/change-source/protocol/current/path.js +0 -0
  1542. /package/out/{zero-cache → packages/zero-cache}/src/services/change-source/protocol/current/status.js +0 -0
  1543. /package/out/{zero-cache → packages/zero-cache}/src/services/change-source/protocol/current/upstream.js +0 -0
  1544. /package/out/{zero-cache → packages/zero-cache}/src/services/change-source/protocol/mod.js +0 -0
  1545. /package/out/{zero-cache → packages/zero-cache}/src/services/change-streamer/backup-monitor.js +0 -0
  1546. /package/out/{zero-cache → packages/zero-cache}/src/services/change-streamer/broadcast.js +0 -0
  1547. /package/out/{zero-cache → packages/zero-cache}/src/services/change-streamer/change-streamer-http.js +0 -0
  1548. /package/out/{zero-cache → packages/zero-cache}/src/services/change-streamer/change-streamer-service.js +0 -0
  1549. /package/out/{zero-cache → packages/zero-cache}/src/services/change-streamer/change-streamer.js +0 -0
  1550. /package/out/{zero-cache → packages/zero-cache}/src/services/change-streamer/forwarder.js +0 -0
  1551. /package/out/{zero-cache → packages/zero-cache}/src/services/change-streamer/replica-monitor.js +0 -0
  1552. /package/out/{zero-cache → packages/zero-cache}/src/services/change-streamer/storer.js +0 -0
  1553. /package/out/{zero-cache → packages/zero-cache}/src/services/change-streamer/subscriber.js +0 -0
  1554. /package/out/{zero-cache → packages/zero-cache}/src/services/heapz.js +0 -0
  1555. /package/out/{zero-cache → packages/zero-cache}/src/services/http-service.js +0 -0
  1556. /package/out/{zero-cache → packages/zero-cache}/src/services/limiter/sliding-window-limiter.js +0 -0
  1557. /package/out/{zero-cache → packages/zero-cache}/src/services/litestream/commands.js +0 -0
  1558. /package/out/{zero-cache → packages/zero-cache}/src/services/mutagen/error.js +0 -0
  1559. /package/out/{zero-cache → packages/zero-cache}/src/services/mutagen/mutagen.js +0 -0
  1560. /package/out/{zero-cache → packages/zero-cache}/src/services/mutagen/pusher.js +0 -0
  1561. /package/out/{zero-cache → packages/zero-cache}/src/services/replicator/change-processor.js +0 -0
  1562. /package/out/{zero-cache → packages/zero-cache}/src/services/replicator/incremental-sync.js +0 -0
  1563. /package/out/{zero-cache → packages/zero-cache}/src/services/replicator/notifier.js +0 -0
  1564. /package/out/{zero-cache → packages/zero-cache}/src/services/replicator/replication-status.js +0 -0
  1565. /package/out/{zero-cache → packages/zero-cache}/src/services/replicator/replicator.js +0 -0
  1566. /package/out/{zero-cache → packages/zero-cache}/src/services/replicator/reporter/recorder.js +0 -0
  1567. /package/out/{zero-cache → packages/zero-cache}/src/services/replicator/reporter/report-schema.js +0 -0
  1568. /package/out/{zero-cache → packages/zero-cache}/src/services/replicator/schema/change-log.js +0 -0
  1569. /package/out/{zero-cache → packages/zero-cache}/src/services/replicator/schema/column-metadata.js +0 -0
  1570. /package/out/{zero-cache → packages/zero-cache}/src/services/replicator/schema/constants.js +0 -0
  1571. /package/out/{zero-cache → packages/zero-cache}/src/services/replicator/schema/replication-state.js +0 -0
  1572. /package/out/{zero-cache → packages/zero-cache}/src/services/replicator/schema/table-metadata.js +0 -0
  1573. /package/out/{zero-cache → packages/zero-cache}/src/services/replicator/write-worker-client.js +0 -0
  1574. /package/out/{zero-cache → packages/zero-cache}/src/services/replicator/write-worker.js +0 -0
  1575. /package/out/{zero-cache → packages/zero-cache}/src/services/runner.js +0 -0
  1576. /package/out/{zero-cache → packages/zero-cache}/src/services/shadow-sync/shadow-sync-service.js +0 -0
  1577. /package/out/{zero-cache → packages/zero-cache}/src/services/statz.js +0 -0
  1578. /package/out/{zero-cache → packages/zero-cache}/src/services/view-syncer/active-users-gauge.js +0 -0
  1579. /package/out/{zero-cache → packages/zero-cache}/src/services/view-syncer/client-schema.js +0 -0
  1580. /package/out/{zero-cache → packages/zero-cache}/src/services/view-syncer/connection-context-manager.js +0 -0
  1581. /package/out/{zero-cache → packages/zero-cache}/src/services/view-syncer/cvr-store.js +0 -0
  1582. /package/out/{zero-cache → packages/zero-cache}/src/services/view-syncer/cvr.js +0 -0
  1583. /package/out/{zero-cache → packages/zero-cache}/src/services/view-syncer/drain-coordinator.js +0 -0
  1584. /package/out/{zero-cache → packages/zero-cache}/src/services/view-syncer/row-record-cache.js +0 -0
  1585. /package/out/{zero-cache → packages/zero-cache}/src/services/view-syncer/row-set-signature.js +0 -0
  1586. /package/out/{zero-cache → packages/zero-cache}/src/services/view-syncer/schema/cvr.js +0 -0
  1587. /package/out/{zero-cache → packages/zero-cache}/src/services/view-syncer/snapshotter.js +0 -0
  1588. /package/out/{zero-cache → packages/zero-cache}/src/services/view-syncer/tracer.js +0 -0
  1589. /package/out/{zero-cache → packages/zero-cache}/src/services/view-syncer/ttl-clock.js +0 -0
  1590. /package/out/{zero-cache → packages/zero-cache}/src/types/error-with-level.js +0 -0
  1591. /package/out/{zero-cache → packages/zero-cache}/src/types/http.js +0 -0
  1592. /package/out/{zero-cache → packages/zero-cache}/src/types/lexi-version.js +0 -0
  1593. /package/out/{zero-cache → packages/zero-cache}/src/types/lite.js +0 -0
  1594. /package/out/{zero-cache → packages/zero-cache}/src/types/names.js +0 -0
  1595. /package/out/{zero-cache → packages/zero-cache}/src/types/pg-data-type.js +0 -0
  1596. /package/out/{zero-cache → packages/zero-cache}/src/types/pg-types.js +0 -0
  1597. /package/out/{zero-cache → packages/zero-cache}/src/types/pg-versions.js +0 -0
  1598. /package/out/{zero-cache → packages/zero-cache}/src/types/processes.js +0 -0
  1599. /package/out/{zero-cache → packages/zero-cache}/src/types/profiler.js +0 -0
  1600. /package/out/{zero-cache → packages/zero-cache}/src/types/row-key.js +0 -0
  1601. /package/out/{zero-cache → packages/zero-cache}/src/types/shards.js +0 -0
  1602. /package/out/{zero-cache → packages/zero-cache}/src/types/sql.js +0 -0
  1603. /package/out/{zero-cache → packages/zero-cache}/src/types/state-version.js +0 -0
  1604. /package/out/{zero-cache → packages/zero-cache}/src/types/streams.js +0 -0
  1605. /package/out/{zero-cache → packages/zero-cache}/src/types/strings.js +0 -0
  1606. /package/out/{zero-cache → packages/zero-cache}/src/types/subscription.js +0 -0
  1607. /package/out/{zero-cache → packages/zero-cache}/src/types/timeout.js +0 -0
  1608. /package/out/{zero-cache → packages/zero-cache}/src/types/url-params.js +0 -0
  1609. /package/out/{zero-cache → packages/zero-cache}/src/types/websocket-handoff.js +0 -0
  1610. /package/out/{zero-cache → packages/zero-cache}/src/types/ws.js +0 -0
  1611. /package/out/{zero-cache → packages/zero-cache}/src/workers/connect-params.js +0 -0
  1612. /package/out/{zero-cache → packages/zero-cache}/src/workers/connection.js +0 -0
  1613. /package/out/{zero-cache → packages/zero-cache}/src/workers/mutator.js +0 -0
  1614. /package/out/{zero-cache → packages/zero-cache}/src/workers/replicator.js +0 -0
  1615. /package/out/{zero-cache → packages/zero-cache}/src/workers/syncer-ws-message-handler.js +0 -0
  1616. /package/out/{zero-cache → packages/zero-cache}/src/workers/syncer.js +0 -0
  1617. /package/out/{zero-client → packages/zero-client}/src/client/active-clients-manager.js +0 -0
  1618. /package/out/{zero-client → packages/zero-client}/src/client/bindings.js +0 -0
  1619. /package/out/{zero-client → packages/zero-client}/src/client/client-error-kind-enum.js +0 -0
  1620. /package/out/{zero-client → packages/zero-client}/src/client/connection.js +0 -0
  1621. /package/out/{zero-client → packages/zero-client}/src/client/context.js +0 -0
  1622. /package/out/{zero-client → packages/zero-client}/src/client/crud.js +0 -0
  1623. /package/out/{zero-client → packages/zero-client}/src/client/delete-clients-manager.js +0 -0
  1624. /package/out/{zero-client → packages/zero-client}/src/client/enable-analytics.js +0 -0
  1625. /package/out/{zero-client → packages/zero-client}/src/client/error.js +0 -0
  1626. /package/out/{zero-client → packages/zero-client}/src/client/http-string.js +0 -0
  1627. /package/out/{zero-client → packages/zero-client}/src/client/inspector/client-group.js +0 -0
  1628. /package/out/{zero-client → packages/zero-client}/src/client/inspector/client.js +0 -0
  1629. /package/out/{zero-client → packages/zero-client}/src/client/inspector/html-dialog-prompt.js +0 -0
  1630. /package/out/{zero-client → packages/zero-client}/src/client/inspector/inspector.js +0 -0
  1631. /package/out/{zero-client → packages/zero-client}/src/client/inspector/lazy-inspector.js +0 -0
  1632. /package/out/{zero-client → packages/zero-client}/src/client/inspector/query.js +0 -0
  1633. /package/out/{zero-client → packages/zero-client}/src/client/ivm-branch.js +0 -0
  1634. /package/out/{zero-client → packages/zero-client}/src/client/keys.js +0 -0
  1635. /package/out/{zero-client → packages/zero-client}/src/client/log-options.js +0 -0
  1636. /package/out/{zero-client → packages/zero-client}/src/client/make-mutate-property.js +0 -0
  1637. /package/out/{zero-client → packages/zero-client}/src/client/make-replicache-mutators.js +0 -0
  1638. /package/out/{zero-client → packages/zero-client}/src/client/metric-name-enum.js +0 -0
  1639. /package/out/{zero-client → packages/zero-client}/src/client/metrics.js +0 -0
  1640. /package/out/{zero-client → packages/zero-client}/src/client/mutation-tracker.js +0 -0
  1641. /package/out/{zero-client → packages/zero-client}/src/client/mutator-proxy.js +0 -0
  1642. /package/out/{zero-client → packages/zero-client}/src/client/options.js +0 -0
  1643. /package/out/{zero-client → packages/zero-client}/src/client/query-manager.js +0 -0
  1644. /package/out/{zero-client → packages/zero-client}/src/client/reload-error-handler.js +0 -0
  1645. /package/out/{zero-client → packages/zero-client}/src/client/server-option.js +0 -0
  1646. /package/out/{zero-client → packages/zero-client}/src/client/zero-poke-handler.js +0 -0
  1647. /package/out/{zero-client → packages/zero-client}/src/client/zero-rep.js +0 -0
  1648. /package/out/{zero-client → packages/zero-client}/src/mod.js +0 -0
  1649. /package/out/{zero-client → packages/zero-client}/src/util/nanoid.js +0 -0
  1650. /package/out/{zero-pg → packages/zero-pg}/src/mod.js +0 -0
  1651. /package/out/{zero-protocol → packages/zero-protocol}/src/application-error.js +0 -0
  1652. /package/out/{zero-protocol → packages/zero-protocol}/src/ast.js +0 -0
  1653. /package/out/{zero-protocol → packages/zero-protocol}/src/client-schema.js +0 -0
  1654. /package/out/{zero-protocol → packages/zero-protocol}/src/close-connection.js +0 -0
  1655. /package/out/{zero-protocol → packages/zero-protocol}/src/custom-queries.js +0 -0
  1656. /package/out/{zero-protocol → packages/zero-protocol}/src/data.js +0 -0
  1657. /package/out/{zero-protocol → packages/zero-protocol}/src/delete-clients.js +0 -0
  1658. /package/out/{zero-protocol → packages/zero-protocol}/src/down.js +0 -0
  1659. /package/out/{zero-protocol → packages/zero-protocol}/src/error-kind-enum.js +0 -0
  1660. /package/out/{zero-protocol → packages/zero-protocol}/src/error-origin-enum.js +0 -0
  1661. /package/out/{zero-protocol → packages/zero-protocol}/src/error-reason-enum.js +0 -0
  1662. /package/out/{zero-protocol → packages/zero-protocol}/src/inspect-down.js +0 -0
  1663. /package/out/{zero-protocol → packages/zero-protocol}/src/mutate-server.js +0 -0
  1664. /package/out/{zero-protocol → packages/zero-protocol}/src/mutation-id.js +0 -0
  1665. /package/out/{zero-protocol → packages/zero-protocol}/src/mutation-type-enum.js +0 -0
  1666. /package/out/{zero-protocol → packages/zero-protocol}/src/mutation.js +0 -0
  1667. /package/out/{zero-protocol → packages/zero-protocol}/src/mutations-patch.js +0 -0
  1668. /package/out/{zero-protocol → packages/zero-protocol}/src/ping.js +0 -0
  1669. /package/out/{zero-protocol → packages/zero-protocol}/src/pong.js +0 -0
  1670. /package/out/{zero-protocol → packages/zero-protocol}/src/primary-key.js +0 -0
  1671. /package/out/{zero-protocol → packages/zero-protocol}/src/protocol-version.js +0 -0
  1672. /package/out/{zero-protocol → packages/zero-protocol}/src/pull.js +0 -0
  1673. /package/out/{zero-protocol → packages/zero-protocol}/src/queries-patch.js +0 -0
  1674. /package/out/{zero-protocol → packages/zero-protocol}/src/query-hash.js +0 -0
  1675. /package/out/{zero-protocol → packages/zero-protocol}/src/query-server.js +0 -0
  1676. /package/out/{zero-protocol → packages/zero-protocol}/src/row-patch.js +0 -0
  1677. /package/out/{zero-protocol → packages/zero-protocol}/src/up.js +0 -0
  1678. /package/out/{zero-protocol → packages/zero-protocol}/src/update-auth.js +0 -0
  1679. /package/out/{zero-protocol → packages/zero-protocol}/src/version.js +0 -0
  1680. /package/out/{zero-react → packages/zero-react}/src/bindings.js +0 -0
  1681. /package/out/{zero-react → packages/zero-react}/src/mod.js +0 -0
  1682. /package/out/{zero-react → packages/zero-react}/src/zero.js +0 -0
  1683. /package/out/{zero-schema → packages/zero-schema}/src/builder/relationship-builder.js +0 -0
  1684. /package/out/{zero-schema → packages/zero-schema}/src/builder/schema-builder.js +0 -0
  1685. /package/out/{zero-schema → packages/zero-schema}/src/builder/table-builder.js +0 -0
  1686. /package/out/{zero-schema → packages/zero-schema}/src/compiled-permissions.js +0 -0
  1687. /package/out/{zero-schema → packages/zero-schema}/src/name-mapper.js +0 -0
  1688. /package/out/{zero-schema → packages/zero-schema}/src/permissions.js +0 -0
  1689. /package/out/{zero-schema → packages/zero-schema}/src/schema-config.js +0 -0
  1690. /package/out/{zero-server → packages/zero-server}/src/adapters/drizzle.js +0 -0
  1691. /package/out/{zero-server → packages/zero-server}/src/adapters/kysely.js +0 -0
  1692. /package/out/{zero-server → packages/zero-server}/src/adapters/postgresjs.js +0 -0
  1693. /package/out/{zero-server → packages/zero-server}/src/adapters/prisma.js +0 -0
  1694. /package/out/{zero-server → packages/zero-server}/src/logging.js +0 -0
  1695. /package/out/{zero-server → packages/zero-server}/src/mod.js +0 -0
  1696. /package/out/{zero-server → packages/zero-server}/src/pg-query-executor.js +0 -0
  1697. /package/out/{zero-server → packages/zero-server}/src/process-mutations.js +0 -0
  1698. /package/out/{zero-server → packages/zero-server}/src/push-processor.js +0 -0
  1699. /package/out/{zero-server → packages/zero-server}/src/queries/process-queries.js +0 -0
  1700. /package/out/{zero-server → packages/zero-server}/src/schema.js +0 -0
  1701. /package/out/{zero-server → packages/zero-server}/src/zql-database.js +0 -0
  1702. /package/out/{zero-solid → packages/zero-solid}/src/bindings.js +0 -0
  1703. /package/out/{zero-solid → packages/zero-solid}/src/mod.js +0 -0
  1704. /package/out/{zero-solid → packages/zero-solid}/src/zero.js +0 -0
  1705. /package/out/{zero-types → packages/zero-types}/src/format.js +0 -0
  1706. /package/out/{zero-types → packages/zero-types}/src/name-mapper.js +0 -0
  1707. /package/out/{zql → packages/zql}/src/builder/filter.js +0 -0
  1708. /package/out/{zql → packages/zql}/src/builder/like.js +0 -0
  1709. /package/out/{zql → packages/zql}/src/error.js +0 -0
  1710. /package/out/{zql → packages/zql}/src/ivm/array-view.js +0 -0
  1711. /package/out/{zql → packages/zql}/src/ivm/change.js +0 -0
  1712. /package/out/{zql → packages/zql}/src/ivm/data.js +0 -0
  1713. /package/out/{zql → packages/zql}/src/ivm/exists.js +0 -0
  1714. /package/out/{zql → packages/zql}/src/ivm/fan-in.js +0 -0
  1715. /package/out/{zql → packages/zql}/src/ivm/fan-out.js +0 -0
  1716. /package/out/{zql → packages/zql}/src/ivm/filter-operators.js +0 -0
  1717. /package/out/{zql → packages/zql}/src/ivm/filter-push.js +0 -0
  1718. /package/out/{zql → packages/zql}/src/ivm/filter.js +0 -0
  1719. /package/out/{zql → packages/zql}/src/ivm/join-utils.js +0 -0
  1720. /package/out/{zql → packages/zql}/src/ivm/join.js +0 -0
  1721. /package/out/{zql → packages/zql}/src/ivm/maybe-split-and-push-edit-change.js +0 -0
  1722. /package/out/{zql → packages/zql}/src/ivm/memory-storage.js +0 -0
  1723. /package/out/{zql → packages/zql}/src/ivm/operator.js +0 -0
  1724. /package/out/{zql → packages/zql}/src/ivm/push-accumulated.js +0 -0
  1725. /package/out/{zql → packages/zql}/src/ivm/skip-yields.js +0 -0
  1726. /package/out/{zql → packages/zql}/src/ivm/skip.js +0 -0
  1727. /package/out/{zql → packages/zql}/src/ivm/source.js +0 -0
  1728. /package/out/{zql → packages/zql}/src/ivm/stream.js +0 -0
  1729. /package/out/{zql → packages/zql}/src/ivm/union-fan-out.js +0 -0
  1730. /package/out/{zql → packages/zql}/src/ivm/view-apply-change.js +0 -0
  1731. /package/out/{zql → packages/zql}/src/mutate/crud.js +0 -0
  1732. /package/out/{zql → packages/zql}/src/mutate/custom.js +0 -0
  1733. /package/out/{zql → packages/zql}/src/mutate/mutator-registry.js +0 -0
  1734. /package/out/{zql → packages/zql}/src/mutate/mutator.js +0 -0
  1735. /package/out/{zql → packages/zql}/src/planner/planner-builder.js +0 -0
  1736. /package/out/{zql → packages/zql}/src/planner/planner-connection.js +0 -0
  1737. /package/out/{zql → packages/zql}/src/planner/planner-constraint.js +0 -0
  1738. /package/out/{zql → packages/zql}/src/planner/planner-debug.js +0 -0
  1739. /package/out/{zql → packages/zql}/src/planner/planner-fan-in.js +0 -0
  1740. /package/out/{zql → packages/zql}/src/planner/planner-fan-out.js +0 -0
  1741. /package/out/{zql → packages/zql}/src/planner/planner-graph.js +0 -0
  1742. /package/out/{zql → packages/zql}/src/planner/planner-node.js +0 -0
  1743. /package/out/{zql → packages/zql}/src/planner/planner-source.js +0 -0
  1744. /package/out/{zql → packages/zql}/src/planner/planner-terminus.js +0 -0
  1745. /package/out/{zql → packages/zql}/src/query/complete-ordering.js +0 -0
  1746. /package/out/{zql → packages/zql}/src/query/create-builder.js +0 -0
  1747. /package/out/{zql → packages/zql}/src/query/error.js +0 -0
  1748. /package/out/{zql → packages/zql}/src/query/escape-like.js +0 -0
  1749. /package/out/{zql → packages/zql}/src/query/expression.js +0 -0
  1750. /package/out/{zql → packages/zql}/src/query/measure-push-operator.js +0 -0
  1751. /package/out/{zql → packages/zql}/src/query/metrics-delegate.js +0 -0
  1752. /package/out/{zql → packages/zql}/src/query/named.js +0 -0
  1753. /package/out/{zql → packages/zql}/src/query/query-delegate-base.js +0 -0
  1754. /package/out/{zql → packages/zql}/src/query/query-internals.js +0 -0
  1755. /package/out/{zql → packages/zql}/src/query/query-registry.js +0 -0
  1756. /package/out/{zql → packages/zql}/src/query/query.js +0 -0
  1757. /package/out/{zql → packages/zql}/src/query/runnable-query-impl.js +0 -0
  1758. /package/out/{zql → packages/zql}/src/query/static-query.js +0 -0
  1759. /package/out/{zql → packages/zql}/src/query/ttl.js +0 -0
  1760. /package/out/{zql → packages/zql}/src/query/validate-input.js +0 -0
  1761. /package/out/{zqlite → packages/zqlite}/src/database-storage.js +0 -0
  1762. /package/out/{zqlite → packages/zqlite}/src/db.js +0 -0
  1763. /package/out/{zqlite → packages/zqlite}/src/explain-queries.js +0 -0
  1764. /package/out/{zqlite → packages/zqlite}/src/internal/sql-inline.js +0 -0
  1765. /package/out/{zqlite → packages/zqlite}/src/internal/sql.js +0 -0
  1766. /package/out/{zqlite → packages/zqlite}/src/internal/statement-cache.js +0 -0
  1767. /package/out/{zqlite → packages/zqlite}/src/mod.js +0 -0
  1768. /package/out/{zqlite → packages/zqlite}/src/query-builder.js +0 -0
  1769. /package/out/{zqlite → packages/zqlite}/src/query-delegate.js +0 -0
  1770. /package/out/{zqlite → packages/zqlite}/src/resolve-scalar-subqueries.js +0 -0
  1771. /package/out/{zqlite → packages/zqlite}/src/sqlite-cost-model.js +0 -0
  1772. /package/out/{zqlite → packages/zqlite}/src/sqlite-stat-fanout.js +0 -0
@@ -1,166 +0,0 @@
1
- import { assert } from "../../../shared/src/asserts.js";
2
- import { deepEqual } from "../../../shared/src/json.js";
3
- import { compareCookies } from "../cookies.js";
4
- import { isErrorResponse } from "../error-responses.js";
5
- import { assertPullerResultV1 } from "../get-default-puller.js";
6
- import { deepFreeze } from "../frozen-json.js";
7
- import { emptyHash } from "../hash.js";
8
- import { BTreeRead } from "../btree/read.js";
9
- import { DEFAULT_HEAD_NAME, assertSnapshotMetaDD31, baseSnapshotFromHash, commitFromHash, commitIsLocalDD31, localMutations, snapshotMetaParts } from "../db/commit.js";
10
- import { diff } from "../btree/diff.js";
11
- import { DiffsMap, addDiffsForIndexes } from "./diff.js";
12
- import { newWriteSnapshotDD31 } from "../db/write.js";
13
- import { withRead, withWriteNoImplicitCommit } from "../with-transactions.js";
14
- import { ReportError } from "../report-error.js";
15
- import { toError } from "../to-error.js";
16
- import { apply } from "./patch.js";
17
- import { PullError } from "./pull-error.js";
18
- import { SYNC_HEAD_NAME } from "./sync-head-name.js";
19
- async function beginPullV1(profileID, clientID, clientGroupID, schemaVersion, puller, requestID, store, formatVersion, lc, createSyncBranch = true) {
20
- const baseCookie = await withRead(store, async (dagRead) => {
21
- const mainHeadHash = await dagRead.getHead(DEFAULT_HEAD_NAME);
22
- if (!mainHeadHash) throw new Error("Internal no main head found");
23
- const baseSnapshotMeta = (await baseSnapshotFromHash(mainHeadHash, dagRead)).meta;
24
- assertSnapshotMetaDD31(baseSnapshotMeta);
25
- return baseSnapshotMeta.cookieJSON;
26
- });
27
- const { response, httpRequestInfo } = await callPuller(lc, puller, {
28
- profileID,
29
- clientGroupID,
30
- cookie: baseCookie,
31
- pullVersion: 1,
32
- schemaVersion
33
- }, requestID);
34
- if (!response) return {
35
- httpRequestInfo,
36
- syncHead: emptyHash
37
- };
38
- if (!createSyncBranch || isErrorResponse(response)) return {
39
- httpRequestInfo,
40
- pullResponse: response,
41
- syncHead: emptyHash
42
- };
43
- const result = await handlePullResponseV1(lc, store, baseCookie, response, clientID, formatVersion);
44
- return {
45
- httpRequestInfo,
46
- pullResponse: response,
47
- syncHead: result.type === 0 ? result.syncHead : emptyHash
48
- };
49
- }
50
- async function callPuller(lc, puller, pullReq, requestID) {
51
- lc.debug?.("Starting pull...");
52
- const pullStart = Date.now();
53
- let pullerResult;
54
- try {
55
- pullerResult = await puller(pullReq, requestID);
56
- lc.debug?.(`...Pull ${pullerResult.response ? "complete" : "failed"} in `, Date.now() - pullStart, "ms");
57
- } catch (e) {
58
- throw new PullError(toError(e));
59
- }
60
- try {
61
- assertPullerResultV1(pullerResult);
62
- return pullerResult;
63
- } catch (e) {
64
- throw new ReportError("Invalid puller result", toError(e));
65
- }
66
- }
67
- function badOrderMessage(name, receivedValue, lastSnapshotValue) {
68
- return `Received ${name} ${receivedValue} is < than last snapshot ${name} ${lastSnapshotValue}; ignoring client view`;
69
- }
70
- function handlePullResponseV1(lc, store, expectedBaseCookie, response, clientID, formatVersion) {
71
- return withWriteNoImplicitCommit(store, async (dagWrite) => {
72
- const dagRead = dagWrite;
73
- const mainHead = await dagRead.getHead(DEFAULT_HEAD_NAME);
74
- if (mainHead === void 0) throw new Error("Main head disappeared");
75
- const baseSnapshot = await baseSnapshotFromHash(mainHead, dagRead);
76
- const baseSnapshotMeta = baseSnapshot.meta;
77
- assertSnapshotMetaDD31(baseSnapshotMeta);
78
- const baseCookie = baseSnapshotMeta.cookieJSON;
79
- if (!deepEqual(expectedBaseCookie, baseCookie)) {
80
- lc.debug?.("handlePullResponse: cookie mismatch, response is not applicable");
81
- return { type: 2 };
82
- }
83
- for (const [clientID, lmidChange] of Object.entries(response.lastMutationIDChanges)) {
84
- const lastMutationID = baseSnapshotMeta.lastMutationIDs[clientID];
85
- if (lastMutationID !== void 0 && lmidChange < lastMutationID) throw new Error(badOrderMessage(`${clientID} lastMutationID`, String(lmidChange), String(lastMutationID)));
86
- }
87
- const frozenResponseCookie = deepFreeze(response.cookie);
88
- if (compareCookies(frozenResponseCookie, baseCookie) < 0) throw new Error(badOrderMessage("cookie", JSON.stringify(frozenResponseCookie), JSON.stringify(baseCookie)));
89
- if (deepEqual(frozenResponseCookie, baseCookie)) {
90
- if (response.patch.length > 0) lc.error?.(`handlePullResponse: cookie ${JSON.stringify(baseCookie)} did not change, but patch is not empty`);
91
- if (Object.keys(response.lastMutationIDChanges).length > 0) lc.error?.(`handlePullResponse: cookie ${JSON.stringify(baseCookie)} did not change, but lastMutationIDChanges is not empty`);
92
- return { type: 1 };
93
- }
94
- const dbWrite = await newWriteSnapshotDD31(baseSnapshot.chunk.hash, {
95
- ...baseSnapshotMeta.lastMutationIDs,
96
- ...response.lastMutationIDChanges
97
- }, frozenResponseCookie, dagWrite, clientID, formatVersion);
98
- await apply(lc, dbWrite, response.patch);
99
- return {
100
- type: 0,
101
- syncHead: await dbWrite.commit(SYNC_HEAD_NAME)
102
- };
103
- });
104
- }
105
- function maybeEndPull(store, lc, expectedSyncHead, clientID, diffConfig, formatVersion) {
106
- return withWriteNoImplicitCommit(store, async (dagWrite) => {
107
- const dagRead = dagWrite;
108
- const syncHeadHash = await dagRead.getHead(SYNC_HEAD_NAME);
109
- if (syncHeadHash === void 0) throw new Error("Missing sync head");
110
- if (syncHeadHash !== expectedSyncHead) {
111
- lc.error?.("maybeEndPull, Wrong sync head. Expecting:", expectedSyncHead, "got:", syncHeadHash);
112
- throw new Error("Wrong sync head");
113
- }
114
- const syncSnapshot = await baseSnapshotFromHash(syncHeadHash, dagRead);
115
- const mainHeadHash = await dagRead.getHead(DEFAULT_HEAD_NAME);
116
- if (mainHeadHash === void 0) throw new Error("Missing main head");
117
- const mainSnapshot = await baseSnapshotFromHash(mainHeadHash, dagRead);
118
- const { meta } = syncSnapshot;
119
- const syncSnapshotBasis = meta.basisHash;
120
- if (syncSnapshot === null) throw new Error("Sync snapshot with no basis");
121
- if (syncSnapshotBasis !== mainSnapshot.chunk.hash) throw new Error("Overlapping syncs");
122
- const syncHead = await commitFromHash(syncHeadHash, dagRead);
123
- const pending = [];
124
- const localMutations$1 = await localMutations(mainHeadHash, dagRead);
125
- for (const commit of localMutations$1) {
126
- let cid = clientID;
127
- assert(commitIsLocalDD31(commit), "Expected commit to be a local DD31 commit");
128
- cid = commit.meta.clientID;
129
- if (await commit.getMutationID(cid, dagRead) > await syncHead.getMutationID(cid, dagRead)) pending.push(commit);
130
- }
131
- pending.reverse();
132
- const diffsMap = new DiffsMap();
133
- if (pending.length > 0) return {
134
- syncHead: syncHeadHash,
135
- oldMainHead: mainHeadHash,
136
- mainHead: mainHeadHash,
137
- replayMutations: pending,
138
- diffs: diffsMap
139
- };
140
- const mainHead = await commitFromHash(mainHeadHash, dagRead);
141
- if (diffConfig.shouldComputeDiffs()) {
142
- const valueDiff = await diff(new BTreeRead(dagRead, formatVersion, mainHead.valueHash), new BTreeRead(dagRead, formatVersion, syncHead.valueHash));
143
- diffsMap.set("", valueDiff);
144
- await addDiffsForIndexes(mainHead, syncHead, dagRead, diffsMap, diffConfig, formatVersion);
145
- }
146
- await Promise.all([dagWrite.setHead(DEFAULT_HEAD_NAME, syncHeadHash), dagWrite.removeHead(SYNC_HEAD_NAME)]);
147
- await dagWrite.commit();
148
- const newMainHeadHash = syncHeadHash;
149
- if (lc.debug) {
150
- const [oldLastMutationID, oldCookie] = snapshotMetaParts(mainSnapshot, clientID);
151
- const [newLastMutationID, newCookie] = snapshotMetaParts(syncSnapshot, clientID);
152
- lc.debug(`Successfully pulled new snapshot with lastMutationID:`, newLastMutationID, `(prev:`, oldLastMutationID, `), cookie: `, newCookie, `(prev:`, oldCookie, `), sync head hash:`, syncHeadHash, ", main head hash:", mainHeadHash, `, valueHash:`, syncHead.valueHash, `(prev:`, mainSnapshot.valueHash);
153
- }
154
- return {
155
- syncHead: syncHeadHash,
156
- oldMainHead: mainHeadHash,
157
- mainHead: newMainHeadHash,
158
- replayMutations: [],
159
- diffs: diffsMap
160
- };
161
- });
162
- }
163
- //#endregion
164
- export { beginPullV1, handlePullResponseV1, maybeEndPull };
165
-
166
- //# sourceMappingURL=pull.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"pull.js","names":[],"sources":["../../../../../replicache/src/sync/pull.ts"],"sourcesContent":["import type {LogContext} from '@rocicorp/logger';\nimport {assert} from '../../../shared/src/asserts.ts';\nimport {deepEqual} from '../../../shared/src/json.ts';\nimport {diff} from '../btree/diff.ts';\nimport {BTreeRead} from '../btree/read.ts';\nimport {compareCookies, type Cookie} from '../cookies.ts';\nimport type {Store} from '../dag/store.ts';\nimport type {Commit} from '../db/commit.ts';\nimport {\n assertSnapshotMetaDD31,\n baseSnapshotFromHash,\n commitFromHash,\n commitIsLocalDD31,\n DEFAULT_HEAD_NAME,\n type LocalMeta,\n localMutations as localMutations_1,\n snapshotMetaParts,\n} from '../db/commit.ts';\nimport {newWriteSnapshotDD31} from '../db/write.ts';\nimport {isErrorResponse} from '../error-responses.ts';\nimport type * as FormatVersion from '../format-version-enum.ts';\nimport {deepFreeze, type FrozenJSONValue} from '../frozen-json.ts';\nimport {assertPullerResultV1} from '../get-default-puller.ts';\nimport {emptyHash, type Hash} from '../hash.ts';\nimport type {HTTPRequestInfo} from '../http-request-info.ts';\nimport type {\n Puller,\n PullerResult,\n PullResponseOKV1Internal,\n PullResponseV1,\n} from '../puller.ts';\nimport {ReportError} from '../report-error.ts';\nimport {toError} from '../to-error.ts';\nimport {withRead, withWriteNoImplicitCommit} from '../with-transactions.ts';\nimport {\n addDiffsForIndexes,\n type DiffComputationConfig,\n DiffsMap,\n} from './diff.ts';\nimport * as HandlePullResponseResultType from './handle-pull-response-result-type-enum.ts';\nimport type {ClientGroupID, ClientID} from './ids.ts';\nimport * as patch from './patch.ts';\nimport {PullError} from './pull-error.ts';\nimport {SYNC_HEAD_NAME} from './sync-head-name.ts';\n\ntype FormatVersion = (typeof FormatVersion)[keyof typeof FormatVersion];\n\nexport const PULL_VERSION_SDD = 0;\nexport const PULL_VERSION_DD31 = 1;\n\n/**\n * The JSON value used as the body when doing a POST to the [pull\n * endpoint](/reference/server-pull).\n */\nexport type PullRequest = PullRequestV1;\n\n/**\n * The JSON value used as the body when doing a POST to the [pull\n * endpoint](/reference/server-pull).\n */\nexport type PullRequestV1 = {\n pullVersion: 1;\n // schemaVersion can optionally be used by the customer's app\n // to indicate to the data layer what format of Client View the\n // app understands.\n schemaVersion: string;\n profileID: string;\n cookie: Cookie;\n\n clientGroupID: ClientGroupID;\n};\n\nexport function isPullRequestV1(pr: PullRequest): pr is PullRequestV1 {\n return pr.pullVersion === PULL_VERSION_DD31;\n}\n\nexport type BeginPullResponseV1 = {\n httpRequestInfo: HTTPRequestInfo;\n pullResponse?: PullResponseV1;\n syncHead: Hash;\n};\n\nexport async function beginPullV1(\n profileID: string,\n clientID: ClientID,\n clientGroupID: ClientGroupID,\n schemaVersion: string,\n puller: Puller,\n requestID: string,\n store: Store,\n formatVersion: FormatVersion,\n lc: LogContext,\n createSyncBranch = true,\n): Promise<BeginPullResponseV1> {\n const baseCookie = await withRead(store, async dagRead => {\n const mainHeadHash = await dagRead.getHead(DEFAULT_HEAD_NAME);\n if (!mainHeadHash) {\n throw new Error('Internal no main head found');\n }\n const baseSnapshot = await baseSnapshotFromHash(mainHeadHash, dagRead);\n const baseSnapshotMeta = baseSnapshot.meta;\n assertSnapshotMetaDD31(baseSnapshotMeta);\n return baseSnapshotMeta.cookieJSON;\n });\n\n const pullReq: PullRequestV1 = {\n profileID,\n clientGroupID,\n cookie: baseCookie,\n pullVersion: PULL_VERSION_DD31,\n schemaVersion,\n };\n\n const {response, httpRequestInfo} = await callPuller(\n lc,\n puller,\n pullReq,\n requestID,\n );\n\n // If Puller did not get a pull response we still want to return the HTTP\n // request info.\n if (!response) {\n return {\n httpRequestInfo,\n syncHead: emptyHash,\n };\n }\n\n if (!createSyncBranch || isErrorResponse(response)) {\n return {\n httpRequestInfo,\n pullResponse: response,\n syncHead: emptyHash,\n };\n }\n\n const result = await handlePullResponseV1(\n lc,\n store,\n baseCookie,\n response,\n clientID,\n formatVersion,\n );\n\n return {\n httpRequestInfo,\n pullResponse: response,\n syncHead:\n result.type === HandlePullResponseResultType.Applied\n ? result.syncHead\n : emptyHash,\n };\n}\n\nasync function callPuller(\n lc: LogContext,\n puller: Puller,\n pullReq: PullRequest,\n requestID: string,\n): Promise<PullerResult> {\n lc.debug?.('Starting pull...');\n const pullStart = Date.now();\n let pullerResult: PullerResult;\n try {\n pullerResult = await puller(pullReq, requestID);\n lc.debug?.(\n `...Pull ${pullerResult.response ? 'complete' : 'failed'} in `,\n Date.now() - pullStart,\n 'ms',\n );\n } catch (e) {\n throw new PullError(toError(e));\n }\n try {\n assertPullerResultV1(pullerResult);\n return pullerResult;\n } catch (e) {\n throw new ReportError('Invalid puller result', toError(e));\n }\n}\n\ntype HandlePullResponseResult =\n | {\n type: HandlePullResponseResultType.Applied;\n syncHead: Hash;\n }\n | {\n type:\n | HandlePullResponseResultType.NoOp\n | HandlePullResponseResultType.CookieMismatch;\n };\n\nfunction badOrderMessage(\n name: string,\n receivedValue: string,\n lastSnapshotValue: string,\n) {\n return `Received ${name} ${receivedValue} is < than last snapshot ${name} ${lastSnapshotValue}; ignoring client view`;\n}\n\nexport function handlePullResponseV1(\n lc: LogContext,\n store: Store,\n expectedBaseCookie: FrozenJSONValue,\n response: PullResponseOKV1Internal,\n clientID: ClientID,\n formatVersion: FormatVersion,\n): Promise<HandlePullResponseResult> {\n // It is possible that another sync completed while we were pulling. Ensure\n // that is not the case by re-checking the base snapshot.\n return withWriteNoImplicitCommit(store, async dagWrite => {\n const dagRead = dagWrite;\n const mainHead = await dagRead.getHead(DEFAULT_HEAD_NAME);\n if (mainHead === undefined) {\n throw new Error('Main head disappeared');\n }\n const baseSnapshot = await baseSnapshotFromHash(mainHead, dagRead);\n const baseSnapshotMeta = baseSnapshot.meta;\n assertSnapshotMetaDD31(baseSnapshotMeta);\n const baseCookie = baseSnapshotMeta.cookieJSON;\n\n // TODO(MP) Here we are using whether the cookie has changed as a proxy for whether\n // the base snapshot changed, which is the check we used to do. I don't think this\n // is quite right. We need to firm up under what conditions we will/not accept an\n // update from the server: https://github.com/rocicorp/replicache/issues/713.\n // In DD31 this is expected to happen if a refresh occurs during a pull.\n if (!deepEqual(expectedBaseCookie, baseCookie)) {\n lc.debug?.(\n 'handlePullResponse: cookie mismatch, response is not applicable',\n );\n return {\n type: HandlePullResponseResultType.CookieMismatch,\n };\n }\n\n // Check that the lastMutationIDs are not going backwards.\n for (const [clientID, lmidChange] of Object.entries(\n response.lastMutationIDChanges,\n )) {\n const lastMutationID = baseSnapshotMeta.lastMutationIDs[clientID];\n if (lastMutationID !== undefined && lmidChange < lastMutationID) {\n throw new Error(\n badOrderMessage(\n `${clientID} lastMutationID`,\n String(lmidChange),\n String(lastMutationID),\n ),\n );\n }\n }\n\n const frozenResponseCookie = deepFreeze(response.cookie);\n if (compareCookies(frozenResponseCookie, baseCookie) < 0) {\n throw new Error(\n badOrderMessage(\n 'cookie',\n JSON.stringify(frozenResponseCookie),\n JSON.stringify(baseCookie),\n ),\n );\n }\n\n if (deepEqual(frozenResponseCookie, baseCookie)) {\n if (response.patch.length > 0) {\n lc.error?.(\n `handlePullResponse: cookie ${JSON.stringify(\n baseCookie,\n )} did not change, but patch is not empty`,\n );\n }\n if (Object.keys(response.lastMutationIDChanges).length > 0) {\n lc.error?.(\n `handlePullResponse: cookie ${JSON.stringify(\n baseCookie,\n )} did not change, but lastMutationIDChanges is not empty`,\n );\n }\n // If the cookie doesn't change, it's a nop.\n return {\n type: HandlePullResponseResultType.NoOp,\n };\n }\n\n const dbWrite = await newWriteSnapshotDD31(\n baseSnapshot.chunk.hash,\n {...baseSnapshotMeta.lastMutationIDs, ...response.lastMutationIDChanges},\n frozenResponseCookie,\n dagWrite,\n clientID,\n formatVersion,\n );\n\n await patch.apply(lc, dbWrite, response.patch);\n\n return {\n type: HandlePullResponseResultType.Applied,\n syncHead: await dbWrite.commit(SYNC_HEAD_NAME),\n };\n });\n}\n\nexport function maybeEndPull<M extends LocalMeta>(\n store: Store,\n lc: LogContext,\n expectedSyncHead: Hash,\n clientID: ClientID,\n diffConfig: DiffComputationConfig,\n formatVersion: FormatVersion,\n): Promise<{\n syncHead: Hash;\n mainHead: Hash;\n oldMainHead: Hash;\n replayMutations: Commit<M>[];\n diffs: DiffsMap;\n}> {\n return withWriteNoImplicitCommit(store, async dagWrite => {\n const dagRead = dagWrite;\n // Ensure sync head is what the caller thinks it is.\n const syncHeadHash = await dagRead.getHead(SYNC_HEAD_NAME);\n if (syncHeadHash === undefined) {\n throw new Error('Missing sync head');\n }\n if (syncHeadHash !== expectedSyncHead) {\n lc.error?.(\n 'maybeEndPull, Wrong sync head. Expecting:',\n expectedSyncHead,\n 'got:',\n syncHeadHash,\n );\n throw new Error('Wrong sync head');\n }\n\n // Ensure another sync has not landed a new snapshot on the main chain.\n // TODO: In DD31, it is expected that a newer snapshot might have appeared\n // on the main chain. In that case, we just abort this pull.\n const syncSnapshot = await baseSnapshotFromHash(syncHeadHash, dagRead);\n const mainHeadHash = await dagRead.getHead(DEFAULT_HEAD_NAME);\n if (mainHeadHash === undefined) {\n throw new Error('Missing main head');\n }\n const mainSnapshot = await baseSnapshotFromHash(mainHeadHash, dagRead);\n\n const {meta} = syncSnapshot;\n const syncSnapshotBasis = meta.basisHash;\n if (syncSnapshot === null) {\n throw new Error('Sync snapshot with no basis');\n }\n if (syncSnapshotBasis !== mainSnapshot.chunk.hash) {\n throw new Error('Overlapping syncs');\n }\n\n // Collect pending commits from the main chain and determine which\n // of them if any need to be replayed.\n const syncHead = await commitFromHash(syncHeadHash, dagRead);\n const pending: Commit<M>[] = [];\n const localMutations = await localMutations_1(mainHeadHash, dagRead);\n for (const commit of localMutations) {\n let cid = clientID;\n assert(\n commitIsLocalDD31(commit),\n 'Expected commit to be a local DD31 commit',\n );\n cid = commit.meta.clientID;\n\n if (\n (await commit.getMutationID(cid, dagRead)) >\n (await syncHead.getMutationID(cid, dagRead))\n ) {\n // We know that the dag can only contain either LocalMetaSDD or LocalMetaDD31\n pending.push(commit as Commit<M>);\n }\n }\n // pending() gave us the pending mutations in sync-head-first order whereas\n // caller wants them in the order to replay (lower mutation ids first).\n pending.reverse();\n\n // We return the keys that changed due to this pull. This is used by\n // subscriptions in the JS API when there are no more pending mutations.\n const diffsMap = new DiffsMap();\n\n // Return replay commits if any.\n if (pending.length > 0) {\n return {\n syncHead: syncHeadHash,\n oldMainHead: mainHeadHash,\n mainHead: mainHeadHash,\n replayMutations: pending,\n // The changed keys are not reported when further replays are\n // needed. The diffs will be reported at the end when there\n // are no more mutations to be replay and then it will be reported\n // relative to DEFAULT_HEAD_NAME.\n diffs: diffsMap,\n };\n }\n\n // TODO check invariants\n\n // Compute diffs (changed keys) for value map and index maps.\n const mainHead = await commitFromHash(mainHeadHash, dagRead);\n if (diffConfig.shouldComputeDiffs()) {\n const mainHeadMap = new BTreeRead(\n dagRead,\n formatVersion,\n mainHead.valueHash,\n );\n const syncHeadMap = new BTreeRead(\n dagRead,\n formatVersion,\n syncHead.valueHash,\n );\n const valueDiff = await diff(mainHeadMap, syncHeadMap);\n diffsMap.set('', valueDiff);\n await addDiffsForIndexes(\n mainHead,\n syncHead,\n dagRead,\n diffsMap,\n diffConfig,\n formatVersion,\n );\n }\n\n // No mutations to replay so set the main head to the sync head and sync complete!\n await Promise.all([\n dagWrite.setHead(DEFAULT_HEAD_NAME, syncHeadHash),\n dagWrite.removeHead(SYNC_HEAD_NAME),\n ]);\n await dagWrite.commit();\n // main head was set to sync head\n const newMainHeadHash = syncHeadHash;\n\n if (lc.debug) {\n const [oldLastMutationID, oldCookie] = snapshotMetaParts(\n mainSnapshot,\n clientID,\n );\n const [newLastMutationID, newCookie] = snapshotMetaParts(\n syncSnapshot,\n clientID,\n );\n lc.debug(\n `Successfully pulled new snapshot with lastMutationID:`,\n newLastMutationID,\n `(prev:`,\n oldLastMutationID,\n `), cookie: `,\n newCookie,\n `(prev:`,\n oldCookie,\n `), sync head hash:`,\n syncHeadHash,\n ', main head hash:',\n mainHeadHash,\n `, valueHash:`,\n syncHead.valueHash,\n `(prev:`,\n mainSnapshot.valueHash,\n );\n }\n\n return {\n syncHead: syncHeadHash,\n oldMainHead: mainHeadHash,\n mainHead: newMainHeadHash,\n replayMutations: [],\n diffs: diffsMap,\n };\n });\n}\n"],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"push.js","names":[],"sources":["../../../../../replicache/src/sync/push.ts"],"sourcesContent":["import type {LogContext} from '@rocicorp/logger';\nimport {assert} from '../../../shared/src/asserts.ts';\nimport {jsonSchema} from '../../../shared/src/json-schema.ts';\nimport type {ReadonlyJSONValue} from '../../../shared/src/json.ts';\nimport * as valita from '../../../shared/src/valita.ts';\nimport type {Store} from '../dag/store.ts';\nimport {\n DEFAULT_HEAD_NAME,\n type LocalMetaDD31,\n commitIsLocalDD31,\n localMutations,\n} from '../db/commit.ts';\nimport type {FrozenJSONValue} from '../frozen-json.ts';\nimport {\n PushError,\n type Pusher,\n type PusherResult,\n assertPusherResult,\n} from '../pusher.ts';\nimport {ReportError} from '../report-error.ts';\nimport {toError} from '../to-error.ts';\nimport {withRead} from '../with-transactions.ts';\nimport {\n type ClientGroupID,\n type ClientID,\n clientGroupIDSchema,\n clientIDSchema,\n} from './ids.ts';\n\nexport const PUSH_VERSION_SDD = 0;\nexport const PUSH_VERSION_DD31 = 1;\n\n/**\n * Mutation describes a single mutation done on the client.\n */\nexport type MutationV1 = {\n readonly id: number;\n readonly name: string;\n readonly args: ReadonlyJSONValue;\n readonly timestamp: number;\n readonly clientID: ClientID;\n};\n\nexport type Mutation = MutationV1;\n\nconst mutationV1Schema: valita.Type<MutationV1> = valita.readonlyObject({\n id: valita.number(),\n name: valita.string(),\n args: jsonSchema,\n timestamp: valita.number(),\n clientID: clientIDSchema,\n});\n\n/**\n * The JSON value used as the body when doing a POST to the [push\n * endpoint](/reference/server-push).\n */\nexport type PushRequestV1 = {\n pushVersion: 1;\n /**\n * `schemaVersion` can optionally be used to specify to the push endpoint\n * version information about the mutators the app is using (e.g., format of\n * mutator args).\n */\n schemaVersion: string;\n profileID: string;\n\n clientGroupID: ClientGroupID;\n mutations: MutationV1[];\n};\n\nconst pushRequestV1Schema = valita.object({\n pushVersion: valita.literal(1),\n schemaVersion: valita.string(),\n profileID: valita.string(),\n clientGroupID: clientGroupIDSchema,\n mutations: valita.array(mutationV1Schema),\n});\n\nexport type PushRequest = PushRequestV1;\n\nexport function assertPushRequestV1(\n value: unknown,\n): asserts value is PushRequestV1 {\n valita.assert(value, pushRequestV1Schema);\n}\n\n/**\n * Mutation describes a single mutation done on the client.\n */\ntype FrozenMutationV1 = {\n readonly id: number;\n readonly name: string;\n readonly args: FrozenJSONValue;\n readonly timestamp: number;\n readonly clientID: ClientID;\n};\n\nfunction convertDD31(lm: LocalMetaDD31): FrozenMutationV1 {\n return {\n id: lm.mutationID,\n name: lm.mutatorName,\n args: lm.mutatorArgsJSON,\n timestamp: lm.timestamp,\n clientID: lm.clientID,\n };\n}\n\nexport async function push(\n requestID: string,\n store: Store,\n lc: LogContext,\n profileID: string,\n clientGroupID: ClientGroupID | undefined,\n _clientID: ClientID,\n pusher: Pusher,\n schemaVersion: string,\n pushVersion: typeof PUSH_VERSION_SDD | typeof PUSH_VERSION_DD31,\n): Promise<PusherResult | undefined> {\n // Find pending commits between the base snapshot and the main head and push\n // them to the data layer.\n const pending = await withRead(store, async dagRead => {\n const mainHeadHash = await dagRead.getHead(DEFAULT_HEAD_NAME);\n if (!mainHeadHash) {\n throw new Error('Internal no main head');\n }\n return localMutations(mainHeadHash, dagRead);\n // Important! Don't hold the lock through an HTTP request!\n });\n\n if (pending.length === 0) {\n return undefined;\n }\n\n // Commit.pending gave us commits in head-first order; the bindings\n // want tail first (in mutation id order).\n pending.reverse();\n\n assert(\n pushVersion === PUSH_VERSION_DD31,\n 'Expected pushVersion to be PUSH_VERSION_DD31',\n );\n\n const pushMutations: FrozenMutationV1[] = [];\n for (const commit of pending) {\n if (commitIsLocalDD31(commit)) {\n pushMutations.push(convertDD31(commit.meta));\n } else {\n throw new Error('Internal non local pending commit');\n }\n }\n assert(clientGroupID, 'Expected clientGroupID to be defined');\n const pushReq: PushRequestV1 = {\n profileID,\n clientGroupID,\n mutations: pushMutations,\n pushVersion: PUSH_VERSION_DD31,\n schemaVersion,\n };\n\n lc.debug?.('Starting push...');\n const pushStart = Date.now();\n const pusherResult = await callPusher(pusher, pushReq, requestID);\n lc.debug?.('...Push complete in ', Date.now() - pushStart, 'ms');\n return pusherResult;\n}\n\nasync function callPusher(\n pusher: Pusher,\n body: PushRequestV1,\n requestID: string,\n): Promise<PusherResult> {\n let pusherResult: PusherResult;\n try {\n pusherResult = await pusher(body, requestID);\n } catch (e) {\n throw new PushError(toError(e));\n }\n try {\n assertPusherResult(pusherResult);\n return pusherResult;\n } catch (e) {\n throw new ReportError('Invalid pusher result', toError(e));\n }\n}\n"],"mappings":";;;;;;;;;AA6CA,IAAM,mBAA4C,eAAsB;CACtE,IAAI,eAAO,QAAQ;CACnB,MAAM,eAAO,QAAQ;CACrB,MAAM;CACN,WAAW,eAAO,QAAQ;CAC1B,UAAU;CACX,CAAC;AAoB0B,eAAO,OAAO;CACxC,aAAa,eAAO,QAAQ,EAAE;CAC9B,eAAe,eAAO,QAAQ;CAC9B,WAAW,eAAO,QAAQ;CAC1B,eAAe;CACf,WAAW,eAAO,MAAM,iBAAiB;CAC1C,CAAC;AAqBF,SAAS,YAAY,IAAqC;AACxD,QAAO;EACL,IAAI,GAAG;EACP,MAAM,GAAG;EACT,MAAM,GAAG;EACT,WAAW,GAAG;EACd,UAAU,GAAG;EACd;;AAGH,eAAsB,KACpB,WACA,OACA,IACA,WACA,eACA,WACA,QACA,eACA,aACmC;CAGnC,MAAM,UAAU,MAAM,SAAS,OAAO,OAAM,YAAW;EACrD,MAAM,eAAe,MAAM,QAAQ,QAAQ,kBAAkB;AAC7D,MAAI,CAAC,aACH,OAAM,IAAI,MAAM,wBAAwB;AAE1C,SAAO,eAAe,cAAc,QAAQ;GAE5C;AAEF,KAAI,QAAQ,WAAW,EACrB;AAKF,SAAQ,SAAS;AAEjB,QACE,gBAAA,GACA,+CACD;CAED,MAAM,gBAAoC,EAAE;AAC5C,MAAK,MAAM,UAAU,QACnB,KAAI,kBAAkB,OAAO,CAC3B,eAAc,KAAK,YAAY,OAAO,KAAK,CAAC;KAE5C,OAAM,IAAI,MAAM,oCAAoC;AAGxD,QAAO,eAAe,uCAAuC;CAC7D,MAAM,UAAyB;EAC7B;EACA;EACA,WAAW;EACX,aAAA;EACA;EACD;AAED,IAAG,QAAQ,mBAAmB;CAC9B,MAAM,YAAY,KAAK,KAAK;CAC5B,MAAM,eAAe,MAAM,WAAW,QAAQ,SAAS,UAAU;AACjE,IAAG,QAAQ,wBAAwB,KAAK,KAAK,GAAG,WAAW,KAAK;AAChE,QAAO;;AAGT,eAAe,WACb,QACA,MACA,WACuB;CACvB,IAAI;AACJ,KAAI;AACF,iBAAe,MAAM,OAAO,MAAM,UAAU;UACrC,GAAG;AACV,QAAM,IAAI,UAAU,QAAQ,EAAE,CAAC;;AAEjC,KAAI;AACF,qBAAmB,aAAa;AAChC,SAAO;UACA,GAAG;AACV,QAAM,IAAI,YAAY,yBAAyB,QAAQ,EAAE,CAAC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"request-id.js","names":[],"sources":["../../../../../replicache/src/sync/request-id.ts"],"sourcesContent":["import {getNonCryptoRandomValues} from '../../../shared/src/random-values.ts';\nimport type {ClientID} from './ids.ts';\n\nlet sessionID = '';\nfunction getSessionID() {\n if (sessionID === '') {\n const buf = new Uint8Array(4);\n getNonCryptoRandomValues(buf);\n sessionID = Array.from(buf, x => x.toString(16)).join('');\n }\n return sessionID;\n}\n\nconst REQUEST_COUNTERS: Map<string, number> = new Map();\n\n/**\n * Returns a new requestID of the form <client ID>-<session ID>-<request\n * count>. The request count enables one to find the request following or\n * preceding a given request. The sessionid scopes the request count, ensuring\n * the requestID is probabilistically unique across restarts (which is good\n * enough).\n */\nexport function newRequestID(clientID: ClientID): string {\n const counter = REQUEST_COUNTERS.get(clientID) ?? 0;\n REQUEST_COUNTERS.set(clientID, counter + 1);\n return `${clientID}-${getSessionID()}-${counter}`;\n}\n"],"mappings":";;AAGA,IAAI,YAAY;AAChB,SAAS,eAAe;AACtB,KAAI,cAAc,IAAI;EACpB,MAAM,MAAM,IAAI,WAAW,EAAE;AAC7B,2BAAyB,IAAI;AAC7B,cAAY,MAAM,KAAK,MAAK,MAAK,EAAE,SAAS,GAAG,CAAC,CAAC,KAAK,GAAG;;AAE3D,QAAO;;AAGT,IAAM,mCAAwC,IAAI,KAAK;;;;;;;;AASvD,SAAgB,aAAa,UAA4B;CACvD,MAAM,UAAU,iBAAiB,IAAI,SAAS,IAAI;AAClD,kBAAiB,IAAI,UAAU,UAAU,EAAE;AAC3C,QAAO,GAAG,SAAS,GAAG,cAAc,CAAC,GAAG"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"sync-head-name.js","names":[],"sources":["../../../../../replicache/src/sync/sync-head-name.ts"],"sourcesContent":["export const SYNC_HEAD_NAME = 'sync';\n"],"mappings":";AAAA,IAAa,iBAAiB"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"to-error.js","names":[],"sources":["../../../../replicache/src/to-error.ts"],"sourcesContent":["export function toError(e: unknown): Error {\n if (e instanceof Error) {\n return e;\n }\n return new Error(String(e));\n}\n"],"mappings":";AAAA,SAAgB,QAAQ,GAAmB;AACzC,KAAI,aAAa,MACf,QAAO;AAET,QAAO,IAAI,MAAM,OAAO,EAAE,CAAC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"transaction-closed-error.js","names":[],"sources":["../../../../replicache/src/transaction-closed-error.ts"],"sourcesContent":["/**\n * This error is thrown when you try to call methods on a closed transaction.\n */\nexport class TransactionClosedError extends Error {\n constructor() {\n super('Transaction is closed');\n }\n}\n\nexport type Closed = {closed: boolean};\n\nexport function throwIfClosed(tx: Closed): void {\n if (tx.closed) {\n throw new TransactionClosedError();\n }\n}\n\nexport function rejectIfClosed(tx: Closed): undefined | Promise<never> {\n return tx.closed ? Promise.reject(new TransactionClosedError()) : undefined;\n}\n"],"mappings":";;;;AAGA,IAAa,yBAAb,cAA4C,MAAM;CAChD,cAAc;AACZ,QAAM,wBAAwB;;;AAMlC,SAAgB,cAAc,IAAkB;AAC9C,KAAI,GAAG,OACL,OAAM,IAAI,wBAAwB;;AAItC,SAAgB,eAAe,IAAwC;AACrE,QAAO,GAAG,SAAS,QAAQ,OAAO,IAAI,wBAAwB,CAAC,GAAG,KAAA"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"transactions.js","names":["#keys","#scans","#tx"],"sources":["../../../../replicache/src/transactions.ts"],"sourcesContent":["import type {LogContext} from '@rocicorp/logger';\nimport {greaterThan} from 'compare-utf8';\nimport type {JSONValue, ReadonlyJSONValue} from '../../shared/src/json.ts';\nimport {type IndexKey, decodeIndexKey} from './db/index.ts';\nimport type {Read} from './db/read.ts';\nimport type {Write} from './db/write.ts';\nimport {deepFreeze} from './frozen-json.ts';\nimport type {IndexDefinition} from './index-defs.ts';\nimport type {ZeroTxData} from './replicache-options.ts';\nimport type {ScanResult} from './scan-iterator.ts';\nimport {ScanResultImpl, fromKeyForIndexScanInternal} from './scan-iterator.ts';\nimport {\n type KeyTypeForScanOptions,\n type ScanIndexOptions,\n type ScanNoIndexOptions,\n type ScanOptions,\n isScanIndexOptions,\n toDbScanOptions,\n} from './scan-options.ts';\nimport type {ScanSubscriptionInfo} from './subscriptions.ts';\nimport type {ClientID} from './sync/ids.ts';\nimport {rejectIfClosed, throwIfClosed} from './transaction-closed-error.ts';\n\nexport type TransactionEnvironment = 'client' | 'server';\nexport type TransactionLocation = TransactionEnvironment;\nexport type TransactionReason = 'initial' | 'rebase' | 'authoritative';\n\n/**\n * Basic deep readonly type. It works for {@link JSONValue}.\n */\nexport type DeepReadonly<T> = T extends\n | null\n | boolean\n | string\n | number\n | undefined\n ? T\n : DeepReadonlyObject<T>;\n\nexport type DeepReadonlyObject<T> = {\n readonly [K in keyof T]: DeepReadonly<T[K]>;\n};\n\n/**\n * ReadTransactions are used with {@link Replicache.query} and\n * {@link Replicache.subscribe} and allows read operations on the\n * database.\n */\nexport interface ReadTransaction {\n readonly clientID: ClientID;\n /** @deprecated Use {@link ReadTransaction.location} instead. */\n readonly environment: TransactionLocation;\n readonly location: TransactionLocation;\n\n /**\n * Get a single value from the database. If the `key` is not present this\n * returns `undefined`.\n *\n * Important: The returned JSON is readonly and should not be modified. This\n * is only enforced statically by TypeScript and there are no runtime checks\n * for performance reasons. If you mutate the return value you will get\n * undefined behavior.\n */\n\n get(key: string): Promise<ReadonlyJSONValue | undefined>;\n get<T extends JSONValue>(key: string): Promise<DeepReadonly<T> | undefined>;\n\n /** Determines if a single `key` is present in the database. */\n has(key: string): Promise<boolean>;\n\n /** Whether the database is empty. */\n isEmpty(): Promise<boolean>;\n\n /**\n * Gets many values from the database. This returns a {@link ScanResult} which\n * implements `AsyncIterable`. It also has methods to iterate over the\n * {@link ScanResult.keys | keys} and {@link ScanResult.entries | entries}.\n *\n * If `options` has an `indexName`, then this does a scan over an index with\n * that name. A scan over an index uses a tuple for the key consisting of\n * `[secondary: string, primary: string]`.\n *\n * If the {@link ScanResult} is used after the `ReadTransaction` has been closed\n * it will throw a {@link TransactionClosedError}.\n *\n * Important: The returned JSON is readonly and should not be modified. This\n * is only enforced statically by TypeScript and there are no runtime checks\n * for performance reasons. If you mutate the return value you will get\n * undefined behavior.\n */\n scan(options: ScanIndexOptions): ScanResult<IndexKey, ReadonlyJSONValue>;\n scan(options?: ScanNoIndexOptions): ScanResult<string, ReadonlyJSONValue>;\n scan(options?: ScanOptions): ScanResult<IndexKey | string, ReadonlyJSONValue>;\n\n scan<V extends ReadonlyJSONValue>(\n options: ScanIndexOptions,\n ): ScanResult<IndexKey, DeepReadonly<V>>;\n scan<V extends ReadonlyJSONValue>(\n options?: ScanNoIndexOptions,\n ): ScanResult<string, DeepReadonly<V>>;\n scan<V extends ReadonlyJSONValue>(\n options?: ScanOptions,\n ): ScanResult<IndexKey | string, DeepReadonly<V>>;\n}\n\nlet transactionIDCounter = 0;\n\nexport class ReadTransactionImpl implements ReadTransaction {\n readonly clientID: ClientID;\n readonly dbtx: Read;\n protected readonly _lc: LogContext;\n\n /**\n * The location in which this transaction is being used. This is either `client` or `server`.\n */\n readonly location: TransactionLocation;\n /** @deprecated Use {@link ReadTransaction.location} instead. */\n readonly environment: TransactionLocation;\n\n constructor(\n clientID: ClientID,\n dbRead: Read,\n lc: LogContext,\n rpcName = 'openReadTransaction',\n ) {\n this.clientID = clientID;\n this.dbtx = dbRead;\n this._lc = lc\n .withContext(rpcName)\n .withContext('txid', transactionIDCounter++);\n this.environment = 'client';\n this.location = 'client';\n }\n\n get(key: string): Promise<ReadonlyJSONValue | undefined>;\n get<V extends JSONValue>(key: string): Promise<DeepReadonly<V> | undefined> {\n return (\n rejectIfClosed(this.dbtx) ||\n (this.dbtx.get(key) as Promise<DeepReadonly<V> | undefined>)\n );\n }\n\n // oxlint-disable-next-line require-await\n async has(key: string): Promise<boolean> {\n throwIfClosed(this.dbtx);\n return this.dbtx.has(key);\n }\n\n // oxlint-disable-next-line require-await\n async isEmpty(): Promise<boolean> {\n throwIfClosed(this.dbtx);\n return this.dbtx.isEmpty();\n }\n\n scan(options: ScanIndexOptions): ScanResult<IndexKey, ReadonlyJSONValue>;\n scan(options?: ScanNoIndexOptions): ScanResult<string, ReadonlyJSONValue>;\n scan(options?: ScanOptions): ScanResult<IndexKey | string, ReadonlyJSONValue>;\n\n scan<V extends ReadonlyJSONValue>(\n options: ScanIndexOptions,\n ): ScanResult<IndexKey, DeepReadonly<V>>;\n scan<V extends ReadonlyJSONValue>(\n options?: ScanNoIndexOptions,\n ): ScanResult<string, DeepReadonly<V>>;\n scan<V extends ReadonlyJSONValue>(\n options?: ScanOptions,\n ): ScanResult<IndexKey | string, DeepReadonly<V>>;\n\n scan(\n options?: ScanOptions,\n ): ScanResult<IndexKey | string, ReadonlyJSONValue> {\n return scan(options, this.dbtx, noop);\n }\n}\n\nfunction noop(_: unknown): void {\n // empty\n}\n\nfunction scan<Options extends ScanOptions, V extends JSONValue>(\n options: Options | undefined,\n dbRead: Read,\n onLimitKey: (inclusiveLimitKey: string) => void,\n): ScanResult<KeyTypeForScanOptions<Options>, V> {\n const iter = getScanIterator<Options, V>(dbRead, options);\n return makeScanResultFromScanIteratorInternal(\n iter,\n options ?? ({} as Options),\n dbRead,\n onLimitKey,\n );\n}\n\n// An implementation of ReadTransaction that keeps track of `keys` and `scans`\n// for use with Subscriptions.\nexport class SubscriptionTransactionWrapper implements ReadTransaction {\n readonly #keys: Set<string> = new Set();\n readonly #scans: ScanSubscriptionInfo[] = [];\n readonly #tx: ReadTransactionImpl;\n\n constructor(tx: ReadTransactionImpl) {\n this.#tx = tx;\n }\n\n get environment(): TransactionLocation {\n return this.#tx.location;\n }\n\n get location(): TransactionLocation {\n return this.#tx.location;\n }\n\n get clientID(): string {\n return this.#tx.clientID;\n }\n\n isEmpty(): Promise<boolean> {\n // Any change to the subscription requires rerunning it.\n this.#scans.push({options: {}});\n return this.#tx.isEmpty();\n }\n\n get(key: string): Promise<ReadonlyJSONValue | undefined>;\n get<T extends JSONValue>(key: string): Promise<DeepReadonly<T> | undefined> {\n this.#keys.add(key);\n return this.#tx.get(key) as Promise<DeepReadonly<T> | undefined>;\n }\n\n has(key: string): Promise<boolean> {\n this.#keys.add(key);\n return this.#tx.has(key);\n }\n\n scan(options: ScanIndexOptions): ScanResult<IndexKey, ReadonlyJSONValue>;\n scan(options?: ScanNoIndexOptions): ScanResult<string, ReadonlyJSONValue>;\n scan(options?: ScanOptions): ScanResult<IndexKey | string, ReadonlyJSONValue>;\n\n scan<V extends ReadonlyJSONValue>(\n options: ScanIndexOptions,\n ): ScanResult<IndexKey, DeepReadonly<V>>;\n scan<V extends ReadonlyJSONValue>(\n options?: ScanNoIndexOptions,\n ): ScanResult<string, DeepReadonly<V>>;\n scan<V extends ReadonlyJSONValue>(\n options?: ScanOptions,\n ): ScanResult<IndexKey | string, DeepReadonly<V>>;\n\n scan(\n options?: ScanOptions,\n ): ScanResult<IndexKey | string, ReadonlyJSONValue> {\n const scanInfo: ScanSubscriptionInfo = {\n options: toDbScanOptions(options),\n inclusiveLimitKey: undefined,\n };\n this.#scans.push(scanInfo);\n return scan(options, this.#tx.dbtx, inclusiveLimitKey => {\n scanInfo.inclusiveLimitKey = inclusiveLimitKey;\n });\n }\n\n get keys(): ReadonlySet<string> {\n return this.#keys;\n }\n\n get scans(): ScanSubscriptionInfo[] {\n return this.#scans;\n }\n}\n\n/**\n * WriteTransactions are used with *mutators* which are registered using\n * {@link ReplicacheOptions.mutators} and allows read and write operations on the\n * database.\n */\nexport interface WriteTransaction extends ReadTransaction {\n /**\n * The ID of the mutation that is being applied.\n */\n readonly mutationID: number;\n\n /**\n * The reason for the transaction. This can be `initial`, `rebase` or `authoriative`.\n */\n readonly reason: TransactionReason;\n\n /**\n * Sets a single `value` in the database. The value will be frozen (using\n * `Object.freeze`) in debug mode.\n */\n set(key: string, value: ReadonlyJSONValue): Promise<void>;\n\n /**\n * @deprecated Use {@link WriteTransaction.set} instead.\n */\n put(key: string, value: ReadonlyJSONValue): Promise<void>;\n\n /**\n * Removes a `key` and its value from the database. Returns `true` if there was a\n * `key` to remove.\n */\n del(key: string): Promise<boolean>;\n}\n\n// Internal symbol, not exported by Replicache\n// but accessible to Zero.\nexport const zeroData = Symbol();\n\nexport class WriteTransactionImpl\n extends ReadTransactionImpl\n implements WriteTransaction\n{\n // use `declare` to specialize the type.\n declare readonly dbtx: Write;\n readonly reason: TransactionReason;\n readonly mutationID: number;\n readonly [zeroData]: ZeroTxData | undefined;\n\n constructor(\n clientID: ClientID,\n mutationID: number,\n reason: TransactionReason,\n zData: ZeroTxData | undefined,\n dbWrite: Write,\n lc: LogContext,\n rpcName = 'openWriteTransaction',\n ) {\n super(clientID, dbWrite, lc, rpcName);\n this.mutationID = mutationID;\n this.reason = reason;\n this[zeroData] = zData;\n }\n\n put(key: string, value: ReadonlyJSONValue): Promise<void> {\n return this.set(key, value);\n }\n\n async set(key: string, value: ReadonlyJSONValue): Promise<void> {\n throwIfClosed(this.dbtx);\n await this.dbtx.put(this._lc, key, deepFreeze(value));\n }\n\n del(key: string): Promise<boolean> {\n return rejectIfClosed(this.dbtx) ?? this.dbtx.del(this._lc, key);\n }\n}\n\nexport type CreateIndexDefinition = IndexDefinition & {name: string};\n\ntype Entry<Key, Value> = readonly [key: Key, value: Value];\n\ntype IndexKeyEntry<Value> = Entry<IndexKey, Value>;\n\ntype StringKeyEntry<Value> = Entry<string, Value>;\n\nexport type EntryForOptions<\n Options extends ScanOptions,\n V,\n> = Options extends ScanIndexOptions ? IndexKeyEntry<V> : StringKeyEntry<V>;\n\nfunction getScanIterator<Options extends ScanOptions, V>(\n dbRead: Read,\n options: Options | undefined,\n): AsyncIterable<EntryForOptions<Options, V>> {\n if (options && isScanIndexOptions(options)) {\n return getScanIteratorForIndexMap(dbRead, options) as AsyncIterable<\n EntryForOptions<Options, V>\n >;\n }\n\n return dbRead.map.scan(fromKeyForNonIndexScan(options)) as AsyncIterable<\n EntryForOptions<Options, V>\n >;\n}\n\nexport function fromKeyForNonIndexScan(\n options: ScanNoIndexOptions | undefined,\n): string {\n if (!options) {\n return '';\n }\n\n const {prefix = '', start} = options;\n if (start && greaterThan(start.key, prefix)) {\n return start.key;\n }\n return prefix;\n}\n\nfunction makeScanResultFromScanIteratorInternal<\n Options extends ScanOptions,\n V extends JSONValue,\n>(\n iter: AsyncIterable<EntryForOptions<Options, V>>,\n options: Options,\n dbRead: Read,\n onLimitKey: (inclusiveLimitKey: string) => void,\n): ScanResult<KeyTypeForScanOptions<Options>, V> {\n return new ScanResultImpl(iter, options, dbRead, onLimitKey);\n}\n\nasync function* getScanIteratorForIndexMap(\n dbRead: Read,\n options: ScanIndexOptions,\n): AsyncIterable<IndexKeyEntry<ReadonlyJSONValue>> {\n const map = dbRead.getMapForIndex(options.indexName);\n for await (const entry of map.scan(fromKeyForIndexScanInternal(options))) {\n yield [decodeIndexKey(entry[0]), entry[1]];\n }\n}\n"],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"version.js","names":[],"sources":["../../../../replicache/src/version.ts"],"sourcesContent":["// The env value should be filled in by esbuild.\n\ndeclare const process: {\n env: {\n ['REPLICACHE_VERSION']?: string;\n };\n};\n\n/**\n * The current version of Replicache.\n */\nexport const version: string = process.env.REPLICACHE_VERSION ?? '0.0.0';\n"],"mappings":";;;;AAWA,IAAa,UAAA"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"with-transactions.js","names":[],"sources":["../../../../replicache/src/with-transactions.ts"],"sourcesContent":["export interface Release {\n release(): void;\n}\n\nexport interface Commit {\n commit(): Promise<void>;\n}\n\ninterface ReadStore<Read extends Release> {\n read(): Promise<Read>;\n}\n\ninterface WriteStore<Write extends Release> {\n write(): Promise<Write>;\n}\n\nexport function withRead<Read extends Release, Return>(\n store: ReadStore<Read>,\n fn: (read: Read) => Return | Promise<Return>,\n): Promise<Return> {\n return using(store.read(), fn);\n}\n\nexport function withWriteNoImplicitCommit<Write extends Release, Return>(\n store: WriteStore<Write>,\n fn: (write: Write) => Return | Promise<Return>,\n): Promise<Return> {\n return using(store.write(), fn);\n}\n\nexport function withWrite<Write extends Release & Commit, Return>(\n store: WriteStore<Write>,\n fn: (write: Write) => Return | Promise<Return>,\n): Promise<Return> {\n return using(store.write(), async write => {\n const result = await fn(write);\n await write.commit();\n return result;\n });\n}\n\n/**\n * This function takes a promise for a resource and a function that uses that\n * resource. It will release the resource after the function returns by calling\n * the `release` function\n */\nexport async function using<TX extends Release, Return>(\n x: Promise<TX>,\n fn: (tx: TX) => Return | Promise<Return>,\n): Promise<Return> {\n const write = await x;\n let result: Return | undefined;\n let operationError: unknown;\n try {\n result = await fn(write);\n } catch (e) {\n operationError = e;\n }\n\n try {\n write.release();\n } catch (releaseError) {\n if (operationError !== undefined) {\n const combinedError = new Error(\n `Transaction operation failed and release also failed: operation error = ${String(\n operationError,\n )}; release error = ${String(releaseError)}`,\n );\n combinedError.cause = operationError;\n throw combinedError;\n }\n throw releaseError;\n }\n\n if (operationError !== undefined) {\n throw operationError;\n }\n return result as Return;\n}\n"],"mappings":";AAgBA,SAAgB,SACd,OACA,IACiB;AACjB,QAAO,MAAM,MAAM,MAAM,EAAE,GAAG;;AAGhC,SAAgB,0BACd,OACA,IACiB;AACjB,QAAO,MAAM,MAAM,OAAO,EAAE,GAAG;;AAGjC,SAAgB,UACd,OACA,IACiB;AACjB,QAAO,MAAM,MAAM,OAAO,EAAE,OAAM,UAAS;EACzC,MAAM,SAAS,MAAM,GAAG,MAAM;AAC9B,QAAM,MAAM,QAAQ;AACpB,SAAO;GACP;;;;;;;AAQJ,eAAsB,MACpB,GACA,IACiB;CACjB,MAAM,QAAQ,MAAM;CACpB,IAAI;CACJ,IAAI;AACJ,KAAI;AACF,WAAS,MAAM,GAAG,MAAM;UACjB,GAAG;AACV,mBAAiB;;AAGnB,KAAI;AACF,QAAM,SAAS;UACR,cAAc;AACrB,MAAI,mBAAmB,KAAA,GAAW;GAChC,MAAM,gCAAgB,IAAI,MACxB,2EAA2E,OACzE,eACD,CAAC,oBAAoB,OAAO,aAAa,GAC3C;AACD,iBAAc,QAAQ;AACtB,SAAM;;AAER,QAAM;;AAGR,KAAI,mBAAmB,KAAA,EACrB,OAAM;AAER,QAAO"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"abort-error.js","names":[],"sources":["../../../../shared/src/abort-error.ts"],"sourcesContent":["export class AbortError extends Error {\n name = 'AbortError';\n}\n"],"mappings":";AAAA,IAAa,aAAb,cAAgC,MAAM;CACpC,OAAO"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"arrays.js","names":[],"sources":["../../../../shared/src/arrays.ts"],"sourcesContent":["import {assert} from './asserts.ts';\n\n/**\n * Returns `arr` as is if none of the elements are `undefined`.\n * Otherwise returns a new array with only defined elements in `arr`.\n */\nexport function defined<T>(arr: (T | undefined)[]): T[] {\n // avoid an array copy if possible\n let i = arr.findIndex(x => x === undefined);\n if (i < 0) {\n return arr as T[];\n }\n const defined: T[] = arr.slice(0, i) as T[];\n for (i++; i < arr.length; i++) {\n const x = arr[i];\n if (x !== undefined) {\n defined.push(x);\n }\n }\n return defined;\n}\n\nexport function areEqual<T>(arr1: readonly T[], arr2: readonly T[]): boolean {\n return arr1.length === arr2.length && arr1.every((e, i) => e === arr2[i]);\n}\n\nexport function zip<T1, T2>(a1: readonly T1[], a2: readonly T2[]): [T1, T2][] {\n assert(a1.length === a2.length, 'zip: arrays must have equal length');\n const result: [T1, T2][] = [];\n for (let i = 0; i < a1.length; i++) {\n result.push([a1[i], a2[i]]);\n }\n return result;\n}\n\nexport function last<T>(arr: T[]): T | undefined {\n return arr.at(-1);\n}\n\nexport function groupBy<T, K>(\n arr: readonly T[],\n keyFn: (el: T) => K,\n): Map<K, T[]> {\n const groups = new Map<K, T[]>();\n for (const el of arr) {\n const key = keyFn(el);\n let group = groups.get(key);\n if (group === undefined) {\n group = [];\n groups.set(key, group);\n }\n group.push(el);\n }\n return groups;\n}\n"],"mappings":";;;;;;AAMA,SAAgB,QAAW,KAA6B;CAEtD,IAAI,IAAI,IAAI,WAAU,MAAK,MAAM,KAAA,EAAU;AAC3C,KAAI,IAAI,EACN,QAAO;CAET,MAAM,UAAe,IAAI,MAAM,GAAG,EAAE;AACpC,MAAK,KAAK,IAAI,IAAI,QAAQ,KAAK;EAC7B,MAAM,IAAI,IAAI;AACd,MAAI,MAAM,KAAA,EACR,SAAQ,KAAK,EAAE;;AAGnB,QAAO;;AAGT,SAAgB,SAAY,MAAoB,MAA6B;AAC3E,QAAO,KAAK,WAAW,KAAK,UAAU,KAAK,OAAO,GAAG,MAAM,MAAM,KAAK,GAAG;;AAG3E,SAAgB,IAAY,IAAmB,IAA+B;AAC5E,QAAO,GAAG,WAAW,GAAG,QAAQ,qCAAqC;CACrE,MAAM,SAAqB,EAAE;AAC7B,MAAK,IAAI,IAAI,GAAG,IAAI,GAAG,QAAQ,IAC7B,QAAO,KAAK,CAAC,GAAG,IAAI,GAAG,GAAG,CAAC;AAE7B,QAAO;;AAGT,SAAgB,KAAQ,KAAyB;AAC/C,QAAO,IAAI,GAAG,GAAG;;AAGnB,SAAgB,QACd,KACA,OACa;CACb,MAAM,yBAAS,IAAI,KAAa;AAChC,MAAK,MAAM,MAAM,KAAK;EACpB,MAAM,MAAM,MAAM,GAAG;EACrB,IAAI,QAAQ,OAAO,IAAI,IAAI;AAC3B,MAAI,UAAU,KAAA,GAAW;AACvB,WAAQ,EAAE;AACV,UAAO,IAAI,KAAK,MAAM;;AAExB,QAAM,KAAK,GAAG;;AAEhB,QAAO"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"asserts.js","names":[],"sources":["../../../../shared/src/asserts.ts"],"sourcesContent":["export function assert(b: unknown, msg: string | (() => string)): asserts b {\n if (!b) {\n throw new Error(typeof msg === 'string' ? msg : msg());\n }\n}\n\nexport function assertString(v: unknown): asserts v is string {\n assertType(v, 'string');\n}\n\nexport function assertNumber(v: unknown): asserts v is number {\n assertType(v, 'number');\n}\n\nexport function assertBoolean(v: unknown): asserts v is boolean {\n assertType(v, 'boolean');\n}\n\nfunction assertType(v: unknown, t: string) {\n if (typeof v !== t) {\n throwInvalidType(v, t);\n }\n}\n\nexport function assertObject(v: unknown): asserts v is Record<string, unknown> {\n if (v === null) {\n throwInvalidType(v, 'object');\n }\n assertType(v, 'object');\n}\n\nexport function assertArray(v: unknown): asserts v is unknown[] {\n if (!Array.isArray(v)) {\n throwInvalidType(v, 'array');\n }\n}\n\nexport function invalidType(v: unknown, t: string): string {\n let s = 'Invalid type: ';\n if (v === null || v === undefined) {\n s += v;\n } else {\n s += `${typeof v} \\`${v}\\``;\n }\n return s + `, expected ${t}`;\n}\n\nexport function throwInvalidType(v: unknown, t: string): never {\n throw new Error(invalidType(v, t));\n}\n\nexport function assertNotNull<T>(v: T | null): asserts v is T {\n if (v === null) {\n throw new Error('Expected non-null value');\n }\n}\n\nexport function assertUndefined<T>(\n v: T | undefined,\n msg = 'Expected undefined value',\n): asserts v is T {\n if (v !== undefined) {\n throw new Error(msg);\n }\n}\n\nexport function assertNotUndefined<T>(\n v: T | undefined,\n msg = 'Expected non undefined value',\n): asserts v is T {\n if (v === undefined) {\n throw new Error(msg);\n }\n}\n\nexport function assertInstanceof<T>(\n v: unknown,\n t: new (...args: unknown[]) => T,\n): asserts v is T {\n if (!(v instanceof t)) {\n throw new Error(`Expected instanceof ${t.name}`);\n }\n}\n\nexport function assertUint8Array(v: unknown): asserts v is Uint8Array {\n assertInstanceof(v, Uint8Array);\n}\n\nexport function unreachable(): never;\nexport function unreachable(v: never): never;\nexport function unreachable(_?: never): never {\n throw new Error('Unreachable');\n}\n\nexport function notImplemented(): never {\n throw new Error('Not implemented');\n}\n"],"mappings":";AAAA,SAAgB,OAAO,GAAY,KAAyC;AAC1E,KAAI,CAAC,EACH,OAAM,IAAI,MAAM,OAAO,QAAQ,WAAW,MAAM,KAAK,CAAC;;AAI1D,SAAgB,aAAa,GAAiC;AAC5D,YAAW,GAAG,SAAS;;AAGzB,SAAgB,aAAa,GAAiC;AAC5D,YAAW,GAAG,SAAS;;AAGzB,SAAgB,cAAc,GAAkC;AAC9D,YAAW,GAAG,UAAU;;AAG1B,SAAS,WAAW,GAAY,GAAW;AACzC,KAAI,OAAO,MAAM,EACf,kBAAiB,GAAG,EAAE;;AAI1B,SAAgB,aAAa,GAAkD;AAC7E,KAAI,MAAM,KACR,kBAAiB,GAAG,SAAS;AAE/B,YAAW,GAAG,SAAS;;AAGzB,SAAgB,YAAY,GAAoC;AAC9D,KAAI,CAAC,MAAM,QAAQ,EAAE,CACnB,kBAAiB,GAAG,QAAQ;;AAIhC,SAAgB,YAAY,GAAY,GAAmB;CACzD,IAAI,IAAI;AACR,KAAI,MAAM,QAAQ,MAAM,KAAA,EACtB,MAAK;KAEL,MAAK,GAAG,OAAO,EAAE,KAAK,EAAE;AAE1B,QAAO,IAAI,cAAc;;AAG3B,SAAgB,iBAAiB,GAAY,GAAkB;AAC7D,OAAM,IAAI,MAAM,YAAY,GAAG,EAAE,CAAC;;AAGpC,SAAgB,cAAiB,GAA6B;AAC5D,KAAI,MAAM,KACR,OAAM,IAAI,MAAM,0BAA0B;;AAa9C,SAAgB,mBACd,GACA,MAAM,gCACU;AAChB,KAAI,MAAM,KAAA,EACR,OAAM,IAAI,MAAM,IAAI;;AAmBxB,SAAgB,YAAY,GAAkB;AAC5C,OAAM,IAAI,MAAM,cAAc"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"bigint-json.js","names":[],"sources":["../../../../shared/src/bigint-json.ts"],"sourcesContent":["/**\n * Background for using `json-custom-numbers`:\n *\n * https://neon.tech/blog/parsing-json-from-postgres-in-js\n */\nimport {\n parse as customParse,\n stringify as customStringify,\n} from 'json-custom-numbers';\nimport * as v from './valita.ts';\n\nfunction numberParser(_: unknown, v: string) {\n const n = +v;\n if (n >= Number.MIN_SAFE_INTEGER && n <= Number.MAX_SAFE_INTEGER) return n;\n if (v.includes('.') || v.includes('e') || v.includes('E')) {\n return n;\n }\n return BigInt(v);\n}\n\n// Variant of postgres.JSONValue adapted to include bigints\nexport type JSONValue =\n | null\n | string\n | number\n | bigint\n | boolean\n | readonly JSONValue[]\n | JSONObject;\n\nexport type JSONObject = {readonly [prop: string]: JSONValue | undefined};\n\nexport const jsonValueSchema: v.Type<JSONValue> = v.lazy(() => {\n const jsonObjectSchema = v.readonly(v.record(jsonValueSchema));\n\n return v.union(\n v.null(),\n v.string(),\n v.number(),\n v.bigint(),\n v.boolean(),\n v.readonly(v.array(jsonValueSchema)),\n jsonObjectSchema,\n );\n});\n\nexport const jsonObjectSchema = v.readonly(v.record(jsonValueSchema));\n\n/**\n * Parses JSON strings that may contain arbitrarily large integers. Integers\n * larger than {@link Number.MAX_SAFE_INTEGER} are deserialized as a `bigint`.\n */\nexport function parse(\n str: string,\n reviver?: (k: string, v: unknown) => unknown,\n): JSONValue {\n return customParse(str, reviver, numberParser);\n}\n\n// oxlint-disable-next-line @typescript-eslint/no-explicit-any\nfunction customSerializer(_: string, v: any, type: string) {\n if (type === 'bigint') return v.toString();\n}\n\n/**\n * Stringifies objects to JSON, supporting objects containing bigint values.\n * Note that the resulting JSON string may not be deserializable by\n * all environments, but it is supported by Postgres. The string should be\n * deserialized with the corresponding {@link parse} method that will represent\n * large numbers as bigints. From there it is up to the application to suitably\n * handle bigints passed to downstream logic.\n */\nexport function stringify(\n obj: unknown,\n replacer?:\n | (string | number)[]\n | ((key: string, value: unknown) => unknown)\n | null,\n indent?: string | number,\n) {\n return customStringify(obj, replacer, indent, customSerializer);\n}\n\nexport const BigIntJSON = {\n parse,\n stringify,\n} as const;\n"],"mappings":";;;;;;;;AAWA,SAAS,aAAa,GAAY,GAAW;CAC3C,MAAM,IAAI,CAAC;AACX,KAAI,KAAK,OAAO,oBAAoB,KAAK,OAAO,iBAAkB,QAAO;AACzE,KAAI,EAAE,SAAS,IAAI,IAAI,EAAE,SAAS,IAAI,IAAI,EAAE,SAAS,IAAI,CACvD,QAAO;AAET,QAAO,OAAO,EAAE;;AAelB,IAAa,kBAAqC,eAAE,WAAW;CAC7D,MAAM,mBAAmB,SAAW,eAAE,OAAO,gBAAgB,CAAC;AAE9D,QAAO,eAAE,MACP,eAAE,MAAM,EACR,eAAE,QAAQ,EACV,eAAE,QAAQ,EACV,eAAE,QAAQ,EACV,eAAE,SAAS,EACX,SAAW,eAAE,MAAM,gBAAgB,CAAC,EACpC,iBACD;EACD;AAEF,IAAa,mBAAmB,SAAW,eAAE,OAAO,gBAAgB,CAAC;;;;;AAMrE,SAAgB,QACd,KACA,SACW;AACX,QAAO,MAAY,KAAK,SAAS,aAAa;;AAIhD,SAAS,iBAAiB,GAAW,GAAQ,MAAc;AACzD,KAAI,SAAS,SAAU,QAAO,EAAE,UAAU;;;;;;;;;;AAW5C,SAAgB,YACd,KACA,UAIA,QACA;AACA,QAAO,UAAgB,KAAK,UAAU,QAAQ,iBAAiB;;AAGjE,IAAa,aAAa;CACxB,OAAA;CACA,WAAA;CACD"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"binary-search.js","names":[],"sources":["../../../../shared/src/binary-search.ts"],"sourcesContent":["/**\n * This is a binary search that returns the index of the first element in the\n * array that is greater than or equal to the given value.\n *\n * Typical usage:\n *\n * ```\n * const haystack = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9];\n * const needle = 3;\n * const index = binarySearch(haystack.length, i => needle - haystack[i]);\n * const found = index < haystack.length && haystack[index] === needle;\n * ```\n */\nexport function binarySearch(high: number, compare: (i: number) => number) {\n let low = 0;\n while (low < high) {\n const mid = low + ((high - low) >> 1);\n const i = compare(mid);\n if (i === 0) {\n return mid;\n }\n if (i > 0) {\n low = mid + 1;\n } else {\n high = mid;\n }\n }\n return low;\n}\n"],"mappings":";;;;;;;;;;;;;;AAaA,SAAgB,aAAa,MAAc,SAAgC;CACzE,IAAI,MAAM;AACV,QAAO,MAAM,MAAM;EACjB,MAAM,MAAM,OAAQ,OAAO,OAAQ;EACnC,MAAM,IAAI,QAAQ,IAAI;AACtB,MAAI,MAAM,EACR,QAAO;AAET,MAAI,IAAI,EACN,OAAM,MAAM;MAEZ,QAAO;;AAGX,QAAO"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"broadcast-channel.js","names":[],"sources":["../../../../shared/src/broadcast-channel.ts"],"sourcesContent":["/* oxlint-disable @typescript-eslint/no-explicit-any */\n\nclass NoopBroadcastChannel implements BroadcastChannel {\n readonly name: string;\n\n onmessage: ((this: BroadcastChannel, ev: MessageEvent<any>) => any) | null =\n null;\n\n onmessageerror:\n | ((this: BroadcastChannel, ev: MessageEvent<any>) => any)\n | null = null;\n\n constructor(name: string) {\n this.name = name;\n }\n\n addEventListener(): void {\n // noop\n }\n removeEventListener(): void {\n // noop\n }\n dispatchEvent(): boolean {\n return false;\n }\n\n close(): void {\n // noop\n }\n\n postMessage(): void {\n // noop\n }\n}\n\nconst bc: typeof BroadcastChannel =\n typeof BroadcastChannel === 'undefined'\n ? NoopBroadcastChannel\n : BroadcastChannel;\n\nexport {bc as BroadcastChannel};\n"],"mappings":";AAEA,IAAM,uBAAN,MAAuD;CACrD;CAEA,YACE;CAEF,iBAEW;CAEX,YAAY,MAAc;AACxB,OAAK,OAAO;;CAGd,mBAAyB;CAGzB,sBAA4B;CAG5B,gBAAyB;AACvB,SAAO;;CAGT,QAAc;CAId,cAAoB;;AAKtB,IAAM,KACJ,OAAO,qBAAqB,cACxB,uBACA"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"browser-env.js","names":[],"sources":["../../../../shared/src/browser-env.ts"],"sourcesContent":["// Helpers for some objects from the browser environment. These are wrapped in\n// functions because Replicache runs in environments that do not have these\n// objects (such as Web Workers, Deno etc).\n\ntype GlobalThis = typeof globalThis;\n\nconst overrides = new Map<keyof GlobalThis, GlobalThis[keyof GlobalThis]>();\n\nexport function overrideBrowserGlobal<T extends keyof GlobalThis>(\n name: T,\n value: GlobalThis[T],\n) {\n overrides.set(name, value);\n}\n\nexport function clearBrowserOverrides() {\n overrides.clear();\n}\n\nexport function getBrowserGlobal<T extends keyof GlobalThis>(\n name: T,\n): GlobalThis[T] | undefined {\n if (overrides.has(name)) {\n return overrides.get(name);\n }\n return globalThis[name];\n}\n\n/**\n * Returns the global method with the given name, bound to the global object.\n * This is important because some methods (e.g. `requestAnimationFrame`) are not\n * bound to the global object by default.\n *\n * If you end up using {@linkcode getBrowserGlobal} instead in a case like this:\n *\n * ```js\n * this.#raf = getBrowserGlobal('requestAnimationFrame') ?? rafFallback;\n * ...\n * this.#raf(() => ...);\n * ```\n *\n * You will end up with `Uncaught TypeError: Illegal invocation` because `this`\n * is not bound to the global object\n */\nexport function getBrowserGlobalMethod<T extends keyof GlobalThis>(\n name: T,\n): GlobalThis[T] | undefined {\n return getBrowserGlobal(name)?.bind(globalThis);\n}\n\nexport function mustGetBrowserGlobal<T extends keyof GlobalThis>(\n name: T,\n): GlobalThis[T] {\n const r = getBrowserGlobal(name);\n if (r === undefined) {\n throw new Error(\n `Unsupported JavaScript environment: Could not find ${name}.`,\n );\n }\n return r;\n}\n"],"mappings":";AAMA,IAAM,4BAAY,IAAI,KAAqD;AAa3E,SAAgB,iBACd,MAC2B;AAC3B,KAAI,UAAU,IAAI,KAAK,CACrB,QAAO,UAAU,IAAI,KAAK;AAE5B,QAAO,WAAW;;AAyBpB,SAAgB,qBACd,MACe;CACf,MAAM,IAAI,iBAAiB,KAAK;AAChC,KAAI,MAAM,KAAA,EACR,OAAM,IAAI,MACR,sDAAsD,KAAK,GAC5D;AAEH,QAAO"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"btree-set.js","names":["#root","#delete","#maxKey","#nodeQueue","#nodeIndex","#leaf","#i"],"sources":["../../../../shared/src/btree-set.ts"],"sourcesContent":["import {assert} from './asserts.ts';\n\nconst MAX_NODE_SIZE = 32;\n\ntype Comparator<K> = (a: K, b: K) => number;\n\nexport class BTreeSet<K> {\n #root: BNode<K> = emptyLeaf as BNode<K>;\n size: number = 0;\n\n readonly comparator: Comparator<K>;\n\n constructor(comparator: Comparator<K>, entries?: IterableIterator<K>) {\n this.comparator = comparator;\n if (entries) {\n for (const key of entries) {\n this.add(key);\n }\n }\n }\n\n /** Releases the tree so that its size is 0. */\n clear() {\n this.#root = emptyLeaf as BNode<K>;\n this.size = 0;\n }\n\n clone() {\n this.#root.isShared = true;\n const ret = new BTreeSet<K>(this.comparator);\n ret.#root = this.#root;\n ret.size = this.size;\n return ret;\n }\n\n get(key: K): K | undefined {\n return this.#root.get(key, this);\n }\n\n add(key: K): this {\n if (this.#root.isShared) this.#root = this.#root.clone();\n const result = this.#root.set(key, this);\n if (result === null) return this;\n // Root node has split, so create a new root node.\n this.#root = new BNodeInternal<K>([this.#root, result]);\n return this;\n }\n\n /**\n * Returns true if the key exists in the B+ tree, false if not.\n * Use get() for best performance; use has() if you need to\n * distinguish between \"undefined value\" and \"key not present\".\n * @param key Key to detect\n * @description Computational complexity: O(log size)\n */\n has(key: K): boolean {\n return this.#root.has(key, this);\n }\n\n /**\n * Removes a single key-value pair from the B+ tree.\n * @param key Key to find\n * @returns true if a pair was found and removed, false otherwise.\n * @description Computational complexity: O(log size)\n */\n delete(key: K): boolean {\n return this.#delete(key);\n }\n\n #delete(key: K): boolean {\n let root = this.#root;\n if (root.isShared) {\n this.#root = root = root.clone();\n }\n try {\n return root.delete(key, this);\n } finally {\n let isShared;\n while (root.keys.length <= 1 && root.isInternal()) {\n isShared ||= root.isShared;\n this.#root = root =\n root.keys.length === 0 ? emptyLeaf : root.children[0];\n }\n // If any ancestor of the new root was shared, the new root must also be shared\n if (isShared) {\n root.isShared = true;\n }\n }\n }\n\n keys(): IterableIterator<K> {\n return valuesFrom(this.#root, this.comparator, undefined, true);\n }\n\n values(): IterableIterator<K> {\n return valuesFrom(this.#root, this.comparator, undefined, true);\n }\n\n valuesFrom(lowestKey?: K, inclusive: boolean = true): IterableIterator<K> {\n return valuesFrom(this.#root, this.comparator, lowestKey, inclusive);\n }\n\n valuesReversed(): IterableIterator<K> {\n return valuesFromReversed(\n this.#maxKey(),\n this.#root,\n this.comparator,\n undefined,\n true,\n );\n }\n\n valuesFromReversed(\n highestKey?: K,\n inclusive: boolean = true,\n ): IterableIterator<K> {\n return valuesFromReversed(\n this.#maxKey(),\n this.#root,\n this.comparator,\n highestKey,\n inclusive,\n );\n }\n\n /** Gets the highest key in the tree. Complexity: O(1) */\n #maxKey(): K | undefined {\n return this.#root.maxKey();\n }\n\n [Symbol.iterator](): IterableIterator<K> {\n return this.keys();\n }\n\n /**\n * Builds a BTreeSet from a pre-sorted iterable in O(N) by constructing\n * the tree bottom-up. The caller must ensure entries are sorted by\n * `comparator`; violating this produces an invalid tree.\n */\n static fromSorted<K>(\n comparator: Comparator<K>,\n sortedEntries: Iterable<K>,\n ): BTreeSet<K> {\n const tree = new BTreeSet<K>(comparator);\n\n // Stream through entries, flushing a leaf node each time we fill MAX_NODE_SIZE keys.\n const leaves: BNode<K>[] = [];\n let currentKeys: K[] = [];\n let size = 0;\n\n for (const key of sortedEntries) {\n currentKeys.push(key);\n if (currentKeys.length === MAX_NODE_SIZE) {\n leaves.push(new BNode<K>(currentKeys));\n currentKeys = [];\n }\n size++;\n }\n\n if (currentKeys.length > 0) {\n leaves.push(new BNode<K>(currentKeys));\n }\n\n if (leaves.length === 0) return tree;\n\n tree.size = size;\n\n if (leaves.length === 1) {\n tree.#root = leaves[0];\n return tree;\n }\n\n // Build internal nodes bottom-up until a single root remains.\n let currentLevel: BNode<K>[] = leaves;\n while (currentLevel.length > 1) {\n const nextLevel: BNodeInternal<K>[] = [];\n for (let i = 0; i < currentLevel.length; i += MAX_NODE_SIZE) {\n nextLevel.push(\n new BNodeInternal<K>(currentLevel.slice(i, i + MAX_NODE_SIZE)),\n );\n }\n currentLevel = nextLevel;\n }\n\n tree.#root = currentLevel[0];\n return tree;\n }\n}\n\nclass BTreeForwardIterator<K> implements IterableIterator<K> {\n readonly #nodeQueue: BNode<K>[][];\n readonly #nodeIndex: number[];\n #leaf: BNode<K>;\n #i: number;\n\n constructor(\n nodeQueue: BNode<K>[][],\n nodeIndex: number[],\n leaf: BNode<K>,\n startI: number,\n ) {\n this.#nodeQueue = nodeQueue;\n this.#nodeIndex = nodeIndex;\n this.#leaf = leaf;\n this.#i = startI;\n }\n\n next(): IteratorResult<K> {\n for (;;) {\n if (++this.#i < this.#leaf.keys.length) {\n return {done: false, value: this.#leaf.keys[this.#i]};\n }\n\n let level = -1;\n for (;;) {\n if (++level >= this.#nodeQueue.length) {\n return {done: true, value: undefined as unknown as K};\n }\n if (++this.#nodeIndex[level] < this.#nodeQueue[level].length) {\n break;\n }\n }\n for (; level > 0; level--) {\n this.#nodeQueue[level - 1] = (\n this.#nodeQueue[level][this.#nodeIndex[level]] as BNodeInternal<K>\n ).children;\n this.#nodeIndex[level - 1] = 0;\n }\n this.#leaf = this.#nodeQueue[0][this.#nodeIndex[0]];\n this.#i = -1;\n }\n }\n\n [Symbol.iterator]() {\n return this;\n }\n}\n\nclass BTreeReverseIterator<K> implements IterableIterator<K> {\n readonly #nodeQueue: BNode<K>[][];\n readonly #nodeIndex: number[];\n #leaf: BNode<K>;\n #i: number;\n\n constructor(\n nodeQueue: BNode<K>[][],\n nodeIndex: number[],\n leaf: BNode<K>,\n startI: number,\n ) {\n this.#nodeQueue = nodeQueue;\n this.#nodeIndex = nodeIndex;\n this.#leaf = leaf;\n this.#i = startI;\n }\n\n next(): IteratorResult<K> {\n for (;;) {\n if (--this.#i >= 0) {\n return {done: false, value: this.#leaf.keys[this.#i]};\n }\n\n let level;\n // Advance to the next leaf node\n for (level = -1; ; ) {\n if (++level >= this.#nodeQueue.length) {\n return {done: true, value: undefined as unknown as K};\n }\n if (--this.#nodeIndex[level] >= 0) {\n break;\n }\n }\n for (; level > 0; level--) {\n this.#nodeQueue[level - 1] = (\n this.#nodeQueue[level][this.#nodeIndex[level]] as BNodeInternal<K>\n ).children;\n this.#nodeIndex[level - 1] = this.#nodeQueue[level - 1].length - 1;\n }\n this.#leaf = this.#nodeQueue[0][this.#nodeIndex[0]];\n this.#i = this.#leaf.keys.length;\n }\n }\n\n [Symbol.iterator]() {\n return this;\n }\n}\n\nfunction valuesFrom<K>(\n root: BNode<K>,\n comparator: Comparator<K>,\n lowestKey: K | undefined,\n inclusive: boolean,\n): IterableIterator<K> {\n const info = findPath(lowestKey, root, comparator);\n if (info === undefined) {\n return iterator<K>(() => ({done: true, value: undefined}));\n }\n\n let [nodeQueue, nodeIndex, leaf] = info;\n let i =\n lowestKey === undefined\n ? -1\n : indexOf(lowestKey, leaf.keys, 0, comparator) - 1;\n\n if (\n !inclusive &&\n lowestKey !== undefined &&\n // +1 because we did -1 above.\n i + 1 < leaf.keys.length &&\n comparator(leaf.keys[i + 1], lowestKey) === 0\n ) {\n i++;\n }\n\n return new BTreeForwardIterator(nodeQueue, nodeIndex, leaf, i);\n}\n\nfunction valuesFromReversed<K>(\n maxKey: K | undefined,\n root: BNode<K>,\n comparator: Comparator<K>,\n highestKey: K | undefined,\n inclusive: boolean,\n): IterableIterator<K> {\n if (highestKey === undefined) {\n highestKey = maxKey;\n if (highestKey === undefined) {\n return iterator<K>(() => ({done: true, value: undefined}));\n } // collection is empty\n }\n let [nodeQueue, nodeIndex, leaf] =\n findPath(highestKey, root, comparator) ||\n findPath(maxKey, root, comparator)!;\n assert(\n !nodeQueue[0] || leaf === nodeQueue[0][nodeIndex[0]],\n 'BTreeSet: leaf node mismatch in iteration',\n );\n let i = indexOf(highestKey, leaf.keys, 0, comparator);\n if (\n inclusive &&\n i < leaf.keys.length &&\n comparator(leaf.keys[i], highestKey) <= 0\n ) {\n i++;\n }\n\n return new BTreeReverseIterator(nodeQueue, nodeIndex, leaf, i);\n}\n\nfunction findPath<K>(\n key: K | undefined,\n root: BNode<K>,\n comparator: Comparator<K>,\n): [nodeQueue: BNode<K>[][], nodeIndex: number[], leaf: BNode<K>] | undefined {\n let nextNode = root;\n const nodeQueue: BNode<K>[][] = [];\n const nodeIndex: number[] = [];\n\n if (nextNode.isInternal()) {\n for (let d = 0; nextNode.isInternal(); d++) {\n nodeQueue[d] = nextNode.children;\n nodeIndex[d] =\n key === undefined ? 0 : indexOf(key, nextNode.keys, 0, comparator);\n if (nodeIndex[d] >= nodeQueue[d].length) return; // first key > maxKey()\n nextNode = nodeQueue[d][nodeIndex[d]];\n }\n nodeQueue.reverse();\n nodeIndex.reverse();\n }\n return [nodeQueue, nodeIndex, nextNode];\n}\n\nfunction iterator<T>(next: () => IteratorResult<T>): IterableIterator<T> {\n return {\n next,\n [Symbol.iterator]() {\n return this;\n },\n };\n}\n\n/** Leaf node / base class. **************************************************/\nclass BNode<K> {\n // If this is an internal node, _keys[i] is the highest key in children[i].\n keys: K[];\n // True if this node might be within multiple `BTree`s (or have multiple parents).\n // If so, it must be cloned before being mutated to avoid changing an unrelated tree.\n // This is transitive: if it's true, children are also shared even if `isShared!=true`\n // in those children. (Certain operations will propagate isShared=true to children.)\n isShared: true | undefined;\n\n constructor(keys: K[]) {\n this.keys = keys;\n this.isShared = undefined;\n }\n\n isInternal(): this is BNodeInternal<K> {\n return false;\n }\n\n maxKey() {\n // oxlint-disable-next-line typescript/no-non-null-assertion\n return this.keys.at(-1)!;\n }\n\n minKey(): K | undefined {\n return this.keys[0];\n }\n\n clone(): BNode<K> {\n return new BNode<K>(this.keys.slice(0));\n }\n\n get(key: K, tree: BTreeSet<K>): K | undefined {\n const i = indexOf(key, this.keys, -1, tree.comparator);\n return i < 0 ? undefined : this.keys[i];\n }\n\n has(key: K, tree: BTreeSet<K>): boolean {\n const i = indexOf(key, this.keys, -1, tree.comparator);\n return i >= 0 && i < this.keys.length;\n }\n\n set(key: K, tree: BTreeSet<K>): null | BNode<K> {\n let i = indexOf(key, this.keys, -1, tree.comparator);\n if (i < 0) {\n // key does not exist yet\n i = ~i;\n tree.size++;\n\n if (this.keys.length < MAX_NODE_SIZE) {\n this.keys.splice(i, 0, key);\n return null;\n }\n // This leaf node is full and must split\n const newRightSibling = this.splitOffRightSide();\n // oxlint-disable-next-line @typescript-eslint/no-this-alias\n let target: BNode<K> = this;\n if (i > this.keys.length) {\n i -= this.keys.length;\n target = newRightSibling;\n }\n // target.#insertInLeaf(i, key);\n target.keys.splice(i, 0, key);\n\n return newRightSibling;\n }\n\n // usually this is a no-op, but some users may wish to edit the key\n this.keys[i] = key;\n return null;\n }\n\n takeFromRight(rhs: BNode<K>) {\n this.keys.push(rhs.keys.shift()!);\n }\n\n takeFromLeft(lhs: BNode<K>) {\n this.keys.unshift(lhs.keys.pop()!);\n }\n\n splitOffRightSide(): BNode<K> {\n const half = this.keys.length >> 1;\n const keys = this.keys.splice(half);\n return new BNode<K>(keys);\n }\n\n delete(key: K, tree: BTreeSet<K>): boolean {\n const cmp = tree.comparator;\n const iLow = indexOf(key, this.keys, -1, cmp);\n const iHigh = iLow + 1;\n\n if (iLow < 0) {\n return false;\n }\n\n const {keys} = this;\n for (let i = iLow; i < iHigh; i++) {\n const key = keys[i];\n\n if (key !== keys[i] || this.isShared === true) {\n throw new Error('BTree illegally changed or cloned in delete');\n }\n\n this.keys.splice(i, 1);\n tree.size--;\n return true;\n }\n\n return false;\n }\n\n mergeSibling(rhs: BNode<K>, _: number) {\n this.keys.push(...rhs.keys);\n }\n}\n\n/** Internal node (non-leaf node) ********************************************/\nclass BNodeInternal<K> extends BNode<K> {\n // Note: conventionally B+ trees have one fewer key than the number of\n // children, but I find it easier to keep the array lengths equal: each\n // keys[i] caches the value of children[i].maxKey().\n children: BNode<K>[];\n\n /**\n * This does not mark `children` as shared, so it is the responsibility of the caller\n * to ensure children are either marked shared, or aren't included in another tree.\n */\n constructor(children: BNode<K>[], keys?: K[]) {\n if (!keys) {\n keys = [];\n for (let i = 0; i < children.length; i++) {\n keys[i] = children[i].maxKey();\n }\n }\n super(keys);\n this.children = children;\n }\n\n isInternal(): this is BNodeInternal<K> {\n return true;\n }\n\n clone(): BNode<K> {\n const children = this.children.slice(0);\n for (let i = 0; i < children.length; i++) {\n children[i].isShared = true;\n }\n return new BNodeInternal<K>(children, this.keys.slice(0));\n }\n\n minKey() {\n return this.children[0].minKey();\n }\n\n get(key: K, tree: BTreeSet<K>): K | undefined {\n const i = indexOf(key, this.keys, 0, tree.comparator);\n const {children} = this;\n return i < children.length ? children[i].get(key, tree) : undefined;\n }\n\n has(key: K, tree: BTreeSet<K>): boolean {\n const i = indexOf(key, this.keys, 0, tree.comparator);\n const {children} = this;\n return i < children.length ? children[i].has(key, tree) : false;\n }\n\n set(key: K, tree: BTreeSet<K>): null | BNode<K> {\n const c = this.children;\n const cmp = tree.comparator;\n let i = Math.min(indexOf(key, this.keys, 0, cmp), c.length - 1);\n let child = c[i];\n\n if (child.isShared) {\n c[i] = child = child.clone();\n }\n if (child.keys.length >= MAX_NODE_SIZE) {\n // child is full; inserting anything else will cause a split.\n // Shifting an item to the left or right sibling may avoid a split.\n // We can do a shift if the adjacent node is not full and if the\n // current key can still be placed in the same node after the shift.\n let other: BNode<K>;\n if (\n i > 0 &&\n (other = c[i - 1]).keys.length < MAX_NODE_SIZE &&\n cmp(child.keys[0], key) < 0\n ) {\n if (other.isShared) {\n c[i - 1] = other = other.clone();\n }\n other.takeFromRight(child);\n this.keys[i - 1] = other.maxKey();\n } else if (\n (other = c[i + 1]) !== undefined &&\n other.keys.length < MAX_NODE_SIZE &&\n cmp(child.maxKey(), key) < 0\n ) {\n if (other.isShared) c[i + 1] = other = other.clone();\n other.takeFromLeft(child);\n this.keys[i] = c[i].maxKey();\n }\n }\n\n const result = child.set(key, tree);\n this.keys[i] = child.maxKey();\n if (result === null) return null;\n\n // The child has split and `result` is a new right child... does it fit?\n if (this.keys.length < MAX_NODE_SIZE) {\n // yes\n this.insert(i + 1, result);\n return null;\n }\n // no, we must split also\n const newRightSibling = this.splitOffRightSide();\n // oxlint-disable-next-line @typescript-eslint/no-this-alias\n let target: BNodeInternal<K> = this;\n if (cmp(result.maxKey(), this.maxKey()) > 0) {\n target = newRightSibling;\n i -= this.keys.length;\n }\n target.insert(i + 1, result);\n return newRightSibling;\n }\n\n /**\n * Inserts `child` at index `i`.\n * This does not mark `child` as shared, so it is the responsibility of the caller\n * to ensure that either child is marked shared, or it is not included in another tree.\n */\n insert(i: number, child: BNode<K>) {\n this.children.splice(i, 0, child);\n this.keys.splice(i, 0, child.maxKey());\n }\n\n /**\n * Split this node.\n * Modifies this to remove the second half of the items, returning a separate node containing them.\n */\n splitOffRightSide() {\n const half = this.children.length >> 1;\n return new BNodeInternal<K>(\n this.children.splice(half),\n this.keys.splice(half),\n );\n }\n\n takeFromRight(rhs: BNode<K>) {\n this.keys.push(rhs.keys.shift()!);\n this.children.push((rhs as BNodeInternal<K>).children.shift()!);\n }\n\n takeFromLeft(lhs: BNode<K>) {\n this.keys.unshift(lhs.keys.pop()!);\n this.children.unshift((lhs as BNodeInternal<K>).children.pop()!);\n }\n\n delete(key: K, tree: BTreeSet<K>): boolean {\n const cmp = tree.comparator;\n const {keys} = this;\n const {children} = this;\n let iLow = indexOf(key, this.keys, 0, cmp);\n let i = iLow;\n const iHigh = Math.min(iLow, keys.length - 1);\n if (i <= iHigh) {\n try {\n if (children[i].isShared) {\n children[i] = children[i].clone();\n }\n const result = children[i].delete(key, tree);\n // Note: if children[i] is empty then keys[i]=undefined.\n // This is an invalid state, but it is fixed below.\n keys[i] = children[i].maxKey();\n return result;\n } finally {\n // Deletions may have occurred, so look for opportunities to merge nodes.\n const half = MAX_NODE_SIZE >> 1;\n if (iLow > 0) iLow--;\n for (i = iHigh; i >= iLow; i--) {\n if (children[i].keys.length <= half) {\n if (children[i].keys.length !== 0) {\n this.tryMerge(i, MAX_NODE_SIZE);\n } else {\n // child is empty! delete it!\n keys.splice(i, 1);\n children.splice(i, 1);\n }\n }\n }\n }\n }\n return false;\n }\n\n /** Merges child i with child i+1 if their combined size is not too large */\n tryMerge(i: number, maxSize: number): boolean {\n const {children} = this;\n if (i >= 0 && i + 1 < children.length) {\n if (children[i].keys.length + children[i + 1].keys.length <= maxSize) {\n if (\n children[i].isShared\n ) // cloned already UNLESS i is outside scan range\n {\n children[i] = children[i].clone();\n }\n children[i].mergeSibling(children[i + 1], maxSize);\n children.splice(i + 1, 1);\n this.keys.splice(i + 1, 1);\n this.keys[i] = children[i].maxKey();\n return true;\n }\n }\n return false;\n }\n\n /**\n * Move children from `rhs` into this.\n * `rhs` must be part of this tree, and be removed from it after this call\n * (otherwise isShared for its children could be incorrect).\n */\n mergeSibling(rhs: BNode<K>, maxNodeSize: number) {\n // assert !this.isShared;\n const oldLength = this.keys.length;\n this.keys.push(...rhs.keys);\n const rhsChildren = (rhs as unknown as BNodeInternal<K>).children;\n this.children.push(...rhsChildren);\n\n if (rhs.isShared && !this.isShared) {\n // All children of a shared node are implicitly shared, and since their new\n // parent is not shared, they must now be explicitly marked as shared.\n for (let i = 0; i < rhsChildren.length; i++) {\n rhsChildren[i].isShared = true;\n }\n }\n\n // If our children are themselves almost empty due to a mass-delete,\n // they may need to be merged too (but only the oldLength-1 and its\n // right sibling should need this).\n this.tryMerge(oldLength - 1, maxNodeSize);\n }\n}\n\n// If key not found, returns i^failXor where i is the insertion index.\n// Callers that don't care whether there was a match will set failXor=0.\nfunction indexOf<K>(\n key: K,\n keys: K[],\n failXor: number,\n comparator: Comparator<K>,\n): number {\n let lo = 0;\n let hi = keys.length;\n let mid = hi >> 1;\n while (lo < hi) {\n const c = comparator(keys[mid], key);\n if (c < 0) {\n lo = mid + 1;\n } else if (c > 0) {\n // key < keys[mid]\n hi = mid;\n } else if (c === 0) {\n return mid;\n } else {\n // c is NaN or otherwise invalid\n if (key === key) {\n // at least the search key is not NaN\n return keys.length;\n }\n throw new Error('NaN was used as a key');\n }\n mid = (lo + hi) >> 1;\n }\n return mid ^ failXor;\n}\n\n// oxlint-disable-next-line @typescript-eslint/no-explicit-any\nconst emptyLeaf = new BNode<any>([]);\nemptyLeaf.isShared = true;\n"],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"cache.js","names":["#cache","#ttlMs","#intervalHandle"],"sources":["../../../../shared/src/cache.ts"],"sourcesContent":["/**\n * Stores values with an expiration time at time of insertion.\n * Does not update the expiration time on retrieval.\n * Values are automatically removed from the cache after the TTL expires.\n * The cache is cleaned up periodically based on the TTL so it does\n * not grow indefinitely.\n */\nexport class TimedCache<T> {\n readonly #cache: Map<string, {value: T; expiresAt: number}>;\n readonly #ttlMs: number;\n readonly #intervalHandle: NodeJS.Timeout;\n\n constructor(ttlMs: number) {\n this.#cache = new Map();\n this.#ttlMs = ttlMs;\n this.#intervalHandle = setInterval(() => {\n const now = Date.now();\n for (const [key, entry] of this.#cache.entries()) {\n if (entry.expiresAt < now) {\n this.#cache.delete(key);\n }\n }\n }, ttlMs * 2);\n }\n\n set(key: string, value: T): void {\n const entry = {value, expiresAt: Date.now() + this.#ttlMs};\n this.#cache.set(key, entry);\n }\n\n get(key: string): T | undefined {\n const entry = this.#cache.get(key);\n if (entry === undefined || entry.expiresAt < Date.now()) {\n this.#cache.delete(key);\n return undefined;\n }\n return entry.value;\n }\n\n destroy(): void {\n clearInterval(this.#intervalHandle);\n this.#cache.clear();\n }\n}\n"],"mappings":";;;;;;;;AAOA,IAAa,aAAb,MAA2B;CACzB;CACA;CACA;CAEA,YAAY,OAAe;AACzB,QAAA,wBAAc,IAAI,KAAK;AACvB,QAAA,QAAc;AACd,QAAA,iBAAuB,kBAAkB;GACvC,MAAM,MAAM,KAAK,KAAK;AACtB,QAAK,MAAM,CAAC,KAAK,UAAU,MAAA,MAAY,SAAS,CAC9C,KAAI,MAAM,YAAY,IACpB,OAAA,MAAY,OAAO,IAAI;KAG1B,QAAQ,EAAE;;CAGf,IAAI,KAAa,OAAgB;EAC/B,MAAM,QAAQ;GAAC;GAAO,WAAW,KAAK,KAAK,GAAG,MAAA;GAAY;AAC1D,QAAA,MAAY,IAAI,KAAK,MAAM;;CAG7B,IAAI,KAA4B;EAC9B,MAAM,QAAQ,MAAA,MAAY,IAAI,IAAI;AAClC,MAAI,UAAU,KAAA,KAAa,MAAM,YAAY,KAAK,KAAK,EAAE;AACvD,SAAA,MAAY,OAAO,IAAI;AACvB;;AAEF,SAAO,MAAM;;CAGf,UAAgB;AACd,gBAAc,MAAA,eAAqB;AACnC,QAAA,MAAY,OAAO"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"centroid.js","names":[],"sources":["../../../../shared/src/centroid.ts"],"sourcesContent":["// Apache License 2.0\n// https://github.com/influxdata/tdigest\n\n// Centroid average position of all points in a shape\nexport class Centroid {\n mean: number;\n weight: number;\n\n constructor(mean: number, weight: number) {\n this.mean = mean;\n this.weight = weight;\n }\n\n add(r: Centroid): void {\n if (r.weight < 0) {\n throw new Error('centroid weight cannot be less than zero');\n }\n if (this.weight !== 0) {\n this.weight += r.weight;\n this.mean += (r.weight * (r.mean - this.mean)) / this.weight;\n } else {\n this.weight = r.weight;\n this.mean = r.mean;\n }\n }\n}\n\n/** CentroidList is sorted by the mean of the centroid, ascending. */\nexport type CentroidList = Centroid[];\n\nexport function sortCentroidList(centroids: CentroidList): void {\n centroids.sort((a, b) => a.mean - b.mean);\n}\n"],"mappings":";AAIA,IAAa,WAAb,MAAsB;CACpB;CACA;CAEA,YAAY,MAAc,QAAgB;AACxC,OAAK,OAAO;AACZ,OAAK,SAAS;;CAGhB,IAAI,GAAmB;AACrB,MAAI,EAAE,SAAS,EACb,OAAM,IAAI,MAAM,2CAA2C;AAE7D,MAAI,KAAK,WAAW,GAAG;AACrB,QAAK,UAAU,EAAE;AACjB,QAAK,QAAS,EAAE,UAAU,EAAE,OAAO,KAAK,QAAS,KAAK;SACjD;AACL,QAAK,SAAS,EAAE;AAChB,QAAK,OAAO,EAAE;;;;AAQpB,SAAgB,iBAAiB,WAA+B;AAC9D,WAAU,MAAM,GAAG,MAAM,EAAE,OAAO,EAAE,KAAK"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"config.js","names":[],"sources":["../../../../shared/src/config.ts"],"sourcesContent":["declare const process: {\n env: {\n NODE_ENV?: string;\n };\n};\n\nexport const isProd = process.env.NODE_ENV === 'production';\n\nexport {isProd as skipAssertJSONValue};\n"],"mappings":";AAMA,IAAa,SAAA,QAAA,IAAA,aAAkC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"custom-key-map.js","names":["#toKey","#map"],"sources":["../../../../shared/src/custom-key-map.ts"],"sourcesContent":["type Primitive = undefined | null | boolean | string | number | symbol | bigint;\n\n/**\n * A {@link Map} that uses a custom key transformation function to convert keys\n * to a primitive type that can be used as a {@link Map} key.\n *\n * This allows for using objects as keys in a {@link Map} without worrying about\n * reference equality.\n */\nexport class CustomKeyMap<K, V> {\n readonly [Symbol.toStringTag] = 'CustomKeyMap';\n readonly #toKey: (key: K) => Primitive;\n readonly #map = new Map<Primitive, readonly [K, V]>();\n\n constructor(\n toKey: (key: K) => Primitive,\n iterable?: Iterable<readonly [K, V]> | null,\n ) {\n this.#toKey = toKey;\n if (iterable) {\n for (const [key, value] of iterable ?? []) {\n this.#map.set(toKey(key), [key, value]);\n }\n }\n }\n\n clear(): void {\n this.#map.clear();\n }\n\n delete(key: K): boolean {\n return this.#map.delete(this.#toKey(key));\n }\n\n forEach(\n callbackfn: (value: V, key: K, map: CustomKeyMap<K, V>) => void,\n // oxlint-disable-next-line @typescript-eslint/no-explicit-any\n thisArg?: any,\n ): void {\n for (const [key, value] of this.#map.values()) {\n callbackfn.call(thisArg, value, key, this);\n }\n }\n\n get(key: K): V | undefined {\n return this.#map.get(this.#toKey(key))?.[1];\n }\n\n has(key: K): boolean {\n return this.#map.has(this.#toKey(key));\n }\n\n set(key: K, value: V): this {\n this.#map.set(this.#toKey(key), [key, value]);\n return this;\n }\n\n get size(): number {\n return this.#map.size;\n }\n\n *entries(): MapIterator<[K, V]> {\n for (const entry of this.#map.values()) {\n yield entry.slice(0, 2) as [K, V];\n }\n }\n\n *keys(): MapIterator<K> {\n for (const entry of this.#map.values()) {\n yield entry[0];\n }\n }\n\n *values(): MapIterator<V> {\n for (const entry of this.#map.values()) {\n yield entry[1];\n }\n }\n\n [Symbol.iterator](): MapIterator<[K, V]> {\n return this.entries();\n }\n}\n"],"mappings":";;;;;;;;AASA,IAAa,eAAb,MAAgC;CAC9B,CAAU,OAAO,eAAe;CAChC;CACA,uBAAgB,IAAI,KAAiC;CAErD,YACE,OACA,UACA;AACA,QAAA,QAAc;AACd,MAAI,SACF,MAAK,MAAM,CAAC,KAAK,UAAU,YAAY,EAAE,CACvC,OAAA,IAAU,IAAI,MAAM,IAAI,EAAE,CAAC,KAAK,MAAM,CAAC;;CAK7C,QAAc;AACZ,QAAA,IAAU,OAAO;;CAGnB,OAAO,KAAiB;AACtB,SAAO,MAAA,IAAU,OAAO,MAAA,MAAY,IAAI,CAAC;;CAG3C,QACE,YAEA,SACM;AACN,OAAK,MAAM,CAAC,KAAK,UAAU,MAAA,IAAU,QAAQ,CAC3C,YAAW,KAAK,SAAS,OAAO,KAAK,KAAK;;CAI9C,IAAI,KAAuB;AACzB,SAAO,MAAA,IAAU,IAAI,MAAA,MAAY,IAAI,CAAC,GAAG;;CAG3C,IAAI,KAAiB;AACnB,SAAO,MAAA,IAAU,IAAI,MAAA,MAAY,IAAI,CAAC;;CAGxC,IAAI,KAAQ,OAAgB;AAC1B,QAAA,IAAU,IAAI,MAAA,MAAY,IAAI,EAAE,CAAC,KAAK,MAAM,CAAC;AAC7C,SAAO;;CAGT,IAAI,OAAe;AACjB,SAAO,MAAA,IAAU;;CAGnB,CAAC,UAA+B;AAC9B,OAAK,MAAM,SAAS,MAAA,IAAU,QAAQ,CACpC,OAAM,MAAM,MAAM,GAAG,EAAE;;CAI3B,CAAC,OAAuB;AACtB,OAAK,MAAM,SAAS,MAAA,IAAU,QAAQ,CACpC,OAAM,MAAM;;CAIhB,CAAC,SAAyB;AACxB,OAAK,MAAM,SAAS,MAAA,IAAU,QAAQ,CACpC,OAAM,MAAM;;CAIhB,CAAC,OAAO,YAAiC;AACvC,SAAO,KAAK,SAAS"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"custom-key-set.js","names":["#toKey","#map"],"sources":["../../../../shared/src/custom-key-set.ts"],"sourcesContent":["type Primitive = undefined | null | boolean | string | number | symbol | bigint;\n\n/**\n * A {@link Set} that uses a custom value transformation function to convert values\n * to a primitive type that can be used as a {@link Set} value.\n *\n * This allows for using objects as values in a {@link Set} without worrying about\n * reference equality.\n */\n\nexport class CustomKeySet<V> {\n readonly [Symbol.toStringTag] = 'CustomKeySet';\n readonly #toKey: (value: V) => Primitive;\n readonly #map = new Map<Primitive, V>();\n\n constructor(toKey: (value: V) => Primitive, iterable?: Iterable<V> | null) {\n this.#toKey = toKey;\n if (iterable) {\n for (const value of iterable ?? []) {\n this.#map.set(toKey(value), value);\n }\n }\n }\n\n add(value: V): this {\n this.#map.set(this.#toKey(value), value);\n return this;\n }\n\n clear(): void {\n this.#map.clear();\n }\n\n delete(value: V): boolean {\n return this.#map.delete(this.#toKey(value));\n }\n\n forEach(\n callbackfn: (value: V, value2: V, set: CustomKeySet<V>) => void,\n // oxlint-disable-next-line @typescript-eslint/no-explicit-any\n thisArg?: any,\n ): void {\n this.#map.forEach(value => {\n callbackfn.call(thisArg, value, value, this);\n });\n }\n\n has(value: V): boolean {\n return this.#map.has(this.#toKey(value));\n }\n\n get size(): number {\n return this.#map.size;\n }\n\n *entries(): IterableIterator<[V, V]> {\n for (const value of this.#map.values()) {\n yield [value, value];\n }\n }\n\n keys(): IterableIterator<V> {\n return this.#map.values();\n }\n\n values(): IterableIterator<V> {\n return this.#map.values();\n }\n\n [Symbol.iterator](): IterableIterator<V> {\n return this.#map.values();\n }\n}\n"],"mappings":";;;;;;;;AAUA,IAAa,eAAb,MAA6B;CAC3B,CAAU,OAAO,eAAe;CAChC;CACA,uBAAgB,IAAI,KAAmB;CAEvC,YAAY,OAAgC,UAA+B;AACzE,QAAA,QAAc;AACd,MAAI,SACF,MAAK,MAAM,SAAS,YAAY,EAAE,CAChC,OAAA,IAAU,IAAI,MAAM,MAAM,EAAE,MAAM;;CAKxC,IAAI,OAAgB;AAClB,QAAA,IAAU,IAAI,MAAA,MAAY,MAAM,EAAE,MAAM;AACxC,SAAO;;CAGT,QAAc;AACZ,QAAA,IAAU,OAAO;;CAGnB,OAAO,OAAmB;AACxB,SAAO,MAAA,IAAU,OAAO,MAAA,MAAY,MAAM,CAAC;;CAG7C,QACE,YAEA,SACM;AACN,QAAA,IAAU,SAAQ,UAAS;AACzB,cAAW,KAAK,SAAS,OAAO,OAAO,KAAK;IAC5C;;CAGJ,IAAI,OAAmB;AACrB,SAAO,MAAA,IAAU,IAAI,MAAA,MAAY,MAAM,CAAC;;CAG1C,IAAI,OAAe;AACjB,SAAO,MAAA,IAAU;;CAGnB,CAAC,UAAoC;AACnC,OAAK,MAAM,SAAS,MAAA,IAAU,QAAQ,CACpC,OAAM,CAAC,OAAO,MAAM;;CAIxB,OAA4B;AAC1B,SAAO,MAAA,IAAU,QAAQ;;CAG3B,SAA8B;AAC5B,SAAO,MAAA,IAAU,QAAQ;;CAG3B,CAAC,OAAO,YAAiC;AACvC,SAAO,MAAA,IAAU,QAAQ"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"deep-clone.js","names":[],"sources":["../../../../shared/src/deep-clone.ts"],"sourcesContent":["import {hasOwn} from './has-own.ts';\nimport type {JSONValue, ReadonlyJSONValue} from './json.ts';\n\nexport function deepClone(value: ReadonlyJSONValue): JSONValue {\n const seen: Array<ReadonlyJSONValue> = [];\n return internalDeepClone(value, seen);\n}\n\nexport function internalDeepClone(\n value: ReadonlyJSONValue,\n seen: Array<ReadonlyJSONValue>,\n): JSONValue {\n switch (typeof value) {\n case 'boolean':\n case 'number':\n case 'string':\n case 'undefined':\n return value;\n case 'object': {\n if (value === null) {\n return null;\n }\n if (seen.includes(value)) {\n throw new Error('Cyclic object');\n }\n seen.push(value);\n if (Array.isArray(value)) {\n const rv = value.map(v => internalDeepClone(v, seen));\n seen.pop();\n return rv;\n }\n\n const obj: JSONValue = {};\n\n for (const k in value) {\n if (hasOwn(value, k)) {\n const v = (value as Record<string, ReadonlyJSONValue>)[k];\n if (v !== undefined) {\n obj[k] = internalDeepClone(v, seen);\n }\n }\n }\n seen.pop();\n return obj;\n }\n\n default:\n throw new Error(`Invalid type: ${typeof value}`);\n }\n}\n"],"mappings":";;AAGA,SAAgB,UAAU,OAAqC;AAE7D,QAAO,kBAAkB,OADc,EAAE,CACJ;;AAGvC,SAAgB,kBACd,OACA,MACW;AACX,SAAQ,OAAO,OAAf;EACE,KAAK;EACL,KAAK;EACL,KAAK;EACL,KAAK,YACH,QAAO;EACT,KAAK,UAAU;AACb,OAAI,UAAU,KACZ,QAAO;AAET,OAAI,KAAK,SAAS,MAAM,CACtB,OAAM,IAAI,MAAM,gBAAgB;AAElC,QAAK,KAAK,MAAM;AAChB,OAAI,MAAM,QAAQ,MAAM,EAAE;IACxB,MAAM,KAAK,MAAM,KAAI,MAAK,kBAAkB,GAAG,KAAK,CAAC;AACrD,SAAK,KAAK;AACV,WAAO;;GAGT,MAAM,MAAiB,EAAE;AAEzB,QAAK,MAAM,KAAK,MACd,KAAI,OAAO,OAAO,EAAE,EAAE;IACpB,MAAM,IAAK,MAA4C;AACvD,QAAI,MAAM,KAAA,EACR,KAAI,KAAK,kBAAkB,GAAG,KAAK;;AAIzC,QAAK,KAAK;AACV,UAAO;;EAGT,QACE,OAAM,IAAI,MAAM,iBAAiB,OAAO,QAAQ"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"deep-merge.js","names":[],"sources":["../../../../shared/src/deep-merge.ts"],"sourcesContent":["// Force TypeScript to evaluate/flatten a type\ntype Simplify<T> = {[K in keyof T]: T[K]} & {};\n\n// Helper to check if T is a plain object (not array or function)\ntype IsPlainObject<T> = T extends object\n ? T extends Function | readonly unknown[]\n ? false\n : true\n : false;\n\ntype IsLeaf<T, Leaf> = [T] extends [Leaf] ? true : false;\n\ntype MergeValue<A, B, Leaf> =\n IsLeaf<A, Leaf> extends true\n ? B\n : IsLeaf<B, Leaf> extends true\n ? B\n : IsPlainObject<A> extends true\n ? IsPlainObject<B> extends true\n ? DeepMerge<A & {}, B & {}, Leaf>\n : B\n : B;\n\n/**\n * Type-level deep merge of two object types. Properties from B override\n * properties from A. When both A[K] and B[K] are objects (not arrays or\n * functions), they are recursively merged.\n */\nexport type DeepMerge<A, B, Leaf = never> = Simplify<\n Omit<A, keyof B> & {\n [K in keyof B]: K extends keyof A ? MergeValue<A[K], B[K], Leaf> : B[K];\n }\n>;\n\nexport function isPlainObject(\n value: unknown,\n): value is Record<string, unknown> {\n return typeof value === 'object' && value !== null;\n}\n\n/**\n * Deep merges two objects. Properties from `b` override properties from `a`.\n * Nested objects are recursively merged.\n *\n * @param a - The base object.\n * @param b - The object to merge into `a`.\n * @param isLeaf - Optional predicate to determine if a value should be treated\n * as a leaf (not recursed into). Defaults to checking if the value is not a\n * plain object.\n */\nexport function deepMerge<\n A extends Record<string, unknown>,\n B extends Record<string, unknown>,\n Leaf = never,\n>(\n a: A,\n b: B,\n isLeaf: (value: unknown) => boolean = v => !isPlainObject(v),\n): DeepMerge<A, B, Leaf> {\n const result: Record<string, unknown> = {};\n\n // Copy all keys from a\n for (const key of Object.keys(a)) {\n result[key] = a[key];\n }\n\n // Merge/override with keys from b\n for (const key of Object.keys(b)) {\n const aVal = a[key];\n const bVal = b[key];\n\n if (key in a && !isLeaf(aVal) && !isLeaf(bVal)) {\n result[key] = deepMerge<\n Record<string, unknown>,\n Record<string, unknown>,\n Leaf\n >(\n aVal as Record<string, unknown>,\n bVal as Record<string, unknown>,\n isLeaf,\n );\n } else {\n result[key] = bVal;\n }\n }\n\n return result as DeepMerge<A, B, Leaf>;\n}\n"],"mappings":";AAkCA,SAAgB,cACd,OACkC;AAClC,QAAO,OAAO,UAAU,YAAY,UAAU;;;;;;;;;;;;AAahD,SAAgB,UAKd,GACA,GACA,UAAsC,MAAK,CAAC,cAAc,EAAE,EACrC;CACvB,MAAM,SAAkC,EAAE;AAG1C,MAAK,MAAM,OAAO,OAAO,KAAK,EAAE,CAC9B,QAAO,OAAO,EAAE;AAIlB,MAAK,MAAM,OAAO,OAAO,KAAK,EAAE,EAAE;EAChC,MAAM,OAAO,EAAE;EACf,MAAM,OAAO,EAAE;AAEf,MAAI,OAAO,KAAK,CAAC,OAAO,KAAK,IAAI,CAAC,OAAO,KAAK,CAC5C,QAAO,OAAO,UAKZ,MACA,MACA,OACD;MAED,QAAO,OAAO;;AAIlB,QAAO"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"document-visible.js","names":["#doc","#hiddenIntervalMS","#promises","#onVisibilityChange","#timeoutID","#setVisibilityState","#waitFor"],"sources":["../../../../shared/src/document-visible.ts"],"sourcesContent":["import {resolver} from '@rocicorp/resolver';\n\ntype PartialDocument = Pick<\n Document,\n 'visibilityState' | 'addEventListener' | 'removeEventListener'\n>;\n\nexport function getDocumentVisibilityWatcher(\n doc: PartialDocument | undefined,\n hiddenIntervalMS: number,\n signal: AbortSignal,\n): DocumentVisibilityWatcher {\n return doc\n ? new DocumentVisibilityWatcherImpl(doc, hiddenIntervalMS, signal)\n : new DocumentVisibilityWatcherNoDoc();\n}\n\nexport interface DocumentVisibilityWatcher {\n readonly visibilityState: DocumentVisibilityState;\n waitForVisible(): Promise<unknown>;\n waitForHidden(): Promise<unknown>;\n}\n\nclass DocumentVisibilityWatcherImpl implements DocumentVisibilityWatcher {\n readonly #doc: PartialDocument;\n readonly #hiddenIntervalMS: number;\n #timeoutID: ReturnType<typeof setTimeout> | 0 = 0;\n\n // This trails doc.visibilityState by hiddenIntervalMS when being hidden. This\n // is because we want to wait for the tab to be hidden for a while before\n // considering as hidden.\n visibilityState: DocumentVisibilityState;\n\n readonly #promises = new Set<{\n resolve: () => void;\n state: DocumentVisibilityState;\n }>();\n\n constructor(\n doc: PartialDocument,\n hiddenIntervalMS: number,\n signal: AbortSignal,\n ) {\n this.#doc = doc;\n this.#hiddenIntervalMS = hiddenIntervalMS;\n this.visibilityState = doc.visibilityState;\n // Safari got support for abort signal in addEventListener in version\n // 15 (Released 2021-09-20)\n this.#doc.addEventListener('visibilitychange', this.#onVisibilityChange, {\n signal,\n });\n }\n\n #onVisibilityChange = () => {\n if (this.#doc.visibilityState === 'visible') {\n clearTimeout(this.#timeoutID);\n this.#setVisibilityState('visible');\n } else {\n this.#timeoutID = setTimeout(() => {\n this.#setVisibilityState('hidden');\n }, this.#hiddenIntervalMS);\n }\n };\n\n #setVisibilityState(visibilityState: DocumentVisibilityState) {\n if (visibilityState === this.visibilityState) {\n return;\n }\n this.visibilityState = visibilityState;\n for (const entry of this.#promises) {\n const {resolve, state} = entry;\n if (state === visibilityState) {\n resolve();\n this.#promises.delete(entry);\n }\n }\n }\n\n waitForVisible(): Promise<unknown> {\n return this.#waitFor('visible');\n }\n\n waitForHidden(): Promise<unknown> {\n return this.#waitFor('hidden');\n }\n\n #waitFor(state: DocumentVisibilityState): Promise<unknown> {\n if (this.visibilityState === state) {\n return Promise.resolve();\n }\n\n const {promise, resolve} = resolver();\n this.#promises.add({resolve, state});\n return promise;\n }\n}\n\nconst resolvedPromise = Promise.resolve();\nconst promiseThatNeverResolves = new Promise(() => undefined);\n\nclass DocumentVisibilityWatcherNoDoc implements DocumentVisibilityWatcher {\n readonly visibilityState: DocumentVisibilityState = 'visible';\n waitForVisible(): Promise<unknown> {\n return resolvedPromise;\n }\n\n waitForHidden(): Promise<unknown> {\n return promiseThatNeverResolves;\n }\n}\n"],"mappings":";;AAOA,SAAgB,6BACd,KACA,kBACA,QAC2B;AAC3B,QAAO,MACH,IAAI,8BAA8B,KAAK,kBAAkB,OAAO,GAChE,IAAI,gCAAgC;;AAS1C,IAAM,gCAAN,MAAyE;CACvE;CACA;CACA,aAAgD;CAKhD;CAEA,4BAAqB,IAAI,KAGrB;CAEJ,YACE,KACA,kBACA,QACA;AACA,QAAA,MAAY;AACZ,QAAA,mBAAyB;AACzB,OAAK,kBAAkB,IAAI;AAG3B,QAAA,IAAU,iBAAiB,oBAAoB,MAAA,oBAA0B,EACvE,QACD,CAAC;;CAGJ,4BAA4B;AAC1B,MAAI,MAAA,IAAU,oBAAoB,WAAW;AAC3C,gBAAa,MAAA,UAAgB;AAC7B,SAAA,mBAAyB,UAAU;QAEnC,OAAA,YAAkB,iBAAiB;AACjC,SAAA,mBAAyB,SAAS;KACjC,MAAA,iBAAuB;;CAI9B,oBAAoB,iBAA0C;AAC5D,MAAI,oBAAoB,KAAK,gBAC3B;AAEF,OAAK,kBAAkB;AACvB,OAAK,MAAM,SAAS,MAAA,UAAgB;GAClC,MAAM,EAAC,SAAS,UAAS;AACzB,OAAI,UAAU,iBAAiB;AAC7B,aAAS;AACT,UAAA,SAAe,OAAO,MAAM;;;;CAKlC,iBAAmC;AACjC,SAAO,MAAA,QAAc,UAAU;;CAGjC,gBAAkC;AAChC,SAAO,MAAA,QAAc,SAAS;;CAGhC,SAAS,OAAkD;AACzD,MAAI,KAAK,oBAAoB,MAC3B,QAAO,QAAQ,SAAS;EAG1B,MAAM,EAAC,SAAS,YAAW,UAAU;AACrC,QAAA,SAAe,IAAI;GAAC;GAAS;GAAM,CAAC;AACpC,SAAO;;;AAIX,IAAM,kBAAkB,QAAQ,SAAS;AACzC,IAAM,2BAA2B,IAAI,cAAc,KAAA,EAAU;AAE7D,IAAM,iCAAN,MAA0E;CACxE,kBAAoD;CACpD,iBAAmC;AACjC,SAAO;;CAGT,gBAAkC;AAChC,SAAO"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"dotenv.js","names":[],"sources":["../../../../shared/src/dotenv.ts"],"sourcesContent":["import {config as dotenvxConfig} from '@dotenvx/dotenvx';\n\n// Import env vars from .env file if present but don't whine if not present.\n// Also no free marketing for dotenvx.\ndotenvxConfig({\n ignore: ['MISSING_ENV_FILE'],\n quiet: true,\n});\n"],"mappings":";;AAIA,OAAc;CACZ,QAAQ,CAAC,mBAAmB;CAC5B,OAAO;CACR,CAAC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"error.js","names":[],"sources":["../../../../shared/src/error.ts"],"sourcesContent":["import {jsonSchema} from './json-schema.ts';\nimport type {ReadonlyJSONValue} from './json.ts';\n\nexport function getErrorMessage(error: unknown): string {\n return getErrorMessageInternal(error, new Set());\n}\n\nfunction getErrorMessageInternal(error: unknown, seen: Set<unknown>): string {\n if (typeof error === 'string') {\n return error;\n }\n\n if (typeof error === 'object' && error !== null) {\n if (seen.has(error)) {\n return 'Circular error reference detected while extracting the error message.';\n }\n seen.add(error);\n }\n\n if (error instanceof Error) {\n if (error.message) {\n return error.message;\n }\n\n if ('cause' in error) {\n const {cause} = error as {cause: unknown};\n if (cause !== undefined) {\n const causeMessage = getErrorMessageInternal(cause, seen);\n if (causeMessage) {\n return causeMessage;\n }\n }\n }\n }\n\n if (\n typeof error === 'object' &&\n error !== null &&\n 'message' in error &&\n typeof (error as {message: unknown}).message === 'string'\n ) {\n const message = (error as {message: string}).message;\n if (message) {\n return message;\n }\n }\n\n try {\n const json = jsonSchema.parse(error);\n return `Parsed message: ${JSON.stringify(json)}`;\n } catch {}\n\n return `Unknown error of type ${typeof error} was thrown and the message could not be determined. See cause for details.`;\n}\n\nexport function getErrorDetails(error: unknown): ReadonlyJSONValue | undefined {\n if (error instanceof Error) {\n if ('details' in error) {\n try {\n return jsonSchema.parse(error?.details);\n } catch {}\n }\n\n if (error.name && error.name !== 'Error') {\n return {name: error.name};\n }\n\n return undefined;\n }\n\n if (typeof error === 'object' && error !== null && 'details' in error) {\n try {\n return jsonSchema.parse((error as {details: ReadonlyJSONValue})?.details);\n } catch {}\n }\n\n try {\n return jsonSchema.parse(error);\n } catch {}\n\n return undefined;\n}\n"],"mappings":";;AAGA,SAAgB,gBAAgB,OAAwB;AACtD,QAAO,wBAAwB,uBAAO,IAAI,KAAK,CAAC;;AAGlD,SAAS,wBAAwB,OAAgB,MAA4B;AAC3E,KAAI,OAAO,UAAU,SACnB,QAAO;AAGT,KAAI,OAAO,UAAU,YAAY,UAAU,MAAM;AAC/C,MAAI,KAAK,IAAI,MAAM,CACjB,QAAO;AAET,OAAK,IAAI,MAAM;;AAGjB,KAAI,iBAAiB,OAAO;AAC1B,MAAI,MAAM,QACR,QAAO,MAAM;AAGf,MAAI,WAAW,OAAO;GACpB,MAAM,EAAC,UAAS;AAChB,OAAI,UAAU,KAAA,GAAW;IACvB,MAAM,eAAe,wBAAwB,OAAO,KAAK;AACzD,QAAI,aACF,QAAO;;;;AAMf,KACE,OAAO,UAAU,YACjB,UAAU,QACV,aAAa,SACb,OAAQ,MAA6B,YAAY,UACjD;EACA,MAAM,UAAW,MAA4B;AAC7C,MAAI,QACF,QAAO;;AAIX,KAAI;EACF,MAAM,OAAO,WAAW,MAAM,MAAM;AACpC,SAAO,mBAAmB,KAAK,UAAU,KAAK;SACxC;AAER,QAAO,yBAAyB,OAAO,MAAM;;AAG/C,SAAgB,gBAAgB,OAA+C;AAC7E,KAAI,iBAAiB,OAAO;AAC1B,MAAI,aAAa,MACf,KAAI;AACF,UAAO,WAAW,MAAM,OAAO,QAAQ;UACjC;AAGV,MAAI,MAAM,QAAQ,MAAM,SAAS,QAC/B,QAAO,EAAC,MAAM,MAAM,MAAK;AAG3B;;AAGF,KAAI,OAAO,UAAU,YAAY,UAAU,QAAQ,aAAa,MAC9D,KAAI;AACF,SAAO,WAAW,MAAO,OAAwC,QAAQ;SACnE;AAGV,KAAI;AACF,SAAO,WAAW,MAAM,MAAM;SACxB"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"has-own.js","names":[],"sources":["../../../../shared/src/has-own.ts"],"sourcesContent":["// hasOwn was added in ES2022\nexport const {hasOwn} = Object;\n"],"mappings":";AACA,IAAa,EAAC,WAAU"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"hash.js","names":[],"sources":["../../../../shared/src/hash.ts"],"sourcesContent":["import {xxHash32} from 'js-xxhash';\n\nexport const h32 = (s: string) => xxHash32(s, 0);\nexport const h64 = (s: string) => hash(s, 2);\nexport const h128 = (s: string) => hash(s, 4);\n\n/**\n * xxHash32 only computes 32-bit values. Run it n times with different seeds to\n * get a larger hash with better collision resistance.\n */\nfunction hash(str: string, words: number): bigint {\n let hash = 0n;\n for (let i = 0; i < words; i++) {\n hash = (hash << 32n) + BigInt(xxHash32(str, i));\n }\n return hash;\n}\n"],"mappings":";;AAEA,IAAa,OAAO,MAAc,SAAS,GAAG,EAAE;AAChD,IAAa,OAAO,MAAc,KAAK,GAAG,EAAE;AAC5C,IAAa,QAAQ,MAAc,KAAK,GAAG,EAAE;;;;;AAM7C,SAAS,KAAK,KAAa,OAAuB;CAChD,IAAI,OAAO;AACX,MAAK,IAAI,IAAI,GAAG,IAAI,OAAO,IACzB,SAAQ,QAAQ,OAAO,OAAO,SAAS,KAAK,EAAE,CAAC;AAEjD,QAAO"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"iterables.js","names":["#iterator"],"sources":["../../../../shared/src/iterables.ts"],"sourcesContent":["export function* joinIterables<T>(...iters: Iterable<T>[]) {\n for (const iter of iters) {\n yield* iter;\n }\n}\n\nfunction* filterIter<T>(\n iter: Iterable<T>,\n p: (t: T, index: number) => boolean,\n): Iterable<T> {\n let index = 0;\n for (const t of iter) {\n if (p(t, index++)) {\n yield t;\n }\n }\n}\n\nfunction* mapIter<T, U>(\n iter: Iterable<T>,\n f: (t: T, index: number) => U,\n): Iterable<U> {\n let index = 0;\n for (const t of iter) {\n yield f(t, index++);\n }\n}\n\nexport function first<T>(stream: Iterable<T>): T | undefined {\n const it = stream[Symbol.iterator]();\n const {value} = it.next();\n it.return?.();\n return value;\n}\n\nexport function* once<T>(stream: Iterable<T>): Iterable<T> {\n const it = stream[Symbol.iterator]();\n const {value} = it.next();\n if (value !== undefined) {\n yield value;\n }\n it.return?.();\n}\n\n// ES2024 Iterator helpers are available in Node 22+ and part of ES2024.\n// https://github.com/tc39/proposal-iterator-helpers\n\ntype IteratorWithHelpers<T> = Iterator<T> & {\n map<U>(f: (t: T, index: number) => U): IteratorWithHelpers<U>;\n filter(p: (t: T, index: number) => boolean): IteratorWithHelpers<T>;\n [Symbol.iterator](): IteratorWithHelpers<T>;\n};\n\ntype IteratorConstructor = {\n from<T>(this: void, iter: Iterable<T>): IteratorWithHelpers<T>;\n};\n\n// Check if native Iterator.from is available and bind it once at startup\n// We use globalThis to access the runtime value safely\nconst iteratorCtor = (globalThis as {Iterator?: IteratorConstructor}).Iterator;\nconst nativeIteratorFrom = iteratorCtor?.from as\n | (<T>(iter: Iterable<T>) => IteratorWithHelpers<T>)\n | undefined;\n\nconst iteratorFrom: <T>(e: Iterable<T>) => IteratorWithHelpers<T> =\n nativeIteratorFrom ?? (e => new IterWrapper(e));\n\n// Fallback implementation for environments without ES2024 Iterator helpers\nclass IterWrapper<T> implements IteratorWithHelpers<T>, IterableIterator<T> {\n readonly #iterator: Iterator<T>;\n\n constructor(iterable: Iterable<T>) {\n this.#iterator = iterable[Symbol.iterator]();\n }\n\n next(): IteratorResult<T> {\n return this.#iterator.next();\n }\n\n [Symbol.iterator](): IteratorWithHelpers<T> {\n return this;\n }\n\n map<U>(f: (t: T, index: number) => U): IterWrapper<U> {\n return new IterWrapper(mapIter(this, f));\n }\n\n filter(p: (t: T, index: number) => boolean): IterWrapper<T> {\n return new IterWrapper(filterIter(this, p));\n }\n}\n\nexport function wrapIterable<T>(iter: Iterable<T>): IteratorWithHelpers<T> {\n return iteratorFrom(iter);\n}\n\n/**\n * This will make a new array where the elements are the same as the iterable\n * but sorted according to the compare function. If the compare function is not\n * provided, it will sort the elements in JS standard way which is string\n * compare.\n */\nexport function toSorted<T>(\n iter: Iterable<T>,\n compare?: (a: T, b: T) => number,\n): T[] {\n // oxlint-disable-next-line e18e/prefer-array-to-sorted\n return [...iter].sort(compare);\n}\n"],"mappings":";AAAA,UAAiB,cAAiB,GAAG,OAAsB;AACzD,MAAK,MAAM,QAAQ,MACjB,QAAO;;AAIX,UAAU,WACR,MACA,GACa;CACb,IAAI,QAAQ;AACZ,MAAK,MAAM,KAAK,KACd,KAAI,EAAE,GAAG,QAAQ,CACf,OAAM;;AAKZ,UAAU,QACR,MACA,GACa;CACb,IAAI,QAAQ;AACZ,MAAK,MAAM,KAAK,KACd,OAAM,EAAE,GAAG,QAAQ;;AAWvB,UAAiB,KAAQ,QAAkC;CACzD,MAAM,KAAK,OAAO,OAAO,WAAW;CACpC,MAAM,EAAC,UAAS,GAAG,MAAM;AACzB,KAAI,UAAU,KAAA,EACZ,OAAM;AAER,IAAG,UAAU;;AAuBf,IAAM,eALgB,WAAgD,UAC7B,UAKhB,MAAK,IAAI,YAAY,EAAE;AAGhD,IAAM,cAAN,MAAM,YAAsE;CAC1E;CAEA,YAAY,UAAuB;AACjC,QAAA,WAAiB,SAAS,OAAO,WAAW;;CAG9C,OAA0B;AACxB,SAAO,MAAA,SAAe,MAAM;;CAG9B,CAAC,OAAO,YAAoC;AAC1C,SAAO;;CAGT,IAAO,GAA+C;AACpD,SAAO,IAAI,YAAY,QAAQ,MAAM,EAAE,CAAC;;CAG1C,OAAO,GAAqD;AAC1D,SAAO,IAAI,YAAY,WAAW,MAAM,EAAE,CAAC;;;AAI/C,SAAgB,aAAgB,MAA2C;AACzE,QAAO,aAAa,KAAK;;;;;;;;AAS3B,SAAgB,SACd,MACA,SACK;AAEL,QAAO,CAAC,GAAG,KAAK,CAAC,KAAK,QAAQ"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"json-schema.js","names":[],"sources":["../../../../shared/src/json-schema.ts"],"sourcesContent":["import * as valita from '@badrap/valita';\nimport {skipAssertJSONValue} from './config.ts';\nimport type {ReadonlyJSONObject, ReadonlyJSONValue} from './json.ts';\nimport {isJSONObject, isJSONValue} from './json.ts';\nimport * as v from './valita.ts';\n\nconst path: (string | number)[] = [];\n\nexport const jsonSchema: valita.Type<ReadonlyJSONValue> = v\n .unknown()\n .chain(v => {\n if (skipAssertJSONValue) {\n return valita.ok(v as ReadonlyJSONValue);\n }\n const rv = isJSONValue(v, path)\n ? valita.ok(v)\n : valita.err({\n message: `Not a JSON value`,\n path: path.slice(),\n });\n path.length = 0;\n return rv;\n });\n\nexport const jsonObjectSchema: valita.Type<ReadonlyJSONObject> = v\n .unknown()\n .chain(v => {\n if (skipAssertJSONValue) {\n return valita.ok(v as ReadonlyJSONObject);\n }\n const rv = isJSONObject(v, path)\n ? valita.ok(v)\n : valita.err({\n message: `Not a JSON object`,\n path: path.slice(),\n });\n path.length = 0;\n return rv;\n });\n"],"mappings":";;;;;AAMA,IAAM,OAA4B,EAAE;AAEpC,IAAa,aAA6C,eACvD,SAAS,CACT,OAAM,MAAK;AACV,KAAI,OACF,QAAO,OAAO,GAAG,EAAuB;CAE1C,MAAM,KAAK,YAAY,GAAG,KAAK,GAC3B,OAAO,GAAG,EAAE,GACZ,OAAO,IAAI;EACT,SAAS;EACT,MAAM,KAAK,OAAO;EACnB,CAAC;AACN,MAAK,SAAS;AACd,QAAO;EACP;AAEJ,IAAa,mBAAoD,eAC9D,SAAS,CACT,OAAM,MAAK;AACV,KAAI,OACF,QAAO,OAAO,GAAG,EAAwB;CAE3C,MAAM,KAAK,aAAa,GAAG,KAAK,GAC5B,OAAO,GAAG,EAAE,GACZ,OAAO,IAAI;EACT,SAAS;EACT,MAAM,KAAK,OAAO;EACnB,CAAC;AACN,MAAK,SAAS;AACd,QAAO;EACP"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"json.js","names":[],"sources":["../../../../shared/src/json.ts"],"sourcesContent":["import {assertObject, throwInvalidType} from './asserts.ts';\nimport {skipAssertJSONValue} from './config.ts';\nimport {hasOwn} from './has-own.ts';\n\n/** The values that can be represented in JSON */\nexport type JSONValue =\n | null\n | string\n | boolean\n | number\n | Array<JSONValue>\n | JSONObject;\n\n/**\n * A JSON object. This is a map from strings to JSON values or `undefined`. We\n * allow `undefined` values as a convenience... but beware that the `undefined`\n * values do not round trip to the server. For example:\n *\n * ```\n * // Time t1\n * await tx.set('a', {a: undefined});\n *\n * // time passes, in a new transaction\n * const v = await tx.get('a');\n * console.log(v); // either {a: undefined} or {}\n * ```\n */\nexport type JSONObject = {[key: string]: JSONValue | undefined};\n\n/** Like {@link JSONValue} but deeply readonly */\nexport type ReadonlyJSONValue =\n | null\n | string\n | boolean\n | number\n | ReadonlyArray<ReadonlyJSONValue>\n | ReadonlyJSONObject;\n\n/** Like {@link JSONObject} but deeply readonly */\nexport type ReadonlyJSONObject = {\n readonly [key: string]: ReadonlyJSONValue | undefined;\n};\n\n/**\n * Checks deep equality of two JSON value with (almost) same semantics as\n * `JSON.stringify`. The only difference is that with `JSON.stringify` the\n * ordering of the properties in an object/map/dictionary matters. In\n * {@link deepEqual} the following two values are consider equal, even though the\n * strings JSON.stringify would produce is different:\n *\n * ```js\n * assert(deepEqual(t({a: 1, b: 2}, {b: 2, a: 1}))\n * ```\n */\nexport function deepEqual(\n a: ReadonlyJSONValue | undefined,\n b: ReadonlyJSONValue | undefined,\n): boolean {\n if (a === b) {\n return true;\n }\n\n if (typeof a !== typeof b) {\n return false;\n }\n\n switch (typeof a) {\n case 'boolean':\n case 'number':\n case 'string':\n return false;\n }\n\n // a cannot be undefined here because either a and b are undefined or their\n // types are different.\n // oxlint-disable-next-line @typescript-eslint/no-non-null-assertion\n a = a!;\n\n // 'object'\n if (Array.isArray(a)) {\n if (!Array.isArray(b)) {\n return false;\n }\n if (a.length !== b.length) {\n return false;\n }\n for (let i = 0; i < a.length; i++) {\n if (!deepEqual(a[i], b[i])) {\n return false;\n }\n }\n return true;\n }\n\n if (a === null || b === null) {\n return false;\n }\n\n if (Array.isArray(b)) {\n return false;\n }\n\n // We know a and b are objects here but type inference is not smart enough.\n a = a as ReadonlyJSONObject;\n b = b as ReadonlyJSONObject;\n\n // We use for-in loops instead of for of Object.keys() to make sure deepEquals\n // does not allocate any objects.\n\n let aSize = 0;\n for (const key in a) {\n if (hasOwn(a, key)) {\n if (!deepEqual(a[key], b[key])) {\n return false;\n }\n aSize++;\n }\n }\n\n let bSize = 0;\n for (const key in b) {\n if (hasOwn(b, key)) {\n bSize++;\n }\n }\n\n return aSize === bSize;\n}\n\nexport function assertJSONValue(v: unknown): asserts v is JSONValue {\n if (skipAssertJSONValue) {\n return;\n }\n switch (typeof v) {\n case 'boolean':\n case 'number':\n case 'string':\n return;\n case 'object':\n if (v === null) {\n return;\n }\n if (Array.isArray(v)) {\n return assertJSONArray(v);\n }\n return assertObjectIsJSONObject(v as Record<string, unknown>);\n }\n throwInvalidType(v, 'JSON value');\n}\n\nexport function assertJSONObject(v: unknown): asserts v is JSONObject {\n assertObject(v);\n assertObjectIsJSONObject(v);\n}\n\nfunction assertObjectIsJSONObject(\n v: Record<string, unknown>,\n): asserts v is JSONObject {\n for (const k in v) {\n if (hasOwn(v, k)) {\n const value = v[k];\n if (value !== undefined) {\n assertJSONValue(value);\n }\n }\n }\n}\n\nfunction assertJSONArray(v: unknown[]): asserts v is JSONValue[] {\n for (const item of v) {\n assertJSONValue(item);\n }\n}\n\ninterface Path {\n push(key: string | number): void;\n pop(): void;\n}\n\n/**\n * Checks if a value is a JSON value. If there is a value that is not a JSON\n * value, the path parameter is updated to the path of the invalid value.\n */\nexport function isJSONValue(v: unknown, path: Path): v is JSONValue {\n switch (typeof v) {\n case 'boolean':\n case 'number':\n case 'string':\n return true;\n case 'object':\n if (v === null) {\n return true;\n }\n if (Array.isArray(v)) {\n return isJSONArray(v, path);\n }\n return objectIsJSONObject(v as Record<string, unknown>, path);\n }\n return false;\n}\n\nexport function isJSONObject(v: unknown, path: Path): v is JSONObject {\n if (typeof v !== 'object' || v === null) {\n return false;\n }\n return objectIsJSONObject(v as Record<string, unknown>, path);\n}\n\nfunction objectIsJSONObject(\n v: Record<string, unknown>,\n path: Path,\n): v is JSONObject {\n for (const k in v) {\n if (hasOwn(v, k)) {\n path.push(k);\n const value = v[k];\n if (value !== undefined && !isJSONValue(value, path)) {\n return false;\n }\n path.pop();\n }\n }\n return true;\n}\n\nfunction isJSONArray(v: unknown[], path: Path): v is JSONValue[] {\n for (let i = 0; i < v.length; i++) {\n path.push(i);\n if (!isJSONValue(v[i], path)) {\n return false;\n }\n path.pop();\n }\n return true;\n}\n\n/** Basic deep readonly type. It works for {@link JSONValue} types. */\nexport type DeepReadonly<T> = T extends\n | null\n | boolean\n | string\n | number\n | undefined\n ? T\n : {readonly [K in keyof T]: DeepReadonly<T[K]>};\n"],"mappings":";;;;;;;;;;;;;;;AAsDA,SAAgB,UACd,GACA,GACS;AACT,KAAI,MAAM,EACR,QAAO;AAGT,KAAI,OAAO,MAAM,OAAO,EACtB,QAAO;AAGT,SAAQ,OAAO,GAAf;EACE,KAAK;EACL,KAAK;EACL,KAAK,SACH,QAAO;;AAMX,KAAI;AAGJ,KAAI,MAAM,QAAQ,EAAE,EAAE;AACpB,MAAI,CAAC,MAAM,QAAQ,EAAE,CACnB,QAAO;AAET,MAAI,EAAE,WAAW,EAAE,OACjB,QAAO;AAET,OAAK,IAAI,IAAI,GAAG,IAAI,EAAE,QAAQ,IAC5B,KAAI,CAAC,UAAU,EAAE,IAAI,EAAE,GAAG,CACxB,QAAO;AAGX,SAAO;;AAGT,KAAI,MAAM,QAAQ,MAAM,KACtB,QAAO;AAGT,KAAI,MAAM,QAAQ,EAAE,CAClB,QAAO;AAIT,KAAI;AACJ,KAAI;CAKJ,IAAI,QAAQ;AACZ,MAAK,MAAM,OAAO,EAChB,KAAI,OAAO,GAAG,IAAI,EAAE;AAClB,MAAI,CAAC,UAAU,EAAE,MAAM,EAAE,KAAK,CAC5B,QAAO;AAET;;CAIJ,IAAI,QAAQ;AACZ,MAAK,MAAM,OAAO,EAChB,KAAI,OAAO,GAAG,IAAI,CAChB;AAIJ,QAAO,UAAU;;AAGnB,SAAgB,gBAAgB,GAAoC;AAClE,KAAI,OACF;AAEF,SAAQ,OAAO,GAAf;EACE,KAAK;EACL,KAAK;EACL,KAAK,SACH;EACF,KAAK;AACH,OAAI,MAAM,KACR;AAEF,OAAI,MAAM,QAAQ,EAAE,CAClB,QAAO,gBAAgB,EAAE;AAE3B,UAAO,yBAAyB,EAA6B;;AAEjE,kBAAiB,GAAG,aAAa;;AAGnC,SAAgB,iBAAiB,GAAqC;AACpE,cAAa,EAAE;AACf,0BAAyB,EAAE;;AAG7B,SAAS,yBACP,GACyB;AACzB,MAAK,MAAM,KAAK,EACd,KAAI,OAAO,GAAG,EAAE,EAAE;EAChB,MAAM,QAAQ,EAAE;AAChB,MAAI,UAAU,KAAA,EACZ,iBAAgB,MAAM;;;AAM9B,SAAS,gBAAgB,GAAwC;AAC/D,MAAK,MAAM,QAAQ,EACjB,iBAAgB,KAAK;;;;;;AAazB,SAAgB,YAAY,GAAY,MAA4B;AAClE,SAAQ,OAAO,GAAf;EACE,KAAK;EACL,KAAK;EACL,KAAK,SACH,QAAO;EACT,KAAK;AACH,OAAI,MAAM,KACR,QAAO;AAET,OAAI,MAAM,QAAQ,EAAE,CAClB,QAAO,YAAY,GAAG,KAAK;AAE7B,UAAO,mBAAmB,GAA8B,KAAK;;AAEjE,QAAO;;AAGT,SAAgB,aAAa,GAAY,MAA6B;AACpE,KAAI,OAAO,MAAM,YAAY,MAAM,KACjC,QAAO;AAET,QAAO,mBAAmB,GAA8B,KAAK;;AAG/D,SAAS,mBACP,GACA,MACiB;AACjB,MAAK,MAAM,KAAK,EACd,KAAI,OAAO,GAAG,EAAE,EAAE;AAChB,OAAK,KAAK,EAAE;EACZ,MAAM,QAAQ,EAAE;AAChB,MAAI,UAAU,KAAA,KAAa,CAAC,YAAY,OAAO,KAAK,CAClD,QAAO;AAET,OAAK,KAAK;;AAGd,QAAO;;AAGT,SAAS,YAAY,GAAc,MAA8B;AAC/D,MAAK,IAAI,IAAI,GAAG,IAAI,EAAE,QAAQ,KAAK;AACjC,OAAK,KAAK,EAAE;AACZ,MAAI,CAAC,YAAY,EAAE,IAAI,KAAK,CAC1B,QAAO;AAET,OAAK,KAAK;;AAEZ,QAAO"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"logging-test-utils.js","names":[],"sources":["../../../../shared/src/logging-test-utils.ts"],"sourcesContent":["import {\n type Context,\n LogContext,\n type LogLevel,\n type LogSink,\n} from '@rocicorp/logger';\n\nexport class TestLogSink implements LogSink {\n messages: [LogLevel, Context | undefined, unknown[]][] = [];\n flushCallCount = 0;\n\n log(level: LogLevel, context: Context | undefined, ...args: unknown[]): void {\n this.messages.push([level, context, args]);\n }\n\n flush() {\n this.flushCallCount++;\n return Promise.resolve();\n }\n}\n\nexport class SilentLogSink implements LogSink {\n log(_l: LogLevel, _c: Context | undefined, ..._args: unknown[]): void {\n return;\n }\n}\n\nexport function createSilentLogContext() {\n return new LogContext('error', undefined, new SilentLogSink());\n}\n"],"mappings":";;AAqBA,IAAa,gBAAb,MAA8C;CAC5C,IAAI,IAAc,IAAyB,GAAG,OAAwB;;AAKxE,SAAgB,yBAAyB;AACvC,QAAO,IAAI,WAAW,SAAS,KAAA,GAAW,IAAI,eAAe,CAAC"}