@rocicorp/zero 0.5.2024103100 → 0.6.2024111600
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/{internal.js → advanced.js} +2 -2
- package/out/{chunk-TBA526RR.js → chunk-V5NTGJ4X.js} +1211 -624
- package/out/chunk-V5NTGJ4X.js.map +7 -0
- package/out/{chunk-RCVGGCMG.js → chunk-YCMA66NH.js} +2 -2
- package/out/{chunk-RCVGGCMG.js.map → chunk-YCMA66NH.js.map} +2 -2
- package/out/react.js.map +2 -2
- package/out/shared/src/browser-env.d.ts +17 -0
- package/out/shared/src/browser-env.d.ts.map +1 -1
- package/out/shared/src/expand.d.ts +7 -0
- package/out/shared/src/expand.d.ts.map +1 -0
- package/out/shared/src/valita.d.ts +7 -0
- package/out/shared/src/valita.d.ts.map +1 -1
- package/out/shared/src/valita.js +28 -0
- package/out/shared/src/valita.js.map +1 -1
- package/out/solid.js +5 -5
- package/out/solid.js.map +2 -2
- package/out/zero-advanced/src/mod.d.ts +7 -7
- package/out/zero-advanced/src/mod.d.ts.map +1 -1
- package/out/zero-cache/src/auth/load-authorization.d.ts +3 -0
- package/out/zero-cache/src/auth/load-authorization.d.ts.map +1 -0
- package/out/zero-cache/src/auth/load-authorization.js +21 -0
- package/out/zero-cache/src/auth/load-authorization.js.map +1 -0
- package/out/zero-cache/src/config/config.d.ts +112 -0
- package/out/zero-cache/src/config/config.d.ts.map +1 -0
- package/out/zero-cache/src/config/config.js +246 -0
- package/out/zero-cache/src/config/config.js.map +1 -0
- package/out/zero-cache/src/config/zero-config.d.ts +145 -964
- package/out/zero-cache/src/config/zero-config.d.ts.map +1 -1
- package/out/zero-cache/src/config/zero-config.js +242 -115
- package/out/zero-cache/src/config/zero-config.js.map +1 -1
- package/out/zero-cache/src/db/delete-lite-db.d.ts +2 -0
- package/out/zero-cache/src/db/delete-lite-db.d.ts.map +1 -0
- package/out/zero-cache/src/db/delete-lite-db.js +7 -0
- package/out/zero-cache/src/db/delete-lite-db.js.map +1 -0
- package/out/zero-cache/src/db/migration.d.ts +1 -0
- package/out/zero-cache/src/db/migration.d.ts.map +1 -1
- package/out/zero-cache/src/db/migration.js +17 -7
- package/out/zero-cache/src/db/migration.js.map +1 -1
- package/out/zero-cache/src/db/pg-to-lite.d.ts +1 -1
- package/out/zero-cache/src/db/pg-to-lite.d.ts.map +1 -1
- package/out/zero-cache/src/db/pg-to-lite.js +7 -3
- package/out/zero-cache/src/db/pg-to-lite.js.map +1 -1
- package/out/zero-cache/src/db/short-lived-client.d.ts +16 -0
- package/out/zero-cache/src/db/short-lived-client.d.ts.map +1 -0
- package/out/zero-cache/src/db/short-lived-client.js +50 -0
- package/out/zero-cache/src/db/short-lived-client.js.map +1 -0
- package/out/zero-cache/src/db/specs.d.ts +12 -3
- package/out/zero-cache/src/db/specs.d.ts.map +1 -1
- package/out/zero-cache/src/db/specs.js +6 -1
- package/out/zero-cache/src/db/specs.js.map +1 -1
- package/out/zero-cache/src/db/transaction-pool.d.ts +7 -2
- package/out/zero-cache/src/db/transaction-pool.d.ts.map +1 -1
- package/out/zero-cache/src/db/transaction-pool.js +42 -8
- package/out/zero-cache/src/db/transaction-pool.js.map +1 -1
- package/out/zero-cache/src/server/change-streamer.d.ts.map +1 -1
- package/out/zero-cache/src/server/change-streamer.js +34 -9
- package/out/zero-cache/src/server/change-streamer.js.map +1 -1
- package/out/zero-cache/src/server/life-cycle.d.ts +1 -1
- package/out/zero-cache/src/server/life-cycle.d.ts.map +1 -1
- package/out/zero-cache/src/server/life-cycle.js +2 -3
- package/out/zero-cache/src/server/life-cycle.js.map +1 -1
- package/out/zero-cache/src/server/logging.d.ts.map +1 -1
- package/out/zero-cache/src/server/logging.js +2 -15
- package/out/zero-cache/src/server/logging.js.map +1 -1
- package/out/zero-cache/src/server/main.js +28 -10
- package/out/zero-cache/src/server/main.js.map +1 -1
- package/out/zero-cache/src/server/replicator.d.ts.map +1 -1
- package/out/zero-cache/src/server/replicator.js +6 -5
- package/out/zero-cache/src/server/replicator.js.map +1 -1
- package/out/zero-cache/src/server/syncer.d.ts.map +1 -1
- package/out/zero-cache/src/server/syncer.js +16 -12
- package/out/zero-cache/src/server/syncer.js.map +1 -1
- package/out/zero-cache/src/services/change-streamer/change-streamer-http.d.ts +2 -3
- 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 +2 -3
- 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-service.d.ts +153 -2
- package/out/zero-cache/src/services/change-streamer/change-streamer-service.d.ts.map +1 -1
- package/out/zero-cache/src/services/change-streamer/change-streamer-service.js +136 -19
- package/out/zero-cache/src/services/change-streamer/change-streamer-service.js.map +1 -1
- package/out/zero-cache/src/services/change-streamer/change-streamer.d.ts +17 -9
- 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 +4 -2
- package/out/zero-cache/src/services/change-streamer/change-streamer.js.map +1 -1
- package/out/zero-cache/src/services/change-streamer/forwarder.d.ts +1 -0
- package/out/zero-cache/src/services/change-streamer/forwarder.d.ts.map +1 -1
- package/out/zero-cache/src/services/change-streamer/forwarder.js +9 -2
- package/out/zero-cache/src/services/change-streamer/forwarder.js.map +1 -1
- package/out/zero-cache/src/services/change-streamer/pg/change-source.d.ts +10 -0
- 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 +171 -24
- 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 +32 -18
- 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 +62 -39
- 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 +8 -40
- 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/init.d.ts +8 -0
- package/out/zero-cache/src/services/change-streamer/pg/schema/init.d.ts.map +1 -1
- package/out/zero-cache/src/services/change-streamer/pg/schema/init.js +41 -8
- package/out/zero-cache/src/services/change-streamer/pg/schema/init.js.map +1 -1
- package/out/zero-cache/src/services/change-streamer/pg/schema/published.d.ts +83 -13
- 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 +15 -5
- 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/shard.d.ts +39 -3
- package/out/zero-cache/src/services/change-streamer/pg/schema/shard.d.ts.map +1 -1
- package/out/zero-cache/src/services/change-streamer/pg/schema/shard.js +67 -36
- package/out/zero-cache/src/services/change-streamer/pg/schema/shard.js.map +1 -1
- package/out/zero-cache/src/services/change-streamer/pg/schema/validation.d.ts +8 -0
- package/out/zero-cache/src/services/change-streamer/pg/schema/validation.d.ts.map +1 -0
- package/out/zero-cache/src/services/change-streamer/pg/schema/validation.js +33 -0
- package/out/zero-cache/src/services/change-streamer/pg/schema/validation.js.map +1 -0
- package/out/zero-cache/src/services/change-streamer/schema/change.d.ts +5 -1
- 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 +3 -0
- package/out/zero-cache/src/services/change-streamer/schema/change.js.map +1 -1
- package/out/zero-cache/src/services/change-streamer/schema/init.d.ts.map +1 -1
- package/out/zero-cache/src/services/change-streamer/schema/init.js +4 -6
- package/out/zero-cache/src/services/change-streamer/schema/init.js.map +1 -1
- package/out/zero-cache/src/services/change-streamer/schema/tables.d.ts +6 -1
- package/out/zero-cache/src/services/change-streamer/schema/tables.d.ts.map +1 -1
- package/out/zero-cache/src/services/change-streamer/schema/tables.js +19 -4
- package/out/zero-cache/src/services/change-streamer/schema/tables.js.map +1 -1
- package/out/zero-cache/src/services/change-streamer/storer.d.ts +29 -2
- package/out/zero-cache/src/services/change-streamer/storer.d.ts.map +1 -1
- package/out/zero-cache/src/services/change-streamer/storer.js +90 -8
- package/out/zero-cache/src/services/change-streamer/storer.js.map +1 -1
- package/out/zero-cache/src/services/change-streamer/subscriber.d.ts +1 -0
- package/out/zero-cache/src/services/change-streamer/subscriber.d.ts.map +1 -1
- package/out/zero-cache/src/services/change-streamer/subscriber.js +18 -3
- package/out/zero-cache/src/services/change-streamer/subscriber.js.map +1 -1
- package/out/zero-cache/src/services/dispatcher/dispatcher.d.ts +5 -3
- package/out/zero-cache/src/services/dispatcher/dispatcher.d.ts.map +1 -1
- package/out/zero-cache/src/services/dispatcher/dispatcher.js +20 -5
- package/out/zero-cache/src/services/dispatcher/dispatcher.js.map +1 -1
- package/out/zero-cache/src/services/mutagen/mutagen.d.ts +6 -5
- package/out/zero-cache/src/services/mutagen/mutagen.d.ts.map +1 -1
- package/out/zero-cache/src/services/mutagen/mutagen.js +26 -20
- package/out/zero-cache/src/services/mutagen/mutagen.js.map +1 -1
- package/out/zero-cache/src/services/mutagen/write-authorizer.d.ts +7 -6
- package/out/zero-cache/src/services/mutagen/write-authorizer.d.ts.map +1 -1
- package/out/zero-cache/src/services/mutagen/write-authorizer.js +12 -20
- package/out/zero-cache/src/services/mutagen/write-authorizer.js.map +1 -1
- package/out/zero-cache/src/services/replicator/incremental-sync.d.ts +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 +8 -8
- package/out/zero-cache/src/services/replicator/incremental-sync.js.map +1 -1
- package/out/zero-cache/src/services/replicator/schema/replication-state.d.ts.map +1 -1
- package/out/zero-cache/src/services/replicator/schema/replication-state.js +1 -10
- package/out/zero-cache/src/services/replicator/schema/replication-state.js.map +1 -1
- package/out/zero-cache/src/services/running-state.d.ts +6 -1
- package/out/zero-cache/src/services/running-state.d.ts.map +1 -1
- package/out/zero-cache/src/services/running-state.js +23 -5
- package/out/zero-cache/src/services/running-state.js.map +1 -1
- package/out/zero-cache/src/services/view-syncer/database-storage.d.ts +1 -1
- package/out/zero-cache/src/services/view-syncer/database-storage.d.ts.map +1 -1
- package/out/zero-cache/src/services/view-syncer/pipeline-driver.js +1 -1
- package/out/zero-cache/src/services/view-syncer/pipeline-driver.js.map +1 -1
- package/out/zero-cache/src/services/view-syncer/schema/types.d.ts +49 -29
- package/out/zero-cache/src/services/view-syncer/schema/types.d.ts.map +1 -1
- 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 +2 -1
- package/out/zero-cache/src/services/view-syncer/view-syncer.js.map +1 -1
- package/out/zero-cache/src/types/lexi-version.d.ts +3 -2
- package/out/zero-cache/src/types/lexi-version.d.ts.map +1 -1
- package/out/zero-cache/src/types/lexi-version.js +8 -6
- package/out/zero-cache/src/types/lexi-version.js.map +1 -1
- package/out/zero-cache/src/types/lite.d.ts +1 -1
- package/out/zero-cache/src/types/lite.d.ts.map +1 -1
- package/out/zero-cache/src/types/lite.js +0 -1
- package/out/zero-cache/src/types/lite.js.map +1 -1
- package/out/zero-cache/src/types/processes.d.ts.map +1 -1
- package/out/zero-cache/src/types/processes.js +1 -0
- package/out/zero-cache/src/types/processes.js.map +1 -1
- package/out/zero-cache/src/workers/replicator.d.ts.map +1 -1
- package/out/zero-cache/src/workers/replicator.js +2 -4
- package/out/zero-cache/src/workers/replicator.js.map +1 -1
- package/out/zero-cache/src/workers/syncer.js +1 -1
- package/out/zero-cache/src/workers/syncer.js.map +1 -1
- package/out/zero-client/src/client/context.d.ts +4 -4
- package/out/zero-client/src/client/context.d.ts.map +1 -1
- package/out/zero-client/src/client/crud.d.ts +57 -26
- package/out/zero-client/src/client/crud.d.ts.map +1 -1
- package/out/zero-client/src/client/http-string.d.ts +1 -0
- package/out/zero-client/src/client/http-string.d.ts.map +1 -1
- package/out/zero-client/src/client/keys.d.ts +1 -1
- package/out/zero-client/src/client/keys.d.ts.map +1 -1
- package/out/zero-client/src/client/log-options.d.ts +2 -1
- package/out/zero-client/src/client/log-options.d.ts.map +1 -1
- package/out/zero-client/src/client/options.d.ts +9 -9
- package/out/zero-client/src/client/options.d.ts.map +1 -1
- package/out/zero-client/src/client/protocol-version.d.ts +2 -0
- package/out/zero-client/src/client/protocol-version.d.ts.map +1 -0
- package/out/zero-client/src/client/query-manager.d.ts +1 -1
- package/out/zero-client/src/client/query-manager.d.ts.map +1 -1
- package/out/zero-client/src/client/server-option.d.ts.map +1 -1
- package/out/zero-client/src/client/zero-poke-handler.d.ts +1 -1
- package/out/zero-client/src/client/zero-poke-handler.d.ts.map +1 -1
- package/out/zero-client/src/client/zero.d.ts +27 -22
- package/out/zero-client/src/client/zero.d.ts.map +1 -1
- package/out/zero-client/src/mod.d.ts +8 -7
- package/out/zero-client/src/mod.d.ts.map +1 -1
- package/out/zero-protocol/src/ast.d.ts +37 -21
- package/out/zero-protocol/src/ast.d.ts.map +1 -1
- package/out/zero-protocol/src/ast.js +21 -6
- package/out/zero-protocol/src/ast.js.map +1 -1
- package/out/zero-protocol/src/change-desired-queries.d.ts +16 -8
- package/out/zero-protocol/src/change-desired-queries.d.ts.map +1 -1
- package/out/zero-protocol/src/connect.d.ts +16 -8
- package/out/zero-protocol/src/connect.d.ts.map +1 -1
- package/out/zero-protocol/src/down.d.ts +16 -8
- package/out/zero-protocol/src/down.d.ts.map +1 -1
- package/out/zero-protocol/src/poke.d.ts +32 -16
- package/out/zero-protocol/src/poke.d.ts.map +1 -1
- package/out/zero-protocol/src/push.d.ts +18 -18
- package/out/zero-protocol/src/push.d.ts.map +1 -1
- package/out/zero-protocol/src/push.js +5 -5
- package/out/zero-protocol/src/push.js.map +1 -1
- package/out/zero-protocol/src/queries-patch.d.ts +24 -12
- package/out/zero-protocol/src/queries-patch.d.ts.map +1 -1
- package/out/zero-protocol/src/up.d.ts +18 -10
- package/out/zero-protocol/src/up.d.ts.map +1 -1
- package/out/zero-react/src/use-query.d.ts +2 -1
- package/out/zero-react/src/use-query.d.ts.map +1 -1
- package/out/zero-react/src/use-zero.d.ts +2 -1
- package/out/zero-react/src/use-zero.d.ts.map +1 -1
- package/out/zero-schema/src/authorization.d.ts +25 -0
- package/out/zero-schema/src/authorization.d.ts.map +1 -0
- package/out/zero-schema/src/compiled-authorization.d.ts +379 -0
- package/out/zero-schema/src/compiled-authorization.d.ts.map +1 -0
- package/out/zero-schema/src/compiled-authorization.js +15 -0
- package/out/zero-schema/src/compiled-authorization.js.map +1 -0
- package/out/zero-schema/src/mod.d.ts +5 -0
- package/out/zero-schema/src/mod.d.ts.map +1 -0
- package/out/{zql/src/zql/query → zero-schema/src}/normalize-table-schema.d.ts +2 -3
- package/out/zero-schema/src/normalize-table-schema.d.ts.map +1 -0
- package/out/{zero-client/src/client → zero-schema/src}/normalized-schema.d.ts +2 -2
- package/out/zero-schema/src/normalized-schema.d.ts.map +1 -0
- package/out/zero-schema/src/schema.d.ts +9 -0
- package/out/zero-schema/src/schema.d.ts.map +1 -0
- package/out/{zql/src/zql/query/schema.d.ts → zero-schema/src/table-schema.d.ts} +47 -3
- package/out/zero-schema/src/table-schema.d.ts.map +1 -0
- package/out/{zql/src/zql/query/schema.js → zero-schema/src/table-schema.js} +1 -1
- package/out/zero-schema/src/table-schema.js.map +1 -0
- package/out/zero-solid/src/create-zero.d.ts +2 -1
- package/out/zero-solid/src/create-zero.d.ts.map +1 -1
- package/out/zero.js +6 -14
- package/out/zql/src/{zql/builder → builder}/builder.d.ts +5 -5
- package/out/zql/src/builder/builder.d.ts.map +1 -0
- package/out/zql/src/{zql/builder → builder}/builder.js +81 -33
- package/out/zql/src/builder/builder.js.map +1 -0
- package/out/zql/src/builder/error.d.ts.map +1 -0
- package/out/zql/src/builder/error.js.map +1 -0
- package/out/zql/src/builder/filter.d.ts +7 -0
- package/out/zql/src/builder/filter.d.ts.map +1 -0
- package/out/zql/src/{zql/builder → builder}/filter.js +19 -1
- package/out/zql/src/builder/filter.js.map +1 -0
- package/out/zql/src/builder/like.d.ts +3 -0
- package/out/zql/src/builder/like.d.ts.map +1 -0
- package/out/zql/src/{zql/builder → builder}/like.js +1 -1
- package/out/zql/src/builder/like.js.map +1 -0
- package/out/zql/src/ivm/array-view.d.ts.map +1 -0
- package/out/zql/src/{zql/ivm → ivm}/change.d.ts +2 -1
- package/out/zql/src/ivm/change.d.ts.map +1 -0
- package/out/zql/src/ivm/change.js +5 -0
- package/out/zql/src/ivm/change.js.map +1 -0
- package/out/zql/src/{zql/ivm → ivm}/data.d.ts +2 -2
- package/out/zql/src/ivm/data.d.ts.map +1 -0
- package/out/zql/src/{zql/ivm → ivm}/data.js +1 -1
- package/out/zql/src/ivm/data.js.map +1 -0
- package/out/zql/src/ivm/exists.d.ts +18 -0
- package/out/zql/src/ivm/exists.d.ts.map +1 -0
- package/out/zql/src/ivm/exists.js +186 -0
- package/out/zql/src/ivm/exists.js.map +1 -0
- package/out/zql/src/{zql/ivm → ivm}/fan-in.d.ts +3 -3
- package/out/zql/src/ivm/fan-in.d.ts.map +1 -0
- package/out/zql/src/{zql/ivm → ivm}/fan-in.js +8 -11
- package/out/zql/src/ivm/fan-in.js.map +1 -0
- package/out/zql/src/{zql/ivm → ivm}/fan-out.d.ts +1 -1
- package/out/zql/src/ivm/fan-out.d.ts.map +1 -0
- package/out/zql/src/{zql/ivm → ivm}/fan-out.js +8 -7
- package/out/zql/src/ivm/fan-out.js.map +1 -0
- package/out/zql/src/{zql/ivm → ivm}/filter.d.ts +3 -3
- package/out/zql/src/ivm/filter.d.ts.map +1 -0
- package/out/zql/src/{zql/ivm → ivm}/filter.js +2 -2
- package/out/zql/src/ivm/filter.js.map +1 -0
- package/out/zql/src/{zql/ivm → ivm}/join.d.ts +2 -2
- package/out/zql/src/ivm/join.d.ts.map +1 -0
- package/out/zql/src/{zql/ivm → ivm}/join.js +2 -2
- package/out/zql/src/ivm/join.js.map +1 -0
- package/out/zql/src/ivm/lookahead-iterator.d.ts.map +1 -0
- package/out/zql/src/ivm/lookahead-iterator.js.map +1 -0
- package/out/zql/src/{zql/ivm → ivm}/maybe-split-and-push-edit-change.d.ts +1 -1
- package/out/zql/src/ivm/maybe-split-and-push-edit-change.d.ts.map +1 -0
- package/out/zql/src/ivm/maybe-split-and-push-edit-change.js.map +1 -0
- package/out/zql/src/{zql/ivm → ivm}/memory-source.d.ts +16 -12
- package/out/zql/src/ivm/memory-source.d.ts.map +1 -0
- package/out/zql/src/{zql/ivm → ivm}/memory-source.js +72 -92
- package/out/zql/src/ivm/memory-source.js.map +1 -0
- package/out/zql/src/{zql/ivm → ivm}/memory-storage.d.ts +1 -1
- package/out/zql/src/ivm/memory-storage.d.ts.map +1 -0
- package/out/zql/src/{zql/ivm → ivm}/operator.d.ts +5 -5
- package/out/zql/src/ivm/operator.d.ts.map +1 -0
- package/out/zql/src/ivm/operator.js.map +1 -0
- package/out/zql/src/ivm/schema.d.ts +15 -0
- package/out/zql/src/ivm/schema.d.ts.map +1 -0
- package/out/zql/src/ivm/schema.js +2 -0
- package/out/zql/src/ivm/schema.js.map +1 -0
- package/out/zql/src/{zql/ivm → ivm}/skip.d.ts +3 -3
- package/out/zql/src/ivm/skip.d.ts.map +1 -0
- package/out/zql/src/{zql/ivm → ivm}/skip.js +2 -2
- package/out/zql/src/ivm/skip.js.map +1 -0
- package/out/zql/src/{zql/ivm → ivm}/source.d.ts +2 -2
- package/out/zql/src/ivm/source.d.ts.map +1 -0
- package/out/zql/src/ivm/source.js.map +1 -0
- package/out/zql/src/ivm/stream.d.ts.map +1 -0
- package/out/zql/src/ivm/stream.js.map +1 -0
- package/out/zql/src/{zql/ivm → ivm}/take.d.ts +3 -3
- package/out/zql/src/ivm/take.d.ts.map +1 -0
- package/out/zql/src/{zql/ivm → ivm}/take.js +13 -9
- package/out/zql/src/ivm/take.js.map +1 -0
- package/out/zql/src/ivm/view-apply-change.d.ts +5 -0
- package/out/zql/src/ivm/view-apply-change.d.ts.map +1 -0
- package/out/zql/src/{zql/ivm → ivm}/view.d.ts +2 -2
- package/out/zql/src/ivm/view.d.ts.map +1 -0
- package/out/zql/src/query/auth-query.d.ts +24 -0
- package/out/zql/src/query/auth-query.d.ts.map +1 -0
- package/out/zql/src/query/dnf.d.ts +10 -0
- package/out/zql/src/query/dnf.d.ts.map +1 -0
- package/out/zql/src/query/escape-like.d.ts.map +1 -0
- package/out/zql/src/query/expression.d.ts +41 -0
- package/out/zql/src/query/expression.d.ts.map +1 -0
- package/out/zql/src/{zql/query → query}/query-impl.d.ts +9 -8
- package/out/zql/src/query/query-impl.d.ts.map +1 -0
- package/out/zql/src/{zql/query → query}/query-internal.d.ts +1 -1
- package/out/zql/src/query/query-internal.d.ts.map +1 -0
- package/out/zql/src/query/query.d.ts +98 -0
- package/out/zql/src/query/query.d.ts.map +1 -0
- package/out/zql/src/{zql/query → query}/typed-view.d.ts +1 -1
- package/out/zql/src/query/typed-view.d.ts.map +1 -0
- package/out/zqlite/src/db.d.ts.map +1 -1
- package/out/zqlite/src/db.js +19 -6
- package/out/zqlite/src/db.js.map +1 -1
- package/out/zqlite/src/table-source.d.ts +24 -3
- package/out/zqlite/src/table-source.d.ts.map +1 -1
- package/out/zqlite/src/table-source.js +117 -18
- package/out/zqlite/src/table-source.js.map +1 -1
- package/package.json +11 -6
- package/out/chunk-TBA526RR.js.map +0 -7
- package/out/datadog/src/datadog-log-sink.js +0 -231
- package/out/datadog/src/datadog-log-sink.js.map +0 -1
- package/out/datadog/src/mod.js +0 -2
- package/out/datadog/src/mod.js.map +0 -1
- package/out/replicache/src/async-iterable-to-array.js +0 -8
- package/out/replicache/src/async-iterable-to-array.js.map +0 -1
- package/out/replicache/src/bg-interval.js +0 -38
- package/out/replicache/src/bg-interval.js.map +0 -1
- package/out/replicache/src/binary-search.js +0 -31
- package/out/replicache/src/binary-search.js.map +0 -1
- package/out/replicache/src/broadcast-channel.js +0 -29
- package/out/replicache/src/broadcast-channel.js.map +0 -1
- package/out/replicache/src/btree/diff.js +0 -6
- package/out/replicache/src/btree/diff.js.map +0 -1
- package/out/replicache/src/btree/node.js +0 -392
- package/out/replicache/src/btree/node.js.map +0 -1
- package/out/replicache/src/btree/read.js +0 -227
- package/out/replicache/src/btree/read.js.map +0 -1
- package/out/replicache/src/btree/splice.js +0 -79
- package/out/replicache/src/btree/splice.js.map +0 -1
- package/out/replicache/src/btree/write.js +0 -154
- package/out/replicache/src/btree/write.js.map +0 -1
- package/out/replicache/src/call-default-fetch.js +0 -37
- package/out/replicache/src/call-default-fetch.js.map +0 -1
- package/out/replicache/src/config.js +0 -13
- package/out/replicache/src/config.js.map +0 -1
- package/out/replicache/src/connection-loop-delegates.js +0 -30
- package/out/replicache/src/connection-loop-delegates.js.map +0 -1
- package/out/replicache/src/connection-loop.js +0 -268
- package/out/replicache/src/connection-loop.js.map +0 -1
- package/out/replicache/src/cookies.js +0 -41
- package/out/replicache/src/cookies.js.map +0 -1
- package/out/replicache/src/dag/chunk.js +0 -60
- package/out/replicache/src/dag/chunk.js.map +0 -1
- package/out/replicache/src/dag/gc.js +0 -126
- package/out/replicache/src/dag/gc.js.map +0 -1
- package/out/replicache/src/dag/key-type-enum.js +0 -6
- package/out/replicache/src/dag/key-type-enum.js.map +0 -1
- package/out/replicache/src/dag/key.js +0 -54
- package/out/replicache/src/dag/key.js.map +0 -1
- package/out/replicache/src/dag/lazy-store.js +0 -532
- package/out/replicache/src/dag/lazy-store.js.map +0 -1
- package/out/replicache/src/dag/store-impl.js +0 -175
- package/out/replicache/src/dag/store-impl.js.map +0 -1
- package/out/replicache/src/dag/store.js +0 -22
- package/out/replicache/src/dag/store.js.map +0 -1
- package/out/replicache/src/dag/visitor.js +0 -22
- package/out/replicache/src/dag/visitor.js.map +0 -1
- package/out/replicache/src/db/commit.js +0 -443
- package/out/replicache/src/db/commit.js.map +0 -1
- package/out/replicache/src/db/index-operation-enum.js +0 -4
- package/out/replicache/src/db/index-operation-enum.js.map +0 -1
- package/out/replicache/src/db/index.js +0 -170
- package/out/replicache/src/db/index.js.map +0 -1
- package/out/replicache/src/db/meta-type-enum.js +0 -7
- package/out/replicache/src/db/meta-type-enum.js.map +0 -1
- package/out/replicache/src/db/read.js +0 -59
- package/out/replicache/src/db/read.js.map +0 -1
- package/out/replicache/src/db/rebase.js +0 -56
- package/out/replicache/src/db/rebase.js.map +0 -1
- package/out/replicache/src/db/scan.js +0 -2
- package/out/replicache/src/db/scan.js.map +0 -1
- package/out/replicache/src/db/write.js +0 -260
- package/out/replicache/src/db/write.js.map +0 -1
- package/out/replicache/src/error-responses.js +0 -30
- package/out/replicache/src/error-responses.js.map +0 -1
- package/out/replicache/src/filter-async-iterable.js +0 -15
- package/out/replicache/src/filter-async-iterable.js.map +0 -1
- package/out/replicache/src/format-version-enum.js +0 -9
- package/out/replicache/src/format-version-enum.js.map +0 -1
- package/out/replicache/src/format-version.js +0 -8
- package/out/replicache/src/format-version.js.map +0 -1
- package/out/replicache/src/frozen-json.js +0 -151
- package/out/replicache/src/frozen-json.js.map +0 -1
- package/out/replicache/src/get-default-puller.js +0 -74
- package/out/replicache/src/get-default-puller.js.map +0 -1
- package/out/replicache/src/get-default-pusher.js +0 -36
- package/out/replicache/src/get-default-pusher.js.map +0 -1
- package/out/replicache/src/hash.js +0 -73
- package/out/replicache/src/hash.js.map +0 -1
- package/out/replicache/src/http-request-info.js +0 -7
- package/out/replicache/src/http-request-info.js.map +0 -1
- package/out/replicache/src/impl.js +0 -2
- package/out/replicache/src/impl.js.map +0 -1
- package/out/replicache/src/index-defs.js +0 -28
- package/out/replicache/src/index-defs.js.map +0 -1
- package/out/replicache/src/invoke-kind-enum.js +0 -4
- package/out/replicache/src/invoke-kind-enum.js.map +0 -1
- package/out/replicache/src/iterable-union.js +0 -5
- package/out/replicache/src/iterable-union.js.map +0 -1
- package/out/replicache/src/kv/idb-store-with-mem-fallback.js +0 -93
- package/out/replicache/src/kv/idb-store-with-mem-fallback.js.map +0 -1
- package/out/replicache/src/kv/idb-store.js +0 -179
- package/out/replicache/src/kv/idb-store.js.map +0 -1
- package/out/replicache/src/kv/mem-store.js +0 -61
- package/out/replicache/src/kv/mem-store.js.map +0 -1
- package/out/replicache/src/kv/read-impl.js +0 -23
- package/out/replicache/src/kv/read-impl.js.map +0 -1
- package/out/replicache/src/kv/store.js +0 -2
- package/out/replicache/src/kv/store.js.map +0 -1
- package/out/replicache/src/kv/write-impl-base.js +0 -48
- package/out/replicache/src/kv/write-impl-base.js.map +0 -1
- package/out/replicache/src/kv/write-impl.js +0 -25
- package/out/replicache/src/kv/write-impl.js.map +0 -1
- package/out/replicache/src/lazy.js +0 -10
- package/out/replicache/src/lazy.js.map +0 -1
- package/out/replicache/src/log-options.js +0 -13
- package/out/replicache/src/log-options.js.map +0 -1
- package/out/replicache/src/merge-async-iterables.js +0 -61
- package/out/replicache/src/merge-async-iterables.js.map +0 -1
- package/out/replicache/src/mod.js +0 -14
- package/out/replicache/src/mod.js.map +0 -1
- package/out/replicache/src/mutation-recovery.js +0 -439
- package/out/replicache/src/mutation-recovery.js.map +0 -1
- package/out/replicache/src/new-client-channel.js +0 -77
- package/out/replicache/src/new-client-channel.js.map +0 -1
- package/out/replicache/src/on-persist-channel.js +0 -33
- package/out/replicache/src/on-persist-channel.js.map +0 -1
- package/out/replicache/src/patch-operation.js +0 -37
- package/out/replicache/src/patch-operation.js.map +0 -1
- package/out/replicache/src/pending-mutations.js +0 -18
- package/out/replicache/src/pending-mutations.js.map +0 -1
- package/out/replicache/src/persist/client-gc.js +0 -38
- package/out/replicache/src/persist/client-gc.js.map +0 -1
- package/out/replicache/src/persist/client-group-gc.js +0 -38
- package/out/replicache/src/persist/client-group-gc.js.map +0 -1
- package/out/replicache/src/persist/client-groups.js +0 -180
- package/out/replicache/src/persist/client-groups.js.map +0 -1
- package/out/replicache/src/persist/clients.js +0 -390
- package/out/replicache/src/persist/clients.js.map +0 -1
- package/out/replicache/src/persist/collect-idb-databases.js +0 -174
- package/out/replicache/src/persist/collect-idb-databases.js.map +0 -1
- package/out/replicache/src/persist/gather-mem-only-visitor.js +0 -25
- package/out/replicache/src/persist/gather-mem-only-visitor.js.map +0 -1
- package/out/replicache/src/persist/gather-not-cached-visitor.js +0 -35
- package/out/replicache/src/persist/gather-not-cached-visitor.js.map +0 -1
- package/out/replicache/src/persist/heartbeat.js +0 -37
- package/out/replicache/src/persist/heartbeat.js.map +0 -1
- package/out/replicache/src/persist/idb-databases-store-db-name.js +0 -18
- package/out/replicache/src/persist/idb-databases-store-db-name.js.map +0 -1
- package/out/replicache/src/persist/idb-databases-store.js +0 -90
- package/out/replicache/src/persist/idb-databases-store.js.map +0 -1
- package/out/replicache/src/persist/make-client-id.js +0 -13
- package/out/replicache/src/persist/make-client-id.js.map +0 -1
- package/out/replicache/src/persist/persist.js +0 -132
- package/out/replicache/src/persist/persist.js.map +0 -1
- package/out/replicache/src/persist/refresh.js +0 -147
- package/out/replicache/src/persist/refresh.js.map +0 -1
- package/out/replicache/src/process-scheduler.js +0 -93
- package/out/replicache/src/process-scheduler.js.map +0 -1
- package/out/replicache/src/puller.js +0 -2
- package/out/replicache/src/puller.js.map +0 -1
- package/out/replicache/src/pusher.js +0 -32
- package/out/replicache/src/pusher.js.map +0 -1
- package/out/replicache/src/replicache-impl.js +0 -1007
- package/out/replicache/src/replicache-impl.js.map +0 -1
- package/out/replicache/src/replicache-options.js +0 -2
- package/out/replicache/src/replicache-options.js.map +0 -1
- package/out/replicache/src/replicache.js +0 -387
- package/out/replicache/src/replicache.js.map +0 -1
- package/out/replicache/src/request-idle.js +0 -15
- package/out/replicache/src/request-idle.js.map +0 -1
- package/out/replicache/src/scan-iterator.js +0 -202
- package/out/replicache/src/scan-iterator.js.map +0 -1
- package/out/replicache/src/scan-options.js +0 -45
- package/out/replicache/src/scan-options.js.map +0 -1
- package/out/replicache/src/set-interval-with-signal.js +0 -7
- package/out/replicache/src/set-interval-with-signal.js.map +0 -1
- package/out/replicache/src/size-of-value.js +0 -77
- package/out/replicache/src/size-of-value.js.map +0 -1
- package/out/replicache/src/subscriptions.js +0 -357
- package/out/replicache/src/subscriptions.js.map +0 -1
- package/out/replicache/src/sync/diff.js +0 -75
- package/out/replicache/src/sync/diff.js.map +0 -1
- package/out/replicache/src/sync/handle-pull-response-result-type-enum.js +0 -5
- package/out/replicache/src/sync/handle-pull-response-result-type-enum.js.map +0 -1
- package/out/replicache/src/sync/ids.js +0 -4
- package/out/replicache/src/sync/ids.js.map +0 -1
- package/out/replicache/src/sync/patch.js +0 -41
- package/out/replicache/src/sync/patch.js.map +0 -1
- package/out/replicache/src/sync/pull-error.js +0 -16
- package/out/replicache/src/sync/pull-error.js.map +0 -1
- package/out/replicache/src/sync/pull.js +0 -375
- package/out/replicache/src/sync/pull.js.map +0 -1
- package/out/replicache/src/sync/push.js +0 -141
- package/out/replicache/src/sync/push.js.map +0 -1
- package/out/replicache/src/sync/request-id.js +0 -31
- package/out/replicache/src/sync/request-id.js.map +0 -1
- package/out/replicache/src/sync/sync-head-name.js +0 -2
- package/out/replicache/src/sync/sync-head-name.js.map +0 -1
- package/out/replicache/src/test-license-key.js +0 -3
- package/out/replicache/src/test-license-key.js.map +0 -1
- package/out/replicache/src/to-error.js +0 -7
- package/out/replicache/src/to-error.js.map +0 -1
- package/out/replicache/src/transaction-closed-error.js +0 -17
- package/out/replicache/src/transaction-closed-error.js.map +0 -1
- package/out/replicache/src/transactions.js +0 -144
- package/out/replicache/src/transactions.js.map +0 -1
- package/out/replicache/src/types.js +0 -2
- package/out/replicache/src/types.js.map +0 -1
- package/out/replicache/src/version.js +0 -6
- package/out/replicache/src/version.js.map +0 -1
- package/out/replicache/src/with-transactions.js +0 -28
- package/out/replicache/src/with-transactions.js.map +0 -1
- package/out/shared/src/browser-env.js +0 -14
- package/out/shared/src/browser-env.js.map +0 -1
- package/out/shared/src/document-visible.js +0 -76
- package/out/shared/src/document-visible.js.map +0 -1
- package/out/shared/src/immutable.js +0 -2
- package/out/shared/src/immutable.js.map +0 -1
- package/out/shared/src/navigator.js +0 -3
- package/out/shared/src/navigator.js.map +0 -1
- package/out/shared/src/random-uint64.js +0 -8
- package/out/shared/src/random-uint64.js.map +0 -1
- package/out/shared/src/sorted-entries.js +0 -6
- package/out/shared/src/sorted-entries.js.map +0 -1
- package/out/shared/src/types.js +0 -2
- package/out/shared/src/types.js.map +0 -1
- package/out/shared/src/writable.js +0 -2
- package/out/shared/src/writable.js.map +0 -1
- package/out/zero/src/config.d.ts +0 -2
- package/out/zero/src/config.d.ts.map +0 -1
- package/out/zero/src/config.js +0 -2
- package/out/zero/src/config.js.map +0 -1
- package/out/zero-cache/src/config/config-query.d.ts +0 -19
- package/out/zero-cache/src/config/config-query.d.ts.map +0 -1
- package/out/zero-cache/src/config/config-query.js +0 -22
- package/out/zero-cache/src/config/config-query.js.map +0 -1
- package/out/zero-cache/src/config/define-config.d.ts +0 -43
- package/out/zero-cache/src/config/define-config.d.ts.map +0 -1
- package/out/zero-cache/src/config/define-config.js +0 -120
- package/out/zero-cache/src/config/define-config.js.map +0 -1
- package/out/zero-cache/src/config/refs.d.ts +0 -3
- package/out/zero-cache/src/config/refs.d.ts.map +0 -1
- package/out/zero-cache/src/config/refs.js +0 -14
- package/out/zero-cache/src/config/refs.js.map +0 -1
- package/out/zero-client/src/client/context.js +0 -113
- package/out/zero-client/src/client/context.js.map +0 -1
- package/out/zero-client/src/client/crud.js +0 -181
- package/out/zero-client/src/client/crud.js.map +0 -1
- package/out/zero-client/src/client/enable-analytics.js +0 -21
- package/out/zero-client/src/client/enable-analytics.js.map +0 -1
- package/out/zero-client/src/client/http-string.js +0 -14
- package/out/zero-client/src/client/http-string.js.map +0 -1
- package/out/zero-client/src/client/keys.js +0 -32
- package/out/zero-client/src/client/keys.js.map +0 -1
- package/out/zero-client/src/client/log-options.js +0 -57
- package/out/zero-client/src/client/log-options.js.map +0 -1
- package/out/zero-client/src/client/metrics.js +0 -268
- package/out/zero-client/src/client/metrics.js.map +0 -1
- package/out/zero-client/src/client/normalized-schema.d.ts.map +0 -1
- package/out/zero-client/src/client/normalized-schema.js +0 -31
- package/out/zero-client/src/client/normalized-schema.js.map +0 -1
- package/out/zero-client/src/client/options.js +0 -2
- package/out/zero-client/src/client/options.js.map +0 -1
- package/out/zero-client/src/client/query-manager.js +0 -146
- package/out/zero-client/src/client/query-manager.js.map +0 -1
- package/out/zero-client/src/client/reload-error-handler.js +0 -23
- package/out/zero-client/src/client/reload-error-handler.js.map +0 -1
- package/out/zero-client/src/client/replicache-types.js +0 -2
- package/out/zero-client/src/client/replicache-types.js.map +0 -1
- package/out/zero-client/src/client/server-error.js +0 -22
- package/out/zero-client/src/client/server-error.js.map +0 -1
- package/out/zero-client/src/client/server-option.js +0 -37
- package/out/zero-client/src/client/server-option.js.map +0 -1
- package/out/zero-client/src/client/version.js +0 -6
- package/out/zero-client/src/client/version.js.map +0 -1
- package/out/zero-client/src/client/zero-poke-handler.js +0 -240
- package/out/zero-client/src/client/zero-poke-handler.js.map +0 -1
- package/out/zero-client/src/client/zero.js +0 -1233
- package/out/zero-client/src/client/zero.js.map +0 -1
- package/out/zero-client/src/mod.js +0 -7
- package/out/zero-client/src/mod.js.map +0 -1
- package/out/zero-client/src/util/nanoid.js +0 -34
- package/out/zero-client/src/util/nanoid.js.map +0 -1
- package/out/zero-client/src/util/socket.js +0 -4
- package/out/zero-client/src/util/socket.js.map +0 -1
- package/out/zero-protocol/src/ast-hash.js +0 -14
- package/out/zero-protocol/src/ast-hash.js.map +0 -1
- package/out/zql/src/zql/builder/builder.d.ts.map +0 -1
- package/out/zql/src/zql/builder/builder.js.map +0 -1
- package/out/zql/src/zql/builder/error.d.ts.map +0 -1
- package/out/zql/src/zql/builder/error.js.map +0 -1
- package/out/zql/src/zql/builder/filter.d.ts +0 -6
- package/out/zql/src/zql/builder/filter.d.ts.map +0 -1
- package/out/zql/src/zql/builder/filter.js.map +0 -1
- package/out/zql/src/zql/builder/like.d.ts +0 -3
- package/out/zql/src/zql/builder/like.d.ts.map +0 -1
- package/out/zql/src/zql/builder/like.js.map +0 -1
- package/out/zql/src/zql/ivm/array-view.d.ts.map +0 -1
- package/out/zql/src/zql/ivm/array-view.js +0 -70
- package/out/zql/src/zql/ivm/array-view.js.map +0 -1
- package/out/zql/src/zql/ivm/change.d.ts.map +0 -1
- package/out/zql/src/zql/ivm/change.js +0 -2
- package/out/zql/src/zql/ivm/change.js.map +0 -1
- package/out/zql/src/zql/ivm/data.d.ts.map +0 -1
- package/out/zql/src/zql/ivm/data.js.map +0 -1
- package/out/zql/src/zql/ivm/fan-in.d.ts.map +0 -1
- package/out/zql/src/zql/ivm/fan-in.js.map +0 -1
- package/out/zql/src/zql/ivm/fan-out.d.ts.map +0 -1
- package/out/zql/src/zql/ivm/fan-out.js.map +0 -1
- package/out/zql/src/zql/ivm/filter.d.ts.map +0 -1
- package/out/zql/src/zql/ivm/filter.js.map +0 -1
- package/out/zql/src/zql/ivm/join.d.ts.map +0 -1
- package/out/zql/src/zql/ivm/join.js.map +0 -1
- package/out/zql/src/zql/ivm/lookahead-iterator.d.ts.map +0 -1
- package/out/zql/src/zql/ivm/lookahead-iterator.js.map +0 -1
- package/out/zql/src/zql/ivm/maybe-split-and-push-edit-change.d.ts.map +0 -1
- package/out/zql/src/zql/ivm/maybe-split-and-push-edit-change.js.map +0 -1
- package/out/zql/src/zql/ivm/memory-source.d.ts.map +0 -1
- package/out/zql/src/zql/ivm/memory-source.js.map +0 -1
- package/out/zql/src/zql/ivm/memory-storage.d.ts.map +0 -1
- package/out/zql/src/zql/ivm/memory-storage.js +0 -33
- package/out/zql/src/zql/ivm/memory-storage.js.map +0 -1
- package/out/zql/src/zql/ivm/operator.d.ts.map +0 -1
- package/out/zql/src/zql/ivm/operator.js.map +0 -1
- package/out/zql/src/zql/ivm/schema.d.ts +0 -29
- package/out/zql/src/zql/ivm/schema.d.ts.map +0 -1
- package/out/zql/src/zql/ivm/schema.js +0 -3
- package/out/zql/src/zql/ivm/schema.js.map +0 -1
- package/out/zql/src/zql/ivm/skip.d.ts.map +0 -1
- package/out/zql/src/zql/ivm/skip.js.map +0 -1
- package/out/zql/src/zql/ivm/source.d.ts.map +0 -1
- package/out/zql/src/zql/ivm/source.js.map +0 -1
- package/out/zql/src/zql/ivm/stream.d.ts.map +0 -1
- package/out/zql/src/zql/ivm/stream.js.map +0 -1
- package/out/zql/src/zql/ivm/take.d.ts.map +0 -1
- package/out/zql/src/zql/ivm/take.js.map +0 -1
- package/out/zql/src/zql/ivm/view-apply-change.d.ts +0 -5
- package/out/zql/src/zql/ivm/view-apply-change.d.ts.map +0 -1
- package/out/zql/src/zql/ivm/view-apply-change.js +0 -156
- package/out/zql/src/zql/ivm/view-apply-change.js.map +0 -1
- package/out/zql/src/zql/ivm/view.d.ts.map +0 -1
- package/out/zql/src/zql/ivm/view.js +0 -2
- package/out/zql/src/zql/ivm/view.js.map +0 -1
- package/out/zql/src/zql/query/escape-like.d.ts.map +0 -1
- package/out/zql/src/zql/query/escape-like.js +0 -4
- package/out/zql/src/zql/query/escape-like.js.map +0 -1
- package/out/zql/src/zql/query/expression.d.ts +0 -25
- package/out/zql/src/zql/query/expression.d.ts.map +0 -1
- package/out/zql/src/zql/query/expression.js +0 -115
- package/out/zql/src/zql/query/expression.js.map +0 -1
- package/out/zql/src/zql/query/normalize-table-schema.d.ts.map +0 -1
- package/out/zql/src/zql/query/normalize-table-schema.js +0 -116
- package/out/zql/src/zql/query/normalize-table-schema.js.map +0 -1
- package/out/zql/src/zql/query/query-impl.d.ts.map +0 -1
- package/out/zql/src/zql/query/query-impl.js +0 -289
- package/out/zql/src/zql/query/query-impl.js.map +0 -1
- package/out/zql/src/zql/query/query-internal.d.ts.map +0 -1
- package/out/zql/src/zql/query/query-internal.js +0 -2
- package/out/zql/src/zql/query/query-internal.js.map +0 -1
- package/out/zql/src/zql/query/query.d.ts +0 -142
- package/out/zql/src/zql/query/query.d.ts.map +0 -1
- package/out/zql/src/zql/query/query.js +0 -3
- package/out/zql/src/zql/query/query.js.map +0 -1
- package/out/zql/src/zql/query/schema.d.ts.map +0 -1
- package/out/zql/src/zql/query/schema.js.map +0 -1
- package/out/zql/src/zql/query/typed-view.d.ts.map +0 -1
- package/out/zql/src/zql/query/typed-view.js +0 -2
- package/out/zql/src/zql/query/typed-view.js.map +0 -1
- /package/out/{internal.js.map → advanced.js.map} +0 -0
- /package/out/zql/src/{zql/builder → builder}/error.d.ts +0 -0
- /package/out/zql/src/{zql/builder → builder}/error.js +0 -0
- /package/out/zql/src/{zql/ivm → ivm}/array-view.d.ts +0 -0
- /package/out/zql/src/{zql/ivm → ivm}/lookahead-iterator.d.ts +0 -0
- /package/out/zql/src/{zql/ivm → ivm}/lookahead-iterator.js +0 -0
- /package/out/zql/src/{zql/ivm → ivm}/maybe-split-and-push-edit-change.js +0 -0
- /package/out/zql/src/{zql/ivm → ivm}/operator.js +0 -0
- /package/out/zql/src/{zql/ivm → ivm}/source.js +0 -0
- /package/out/zql/src/{zql/ivm → ivm}/stream.d.ts +0 -0
- /package/out/zql/src/{zql/ivm → ivm}/stream.js +0 -0
- /package/out/zql/src/{zql/query → query}/escape-like.d.ts +0 -0
|
@@ -1,79 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"splice.js","sourceRoot":"","sources":["../../../../../replicache/src/btree/splice.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,154 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"write.js","sourceRoot":"","sources":["../../../../../replicache/src/btree/write.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,37 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,13 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,30 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,268 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"connection-loop.js","sourceRoot":"","sources":["../../../../replicache/src/connection-loop.ts"],"names":[],"mappings":"AACA,OAAO,EAAC,QAAQ,EAAC,MAAM,oBAAoB,CAAC;AAE5C,OAAO,EAAC,KAAK,EAAC,MAAM,2BAA2B,CAAC;AAEhD,MAAM,CAAC,MAAM,iBAAiB,GAAG,EAAE,CAAC;AAEpC,MAAM,CAAC,MAAM,YAAY,GAAG,EAAE,CAAC;AAC/B,MAAM,CAAC,MAAM,YAAY,GAAG,MAAM,CAAC;AAcnC,MAAM,OAAO,cAAc;IACzB,wEAAwE;IACxE,4EAA4E;IAC5E,0EAA0E;IAC1E,wEAAwE;IACxE,yEAAyE;IACzE,+BAA+B;IAC/B,EAAE;IACF,2EAA2E;IAC3E,EAAE;IACF,sCAAsC;IACtC,aAAa;IACb,aAAa;IACb,sDAAsD;IACtD,aAAa;IACb,aAAa;IACb,sEAAsE;IACtE,WAAW;IACX,aAAa;IACb,aAAa;IACb,oEAAoE;IACpE,aAAa;IACb,aAAa;IACb,sCAAsC;IACtC,aAAa;IACb,aAAa;IACb,uBAAuB;IAEvB,2EAA2E;IAC3E,SAAS;IACT,gBAAgB,GAAG,QAAQ,EAAQ,CAAC;IAEpC;;OAEG;IACH,mBAAmB,GAAG,QAAQ,EAAQ,CAAC;IAEvC;;;;OAIG;IACH,aAAa,GAAG,QAAQ,EAAgC,CAAC;IAEhD,SAAS,CAAyB;IAC3C,OAAO,GAAG,KAAK,CAAC;IAEhB;;;;;OAKG;IACH,YAAY,GAAG,CAAC,CAAC;IACR,GAAG,CAAa;IAChB,kBAAkB,CAAwC;IAEnE,YACE,EAAc,EACd,QAAgC,EAChC,iBAA6C;QAE7C,IAAI,CAAC,GAAG,GAAG,EAAE,CAAC;QACd,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;QAC1B,IAAI,CAAC,kBAAkB,GAAG,iBAAiB,CAAC;QAC5C,KAAK,IAAI,CAAC,GAAG,EAAE,CAAC;IAClB,CAAC;IAED,KAAK;QACH,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACpB,IAAI,IAAI,CAAC,YAAY,GAAG,CAAC,EAAE,CAAC;YAC1B,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,EAAC,KAAK,EAAE,UAAU,EAAE,EAAC,CAAC,CAAC;QACpD,CAAC;IACH,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,IAAI,CAAC,GAAY;QACrB,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,OAAO,EAAC,KAAK,EAAE,UAAU,EAAE,EAAC,CAAC;QAC/B,CAAC;QACD,IAAI,CAAC,YAAY,EAAE,CAAC;QACpB,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;QAC9B,IAAI,GAAG,EAAE,CAAC;YACR,IAAI,CAAC,mBAAmB,CAAC,OAAO,EAAE,CAAC;QACrC,CAAC;aAAM,CAAC;YACN,MAAM,IAAI,CAAC,kBAAkB,EAAE,cAAc,EAAE,CAAC;QAClD,CAAC;QAED,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,CAAC;QAEhC,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC;QAChD,IAAI,CAAC,YAAY,EAAE,CAAC;QACpB,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,KAAK,CAAC,GAAG;QACP,MAAM,WAAW,GAAiB,EAAE,CAAC;QAErC,IAAI,eAAe,GAAG,QAAQ,EAAE,CAAC;QACjC,IAAI,YAAY,CAAC;QAEjB,oCAAoC;QACpC,IAAI,OAAO,GAAG,CAAC,CAAC;QAChB,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC;QAChC,MAAM,EAAC,KAAK,EAAC,GAAG,IAAI,CAAC,GAAG,CAAC;QACzB,IAAI,KAAK,GAAG,CAAC,CAAC;QAEd,KAAK,EAAE,CAAC,0BAA0B,CAAC,CAAC;QAEpC,MAAM,cAAc,GAAiB,EAAE,CAAC,EAAE,CACxC,OAAO,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,mBAAmB,CAAC,OAAO,EAAE,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAE9D,OAAO,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;YACrB,KAAK,EAAE,CACL,sBAAsB,CAAC,WAAW,CAAC;gBACjC,CAAC,CAAC,mCAAmC;gBACrC,CAAC,CAAC,oBAAoB,CACzB,CAAC;YAEF,+DAA+D;YAC/D,MAAM,KAAK,GAAG,CAAC,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC;YAC9C,MAAM,CAAC,GAAG,QAAQ,CAAC,aAAa,CAAC;YACjC,IAAI,CAAC,KAAK,IAAI,EAAE,CAAC;gBACf,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;YACvB,CAAC;YACD,MAAM,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAC1B,IAAI,IAAI,CAAC,OAAO;gBAAE,MAAM;YAExB,KAAK,EAAE,CAAC,sBAAsB,CAAC,CAAC;YAChC,MAAM,cAAc,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC;YAC7C,IAAI,IAAI,CAAC,OAAO;gBAAE,MAAM;YACxB,KAAK,EAAE,CAAC,WAAW,CAAC,CAAC;YAErB,yDAAyD;YACzD,IAAI,CAAC,gBAAgB,GAAG,QAAQ,EAAE,CAAC;YAEnC,IAAI,OAAO,IAAI,QAAQ,CAAC,cAAc,EAAE,CAAC;gBACvC,KAAK,EAAE,CAAC,2DAA2D,CAAC,CAAC;gBACrE,MAAM,IAAI,CAAC,6BAA6B,EAAE,CAAC;gBAC3C,IAAI,IAAI,CAAC,OAAO;oBAAE,MAAM;gBACxB,KAAK,EAAE,CAAC,aAAa,CAAC,CAAC;YACzB,CAAC;YAED,yEAAyE;YACzE,oBAAoB;YACpB,IAAI,OAAO,GAAG,CAAC,IAAI,sBAAsB,CAAC,WAAW,CAAC,EAAE,CAAC;gBACvD,KAAK,GAAG,8BAA8B,CAAC,KAAK,EAAE,QAAQ,EAAE,WAAW,CAAC,CAAC;gBACrE,KAAK,EAAE,CACL,sBAAsB,CAAC,WAAW,CAAC;oBACjC,CAAC,CAAC,uCAAuC;oBACzC,CAAC,CAAC,wCAAwC;wBACtC,OAAO;wBACP,iBAAiB,EACvB,KAAK,EACL,IAAI,CACL,CAAC;YACJ,CAAC;iBAAM,CAAC;gBACN,uEAAuE;gBACvE,sEAAsE;gBACtE,sEAAsE;gBACtE,+BAA+B;gBAC/B,KAAK,GAAG,CAAC,CAAC;YACZ,CAAC;YAED,MAAM,YAAY,GAAG,IAAI,CAAC,GAAG,CAC3B,QAAQ,CAAC,UAAU,EACnB,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,UAAU,EAAE,KAAK,CAAC,CACrC,CAAC;YACF,IAAI,YAAY,KAAK,SAAS,EAAE,CAAC;gBAC/B,MAAM,iBAAiB,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,YAAY,CAAC;gBACpD,IAAI,YAAY,GAAG,iBAAiB,EAAE,CAAC;oBACrC,MAAM,OAAO,CAAC,IAAI,CAAC;wBACjB,cAAc,CAAC,YAAY,GAAG,iBAAiB,CAAC;wBAChD,eAAe,CAAC,OAAO;qBACxB,CAAC,CAAC;oBACH,IAAI,IAAI,CAAC,OAAO;wBAAE,MAAM;gBAC1B,CAAC;YACH,CAAC;YAED,OAAO,EAAE,CAAC;YACV,mEAAmE;YACnE,CAAC,KAAK,IAAI,EAAE;gBACV,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;gBACzB,IAAI,EAAW,CAAC;gBAChB,IAAI,KAAc,CAAC;gBACnB,IAAI,CAAC;oBACH,YAAY,GAAG,KAAK,CAAC;oBACrB,KAAK,EAAE,CAAC,iBAAiB,CAAC,CAAC;oBAC3B,IAAI,CAAC,mBAAmB,GAAG,QAAQ,EAAE,CAAC;oBACtC,EAAE,GAAG,MAAM,QAAQ,CAAC,UAAU,EAAE,CAAC;oBACjC,KAAK,EAAE,CAAC,eAAe,EAAE,EAAE,CAAC,CAAC;gBAC/B,CAAC;gBAAC,OAAO,CAAC,EAAE,CAAC;oBACX,KAAK,EAAE,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC;oBAC1B,KAAK,GAAG,CAAC,CAAC;oBACV,EAAE,GAAG,KAAK,CAAC;gBACb,CAAC;gBACD,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;oBACjB,KAAK,EAAE,CAAC,yBAAyB,CAAC,CAAC;oBACnC,OAAO;gBACT,CAAC;gBACD,KAAK,EAAE,CAAC,cAAc,EAAE,EAAC,QAAQ,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK,EAAE,EAAE,EAAC,CAAC,CAAC;gBAC5D,WAAW,CAAC,IAAI,CAAC,EAAC,QAAQ,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK,EAAE,EAAE,EAAC,CAAC,CAAC;gBACrD,IAAI,SAAS,CAAC,WAAW,CAAC,EAAE,CAAC;oBAC3B,eAAe,CAAC,OAAO,EAAE,CAAC;oBAC1B,eAAe,GAAG,QAAQ,EAAE,CAAC;gBAC/B,CAAC;gBACD,OAAO,EAAE,CAAC;gBACV,IAAI,CAAC,oBAAoB,EAAE,CAAC;gBAC5B,MAAM,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC;gBACxC,IAAI,CAAC,aAAa,GAAG,QAAQ,EAAE,CAAC;gBAChC,IAAI,KAAK,EAAE,CAAC;oBACV,YAAY,CAAC,OAAO,CAAC,EAAC,KAAK,EAAC,CAAC,CAAC;gBAChC,CAAC;qBAAM,CAAC;oBACN,YAAY,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;gBAClC,CAAC;gBACD,IAAI,CAAC,EAAE,EAAE,CAAC;oBACR,cAAc;oBACd,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,CAAC;gBAClC,CAAC;YACH,CAAC,CAAC,EAAE,CAAC;QACP,CAAC;IACH,CAAC;IAED,yBAAyB,GAA6B,SAAS,CAAC;IAEhE,oBAAoB;QAClB,IAAI,IAAI,CAAC,yBAAyB,EAAE,CAAC;YACnC,MAAM,OAAO,GAAG,IAAI,CAAC,yBAAyB,CAAC;YAC/C,IAAI,CAAC,yBAAyB,GAAG,SAAS,CAAC;YAC3C,OAAO,EAAE,CAAC;QACZ,CAAC;IACH,CAAC;IAED,6BAA6B;QAC3B,MAAM,EAAC,OAAO,EAAE,OAAO,EAAC,GAAG,QAAQ,EAAE,CAAC;QACtC,IAAI,CAAC,yBAAyB,GAAG,OAAO,CAAC;QACzC,OAAO,OAAO,CAAC;IACjB,CAAC;CACF;AAED,kEAAkE;AAClE,MAAM,uBAAuB,GAAG,CAAC,CAAC;AAElC,SAAS,UAAU;IACjB,OAAO,IAAI,KAAK,CAAC,QAAQ,CAAC,CAAC;AAC7B,CAAC;AAED,gFAAgF;AAChF,8EAA8E;AAC9E,+EAA+E;AAC/E,0BAA0B;AAC1B,SAAS,8BAA8B,CACrC,KAAa,EACb,QAAgC,EAChC,WAAyB;IAEzB,MAAM,EAAC,MAAM,EAAC,GAAG,WAAW,CAAC;IAC7B,IAAI,MAAM,KAAK,CAAC,EAAE,CAAC;QACjB,OAAO,KAAK,CAAC;IACf,CAAC;IAED,MAAM,EAAC,EAAE,EAAC,GAAG,WAAW,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;IACjD,MAAM,EAAC,cAAc,EAAE,UAAU,EAAC,GAAG,QAAQ,CAAC;IAE9C,IAAI,CAAC,EAAE,EAAE,CAAC;QACR,OAAO,KAAK,KAAK,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC;IAC9C,CAAC;IAED,IAAI,MAAM,GAAG,CAAC,EAAE,CAAC;QACf,aAAa;QACb,MAAM,QAAQ,GAAe,WAAW,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;QAEjE,QAAQ;QACR,OAAO,WAAW,CAAC,MAAM,GAAG,uBAAuB,EAAE,CAAC;YACpD,WAAW,CAAC,KAAK,EAAE,CAAC;QACtB,CAAC;QAED,IAAI,EAAE,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE,CAAC;YACvB,YAAY;YACZ,OAAO,UAAU,CAAC;QACpB,CAAC;IACH,CAAC;IAED,MAAM,GAAG,GAAG,MAAM,CAChB,WAAW,CAAC,MAAM,CAAC,CAAC,EAAC,EAAE,EAAC,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,EAAC,QAAQ,EAAC,EAAE,EAAE,CAAC,QAAQ,CAAC,CAC/D,CAAC;IAEF,OAAO,CAAC,GAAG,GAAG,cAAc,CAAC,GAAG,CAAC,CAAC;AACpC,CAAC;AAED,SAAS,MAAM,CAAC,MAAgB;IAC9B,MAAM,CAAC,IAAI,EAAE,CAAC;IACd,MAAM,EAAC,MAAM,EAAC,GAAG,MAAM,CAAC;IACxB,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,CAAC;IACzB,IAAI,MAAM,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC;QACrB,OAAO,MAAM,CAAC,IAAI,CAAC,CAAC;IACtB,CAAC;IACD,OAAO,CAAC,MAAM,CAAC,IAAI,GAAG,CAAC,CAAC,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;AAC/C,CAAC;AAED,SAAS,sBAAsB,CAAC,WAAyB;IACvD,OAAO,WAAW,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC;AAC3E,CAAC;AAED,SAAS,SAAS,CAAC,WAAyB;IAC1C,OAAO,CACL,WAAW,CAAC,MAAM,GAAG,CAAC;QACtB,CAAC,WAAW,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,EAAE;QACvC,WAAW,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,EAAE,CACvC,CAAC;AACJ,CAAC"}
|