@rocicorp/zero 0.2.2024101100 → 0.3.2024102300
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/out/react.js +92 -39
- package/out/react.js.map +2 -2
- package/out/replicache/src/async-iterable-to-array.js +8 -0
- package/out/replicache/src/async-iterable-to-array.js.map +1 -0
- package/out/replicache/src/bg-interval.js +38 -0
- package/out/replicache/src/bg-interval.js.map +1 -0
- package/out/replicache/src/binary-search.js +31 -0
- package/out/replicache/src/binary-search.js.map +1 -0
- package/out/replicache/src/broadcast-channel.js +29 -0
- package/out/replicache/src/broadcast-channel.js.map +1 -0
- package/out/replicache/src/btree/diff.js +6 -0
- package/out/replicache/src/btree/diff.js.map +1 -0
- package/out/replicache/src/btree/node.js +392 -0
- package/out/replicache/src/btree/node.js.map +1 -0
- package/out/replicache/src/btree/read.js +227 -0
- package/out/replicache/src/btree/read.js.map +1 -0
- package/out/replicache/src/btree/splice.js +79 -0
- package/out/replicache/src/btree/splice.js.map +1 -0
- package/out/replicache/src/btree/write.js +154 -0
- package/out/replicache/src/btree/write.js.map +1 -0
- package/out/replicache/src/call-default-fetch.js +37 -0
- package/out/replicache/src/call-default-fetch.js.map +1 -0
- package/out/replicache/src/config.js +13 -0
- package/out/replicache/src/config.js.map +1 -0
- package/out/replicache/src/connection-loop-delegates.js +30 -0
- package/out/replicache/src/connection-loop-delegates.js.map +1 -0
- package/out/replicache/src/connection-loop.js +268 -0
- package/out/replicache/src/connection-loop.js.map +1 -0
- package/out/replicache/src/cookies.js +41 -0
- package/out/replicache/src/cookies.js.map +1 -0
- package/out/replicache/src/dag/chunk.js +60 -0
- package/out/replicache/src/dag/chunk.js.map +1 -0
- package/out/replicache/src/dag/gc.js +126 -0
- package/out/replicache/src/dag/gc.js.map +1 -0
- package/out/replicache/src/dag/key-type-enum.js +6 -0
- package/out/replicache/src/dag/key-type-enum.js.map +1 -0
- package/out/replicache/src/dag/key.js +54 -0
- package/out/replicache/src/dag/key.js.map +1 -0
- package/out/replicache/src/dag/lazy-store.js +532 -0
- package/out/replicache/src/dag/lazy-store.js.map +1 -0
- package/out/replicache/src/dag/store-impl.js +175 -0
- package/out/replicache/src/dag/store-impl.js.map +1 -0
- package/out/replicache/src/dag/store.js +22 -0
- package/out/replicache/src/dag/store.js.map +1 -0
- package/out/replicache/src/dag/visitor.js +22 -0
- package/out/replicache/src/dag/visitor.js.map +1 -0
- package/out/replicache/src/db/commit.js +443 -0
- package/out/replicache/src/db/commit.js.map +1 -0
- package/out/replicache/src/db/index-operation-enum.js +4 -0
- package/out/replicache/src/db/index-operation-enum.js.map +1 -0
- package/out/replicache/src/db/index.js +170 -0
- package/out/replicache/src/db/index.js.map +1 -0
- package/out/replicache/src/db/meta-type-enum.js +7 -0
- package/out/replicache/src/db/meta-type-enum.js.map +1 -0
- package/out/replicache/src/db/read.js +59 -0
- package/out/replicache/src/db/read.js.map +1 -0
- package/out/replicache/src/db/rebase.js +56 -0
- package/out/replicache/src/db/rebase.js.map +1 -0
- package/out/replicache/src/db/scan.js +2 -0
- package/out/replicache/src/db/scan.js.map +1 -0
- package/out/replicache/src/db/write.js +260 -0
- package/out/replicache/src/db/write.js.map +1 -0
- package/out/replicache/src/error-responses.js +30 -0
- package/out/replicache/src/error-responses.js.map +1 -0
- package/out/replicache/src/filter-async-iterable.js +15 -0
- package/out/replicache/src/filter-async-iterable.js.map +1 -0
- package/out/replicache/src/format-version-enum.js +9 -0
- package/out/replicache/src/format-version-enum.js.map +1 -0
- package/out/replicache/src/format-version.js +8 -0
- package/out/replicache/src/format-version.js.map +1 -0
- package/out/replicache/src/frozen-json.js +151 -0
- package/out/replicache/src/frozen-json.js.map +1 -0
- package/out/replicache/src/get-default-puller.js +74 -0
- package/out/replicache/src/get-default-puller.js.map +1 -0
- package/out/replicache/src/get-default-pusher.js +36 -0
- package/out/replicache/src/get-default-pusher.js.map +1 -0
- package/out/replicache/src/hash.js +73 -0
- package/out/replicache/src/hash.js.map +1 -0
- package/out/replicache/src/http-request-info.js +7 -0
- package/out/replicache/src/http-request-info.js.map +1 -0
- package/out/replicache/src/impl.js +2 -0
- package/out/replicache/src/impl.js.map +1 -0
- package/out/replicache/src/index-defs.js +28 -0
- package/out/replicache/src/index-defs.js.map +1 -0
- package/out/replicache/src/invoke-kind-enum.js +4 -0
- package/out/replicache/src/invoke-kind-enum.js.map +1 -0
- package/out/replicache/src/iterable-union.js +5 -0
- package/out/replicache/src/iterable-union.js.map +1 -0
- package/out/replicache/src/kv/idb-store-with-mem-fallback.js +93 -0
- package/out/replicache/src/kv/idb-store-with-mem-fallback.js.map +1 -0
- package/out/replicache/src/kv/idb-store.js +179 -0
- package/out/replicache/src/kv/idb-store.js.map +1 -0
- package/out/replicache/src/kv/mem-store.js +61 -0
- package/out/replicache/src/kv/mem-store.js.map +1 -0
- package/out/replicache/src/kv/read-impl.js +23 -0
- package/out/replicache/src/kv/read-impl.js.map +1 -0
- package/out/replicache/src/kv/store.js +2 -0
- package/out/replicache/src/kv/store.js.map +1 -0
- package/out/replicache/src/kv/write-impl-base.js +48 -0
- package/out/replicache/src/kv/write-impl-base.js.map +1 -0
- package/out/replicache/src/kv/write-impl.js +25 -0
- package/out/replicache/src/kv/write-impl.js.map +1 -0
- package/out/replicache/src/lazy.js +10 -0
- package/out/replicache/src/lazy.js.map +1 -0
- package/out/replicache/src/log-options.js +13 -0
- package/out/replicache/src/log-options.js.map +1 -0
- package/out/replicache/src/merge-async-iterables.js +61 -0
- package/out/replicache/src/merge-async-iterables.js.map +1 -0
- package/out/replicache/src/mod.js +14 -0
- package/out/replicache/src/mod.js.map +1 -0
- package/out/replicache/src/mutation-recovery.js +439 -0
- package/out/replicache/src/mutation-recovery.js.map +1 -0
- package/out/replicache/src/new-client-channel.js +77 -0
- package/out/replicache/src/new-client-channel.js.map +1 -0
- package/out/replicache/src/on-persist-channel.js +33 -0
- package/out/replicache/src/on-persist-channel.js.map +1 -0
- package/out/replicache/src/patch-operation.js +37 -0
- package/out/replicache/src/patch-operation.js.map +1 -0
- package/out/replicache/src/pending-mutations.js +18 -0
- package/out/replicache/src/pending-mutations.js.map +1 -0
- package/out/replicache/src/persist/client-gc.js +38 -0
- package/out/replicache/src/persist/client-gc.js.map +1 -0
- package/out/replicache/src/persist/client-group-gc.js +38 -0
- package/out/replicache/src/persist/client-group-gc.js.map +1 -0
- package/out/replicache/src/persist/client-groups.js +180 -0
- package/out/replicache/src/persist/client-groups.js.map +1 -0
- package/out/replicache/src/persist/clients.js +390 -0
- package/out/replicache/src/persist/clients.js.map +1 -0
- package/out/replicache/src/persist/collect-idb-databases.js +174 -0
- package/out/replicache/src/persist/collect-idb-databases.js.map +1 -0
- package/out/replicache/src/persist/gather-mem-only-visitor.js +25 -0
- package/out/replicache/src/persist/gather-mem-only-visitor.js.map +1 -0
- package/out/replicache/src/persist/gather-not-cached-visitor.js +35 -0
- package/out/replicache/src/persist/gather-not-cached-visitor.js.map +1 -0
- package/out/replicache/src/persist/heartbeat.js +37 -0
- package/out/replicache/src/persist/heartbeat.js.map +1 -0
- package/out/replicache/src/persist/idb-databases-store-db-name.js +18 -0
- package/out/replicache/src/persist/idb-databases-store-db-name.js.map +1 -0
- package/out/replicache/src/persist/idb-databases-store.js +90 -0
- package/out/replicache/src/persist/idb-databases-store.js.map +1 -0
- package/out/replicache/src/persist/make-client-id.js +13 -0
- package/out/replicache/src/persist/make-client-id.js.map +1 -0
- package/out/replicache/src/persist/persist.js +132 -0
- package/out/replicache/src/persist/persist.js.map +1 -0
- package/out/replicache/src/persist/refresh.js +147 -0
- package/out/replicache/src/persist/refresh.js.map +1 -0
- package/out/replicache/src/process-scheduler.js +93 -0
- package/out/replicache/src/process-scheduler.js.map +1 -0
- package/out/replicache/src/puller.js +2 -0
- package/out/replicache/src/puller.js.map +1 -0
- package/out/replicache/src/pusher.js +32 -0
- package/out/replicache/src/pusher.js.map +1 -0
- package/out/replicache/src/replicache-impl.js +1007 -0
- package/out/replicache/src/replicache-impl.js.map +1 -0
- package/out/replicache/src/replicache-options.js +2 -0
- package/out/replicache/src/replicache-options.js.map +1 -0
- package/out/replicache/src/replicache.js +387 -0
- package/out/replicache/src/replicache.js.map +1 -0
- package/out/replicache/src/request-idle.js +15 -0
- package/out/replicache/src/request-idle.js.map +1 -0
- package/out/replicache/src/scan-iterator.js +202 -0
- package/out/replicache/src/scan-iterator.js.map +1 -0
- package/out/replicache/src/scan-options.js +45 -0
- package/out/replicache/src/scan-options.js.map +1 -0
- package/out/replicache/src/set-interval-with-signal.js +7 -0
- package/out/replicache/src/set-interval-with-signal.js.map +1 -0
- package/out/replicache/src/size-of-value.js +77 -0
- package/out/replicache/src/size-of-value.js.map +1 -0
- package/out/replicache/src/subscriptions.js +357 -0
- package/out/replicache/src/subscriptions.js.map +1 -0
- package/out/replicache/src/sync/diff.js +75 -0
- package/out/replicache/src/sync/diff.js.map +1 -0
- package/out/replicache/src/sync/handle-pull-response-result-type-enum.js +5 -0
- package/out/replicache/src/sync/handle-pull-response-result-type-enum.js.map +1 -0
- package/out/replicache/src/sync/ids.js +4 -0
- package/out/replicache/src/sync/ids.js.map +1 -0
- package/out/replicache/src/sync/patch.js +41 -0
- package/out/replicache/src/sync/patch.js.map +1 -0
- package/out/replicache/src/sync/pull-error.js +16 -0
- package/out/replicache/src/sync/pull-error.js.map +1 -0
- package/out/replicache/src/sync/pull.js +375 -0
- package/out/replicache/src/sync/pull.js.map +1 -0
- package/out/replicache/src/sync/push.js +141 -0
- package/out/replicache/src/sync/push.js.map +1 -0
- package/out/replicache/src/sync/request-id.js +31 -0
- package/out/replicache/src/sync/request-id.js.map +1 -0
- package/out/replicache/src/sync/sync-head-name.js +2 -0
- package/out/replicache/src/sync/sync-head-name.js.map +1 -0
- package/out/replicache/src/test-license-key.js +3 -0
- package/out/replicache/src/test-license-key.js.map +1 -0
- package/out/replicache/src/to-error.js +7 -0
- package/out/replicache/src/to-error.js.map +1 -0
- package/out/replicache/src/transaction-closed-error.js +17 -0
- package/out/replicache/src/transaction-closed-error.js.map +1 -0
- package/out/replicache/src/transactions.js +144 -0
- package/out/replicache/src/transactions.js.map +1 -0
- package/out/replicache/src/types.js +2 -0
- package/out/replicache/src/types.js.map +1 -0
- package/out/replicache/src/version.js +5 -0
- package/out/replicache/src/version.js.map +1 -0
- package/out/replicache/src/with-transactions.js +28 -0
- package/out/replicache/src/with-transactions.js.map +1 -0
- package/out/shared/src/browser-env.js +14 -0
- package/out/shared/src/browser-env.js.map +1 -0
- package/out/shared/src/document-visible.js +76 -0
- package/out/shared/src/document-visible.js.map +1 -0
- package/out/shared/src/immutable.js +2 -0
- package/out/shared/src/immutable.js.map +1 -0
- package/out/shared/src/iterables.d.ts +2 -2
- package/out/shared/src/iterables.d.ts.map +1 -1
- package/out/shared/src/iterables.js +40 -0
- package/out/shared/src/iterables.js.map +1 -0
- package/out/shared/src/navigator.js +3 -0
- package/out/shared/src/navigator.js.map +1 -0
- package/out/shared/src/random-uint64.js +8 -0
- package/out/shared/src/random-uint64.js.map +1 -0
- package/out/shared/src/random-values.d.ts +1 -0
- package/out/shared/src/random-values.d.ts.map +1 -1
- package/out/shared/src/random-values.js +22 -0
- package/out/shared/src/random-values.js.map +1 -0
- package/out/shared/src/set-utils.d.ts +1 -1
- package/out/shared/src/set-utils.d.ts.map +1 -1
- package/out/shared/src/set-utils.js +6 -4
- package/out/shared/src/set-utils.js.map +1 -1
- package/out/shared/src/sorted-entries.d.ts +2 -0
- package/out/shared/src/sorted-entries.d.ts.map +1 -0
- package/out/shared/src/sorted-entries.js +6 -0
- package/out/shared/src/sorted-entries.js.map +1 -0
- package/out/shared/src/types.js +2 -0
- package/out/shared/src/types.js.map +1 -0
- package/out/shared/src/valita.d.ts +1 -1
- package/out/shared/src/valita.d.ts.map +1 -1
- package/out/shared/src/valita.js.map +1 -1
- package/out/shared/src/writable.d.ts +4 -0
- package/out/shared/src/writable.d.ts.map +1 -0
- package/out/shared/src/writable.js +2 -0
- package/out/shared/src/writable.js.map +1 -0
- package/out/zero/src/config.d.ts +2 -0
- package/out/zero/src/config.d.ts.map +1 -0
- package/out/zero/src/config.js +2 -0
- package/out/zero/src/config.js.map +1 -0
- package/out/zero-cache/src/config/config-query.d.ts +18 -0
- package/out/zero-cache/src/config/config-query.d.ts.map +1 -0
- package/out/zero-cache/src/config/config-query.js +19 -0
- package/out/zero-cache/src/config/config-query.js.map +1 -0
- package/out/zero-cache/src/config/define-config.d.ts +43 -0
- package/out/zero-cache/src/config/define-config.d.ts.map +1 -0
- package/out/zero-cache/src/config/define-config.js +120 -0
- package/out/zero-cache/src/config/define-config.js.map +1 -0
- package/out/zero-cache/src/config/refs.d.ts +3 -0
- package/out/zero-cache/src/config/refs.d.ts.map +1 -0
- package/out/zero-cache/src/config/refs.js +14 -0
- package/out/zero-cache/src/config/refs.js.map +1 -0
- package/out/zero-cache/src/config/zero-config.d.ts +126 -686
- package/out/zero-cache/src/config/zero-config.d.ts.map +1 -1
- package/out/zero-cache/src/config/zero-config.js +43 -159
- package/out/zero-cache/src/config/zero-config.js.map +1 -1
- package/out/zero-cache/src/db/create.d.ts +8 -0
- package/out/zero-cache/src/db/create.d.ts.map +1 -0
- package/out/zero-cache/src/db/create.js +39 -0
- package/out/zero-cache/src/db/create.js.map +1 -0
- package/out/zero-cache/src/db/lite-tables.d.ts +3 -3
- package/out/zero-cache/src/db/lite-tables.d.ts.map +1 -1
- package/out/zero-cache/src/db/lite-tables.js +29 -20
- package/out/zero-cache/src/db/lite-tables.js.map +1 -1
- package/out/zero-cache/src/db/{migration-lite.d.ts → old-migration-lite.d.ts} +1 -1
- package/out/zero-cache/src/db/old-migration-lite.d.ts.map +1 -0
- package/out/zero-cache/src/db/{migration-lite.js → old-migration-lite.js} +1 -1
- package/out/zero-cache/src/db/old-migration-lite.js.map +1 -0
- package/out/zero-cache/src/db/{migration.d.ts → old-migration.d.ts} +1 -1
- package/out/zero-cache/src/db/old-migration.d.ts.map +1 -0
- package/out/zero-cache/src/db/{migration.js → old-migration.js} +1 -1
- package/out/zero-cache/src/db/old-migration.js.map +1 -0
- package/out/zero-cache/src/db/pg-to-lite.d.ts +11 -0
- package/out/zero-cache/src/db/pg-to-lite.d.ts.map +1 -0
- package/out/zero-cache/src/{services/change-streamer/pg/schema/lite.js → db/pg-to-lite.js} +27 -15
- package/out/zero-cache/src/db/pg-to-lite.js.map +1 -0
- package/out/zero-cache/src/db/specs.d.ts +73 -0
- package/out/zero-cache/src/db/specs.d.ts.map +1 -0
- package/out/zero-cache/src/db/specs.js +30 -0
- package/out/zero-cache/src/db/specs.js.map +1 -0
- package/out/zero-cache/src/db/statements.d.ts +1 -1
- package/out/zero-cache/src/db/statements.d.ts.map +1 -1
- package/out/zero-cache/src/server/life-cycle.d.ts.map +1 -1
- package/out/zero-cache/src/server/life-cycle.js +9 -5
- package/out/zero-cache/src/server/life-cycle.js.map +1 -1
- package/out/zero-cache/src/server/main.js +2 -2
- package/out/zero-cache/src/server/main.js.map +1 -1
- package/out/zero-cache/src/server/syncer.d.ts.map +1 -1
- package/out/zero-cache/src/server/syncer.js +2 -1
- package/out/zero-cache/src/server/syncer.js.map +1 -1
- package/out/zero-cache/src/services/change-streamer/change-streamer-http.d.ts +1 -1
- package/out/zero-cache/src/services/change-streamer/change-streamer-http.d.ts.map +1 -1
- package/out/zero-cache/src/services/change-streamer/change-streamer-http.js +1 -4
- package/out/zero-cache/src/services/change-streamer/change-streamer-http.js.map +1 -1
- package/out/zero-cache/src/services/change-streamer/change-streamer.d.ts +455 -13
- package/out/zero-cache/src/services/change-streamer/change-streamer.d.ts.map +1 -1
- package/out/zero-cache/src/services/change-streamer/change-streamer.js +16 -0
- package/out/zero-cache/src/services/change-streamer/change-streamer.js.map +1 -1
- package/out/zero-cache/src/services/change-streamer/pg/change-source.d.ts.map +1 -1
- package/out/zero-cache/src/services/change-streamer/pg/change-source.js +311 -86
- package/out/zero-cache/src/services/change-streamer/pg/change-source.js.map +1 -1
- package/out/zero-cache/src/services/change-streamer/pg/initial-sync.d.ts.map +1 -1
- package/out/zero-cache/src/services/change-streamer/pg/initial-sync.js +7 -51
- package/out/zero-cache/src/services/change-streamer/pg/initial-sync.js.map +1 -1
- package/out/zero-cache/src/services/change-streamer/pg/schema/ddl.d.ts +239 -59
- package/out/zero-cache/src/services/change-streamer/pg/schema/ddl.d.ts.map +1 -1
- package/out/zero-cache/src/services/change-streamer/pg/schema/ddl.js +263 -183
- package/out/zero-cache/src/services/change-streamer/pg/schema/ddl.js.map +1 -1
- package/out/zero-cache/src/services/change-streamer/pg/schema/published.d.ts +4 -4
- package/out/zero-cache/src/services/change-streamer/pg/schema/published.d.ts.map +1 -1
- package/out/zero-cache/src/services/change-streamer/pg/schema/published.js +14 -19
- package/out/zero-cache/src/services/change-streamer/pg/schema/published.js.map +1 -1
- package/out/zero-cache/src/services/change-streamer/pg/schema/zero.d.ts +2 -1
- package/out/zero-cache/src/services/change-streamer/pg/schema/zero.d.ts.map +1 -1
- package/out/zero-cache/src/services/change-streamer/pg/schema/zero.js +51 -6
- package/out/zero-cache/src/services/change-streamer/pg/schema/zero.js.map +1 -1
- package/out/zero-cache/src/services/change-streamer/pg/sync-schema.js +1 -1
- package/out/zero-cache/src/services/change-streamer/pg/sync-schema.js.map +1 -1
- package/out/zero-cache/src/services/change-streamer/schema/change.d.ts +325 -26
- package/out/zero-cache/src/services/change-streamer/schema/change.d.ts.map +1 -1
- package/out/zero-cache/src/services/change-streamer/schema/change.js +84 -1
- package/out/zero-cache/src/services/change-streamer/schema/change.js.map +1 -1
- package/out/zero-cache/src/services/change-streamer/schema/init.js +1 -1
- package/out/zero-cache/src/services/change-streamer/schema/init.js.map +1 -1
- package/out/zero-cache/src/services/dispatcher/connect-params.d.ts +1 -0
- package/out/zero-cache/src/services/dispatcher/connect-params.d.ts.map +1 -1
- package/out/zero-cache/src/services/dispatcher/connect-params.js +5 -2
- package/out/zero-cache/src/services/dispatcher/connect-params.js.map +1 -1
- package/out/zero-cache/src/services/mutagen/mutagen.d.ts.map +1 -1
- package/out/zero-cache/src/services/mutagen/mutagen.js +17 -19
- package/out/zero-cache/src/services/mutagen/mutagen.js.map +1 -1
- package/out/zero-cache/src/services/mutagen/write-authorizer.d.ts.map +1 -1
- package/out/zero-cache/src/services/mutagen/write-authorizer.js +18 -9
- package/out/zero-cache/src/services/mutagen/write-authorizer.js.map +1 -1
- package/out/zero-cache/src/services/replicator/incremental-sync.d.ts.map +1 -1
- package/out/zero-cache/src/services/replicator/incremental-sync.js +120 -16
- package/out/zero-cache/src/services/replicator/incremental-sync.js.map +1 -1
- package/out/zero-cache/src/services/replicator/schema/change-log.d.ts +20 -3
- package/out/zero-cache/src/services/replicator/schema/change-log.d.ts.map +1 -1
- package/out/zero-cache/src/services/replicator/schema/change-log.js +44 -12
- package/out/zero-cache/src/services/replicator/schema/change-log.js.map +1 -1
- package/out/zero-cache/src/services/view-syncer/client-handler.d.ts +3 -2
- package/out/zero-cache/src/services/view-syncer/client-handler.d.ts.map +1 -1
- package/out/zero-cache/src/services/view-syncer/client-handler.js +21 -18
- package/out/zero-cache/src/services/view-syncer/client-handler.js.map +1 -1
- package/out/zero-cache/src/services/view-syncer/cvr-store.d.ts +5 -1
- package/out/zero-cache/src/services/view-syncer/cvr-store.d.ts.map +1 -1
- package/out/zero-cache/src/services/view-syncer/cvr-store.js +49 -8
- package/out/zero-cache/src/services/view-syncer/cvr-store.js.map +1 -1
- package/out/zero-cache/src/services/view-syncer/cvr.d.ts +1 -1
- package/out/zero-cache/src/services/view-syncer/cvr.d.ts.map +1 -1
- package/out/zero-cache/src/services/view-syncer/cvr.js +1 -1
- package/out/zero-cache/src/services/view-syncer/cvr.js.map +1 -1
- package/out/zero-cache/src/services/view-syncer/database-storage.js +1 -1
- package/out/zero-cache/src/services/view-syncer/database-storage.js.map +1 -1
- package/out/zero-cache/src/services/view-syncer/drain-coordinator.d.ts +31 -0
- package/out/zero-cache/src/services/view-syncer/drain-coordinator.d.ts.map +1 -0
- package/out/zero-cache/src/services/view-syncer/drain-coordinator.js +53 -0
- package/out/zero-cache/src/services/view-syncer/drain-coordinator.js.map +1 -0
- package/out/zero-cache/src/services/view-syncer/pipeline-driver.d.ts +11 -5
- package/out/zero-cache/src/services/view-syncer/pipeline-driver.d.ts.map +1 -1
- package/out/zero-cache/src/services/view-syncer/pipeline-driver.js +17 -0
- package/out/zero-cache/src/services/view-syncer/pipeline-driver.js.map +1 -1
- package/out/zero-cache/src/services/view-syncer/schema/cvr.d.ts.map +1 -1
- package/out/zero-cache/src/services/view-syncer/schema/cvr.js +2 -2
- package/out/zero-cache/src/services/view-syncer/schema/cvr.js.map +1 -1
- package/out/zero-cache/src/services/view-syncer/schema/pg-migrations.js +1 -1
- package/out/zero-cache/src/services/view-syncer/schema/pg-migrations.js.map +1 -1
- package/out/zero-cache/src/services/view-syncer/schema/types.d.ts +11 -11
- package/out/zero-cache/src/services/view-syncer/schema/types.js +2 -2
- package/out/zero-cache/src/services/view-syncer/schema/types.js.map +1 -1
- package/out/zero-cache/src/services/view-syncer/snapshotter.d.ts +12 -4
- package/out/zero-cache/src/services/view-syncer/snapshotter.d.ts.map +1 -1
- package/out/zero-cache/src/services/view-syncer/snapshotter.js +59 -49
- package/out/zero-cache/src/services/view-syncer/snapshotter.js.map +1 -1
- package/out/zero-cache/src/services/view-syncer/view-syncer.d.ts +2 -3
- package/out/zero-cache/src/services/view-syncer/view-syncer.d.ts.map +1 -1
- package/out/zero-cache/src/services/view-syncer/view-syncer.js +50 -10
- package/out/zero-cache/src/services/view-syncer/view-syncer.js.map +1 -1
- package/out/zero-cache/src/types/pg.d.ts +7 -1
- package/out/zero-cache/src/types/pg.d.ts.map +1 -1
- package/out/zero-cache/src/types/pg.js +14 -1
- package/out/zero-cache/src/types/pg.js.map +1 -1
- package/out/zero-cache/src/workers/connection.d.ts +3 -1
- package/out/zero-cache/src/workers/connection.d.ts.map +1 -1
- package/out/zero-cache/src/workers/connection.js +19 -1
- package/out/zero-cache/src/workers/connection.js.map +1 -1
- package/out/zero-cache/src/workers/syncer.d.ts +2 -1
- package/out/zero-cache/src/workers/syncer.d.ts.map +1 -1
- package/out/zero-cache/src/workers/syncer.js +20 -9
- package/out/zero-cache/src/workers/syncer.js.map +1 -1
- package/out/zero-client/src/client/context.d.ts +1 -1
- package/out/zero-client/src/client/context.d.ts.map +1 -1
- package/out/zero-client/src/client/context.js +99 -0
- package/out/zero-client/src/client/context.js.map +1 -0
- package/out/zero-client/src/client/crud.d.ts +8 -10
- package/out/zero-client/src/client/crud.d.ts.map +1 -1
- package/out/zero-client/src/client/crud.js +181 -0
- package/out/zero-client/src/client/crud.js.map +1 -0
- package/out/zero-client/src/client/enable-analytics.js +21 -0
- package/out/zero-client/src/client/enable-analytics.js.map +1 -0
- package/out/zero-client/src/client/http-string.js +14 -0
- package/out/zero-client/src/client/http-string.js.map +1 -0
- package/out/zero-client/src/client/keys.d.ts +3 -2
- package/out/zero-client/src/client/keys.d.ts.map +1 -1
- package/out/zero-client/src/client/keys.js +32 -0
- package/out/zero-client/src/client/keys.js.map +1 -0
- package/out/zero-client/src/client/log-options.js +57 -0
- package/out/zero-client/src/client/log-options.js.map +1 -0
- package/out/zero-client/src/client/metrics.js +268 -0
- package/out/zero-client/src/client/metrics.js.map +1 -0
- package/out/zero-client/src/client/normalized-schema.d.ts +17 -0
- package/out/zero-client/src/client/normalized-schema.d.ts.map +1 -0
- package/out/zero-client/src/client/normalized-schema.js +31 -0
- package/out/zero-client/src/client/normalized-schema.js.map +1 -0
- package/out/zero-client/src/client/options.js +2 -0
- package/out/zero-client/src/client/options.js.map +1 -0
- package/out/zero-client/src/client/query-manager.d.ts +18 -3
- package/out/zero-client/src/client/query-manager.d.ts.map +1 -1
- package/out/zero-client/src/client/query-manager.js +149 -0
- package/out/zero-client/src/client/query-manager.js.map +1 -0
- package/out/zero-client/src/client/reload-error-handler.js +23 -0
- package/out/zero-client/src/client/reload-error-handler.js.map +1 -0
- package/out/zero-client/src/client/replicache-types.js +2 -0
- package/out/zero-client/src/client/replicache-types.js.map +1 -0
- package/out/zero-client/src/client/server-error.js +22 -0
- package/out/zero-client/src/client/server-error.js.map +1 -0
- package/out/zero-client/src/client/server-option.js +37 -0
- package/out/zero-client/src/client/server-option.js.map +1 -0
- package/out/zero-client/src/client/version.js +5 -0
- package/out/zero-client/src/client/version.js.map +1 -0
- package/out/zero-client/src/client/zero-poke-handler.d.ts +3 -3
- package/out/zero-client/src/client/zero-poke-handler.d.ts.map +1 -1
- package/out/zero-client/src/client/zero-poke-handler.js +240 -0
- package/out/zero-client/src/client/zero-poke-handler.js.map +1 -0
- package/out/zero-client/src/client/zero.d.ts +3 -2
- package/out/zero-client/src/client/zero.d.ts.map +1 -1
- package/out/zero-client/src/client/zero.js +1212 -0
- package/out/zero-client/src/client/zero.js.map +1 -0
- package/out/zero-client/src/mod.js +4 -0
- package/out/zero-client/src/mod.js.map +1 -0
- package/out/zero-client/src/util/nanoid.js +34 -0
- package/out/zero-client/src/util/nanoid.js.map +1 -0
- package/out/zero-client/src/util/socket.js +4 -0
- package/out/zero-client/src/util/socket.js.map +1 -0
- package/out/zero-protocol/src/ast.d.ts +87 -1
- package/out/zero-protocol/src/ast.d.ts.map +1 -1
- package/out/zero-protocol/src/ast.js +53 -0
- package/out/zero-protocol/src/ast.js.map +1 -1
- package/out/zero-protocol/src/change-desired-queries.d.ts +6 -6
- package/out/zero-protocol/src/change-desired-queries.d.ts.map +1 -1
- package/out/zero-protocol/src/clients-patch.d.ts +1 -1
- package/out/zero-protocol/src/connect.d.ts +15 -8
- package/out/zero-protocol/src/connect.d.ts.map +1 -1
- package/out/zero-protocol/src/connect.js +21 -0
- package/out/zero-protocol/src/connect.js.map +1 -1
- package/out/zero-protocol/src/data.d.ts +36 -0
- package/out/zero-protocol/src/data.d.ts.map +1 -0
- package/out/zero-protocol/src/data.js +4 -0
- package/out/zero-protocol/src/data.js.map +1 -0
- package/out/zero-protocol/src/delete-clients.d.ts +4 -4
- package/out/zero-protocol/src/delete-clients.d.ts.map +1 -1
- package/out/zero-protocol/src/down.d.ts +18 -16
- package/out/zero-protocol/src/down.d.ts.map +1 -1
- package/out/zero-protocol/src/down.js +2 -1
- package/out/zero-protocol/src/down.js.map +1 -1
- package/out/zero-protocol/src/mod.d.ts +1 -2
- package/out/zero-protocol/src/mod.d.ts.map +1 -1
- package/out/zero-protocol/src/mod.js +2 -2
- package/out/zero-protocol/src/mod.js.map +1 -1
- package/out/zero-protocol/src/ping.d.ts +1 -1
- package/out/zero-protocol/src/ping.d.ts.map +1 -1
- package/out/zero-protocol/src/poke.d.ts +26 -26
- package/out/zero-protocol/src/poke.d.ts.map +1 -1
- package/out/zero-protocol/src/poke.js +8 -5
- package/out/zero-protocol/src/poke.js.map +1 -1
- package/out/zero-protocol/src/pong.d.ts +1 -1
- package/out/zero-protocol/src/pong.d.ts.map +1 -1
- package/out/zero-protocol/src/primary-key.d.ts +2 -3
- package/out/zero-protocol/src/primary-key.d.ts.map +1 -1
- package/out/zero-protocol/src/primary-key.js +1 -3
- package/out/zero-protocol/src/primary-key.js.map +1 -1
- package/out/zero-protocol/src/pull.d.ts +4 -4
- package/out/zero-protocol/src/pull.d.ts.map +1 -1
- package/out/zero-protocol/src/push.d.ts +105 -98
- package/out/zero-protocol/src/push.d.ts.map +1 -1
- package/out/zero-protocol/src/push.js +17 -13
- package/out/zero-protocol/src/push.js.map +1 -1
- package/out/zero-protocol/src/queries-patch.d.ts +4 -4
- package/out/zero-protocol/src/row-patch.d.ts +38 -0
- package/out/zero-protocol/src/row-patch.d.ts.map +1 -0
- package/out/zero-protocol/src/{entities-patch.js → row-patch.js} +10 -11
- package/out/zero-protocol/src/row-patch.js.map +1 -0
- package/out/zero-protocol/src/up.d.ts +28 -27
- package/out/zero-protocol/src/up.d.ts.map +1 -1
- package/out/zero-protocol/src/warm.d.ts +10 -0
- package/out/zero-protocol/src/warm.d.ts.map +1 -0
- package/out/zero-protocol/src/warm.js +6 -0
- package/out/zero-protocol/src/warm.js.map +1 -0
- package/out/zero-react/src/use-query.d.ts.map +1 -1
- package/out/zero.js +499 -208
- package/out/zero.js.map +4 -4
- package/out/zql/src/zql/builder/builder.d.ts +3 -3
- package/out/zql/src/zql/builder/builder.d.ts.map +1 -1
- package/out/zql/src/zql/builder/builder.js +1 -1
- package/out/zql/src/zql/builder/builder.js.map +1 -1
- package/out/zql/src/zql/builder/filter.d.ts +2 -2
- package/out/zql/src/zql/builder/filter.d.ts.map +1 -1
- package/out/zql/src/zql/builder/filter.js.map +1 -1
- package/out/zql/src/zql/ivm/array-view.d.ts +1 -1
- package/out/zql/src/zql/ivm/array-view.d.ts.map +1 -1
- package/out/zql/src/zql/ivm/array-view.js +232 -0
- package/out/zql/src/zql/ivm/array-view.js.map +1 -0
- package/out/zql/src/zql/ivm/change.d.ts +2 -1
- package/out/zql/src/zql/ivm/change.d.ts.map +1 -1
- package/out/zql/src/zql/ivm/data.d.ts +2 -33
- package/out/zql/src/zql/ivm/data.d.ts.map +1 -1
- package/out/zql/src/zql/ivm/data.js.map +1 -1
- package/out/zql/src/zql/ivm/filter.d.ts +2 -1
- package/out/zql/src/zql/ivm/filter.d.ts.map +1 -1
- package/out/zql/src/zql/ivm/filter.js.map +1 -1
- package/out/zql/src/zql/ivm/join.d.ts +1 -1
- package/out/zql/src/zql/ivm/join.d.ts.map +1 -1
- package/out/zql/src/zql/ivm/join.js +68 -24
- package/out/zql/src/zql/ivm/join.js.map +1 -1
- package/out/zql/src/zql/ivm/maybe-split-and-push-edit-change.d.ts +1 -1
- package/out/zql/src/zql/ivm/maybe-split-and-push-edit-change.d.ts.map +1 -1
- package/out/zql/src/zql/ivm/memory-source.d.ts +8 -6
- package/out/zql/src/zql/ivm/memory-source.d.ts.map +1 -1
- package/out/zql/src/zql/ivm/memory-source.js +2 -0
- package/out/zql/src/zql/ivm/memory-source.js.map +1 -1
- package/out/zql/src/zql/ivm/memory-storage.js +33 -0
- package/out/zql/src/zql/ivm/memory-storage.js.map +1 -0
- package/out/zql/src/zql/ivm/operator.d.ts +2 -1
- package/out/zql/src/zql/ivm/operator.d.ts.map +1 -1
- package/out/zql/src/zql/ivm/schema.d.ts +3 -3
- package/out/zql/src/zql/ivm/schema.d.ts.map +1 -1
- package/out/zql/src/zql/ivm/schema.js.map +1 -1
- package/out/zql/src/zql/ivm/skip.d.ts +2 -1
- package/out/zql/src/zql/ivm/skip.d.ts.map +1 -1
- package/out/zql/src/zql/ivm/skip.js.map +1 -1
- package/out/zql/src/zql/ivm/source.d.ts +2 -2
- package/out/zql/src/zql/ivm/source.d.ts.map +1 -1
- package/out/zql/src/zql/ivm/take.d.ts.map +1 -1
- package/out/zql/src/zql/ivm/take.js.map +1 -1
- package/out/zql/src/zql/query/normalize-table-schema.d.ts +48 -0
- package/out/zql/src/zql/query/normalize-table-schema.d.ts.map +1 -0
- package/out/zql/src/zql/query/normalize-table-schema.js +116 -0
- package/out/zql/src/zql/query/normalize-table-schema.js.map +1 -0
- package/out/zql/src/zql/query/query-impl.d.ts +6 -5
- package/out/zql/src/zql/query/query-impl.d.ts.map +1 -1
- package/out/zql/src/zql/query/query-impl.js +263 -0
- package/out/zql/src/zql/query/query-impl.js.map +1 -0
- package/out/zql/src/zql/query/query.d.ts +1 -1
- package/out/zql/src/zql/query/query.d.ts.map +1 -1
- package/out/zql/src/zql/query/query.js +3 -0
- package/out/zql/src/zql/query/query.js.map +1 -0
- package/out/zql/src/zql/query/schema.d.ts +13 -4
- package/out/zql/src/zql/query/schema.d.ts.map +1 -1
- package/out/zql/src/zql/query/schema.js +7 -0
- package/out/zql/src/zql/query/schema.js.map +1 -0
- package/out/zql/src/zql/query/typed-view.js +2 -0
- package/out/zql/src/zql/query/typed-view.js.map +1 -0
- package/out/zqlite/src/db.d.ts +1 -1
- package/out/zqlite/src/db.d.ts.map +1 -1
- package/out/zqlite/src/db.js +1 -1
- package/out/zqlite/src/db.js.map +1 -1
- package/out/zqlite/src/table-source.d.ts +2 -2
- package/out/zqlite/src/table-source.d.ts.map +1 -1
- package/out/zqlite/src/table-source.js.map +1 -1
- package/package.json +10 -8
- package/deps/sqlite3/sqlite3.c +0 -260574
- package/deps/sqlite3/sqlite3.h +0 -13572
- package/deps/sqlite3/sqlite3ext.h +0 -719
- package/out/zero-cache/src/db/migration-lite.d.ts.map +0 -1
- package/out/zero-cache/src/db/migration-lite.js.map +0 -1
- package/out/zero-cache/src/db/migration.d.ts.map +0 -1
- package/out/zero-cache/src/db/migration.js.map +0 -1
- package/out/zero-cache/src/services/change-streamer/pg/schema/create.d.ts +0 -6
- package/out/zero-cache/src/services/change-streamer/pg/schema/create.d.ts.map +0 -1
- package/out/zero-cache/src/services/change-streamer/pg/schema/create.js +0 -29
- package/out/zero-cache/src/services/change-streamer/pg/schema/create.js.map +0 -1
- package/out/zero-cache/src/services/change-streamer/pg/schema/lite.d.ts +0 -6
- package/out/zero-cache/src/services/change-streamer/pg/schema/lite.d.ts.map +0 -1
- package/out/zero-cache/src/services/change-streamer/pg/schema/lite.js.map +0 -1
- package/out/zero-cache/src/types/specs.d.ts +0 -29
- package/out/zero-cache/src/types/specs.d.ts.map +0 -1
- package/out/zero-cache/src/types/specs.js +0 -2
- package/out/zero-cache/src/types/specs.js.map +0 -1
- package/out/zero-client/src/client/make-id-from-primary-key.d.ts +0 -5
- package/out/zero-client/src/client/make-id-from-primary-key.d.ts.map +0 -1
- package/out/zero-protocol/src/entities-patch.d.ts +0 -66
- package/out/zero-protocol/src/entities-patch.d.ts.map +0 -1
- package/out/zero-protocol/src/entities-patch.js.map +0 -1
- package/out/zql/src/zql/ast/ast.d.ts +0 -84
- package/out/zql/src/zql/ast/ast.d.ts.map +0 -1
- package/out/zql/src/zql/ast/ast.js +0 -54
- package/out/zql/src/zql/ast/ast.js.map +0 -1
- package/tool/install-sqlite3.js +0 -37
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
import { deepEqual } from '../../../shared/src/json.js';
|
|
2
|
+
const SPLICE_UNASSIGNED = -1;
|
|
3
|
+
export const SPLICE_AT = 0;
|
|
4
|
+
export const SPLICE_REMOVED = 1;
|
|
5
|
+
export const SPLICE_ADDED = 2;
|
|
6
|
+
export const SPLICE_FROM = 3;
|
|
7
|
+
const KEY = 0;
|
|
8
|
+
const VALUE = 1;
|
|
9
|
+
export function* computeSplices(previous, current) {
|
|
10
|
+
let previousIndex = 0;
|
|
11
|
+
let currentIndex = 0;
|
|
12
|
+
let splice;
|
|
13
|
+
function ensureAssigned(splice, index) {
|
|
14
|
+
if (splice[SPLICE_FROM] === SPLICE_UNASSIGNED) {
|
|
15
|
+
splice[SPLICE_FROM] = index;
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
function newSplice() {
|
|
19
|
+
return [previousIndex, 0, 0, SPLICE_UNASSIGNED];
|
|
20
|
+
}
|
|
21
|
+
while (previousIndex < previous.length && currentIndex < current.length) {
|
|
22
|
+
if (previous[previousIndex][KEY] === current[currentIndex][KEY]) {
|
|
23
|
+
if (deepEqual(
|
|
24
|
+
// These are really Hash | InternalValue
|
|
25
|
+
previous[previousIndex][VALUE], current[currentIndex][VALUE])) {
|
|
26
|
+
if (splice) {
|
|
27
|
+
ensureAssigned(splice, 0);
|
|
28
|
+
yield splice;
|
|
29
|
+
splice = undefined;
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
else {
|
|
33
|
+
if (!splice) {
|
|
34
|
+
splice = newSplice();
|
|
35
|
+
}
|
|
36
|
+
splice[SPLICE_ADDED]++;
|
|
37
|
+
splice[SPLICE_REMOVED]++;
|
|
38
|
+
ensureAssigned(splice, currentIndex);
|
|
39
|
+
}
|
|
40
|
+
previousIndex++;
|
|
41
|
+
currentIndex++;
|
|
42
|
+
}
|
|
43
|
+
else if (previous[previousIndex][KEY] < current[currentIndex][KEY]) {
|
|
44
|
+
// previous was removed
|
|
45
|
+
if (!splice) {
|
|
46
|
+
splice = newSplice();
|
|
47
|
+
}
|
|
48
|
+
splice[SPLICE_REMOVED]++;
|
|
49
|
+
previousIndex++;
|
|
50
|
+
}
|
|
51
|
+
else {
|
|
52
|
+
// current was added
|
|
53
|
+
if (!splice) {
|
|
54
|
+
splice = newSplice();
|
|
55
|
+
}
|
|
56
|
+
splice[SPLICE_ADDED]++;
|
|
57
|
+
ensureAssigned(splice, currentIndex);
|
|
58
|
+
currentIndex++;
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
if (currentIndex < current.length) {
|
|
62
|
+
if (!splice) {
|
|
63
|
+
splice = newSplice();
|
|
64
|
+
}
|
|
65
|
+
splice[SPLICE_ADDED] += current.length - currentIndex;
|
|
66
|
+
ensureAssigned(splice, currentIndex);
|
|
67
|
+
}
|
|
68
|
+
if (previousIndex < previous.length) {
|
|
69
|
+
if (!splice) {
|
|
70
|
+
splice = newSplice();
|
|
71
|
+
}
|
|
72
|
+
splice[SPLICE_REMOVED] += previous.length - previousIndex;
|
|
73
|
+
}
|
|
74
|
+
if (splice) {
|
|
75
|
+
ensureAssigned(splice, 0);
|
|
76
|
+
yield splice;
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
//# sourceMappingURL=splice.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"splice.js","sourceRoot":"","sources":["../../../../../replicache/src/btree/splice.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,154 @@
|
|
|
1
|
+
import { Lock } from '@rocicorp/lock';
|
|
2
|
+
import { assert } from '../../../shared/src/asserts.js';
|
|
3
|
+
import { toRefs } from '../dag/chunk.js';
|
|
4
|
+
import { emptyHash, newRandomHash } from '../hash.js';
|
|
5
|
+
import { getSizeOfEntry } from '../size-of-value.js';
|
|
6
|
+
import { DataNodeImpl, InternalNodeImpl, createNewInternalEntryForNode, emptyDataNode, isDataNodeImpl, newNodeImpl, partition, toChunkData, } from './node.js';
|
|
7
|
+
import { BTreeRead } from './read.js';
|
|
8
|
+
export class BTreeWrite extends BTreeRead {
|
|
9
|
+
/**
|
|
10
|
+
* This rw lock is used to ensure we do not mutate the btree in parallel. It
|
|
11
|
+
* would be a problem if we didn't have the lock in cases like this:
|
|
12
|
+
*
|
|
13
|
+
* ```ts
|
|
14
|
+
* const p1 = tree.put('a', 0);
|
|
15
|
+
* const p2 = tree.put('b', 1);
|
|
16
|
+
* await p1;
|
|
17
|
+
* await p2;
|
|
18
|
+
* ```
|
|
19
|
+
*
|
|
20
|
+
* because both `p1` and `p2` would start from the old root hash but a put
|
|
21
|
+
* changes the root hash so the two concurrent puts would lead to only one of
|
|
22
|
+
* them actually working, and it is not deterministic which one would finish
|
|
23
|
+
* last.
|
|
24
|
+
*/
|
|
25
|
+
#lock = new Lock();
|
|
26
|
+
#modified = new Map();
|
|
27
|
+
minSize;
|
|
28
|
+
maxSize;
|
|
29
|
+
constructor(dagWrite, formatVersion, root = emptyHash, minSize = 8 * 1024, maxSize = 16 * 1024, getEntrySize = getSizeOfEntry, chunkHeaderSize) {
|
|
30
|
+
super(dagWrite, formatVersion, root, getEntrySize, chunkHeaderSize);
|
|
31
|
+
this.minSize = minSize;
|
|
32
|
+
this.maxSize = maxSize;
|
|
33
|
+
}
|
|
34
|
+
#addToModified(node) {
|
|
35
|
+
assert(node.isMutable);
|
|
36
|
+
this.#modified.set(node.hash, node);
|
|
37
|
+
this._cache.set(node.hash, node);
|
|
38
|
+
}
|
|
39
|
+
updateNode(node) {
|
|
40
|
+
assert(node.isMutable);
|
|
41
|
+
this.#modified.delete(node.hash);
|
|
42
|
+
node.hash = newRandomHash();
|
|
43
|
+
this.#addToModified(node);
|
|
44
|
+
}
|
|
45
|
+
newInternalNodeImpl(entries, level) {
|
|
46
|
+
const n = new InternalNodeImpl(entries, newRandomHash(), level, true);
|
|
47
|
+
this.#addToModified(n);
|
|
48
|
+
return n;
|
|
49
|
+
}
|
|
50
|
+
newDataNodeImpl(entries) {
|
|
51
|
+
const n = new DataNodeImpl(entries, newRandomHash(), true);
|
|
52
|
+
this.#addToModified(n);
|
|
53
|
+
return n;
|
|
54
|
+
}
|
|
55
|
+
newNodeImpl(entries, level) {
|
|
56
|
+
const n = newNodeImpl(entries, newRandomHash(), level, true);
|
|
57
|
+
this.#addToModified(n);
|
|
58
|
+
return n;
|
|
59
|
+
}
|
|
60
|
+
put(key, value) {
|
|
61
|
+
return this.#lock.withLock(async () => {
|
|
62
|
+
const oldRootNode = await this.getNode(this.rootHash);
|
|
63
|
+
const entrySize = this.getEntrySize(key, value);
|
|
64
|
+
const rootNode = await oldRootNode.set(key, value, entrySize, this);
|
|
65
|
+
// We do the rebalancing in the parent so we need to do it here as well.
|
|
66
|
+
if (rootNode.getChildNodeSize(this) > this.maxSize) {
|
|
67
|
+
const headerSize = this.chunkHeaderSize;
|
|
68
|
+
const partitions = partition(rootNode.entries, value => value[2], this.minSize - headerSize, this.maxSize - headerSize);
|
|
69
|
+
const { level } = rootNode;
|
|
70
|
+
const entries = partitions.map(entries => {
|
|
71
|
+
const node = this.newNodeImpl(entries, level);
|
|
72
|
+
return createNewInternalEntryForNode(node, this.getEntrySize);
|
|
73
|
+
});
|
|
74
|
+
const newRoot = this.newInternalNodeImpl(entries, level + 1);
|
|
75
|
+
this.rootHash = newRoot.hash;
|
|
76
|
+
return;
|
|
77
|
+
}
|
|
78
|
+
this.rootHash = rootNode.hash;
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
del(key) {
|
|
82
|
+
return this.#lock.withLock(async () => {
|
|
83
|
+
const oldRootNode = await this.getNode(this.rootHash);
|
|
84
|
+
const newRootNode = await oldRootNode.del(key, this);
|
|
85
|
+
// No need to rebalance here since if root gets too small there is nothing
|
|
86
|
+
// we can do about that.
|
|
87
|
+
const found = this.rootHash !== newRootNode.hash;
|
|
88
|
+
if (found) {
|
|
89
|
+
// Flatten one layer.
|
|
90
|
+
if (newRootNode.level > 0 && newRootNode.entries.length === 1) {
|
|
91
|
+
this.rootHash = newRootNode.entries[0][1];
|
|
92
|
+
}
|
|
93
|
+
else {
|
|
94
|
+
this.rootHash = newRootNode.hash;
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
return found;
|
|
98
|
+
});
|
|
99
|
+
}
|
|
100
|
+
clear() {
|
|
101
|
+
return this.#lock.withLock(() => {
|
|
102
|
+
this.#modified.clear();
|
|
103
|
+
this.rootHash = emptyHash;
|
|
104
|
+
});
|
|
105
|
+
}
|
|
106
|
+
flush() {
|
|
107
|
+
return this.#lock.withLock(async () => {
|
|
108
|
+
const dagWrite = this._dagRead;
|
|
109
|
+
if (this.rootHash === emptyHash) {
|
|
110
|
+
// Write a chunk for the empty tree.
|
|
111
|
+
const chunk = dagWrite.createChunk(emptyDataNode, []);
|
|
112
|
+
await dagWrite.putChunk(chunk);
|
|
113
|
+
return chunk.hash;
|
|
114
|
+
}
|
|
115
|
+
const newChunks = [];
|
|
116
|
+
const newRoot = gatherNewChunks(this.rootHash, newChunks, dagWrite.createChunk, this.#modified, this._formatVersion);
|
|
117
|
+
await Promise.all(newChunks.map(chunk => dagWrite.putChunk(chunk)));
|
|
118
|
+
this.#modified.clear();
|
|
119
|
+
this.rootHash = newRoot;
|
|
120
|
+
return newRoot;
|
|
121
|
+
});
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
function gatherNewChunks(hash, newChunks, createChunk, modified, formatVersion) {
|
|
125
|
+
const node = modified.get(hash);
|
|
126
|
+
if (node === undefined) {
|
|
127
|
+
// Not modified, use the original.
|
|
128
|
+
return hash;
|
|
129
|
+
}
|
|
130
|
+
if (isDataNodeImpl(node)) {
|
|
131
|
+
const chunk = createChunk(toChunkData(node, formatVersion), []);
|
|
132
|
+
newChunks.push(chunk);
|
|
133
|
+
return chunk.hash;
|
|
134
|
+
}
|
|
135
|
+
// The BTree cannot have duplicate keys so the child entry hashes are unique.
|
|
136
|
+
// No need fot a set to dedupe here.
|
|
137
|
+
const refs = [];
|
|
138
|
+
const { entries } = node;
|
|
139
|
+
for (let i = 0; i < entries.length; i++) {
|
|
140
|
+
const entry = entries[i];
|
|
141
|
+
const childHash = entry[1];
|
|
142
|
+
const newChildHash = gatherNewChunks(childHash, newChunks, createChunk, modified, formatVersion);
|
|
143
|
+
if (newChildHash !== childHash) {
|
|
144
|
+
// MUTATES the entries!
|
|
145
|
+
// Hashes do not change the size of the entry because all hashes have the same length
|
|
146
|
+
entries[i] = [entry[0], newChildHash, entry[2]];
|
|
147
|
+
}
|
|
148
|
+
refs.push(newChildHash);
|
|
149
|
+
}
|
|
150
|
+
const chunk = createChunk(toChunkData(node, formatVersion), toRefs(refs));
|
|
151
|
+
newChunks.push(chunk);
|
|
152
|
+
return chunk.hash;
|
|
153
|
+
}
|
|
154
|
+
//# sourceMappingURL=write.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"write.js","sourceRoot":"","sources":["../../../../../replicache/src/btree/write.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,IAAI,EAAC,MAAM,gBAAgB,CAAC;AACpC,OAAO,EAAC,MAAM,EAAC,MAAM,gCAAgC,CAAC;AAEtD,OAAO,EAA+B,MAAM,EAAC,MAAM,iBAAiB,CAAC;AAIrE,OAAO,EAAY,SAAS,EAAE,aAAa,EAAC,MAAM,YAAY,CAAC;AAC/D,OAAO,EAAC,cAAc,EAAC,MAAM,qBAAqB,CAAC;AACnD,OAAO,EACL,YAAY,EAEZ,gBAAgB,EAChB,6BAA6B,EAC7B,aAAa,EACb,cAAc,EACd,WAAW,EACX,SAAS,EACT,WAAW,GACZ,MAAM,WAAW,CAAC;AACnB,OAAO,EAAC,SAAS,EAAC,MAAM,WAAW,CAAC;AAEpC,MAAM,OAAO,UAAW,SAAQ,SAAS;IACvC;;;;;;;;;;;;;;;OAeG;IACM,KAAK,GAAG,IAAI,IAAI,EAAE,CAAC;IACnB,SAAS,GAA+C,IAAI,GAAG,EAAE,CAAC;IAIlE,OAAO,CAAS;IAChB,OAAO,CAAS;IAEzB,YACE,QAAe,EACf,aAA4B,EAC5B,OAAa,SAAS,EACtB,OAAO,GAAG,CAAC,GAAG,IAAI,EAClB,OAAO,GAAG,EAAE,GAAG,IAAI,EACnB,eAA6C,cAAc,EAC3D,eAAwB;QAExB,KAAK,CAAC,QAAQ,EAAE,aAAa,EAAE,IAAI,EAAE,YAAY,EAAE,eAAe,CAAC,CAAC;QAEpE,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;QACvB,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;IACzB,CAAC;IAED,cAAc,CAAC,IAAqC;QAClD,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACvB,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;QACpC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;IACnC,CAAC;IAED,UAAU,CAAC,IAAqC;QAC9C,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACvB,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACjC,IAAI,CAAC,IAAI,GAAG,aAAa,EAAE,CAAC;QAC5B,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;IAC5B,CAAC;IAED,mBAAmB,CACjB,OAA2B,EAC3B,KAAa;QAEb,MAAM,CAAC,GAAG,IAAI,gBAAgB,CAAC,OAAO,EAAE,aAAa,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC;QACtE,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC;QACvB,OAAO,CAAC,CAAC;IACX,CAAC;IAED,eAAe,CAAC,OAAiC;QAC/C,MAAM,CAAC,GAAG,IAAI,YAAY,CAAC,OAAO,EAAE,aAAa,EAAE,EAAE,IAAI,CAAC,CAAC;QAC3D,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC;QACvB,OAAO,CAAC,CAAC;IACX,CAAC;IAQD,WAAW,CACT,OAAiD,EACjD,KAAa;QAEb,MAAM,CAAC,GAAG,WAAW,CAAC,OAAO,EAAE,aAAa,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC;QAC7D,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC;QACvB,OAAO,CAAC,CAAC;IACX,CAAC;IAED,GAAG,CAAC,GAAW,EAAE,KAAsB;QACrC,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,KAAK,IAAI,EAAE;YACpC,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YACtD,MAAM,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;YAChD,MAAM,QAAQ,GAAG,MAAM,WAAW,CAAC,GAAG,CAAC,GAAG,EAAE,KAAK,EAAE,SAAS,EAAE,IAAI,CAAC,CAAC;YAEpE,wEAAwE;YACxE,IAAI,QAAQ,CAAC,gBAAgB,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC;gBACnD,MAAM,UAAU,GAAG,IAAI,CAAC,eAAe,CAAC;gBACxC,MAAM,UAAU,GAAG,SAAS,CAC1B,QAAQ,CAAC,OAAO,EAChB,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,EACjB,IAAI,CAAC,OAAO,GAAG,UAAU,EACzB,IAAI,CAAC,OAAO,GAAG,UAAU,CAC1B,CAAC;gBACF,MAAM,EAAC,KAAK,EAAC,GAAG,QAAQ,CAAC;gBACzB,MAAM,OAAO,GAAkB,UAAU,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE;oBACtD,MAAM,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;oBAC9C,OAAO,6BAA6B,CAAC,IAAI,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;gBAChE,CAAC,CAAC,CAAC;gBACH,MAAM,OAAO,GAAG,IAAI,CAAC,mBAAmB,CAAC,OAAO,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC;gBAC7D,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC,IAAI,CAAC;gBAC7B,OAAO;YACT,CAAC;YAED,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC,IAAI,CAAC;QAChC,CAAC,CAAC,CAAC;IACL,CAAC;IAED,GAAG,CAAC,GAAW;QACb,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,KAAK,IAAI,EAAE;YACpC,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YACtD,MAAM,WAAW,GAAG,MAAM,WAAW,CAAC,GAAG,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;YAErD,0EAA0E;YAC1E,wBAAwB;YACxB,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,KAAK,WAAW,CAAC,IAAI,CAAC;YACjD,IAAI,KAAK,EAAE,CAAC;gBACV,qBAAqB;gBACrB,IAAI,WAAW,CAAC,KAAK,GAAG,CAAC,IAAI,WAAW,CAAC,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;oBAC9D,IAAI,CAAC,QAAQ,GAAI,WAAgC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;gBAClE,CAAC;qBAAM,CAAC;oBACN,IAAI,CAAC,QAAQ,GAAG,WAAW,CAAC,IAAI,CAAC;gBACnC,CAAC;YACH,CAAC;YAED,OAAO,KAAK,CAAC;QACf,CAAC,CAAC,CAAC;IACL,CAAC;IAED,KAAK;QACH,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,GAAG,EAAE;YAC9B,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC;YACvB,IAAI,CAAC,QAAQ,GAAG,SAAS,CAAC;QAC5B,CAAC,CAAC,CAAC;IACL,CAAC;IAED,KAAK;QACH,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,KAAK,IAAI,EAAE;YACpC,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;YAE/B,IAAI,IAAI,CAAC,QAAQ,KAAK,SAAS,EAAE,CAAC;gBAChC,oCAAoC;gBACpC,MAAM,KAAK,GAAG,QAAQ,CAAC,WAAW,CAAC,aAAa,EAAE,EAAE,CAAC,CAAC;gBACtD,MAAM,QAAQ,CAAC,QAAQ,CAAC,KAAiC,CAAC,CAAC;gBAC3D,OAAO,KAAK,CAAC,IAAI,CAAC;YACpB,CAAC;YAED,MAAM,SAAS,GAAY,EAAE,CAAC;YAC9B,MAAM,OAAO,GAAG,eAAe,CAC7B,IAAI,CAAC,QAAQ,EACb,SAAS,EACT,QAAQ,CAAC,WAAW,EACpB,IAAI,CAAC,SAAS,EACd,IAAI,CAAC,cAAc,CACpB,CAAC;YACF,MAAM,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,QAAQ,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YACpE,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC;YACvB,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC;YACxB,OAAO,OAAO,CAAC;QACjB,CAAC,CAAC,CAAC;IACL,CAAC;CACF;AAED,SAAS,eAAe,CACtB,IAAU,EACV,SAAkB,EAClB,WAAwB,EACxB,QAAoD,EACpD,aAA4B;IAE5B,MAAM,IAAI,GAAG,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IAChC,IAAI,IAAI,KAAK,SAAS,EAAE,CAAC;QACvB,kCAAkC;QAClC,OAAO,IAAI,CAAC;IACd,CAAC;IAED,IAAI,cAAc,CAAC,IAAI,CAAC,EAAE,CAAC;QACzB,MAAM,KAAK,GAAG,WAAW,CAAC,WAAW,CAAC,IAAI,EAAE,aAAa,CAAC,EAAE,EAAE,CAAC,CAAC;QAChE,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACtB,OAAO,KAAK,CAAC,IAAI,CAAC;IACpB,CAAC;IAED,6EAA6E;IAC7E,oCAAoC;IACpC,MAAM,IAAI,GAAW,EAAE,CAAC;IACxB,MAAM,EAAC,OAAO,EAAC,GAAG,IAAI,CAAC;IACvB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;QACxC,MAAM,KAAK,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;QACzB,MAAM,SAAS,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;QAC3B,MAAM,YAAY,GAAG,eAAe,CAClC,SAAS,EACT,SAAS,EACT,WAAW,EACX,QAAQ,EACR,aAAa,CACd,CAAC;QACF,IAAI,YAAY,KAAK,SAAS,EAAE,CAAC;YAC/B,uBAAuB;YACvB,qFAAqF;YACrF,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,YAAY,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;QAClD,CAAC;QACD,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IAC1B,CAAC;IACD,MAAM,KAAK,GAAG,WAAW,CAAC,WAAW,CAAC,IAAI,EAAE,aAAa,CAAC,EAAE,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;IAC1E,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACtB,OAAO,KAAK,CAAC,IAAI,CAAC;AACpB,CAAC"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Helper function for {@link getDefaultPuller} and {@link getDefaultPusher}.
|
|
3
|
+
*/
|
|
4
|
+
export async function callDefaultFetch(url, auth, requestID, requestBody) {
|
|
5
|
+
const init = {
|
|
6
|
+
headers: {
|
|
7
|
+
// eslint-disable-next-line @typescript-eslint/naming-convention
|
|
8
|
+
'Content-type': 'application/json',
|
|
9
|
+
// eslint-disable-next-line @typescript-eslint/naming-convention
|
|
10
|
+
'Authorization': auth,
|
|
11
|
+
// eslint-disable-next-line @typescript-eslint/naming-convention
|
|
12
|
+
'X-Replicache-RequestID': requestID,
|
|
13
|
+
},
|
|
14
|
+
body: JSON.stringify(requestBody),
|
|
15
|
+
method: 'POST',
|
|
16
|
+
};
|
|
17
|
+
const request = new Request(url, init);
|
|
18
|
+
const response = await fetch(request);
|
|
19
|
+
const httpStatusCode = response.status;
|
|
20
|
+
if (httpStatusCode !== 200) {
|
|
21
|
+
return [
|
|
22
|
+
undefined,
|
|
23
|
+
{
|
|
24
|
+
httpStatusCode,
|
|
25
|
+
errorMessage: await response.text(),
|
|
26
|
+
},
|
|
27
|
+
];
|
|
28
|
+
}
|
|
29
|
+
return [
|
|
30
|
+
response,
|
|
31
|
+
{
|
|
32
|
+
httpStatusCode,
|
|
33
|
+
errorMessage: '',
|
|
34
|
+
},
|
|
35
|
+
];
|
|
36
|
+
}
|
|
37
|
+
//# sourceMappingURL=call-default-fetch.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"call-default-fetch.js","sourceRoot":"","sources":["../../../../replicache/src/call-default-fetch.ts"],"names":[],"mappings":"AAEA;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,gBAAgB,CACpC,GAAW,EACX,IAAY,EACZ,SAAiB,EACjB,WAAiB;IAEjB,MAAM,IAAI,GAAG;QACX,OAAO,EAAE;YACP,gEAAgE;YAChE,cAAc,EAAE,kBAAkB;YAClC,gEAAgE;YAChE,eAAe,EAAE,IAAI;YACrB,gEAAgE;YAChE,wBAAwB,EAAE,SAAS;SACpC;QACD,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC;QACjC,MAAM,EAAE,MAAM;KACf,CAAC;IACF,MAAM,OAAO,GAAG,IAAI,OAAO,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;IACvC,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,OAAO,CAAC,CAAC;IACtC,MAAM,cAAc,GAAG,QAAQ,CAAC,MAAM,CAAC;IACvC,IAAI,cAAc,KAAK,GAAG,EAAE,CAAC;QAC3B,OAAO;YACL,SAAS;YACT;gBACE,cAAc;gBACd,YAAY,EAAE,MAAM,QAAQ,CAAC,IAAI,EAAE;aACpC;SACF,CAAC;IACJ,CAAC;IACD,OAAO;QACL,QAAQ;QACR;YACE,cAAc;YACd,YAAY,EAAE,EAAE;SACjB;KACF,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { isProd } from '../../shared/src/config.js';
|
|
2
|
+
export { isProd as skipBTreeNodeAsserts, isProd as skipCommitDataAsserts,
|
|
3
|
+
/**
|
|
4
|
+
* In debug mode we deeply freeze the values we read out of the IDB store and we
|
|
5
|
+
* deeply freeze the values we put into the stores.
|
|
6
|
+
*/
|
|
7
|
+
isProd as skipFreeze,
|
|
8
|
+
/**
|
|
9
|
+
* In debug mode we assert that chunks and BTree data is deeply frozen. In
|
|
10
|
+
* release mode we skip these asserts.
|
|
11
|
+
*/
|
|
12
|
+
isProd as skipFrozenAsserts, isProd as skipGCAsserts, };
|
|
13
|
+
//# sourceMappingURL=config.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"config.js","sourceRoot":"","sources":["../../../../replicache/src/config.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,MAAM,EAAC,MAAM,4BAA4B,CAAC;AAElD,OAAO,EACL,MAAM,IAAI,oBAAoB,EAC9B,MAAM,IAAI,qBAAqB;AAC/B;;;GAGG;AACH,MAAM,IAAI,UAAU;AACpB;;;GAGG;AACH,MAAM,IAAI,iBAAiB,EAC3B,MAAM,IAAI,aAAa,GACxB,CAAC"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
class ConnectionLoopDelegateImpl {
|
|
2
|
+
rep;
|
|
3
|
+
invokeSend;
|
|
4
|
+
// TODO: Remove the ability to have more than one concurrent connection and update tests.
|
|
5
|
+
// Bug: https://github.com/rocicorp/replicache-internal/issues/303
|
|
6
|
+
maxConnections = 1;
|
|
7
|
+
constructor(rep, invokeSend) {
|
|
8
|
+
this.rep = rep;
|
|
9
|
+
this.invokeSend = invokeSend;
|
|
10
|
+
}
|
|
11
|
+
get maxDelayMs() {
|
|
12
|
+
return this.rep.requestOptions.maxDelayMs;
|
|
13
|
+
}
|
|
14
|
+
get minDelayMs() {
|
|
15
|
+
return this.rep.requestOptions.minDelayMs;
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
export class PullDelegate extends ConnectionLoopDelegateImpl {
|
|
19
|
+
debounceDelay = 0;
|
|
20
|
+
get watchdogTimer() {
|
|
21
|
+
return this.rep.pullInterval;
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
export class PushDelegate extends ConnectionLoopDelegateImpl {
|
|
25
|
+
get debounceDelay() {
|
|
26
|
+
return this.rep.pushDelay;
|
|
27
|
+
}
|
|
28
|
+
watchdogTimer = null;
|
|
29
|
+
}
|
|
30
|
+
//# sourceMappingURL=connection-loop-delegates.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"connection-loop-delegates.js","sourceRoot":"","sources":["../../../../replicache/src/connection-loop-delegates.ts"],"names":[],"mappings":"AAGA,MAAM,0BAA0B;IACrB,GAAG,CAAiB;IACpB,UAAU,CAAyB;IAE5C,yFAAyF;IACzF,kEAAkE;IACzD,cAAc,GAAG,CAAC,CAAC;IAE5B,YAAY,GAAmB,EAAE,UAAkC;QACjE,IAAI,CAAC,GAAG,GAAG,GAAG,CAAC;QACf,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;IAC/B,CAAC;IAED,IAAI,UAAU;QACZ,OAAO,IAAI,CAAC,GAAG,CAAC,cAAc,CAAC,UAAU,CAAC;IAC5C,CAAC;IAED,IAAI,UAAU;QACZ,OAAO,IAAI,CAAC,GAAG,CAAC,cAAc,CAAC,UAAU,CAAC;IAC5C,CAAC;CACF;AAED,MAAM,OAAO,YACX,SAAQ,0BAA0B;IAGzB,aAAa,GAAG,CAAC,CAAC;IAE3B,IAAI,aAAa;QACf,OAAO,IAAI,CAAC,GAAG,CAAC,YAAY,CAAC;IAC/B,CAAC;CACF;AAED,MAAM,OAAO,YACX,SAAQ,0BAA0B;IAGlC,IAAI,aAAa;QACf,OAAO,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC;IAC5B,CAAC;IAED,aAAa,GAAG,IAAI,CAAC;CACtB"}
|
|
@@ -0,0 +1,268 @@
|
|
|
1
|
+
import { resolver } from '@rocicorp/resolver';
|
|
2
|
+
import { sleep } from '../../shared/src/sleep.js';
|
|
3
|
+
export const DEBOUNCE_DELAY_MS = 10;
|
|
4
|
+
export const MIN_DELAY_MS = 30;
|
|
5
|
+
export const MAX_DELAY_MS = 60_000;
|
|
6
|
+
export class ConnectionLoop {
|
|
7
|
+
// ConnectionLoop runs a loop sending network requests (either pushes or
|
|
8
|
+
// pulls) to the server. Our goal, generally, is to send requests as fast as
|
|
9
|
+
// we can, but to adjust in case of slowness, network errors, etc. We will
|
|
10
|
+
// send requests in parallel if the server supports it. We also debounce
|
|
11
|
+
// pushes since they frequently happen in series very near to one another
|
|
12
|
+
// (e.g., during drag'n drops).
|
|
13
|
+
//
|
|
14
|
+
// The loop flows through the following states forever, until it is closed:
|
|
15
|
+
//
|
|
16
|
+
// Pending: Wait for event or watchdog
|
|
17
|
+
// |
|
|
18
|
+
// v
|
|
19
|
+
// Debounce: Wait for more events (we debounce pushes)
|
|
20
|
+
// |
|
|
21
|
+
// v
|
|
22
|
+
// Wait for available connection (we limit number of parallel requests
|
|
23
|
+
// allowed)
|
|
24
|
+
// |
|
|
25
|
+
// v
|
|
26
|
+
// Wait to send (if requests are taking too long, we will slow down)
|
|
27
|
+
// |
|
|
28
|
+
// v
|
|
29
|
+
// Send (asynchronously, wrt the loop)
|
|
30
|
+
// |
|
|
31
|
+
// v
|
|
32
|
+
// Back to the pending!
|
|
33
|
+
// Controls whether the next iteration of the loop will wait at the pending
|
|
34
|
+
// state.
|
|
35
|
+
#pendingResolver = resolver();
|
|
36
|
+
/**
|
|
37
|
+
* This resolver is used to allow us to skip sleeps when we do send(true)
|
|
38
|
+
*/
|
|
39
|
+
#skipSleepsResolver = resolver();
|
|
40
|
+
/**
|
|
41
|
+
* Resolver for the next send. Never rejects. Returns an error instead since
|
|
42
|
+
* this resolver is used in cases where they might not be someone waiting,
|
|
43
|
+
* and we don't want an unhandled promise rejection in that case.
|
|
44
|
+
*/
|
|
45
|
+
#sendResolver = resolver();
|
|
46
|
+
#delegate;
|
|
47
|
+
#closed = false;
|
|
48
|
+
/**
|
|
49
|
+
* Number of pending send calls.
|
|
50
|
+
*
|
|
51
|
+
* We keep track of this because if close happens while we are waiting for the
|
|
52
|
+
* send to resolve we should reject the send promise.
|
|
53
|
+
*/
|
|
54
|
+
#sendCounter = 0;
|
|
55
|
+
#lc;
|
|
56
|
+
#visibilityWatcher;
|
|
57
|
+
constructor(lc, delegate, visibilityWatcher) {
|
|
58
|
+
this.#lc = lc;
|
|
59
|
+
this.#delegate = delegate;
|
|
60
|
+
this.#visibilityWatcher = visibilityWatcher;
|
|
61
|
+
void this.run();
|
|
62
|
+
}
|
|
63
|
+
close() {
|
|
64
|
+
this.#closed = true;
|
|
65
|
+
if (this.#sendCounter > 0) {
|
|
66
|
+
this.#sendResolver.resolve({ error: closeError() });
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
/**
|
|
70
|
+
*
|
|
71
|
+
* @returns Returns undefined if ok, otherwise it return the error that caused
|
|
72
|
+
* the send to fail.
|
|
73
|
+
*/
|
|
74
|
+
async send(now) {
|
|
75
|
+
if (this.#closed) {
|
|
76
|
+
return { error: closeError() };
|
|
77
|
+
}
|
|
78
|
+
this.#sendCounter++;
|
|
79
|
+
this.#lc.debug?.('send', now);
|
|
80
|
+
if (now) {
|
|
81
|
+
this.#skipSleepsResolver.resolve();
|
|
82
|
+
}
|
|
83
|
+
else {
|
|
84
|
+
await this.#visibilityWatcher?.waitForVisible();
|
|
85
|
+
}
|
|
86
|
+
this.#pendingResolver.resolve();
|
|
87
|
+
const result = await this.#sendResolver.promise;
|
|
88
|
+
this.#sendCounter--;
|
|
89
|
+
return result;
|
|
90
|
+
}
|
|
91
|
+
async run() {
|
|
92
|
+
const sendRecords = [];
|
|
93
|
+
let recoverResolver = resolver();
|
|
94
|
+
let lastSendTime;
|
|
95
|
+
// The number of active connections.
|
|
96
|
+
let counter = 0;
|
|
97
|
+
const delegate = this.#delegate;
|
|
98
|
+
const { debug } = this.#lc;
|
|
99
|
+
let delay = 0;
|
|
100
|
+
debug?.('Starting connection loop');
|
|
101
|
+
const sleepMaybeSkip = ms => Promise.race([this.#skipSleepsResolver.promise, sleep(ms)]);
|
|
102
|
+
while (!this.#closed) {
|
|
103
|
+
debug?.(didLastSendRequestFail(sendRecords)
|
|
104
|
+
? 'Last request failed. Trying again'
|
|
105
|
+
: 'Waiting for a send');
|
|
106
|
+
// Wait until send is called or until the watchdog timer fires.
|
|
107
|
+
const races = [this.#pendingResolver.promise];
|
|
108
|
+
const t = delegate.watchdogTimer;
|
|
109
|
+
if (t !== null) {
|
|
110
|
+
races.push(sleep(t));
|
|
111
|
+
}
|
|
112
|
+
await Promise.race(races);
|
|
113
|
+
if (this.#closed)
|
|
114
|
+
break;
|
|
115
|
+
debug?.('Waiting for debounce');
|
|
116
|
+
await sleepMaybeSkip(delegate.debounceDelay);
|
|
117
|
+
if (this.#closed)
|
|
118
|
+
break;
|
|
119
|
+
debug?.('debounced');
|
|
120
|
+
// This resolver is used to wait for incoming push calls.
|
|
121
|
+
this.#pendingResolver = resolver();
|
|
122
|
+
if (counter >= delegate.maxConnections) {
|
|
123
|
+
debug?.('Too many request in flight. Waiting until one finishes...');
|
|
124
|
+
await this.#waitUntilAvailableConnection();
|
|
125
|
+
if (this.#closed)
|
|
126
|
+
break;
|
|
127
|
+
debug?.('...finished');
|
|
128
|
+
}
|
|
129
|
+
// We need to delay the next request even if there are no active requests
|
|
130
|
+
// in case of error.
|
|
131
|
+
if (counter > 0 || didLastSendRequestFail(sendRecords)) {
|
|
132
|
+
delay = computeDelayAndUpdateDurations(delay, delegate, sendRecords);
|
|
133
|
+
debug?.(didLastSendRequestFail(sendRecords)
|
|
134
|
+
? 'Last connection errored. Sleeping for'
|
|
135
|
+
: 'More than one outstanding connection (' +
|
|
136
|
+
counter +
|
|
137
|
+
'). Sleeping for', delay, 'ms');
|
|
138
|
+
}
|
|
139
|
+
else {
|
|
140
|
+
// We set this to 0 here in case minDelayMs is mutated to a lower value
|
|
141
|
+
// than the old delay so that we still get minDelayMs. This can happen
|
|
142
|
+
// if we get an error during a run where minDelayMs is larger than the
|
|
143
|
+
// current value of minDelayMs.
|
|
144
|
+
delay = 0;
|
|
145
|
+
}
|
|
146
|
+
const clampedDelay = Math.min(delegate.maxDelayMs, Math.max(delegate.minDelayMs, delay));
|
|
147
|
+
if (lastSendTime !== undefined) {
|
|
148
|
+
const timeSinceLastSend = Date.now() - lastSendTime;
|
|
149
|
+
if (clampedDelay > timeSinceLastSend) {
|
|
150
|
+
await Promise.race([
|
|
151
|
+
sleepMaybeSkip(clampedDelay - timeSinceLastSend),
|
|
152
|
+
recoverResolver.promise,
|
|
153
|
+
]);
|
|
154
|
+
if (this.#closed)
|
|
155
|
+
break;
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
counter++;
|
|
159
|
+
// eslint-disable-next-line @typescript-eslint/no-floating-promises
|
|
160
|
+
(async () => {
|
|
161
|
+
const start = Date.now();
|
|
162
|
+
let ok;
|
|
163
|
+
let error;
|
|
164
|
+
try {
|
|
165
|
+
lastSendTime = start;
|
|
166
|
+
debug?.('Sending request');
|
|
167
|
+
this.#skipSleepsResolver = resolver();
|
|
168
|
+
ok = await delegate.invokeSend();
|
|
169
|
+
debug?.('Send returned', ok);
|
|
170
|
+
}
|
|
171
|
+
catch (e) {
|
|
172
|
+
debug?.('Send failed', e);
|
|
173
|
+
error = e;
|
|
174
|
+
ok = false;
|
|
175
|
+
}
|
|
176
|
+
if (this.#closed) {
|
|
177
|
+
debug?.('Closed after invokeSend');
|
|
178
|
+
return;
|
|
179
|
+
}
|
|
180
|
+
debug?.('Request done', { duration: Date.now() - start, ok });
|
|
181
|
+
sendRecords.push({ duration: Date.now() - start, ok });
|
|
182
|
+
if (recovered(sendRecords)) {
|
|
183
|
+
recoverResolver.resolve();
|
|
184
|
+
recoverResolver = resolver();
|
|
185
|
+
}
|
|
186
|
+
counter--;
|
|
187
|
+
this.#connectionAvailable();
|
|
188
|
+
const sendResolver = this.#sendResolver;
|
|
189
|
+
this.#sendResolver = resolver();
|
|
190
|
+
if (error) {
|
|
191
|
+
sendResolver.resolve({ error });
|
|
192
|
+
}
|
|
193
|
+
else {
|
|
194
|
+
sendResolver.resolve(undefined);
|
|
195
|
+
}
|
|
196
|
+
if (!ok) {
|
|
197
|
+
// Keep trying
|
|
198
|
+
this.#pendingResolver.resolve();
|
|
199
|
+
}
|
|
200
|
+
})();
|
|
201
|
+
}
|
|
202
|
+
}
|
|
203
|
+
#waitingConnectionResolve = undefined;
|
|
204
|
+
#connectionAvailable() {
|
|
205
|
+
if (this.#waitingConnectionResolve) {
|
|
206
|
+
const resolve = this.#waitingConnectionResolve;
|
|
207
|
+
this.#waitingConnectionResolve = undefined;
|
|
208
|
+
resolve();
|
|
209
|
+
}
|
|
210
|
+
}
|
|
211
|
+
#waitUntilAvailableConnection() {
|
|
212
|
+
const { promise, resolve } = resolver();
|
|
213
|
+
this.#waitingConnectionResolve = resolve;
|
|
214
|
+
return promise;
|
|
215
|
+
}
|
|
216
|
+
}
|
|
217
|
+
// Number of connections to remember when computing the new delay.
|
|
218
|
+
const CONNECTION_MEMORY_COUNT = 9;
|
|
219
|
+
function closeError() {
|
|
220
|
+
return new Error('Closed');
|
|
221
|
+
}
|
|
222
|
+
// Computes a new delay based on the previous requests. We use the median of the
|
|
223
|
+
// previous successful request divided by `maxConnections`. When we get errors
|
|
224
|
+
// we do exponential backoff. As soon as we recover from an error we reset back
|
|
225
|
+
// to delegate.minDelayMs.
|
|
226
|
+
function computeDelayAndUpdateDurations(delay, delegate, sendRecords) {
|
|
227
|
+
const { length } = sendRecords;
|
|
228
|
+
if (length === 0) {
|
|
229
|
+
return delay;
|
|
230
|
+
}
|
|
231
|
+
const { ok } = sendRecords[sendRecords.length - 1];
|
|
232
|
+
const { maxConnections, minDelayMs } = delegate;
|
|
233
|
+
if (!ok) {
|
|
234
|
+
return delay === 0 ? minDelayMs : delay * 2;
|
|
235
|
+
}
|
|
236
|
+
if (length > 1) {
|
|
237
|
+
// length > 1
|
|
238
|
+
const previous = sendRecords[sendRecords.length - 2];
|
|
239
|
+
// Prune
|
|
240
|
+
while (sendRecords.length > CONNECTION_MEMORY_COUNT) {
|
|
241
|
+
sendRecords.shift();
|
|
242
|
+
}
|
|
243
|
+
if (ok && !previous.ok) {
|
|
244
|
+
// Recovered
|
|
245
|
+
return minDelayMs;
|
|
246
|
+
}
|
|
247
|
+
}
|
|
248
|
+
const med = median(sendRecords.filter(({ ok }) => ok).map(({ duration }) => duration));
|
|
249
|
+
return (med / maxConnections) | 0;
|
|
250
|
+
}
|
|
251
|
+
function median(values) {
|
|
252
|
+
values.sort();
|
|
253
|
+
const { length } = values;
|
|
254
|
+
const half = length >> 1;
|
|
255
|
+
if (length % 2 === 1) {
|
|
256
|
+
return values[half];
|
|
257
|
+
}
|
|
258
|
+
return (values[half - 1] + values[half]) / 2;
|
|
259
|
+
}
|
|
260
|
+
function didLastSendRequestFail(sendRecords) {
|
|
261
|
+
return sendRecords.length > 0 && !sendRecords[sendRecords.length - 1].ok;
|
|
262
|
+
}
|
|
263
|
+
function recovered(sendRecords) {
|
|
264
|
+
return (sendRecords.length > 1 &&
|
|
265
|
+
!sendRecords[sendRecords.length - 2].ok &&
|
|
266
|
+
sendRecords[sendRecords.length - 1].ok);
|
|
267
|
+
}
|
|
268
|
+
//# sourceMappingURL=connection-loop.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"connection-loop.js","sourceRoot":"","sources":["../../../../replicache/src/connection-loop.ts"],"names":[],"mappings":"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"}
|