lib0 0.2.116 → 1.0.0-0
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/package.json +160 -407
- package/{array.js → src/array.js} +6 -2
- package/{binary.js → src/binary.js} +29 -35
- package/{delta → src/delta}/delta.js +474 -410
- package/{environment.js → src/environment.js} +30 -16
- package/{hash → src/hash}/rabin.js +6 -6
- package/{schema.js → src/schema.js} +127 -58
- package/{string.js → src/string.js} +47 -26
- package/{testing.js → src/testing.js} +3 -1
- package/src/ts.js +46 -0
- package/{dist → types}/array.d.ts +1 -1
- package/types/array.d.ts.map +1 -0
- package/{dist → types}/binary.d.ts +31 -37
- package/types/binary.d.ts.map +1 -0
- package/types/broadcastchannel.d.ts.map +1 -0
- package/types/buffer.d.ts.map +1 -0
- package/types/cache.d.ts.map +1 -0
- package/types/component.d.ts.map +1 -0
- package/types/conditions.d.ts.map +1 -0
- package/types/decoding.d.ts.map +1 -0
- package/types/delta/delta.d.ts +87 -16
- package/types/delta/delta.d.ts.map +1 -1
- package/types/delta/t3.test.d.ts.map +1 -1
- package/types/diff.d.ts.map +1 -0
- package/types/dom.d.ts.map +1 -0
- package/types/encoding.d.ts.map +1 -0
- package/{environment.d.ts → types/environment.d.ts} +2 -0
- package/types/environment.d.ts.map +1 -0
- package/types/error.d.ts.map +1 -0
- package/types/eventloop.d.ts.map +1 -0
- package/{function.d.ts → types/function.d.ts} +1 -1
- package/types/function.d.ts.map +1 -0
- package/types/indexeddb.d.ts.map +1 -0
- package/types/indexeddbV2.d.ts.map +1 -0
- package/types/iterator.d.ts.map +1 -0
- package/types/json.d.ts.map +1 -0
- package/types/list.d.ts.map +1 -0
- package/types/logging.common.d.ts.map +1 -0
- package/types/logging.d.ts.map +1 -0
- package/types/logging.node.d.ts.map +1 -0
- package/types/map.d.ts.map +1 -0
- package/types/math.d.ts.map +1 -0
- package/types/metric.d.ts.map +1 -0
- package/types/mutex.d.ts.map +1 -0
- package/{number.d.ts → types/number.d.ts} +2 -2
- package/types/number.d.ts.map +1 -0
- package/types/object.d.ts.map +1 -0
- package/types/observable.d.ts.map +1 -0
- package/types/pair.d.ts.map +1 -0
- package/types/performance.d.ts.map +1 -0
- package/types/performance.node.d.ts.map +1 -0
- package/types/pledge.d.ts.map +1 -0
- package/types/prng.d.ts.map +1 -0
- package/types/promise.d.ts.map +1 -0
- package/types/queue.d.ts.map +1 -0
- package/types/random.d.ts.map +1 -0
- package/{schema.d.ts → types/schema.d.ts} +65 -59
- package/types/schema.d.ts.map +1 -0
- package/types/set.d.ts.map +1 -0
- package/types/sort.d.ts.map +1 -0
- package/types/statistics.d.ts.map +1 -0
- package/types/storage.d.ts.map +1 -0
- package/{string.d.ts → types/string.d.ts} +3 -8
- package/types/string.d.ts.map +1 -0
- package/types/symbol.d.ts.map +1 -0
- package/{testing.d.ts → types/testing.d.ts} +2 -1
- package/types/testing.d.ts.map +1 -0
- package/types/time.d.ts.map +1 -0
- package/types/trait/equality.d.ts.map +1 -1
- package/types/tree.d.ts.map +1 -0
- package/types/ts.d.ts +22 -0
- package/types/ts.d.ts.map +1 -0
- package/types/url.d.ts.map +1 -0
- package/types/webcrypto.d.ts.map +1 -0
- package/types/webcrypto.deno.d.ts.map +1 -0
- package/types/webcrypto.node.d.ts.map +1 -0
- package/types/webcrypto.react-native.d.ts.map +1 -0
- package/types/websocket.d.ts.map +1 -0
- package/.github/workflows/node.js.yml +0 -24
- package/.jsdoc.json +0 -18
- package/.vscode/launch.json +0 -17
- package/array.d.ts +0 -30
- package/array.d.ts.map +0 -1
- package/array.test.d.ts +0 -13
- package/array.test.d.ts.map +0 -1
- package/bin/0ecdsa-generate-keypair.d.ts +0 -3
- package/bin/0ecdsa-generate-keypair.d.ts.map +0 -1
- package/bin/0serve.d.ts +0 -3
- package/bin/0serve.d.ts.map +0 -1
- package/bin/gendocs.d.ts +0 -3
- package/bin/gendocs.d.ts.map +0 -1
- package/bin/gentesthtml.d.ts +0 -3
- package/bin/gentesthtml.d.ts.map +0 -1
- package/binary.d.ts +0 -87
- package/binary.d.ts.map +0 -1
- package/binary.test.d.ts +0 -4
- package/binary.test.d.ts.map +0 -1
- package/broadcastchannel.d.ts.map +0 -1
- package/broadcastchannel.test.d.ts +0 -3
- package/broadcastchannel.test.d.ts.map +0 -1
- package/buffer.d.ts.map +0 -1
- package/buffer.test.d.ts +0 -6
- package/buffer.test.d.ts.map +0 -1
- package/cache.d.ts.map +0 -1
- package/cache.test.d.ts +0 -3
- package/cache.test.d.ts.map +0 -1
- package/component.d.ts.map +0 -1
- package/conditions.d.ts.map +0 -1
- package/coverage/tmp/coverage-54474-1766470859038-0.json +0 -1
- package/crypto/aes-gcm.d.ts +0 -17
- package/crypto/aes-gcm.d.ts.map +0 -1
- package/crypto/common.d.ts +0 -3
- package/crypto/common.d.ts.map +0 -1
- package/crypto/ecdsa.d.ts +0 -17
- package/crypto/ecdsa.d.ts.map +0 -1
- package/crypto/jwt.d.ts +0 -10
- package/crypto/jwt.d.ts.map +0 -1
- package/crypto/rsa-oaep.d.ts +0 -13
- package/crypto/rsa-oaep.d.ts.map +0 -1
- package/crypto.test.d.ts +0 -9
- package/crypto.test.d.ts.map +0 -1
- package/decoding.d.ts.map +0 -1
- package/delta/binding.d.ts +0 -107
- package/delta/binding.d.ts.map +0 -1
- package/delta/binding.test.d.ts +0 -5
- package/delta/binding.test.d.ts.map +0 -1
- package/delta/delta-pitch.test.d.ts +0 -5
- package/delta/delta-pitch.test.d.ts.map +0 -1
- package/delta/delta.d.ts +0 -1008
- package/delta/delta.d.ts.map +0 -1
- package/delta/delta.test.d.ts +0 -28
- package/delta/delta.test.d.ts.map +0 -1
- package/delta/t3.test.d.ts +0 -19
- package/delta/t3.test.d.ts.map +0 -1
- package/deno.json +0 -12
- package/deno.lock +0 -122
- package/diff/patience.d.ts +0 -16
- package/diff/patience.d.ts.map +0 -1
- package/diff/patience.test.d.ts +0 -4
- package/diff/patience.test.d.ts.map +0 -1
- package/diff.d.ts.map +0 -1
- package/diff.test.d.ts +0 -6
- package/diff.test.d.ts.map +0 -1
- package/dist/aes-gcm.cjs +0 -171
- package/dist/aes-gcm.cjs.map +0 -1
- package/dist/array-78849c95.cjs +0 -260
- package/dist/array-78849c95.cjs.map +0 -1
- package/dist/array.cjs +0 -26
- package/dist/array.cjs.map +0 -1
- package/dist/array.d.ts.map +0 -1
- package/dist/array.test.d.ts +0 -13
- package/dist/array.test.d.ts.map +0 -1
- package/dist/bin/0ecdsa-generate-keypair.d.ts +0 -3
- package/dist/bin/0ecdsa-generate-keypair.d.ts.map +0 -1
- package/dist/bin/0serve.d.ts +0 -3
- package/dist/bin/0serve.d.ts.map +0 -1
- package/dist/bin/gendocs.d.ts +0 -3
- package/dist/bin/gendocs.d.ts.map +0 -1
- package/dist/bin/gentesthtml.d.ts +0 -3
- package/dist/bin/gentesthtml.d.ts.map +0 -1
- package/dist/binary-ac8e39e2.cjs +0 -229
- package/dist/binary-ac8e39e2.cjs.map +0 -1
- package/dist/binary.cjs +0 -74
- package/dist/binary.cjs.map +0 -1
- package/dist/binary.d.ts.map +0 -1
- package/dist/binary.test.d.ts +0 -4
- package/dist/binary.test.d.ts.map +0 -1
- package/dist/binding.cjs +0 -484
- package/dist/binding.cjs.map +0 -1
- package/dist/broadcastchannel-aca4f606.cjs +0 -128
- package/dist/broadcastchannel-aca4f606.cjs.map +0 -1
- package/dist/broadcastchannel.cjs +0 -29
- package/dist/broadcastchannel.cjs.map +0 -1
- package/dist/broadcastchannel.d.ts +0 -8
- package/dist/broadcastchannel.d.ts.map +0 -1
- package/dist/broadcastchannel.test.d.ts +0 -3
- package/dist/broadcastchannel.test.d.ts.map +0 -1
- package/dist/buffer-3e750729.cjs +0 -198
- package/dist/buffer-3e750729.cjs.map +0 -1
- package/dist/buffer.cjs +0 -38
- package/dist/buffer.cjs.map +0 -1
- package/dist/buffer.d.ts +0 -22
- package/dist/buffer.d.ts.map +0 -1
- package/dist/buffer.test.d.ts +0 -6
- package/dist/buffer.test.d.ts.map +0 -1
- package/dist/cache.cjs +0 -223
- package/dist/cache.cjs.map +0 -1
- package/dist/cache.d.ts +0 -52
- package/dist/cache.d.ts.map +0 -1
- package/dist/cache.test.d.ts +0 -3
- package/dist/cache.test.d.ts.map +0 -1
- package/dist/common.cjs +0 -47
- package/dist/common.cjs.map +0 -1
- package/dist/component.cjs +0 -437
- package/dist/component.cjs.map +0 -1
- package/dist/component.d.ts +0 -86
- package/dist/component.d.ts.map +0 -1
- package/dist/conditions-f5c0c102.cjs +0 -24
- package/dist/conditions-f5c0c102.cjs.map +0 -1
- package/dist/conditions.cjs +0 -10
- package/dist/conditions.cjs.map +0 -1
- package/dist/conditions.d.ts +0 -2
- package/dist/conditions.d.ts.map +0 -1
- package/dist/crypto/aes-gcm.d.ts +0 -17
- package/dist/crypto/aes-gcm.d.ts.map +0 -1
- package/dist/crypto/common.d.ts +0 -3
- package/dist/crypto/common.d.ts.map +0 -1
- package/dist/crypto/ecdsa.d.ts +0 -17
- package/dist/crypto/ecdsa.d.ts.map +0 -1
- package/dist/crypto/jwt.d.ts +0 -10
- package/dist/crypto/jwt.d.ts.map +0 -1
- package/dist/crypto/rsa-oaep.d.ts +0 -13
- package/dist/crypto/rsa-oaep.d.ts.map +0 -1
- package/dist/crypto.test.d.ts +0 -9
- package/dist/crypto.test.d.ts.map +0 -1
- package/dist/decoding-76e75827.cjs +0 -795
- package/dist/decoding-76e75827.cjs.map +0 -1
- package/dist/decoding.cjs +0 -55
- package/dist/decoding.cjs.map +0 -1
- package/dist/decoding.d.ts +0 -165
- package/dist/decoding.d.ts.map +0 -1
- package/dist/delta/binding.d.ts +0 -107
- package/dist/delta/binding.d.ts.map +0 -1
- package/dist/delta/binding.test.d.ts +0 -5
- package/dist/delta/binding.test.d.ts.map +0 -1
- package/dist/delta/delta-pitch.test.d.ts +0 -5
- package/dist/delta/delta-pitch.test.d.ts.map +0 -1
- package/dist/delta/delta.d.ts +0 -1008
- package/dist/delta/delta.d.ts.map +0 -1
- package/dist/delta/delta.test.d.ts +0 -28
- package/dist/delta/delta.test.d.ts.map +0 -1
- package/dist/delta/t3.test.d.ts +0 -19
- package/dist/delta/t3.test.d.ts.map +0 -1
- package/dist/delta.cjs +0 -2409
- package/dist/delta.cjs.map +0 -1
- package/dist/diff/patience.d.ts +0 -16
- package/dist/diff/patience.d.ts.map +0 -1
- package/dist/diff/patience.test.d.ts +0 -4
- package/dist/diff/patience.test.d.ts.map +0 -1
- package/dist/diff-9d236524.cjs +0 -162
- package/dist/diff-9d236524.cjs.map +0 -1
- package/dist/diff.cjs +0 -18
- package/dist/diff.cjs.map +0 -1
- package/dist/diff.d.ts +0 -36
- package/dist/diff.d.ts.map +0 -1
- package/dist/diff.test.d.ts +0 -6
- package/dist/diff.test.d.ts.map +0 -1
- package/dist/dom-7e625b09.cjs +0 -371
- package/dist/dom-7e625b09.cjs.map +0 -1
- package/dist/dom.cjs +0 -71
- package/dist/dom.cjs.map +0 -1
- package/dist/dom.d.ts.map +0 -1
- package/dist/ecdsa.cjs +0 -130
- package/dist/ecdsa.cjs.map +0 -1
- package/dist/encoding-1a745c43.cjs +0 -1025
- package/dist/encoding-1a745c43.cjs.map +0 -1
- package/dist/encoding.cjs +0 -54
- package/dist/encoding.cjs.map +0 -1
- package/dist/encoding.d.ts.map +0 -1
- package/dist/encoding.test.d.ts +0 -50
- package/dist/encoding.test.d.ts.map +0 -1
- package/dist/environment-1c97264d.cjs +0 -180
- package/dist/environment-1c97264d.cjs.map +0 -1
- package/dist/environment.cjs +0 -29
- package/dist/environment.cjs.map +0 -1
- package/dist/environment.d.ts +0 -19
- package/dist/environment.d.ts.map +0 -1
- package/dist/equality.cjs +0 -34
- package/dist/equality.cjs.map +0 -1
- package/dist/error-0c1f634f.cjs +0 -53
- package/dist/error-0c1f634f.cjs.map +0 -1
- package/dist/error.cjs +0 -13
- package/dist/error.cjs.map +0 -1
- package/dist/error.d.ts.map +0 -1
- package/dist/eventloop-a0168106.cjs +0 -151
- package/dist/eventloop-a0168106.cjs.map +0 -1
- package/dist/eventloop.cjs +0 -19
- package/dist/eventloop.cjs.map +0 -1
- package/dist/eventloop.d.ts.map +0 -1
- package/dist/eventloop.test.d.ts +0 -10
- package/dist/eventloop.test.d.ts.map +0 -1
- package/dist/fingerprint.cjs +0 -44
- package/dist/fingerprint.cjs.map +0 -1
- package/dist/function-314580f7.cjs +0 -223
- package/dist/function-314580f7.cjs.map +0 -1
- package/dist/function.cjs +0 -26
- package/dist/function.cjs.map +0 -1
- package/dist/function.d.ts +0 -19
- package/dist/function.d.ts.map +0 -1
- package/dist/function.test.d.ts +0 -5
- package/dist/function.test.d.ts.map +0 -1
- package/dist/hash/rabin-gf2-polynomial.d.ts +0 -45
- package/dist/hash/rabin-gf2-polynomial.d.ts.map +0 -1
- package/dist/hash/rabin-uncached.d.ts +0 -29
- package/dist/hash/rabin-uncached.d.ts.map +0 -1
- package/dist/hash/rabin.d.ts +0 -27
- package/dist/hash/rabin.d.ts.map +0 -1
- package/dist/hash/rabin.test.d.ts +0 -8
- package/dist/hash/rabin.test.d.ts.map +0 -1
- package/dist/hash/sha256.d.ts +0 -2
- package/dist/hash/sha256.d.ts.map +0 -1
- package/dist/hash/sha256.node.d.ts +0 -2
- package/dist/hash/sha256.node.d.ts.map +0 -1
- package/dist/hash/sha256.test.d.ts +0 -7
- package/dist/hash/sha256.test.d.ts.map +0 -1
- package/dist/index.cjs +0 -99
- package/dist/index.cjs.map +0 -1
- package/dist/index.d.ts +0 -35
- package/dist/index.d.ts.map +0 -1
- package/dist/indexeddb-46d1e737.cjs +0 -311
- package/dist/indexeddb-46d1e737.cjs.map +0 -1
- package/dist/indexeddb.cjs +0 -37
- package/dist/indexeddb.cjs.map +0 -1
- package/dist/indexeddb.d.ts.map +0 -1
- package/dist/indexeddb.test.d.ts +0 -3
- package/dist/indexeddb.test.d.ts.map +0 -1
- package/dist/indexeddbV2.cjs +0 -288
- package/dist/indexeddbV2.cjs.map +0 -1
- package/dist/indexeddbV2.d.ts.map +0 -1
- package/dist/indexeddbV2.test.d.ts +0 -3
- package/dist/indexeddbV2.test.d.ts.map +0 -1
- package/dist/isomorphic.cjs +0 -17
- package/dist/isomorphic.cjs.map +0 -1
- package/dist/iterator-9fc627c1.cjs +0 -78
- package/dist/iterator-9fc627c1.cjs.map +0 -1
- package/dist/iterator.cjs +0 -13
- package/dist/iterator.cjs.map +0 -1
- package/dist/iterator.d.ts.map +0 -1
- package/dist/json-092190a1.cjs +0 -34
- package/dist/json-092190a1.cjs.map +0 -1
- package/dist/json.cjs +0 -11
- package/dist/json.cjs.map +0 -1
- package/dist/json.d.ts.map +0 -1
- package/dist/jwt.cjs +0 -96
- package/dist/jwt.cjs.map +0 -1
- package/dist/list.cjs +0 -266
- package/dist/list.cjs.map +0 -1
- package/dist/list.d.ts.map +0 -1
- package/dist/list.test.d.ts +0 -6
- package/dist/list.test.d.ts.map +0 -1
- package/dist/logging.cjs +0 -428
- package/dist/logging.cjs.map +0 -1
- package/dist/logging.common.cjs +0 -132
- package/dist/logging.common.cjs.map +0 -1
- package/dist/logging.common.d.ts.map +0 -1
- package/dist/logging.d.ts.map +0 -1
- package/dist/logging.node.cjs +0 -203
- package/dist/logging.node.cjs.map +0 -1
- package/dist/logging.node.d.ts.map +0 -1
- package/dist/logging.test.d.ts +0 -3
- package/dist/logging.test.d.ts.map +0 -1
- package/dist/map-24d263c0.cjs +0 -139
- package/dist/map-24d263c0.cjs.map +0 -1
- package/dist/map.cjs +0 -15
- package/dist/map.cjs.map +0 -1
- package/dist/map.d.ts.map +0 -1
- package/dist/map.test.d.ts +0 -4
- package/dist/map.test.d.ts.map +0 -1
- package/dist/math-96d5e8c4.cjs +0 -103
- package/dist/math-96d5e8c4.cjs.map +0 -1
- package/dist/math.cjs +0 -26
- package/dist/math.cjs.map +0 -1
- package/dist/math.d.ts.map +0 -1
- package/dist/math.test.d.ts +0 -3
- package/dist/math.test.d.ts.map +0 -1
- package/dist/metric.cjs +0 -83
- package/dist/metric.cjs.map +0 -1
- package/dist/metric.d.ts.map +0 -1
- package/dist/metric.test.d.ts +0 -3
- package/dist/metric.test.d.ts.map +0 -1
- package/dist/mutex-63f09c81.cjs +0 -54
- package/dist/mutex-63f09c81.cjs.map +0 -1
- package/dist/mutex.cjs +0 -10
- package/dist/mutex.cjs.map +0 -1
- package/dist/mutex.d.ts.map +0 -1
- package/dist/mutex.test.d.ts +0 -3
- package/dist/mutex.test.d.ts.map +0 -1
- package/dist/number-1fb57bba.cjs +0 -64
- package/dist/number-1fb57bba.cjs.map +0 -1
- package/dist/number.cjs +0 -20
- package/dist/number.cjs.map +0 -1
- package/dist/number.d.ts +0 -10
- package/dist/number.d.ts.map +0 -1
- package/dist/number.test.d.ts +0 -4
- package/dist/number.test.d.ts.map +0 -1
- package/dist/object-c0c9435b.cjs +0 -212
- package/dist/object-c0c9435b.cjs.map +0 -1
- package/dist/object.cjs +0 -27
- package/dist/object.cjs.map +0 -1
- package/dist/object.d.ts.map +0 -1
- package/dist/object.test.d.ts +0 -6
- package/dist/object.test.d.ts.map +0 -1
- package/dist/observable.cjs +0 -169
- package/dist/observable.cjs.map +0 -1
- package/dist/observable.d.ts.map +0 -1
- package/dist/observable.test.d.ts +0 -3
- package/dist/observable.test.d.ts.map +0 -1
- package/dist/pair-ab022bc3.cjs +0 -69
- package/dist/pair-ab022bc3.cjs.map +0 -1
- package/dist/pair.cjs +0 -14
- package/dist/pair.cjs.map +0 -1
- package/dist/pair.d.ts.map +0 -1
- package/dist/pair.test.d.ts +0 -3
- package/dist/pair.test.d.ts.map +0 -1
- package/dist/patience.cjs +0 -236
- package/dist/patience.cjs.map +0 -1
- package/dist/performance.cjs +0 -14
- package/dist/performance.cjs.map +0 -1
- package/dist/performance.d.ts.map +0 -1
- package/dist/performance.node.cjs +0 -36
- package/dist/performance.node.cjs.map +0 -1
- package/dist/performance.node.d.ts.map +0 -1
- package/dist/pledge.cjs +0 -308
- package/dist/pledge.cjs.map +0 -1
- package/dist/pledge.d.ts.map +0 -1
- package/dist/pledge.test.d.ts +0 -6
- package/dist/pledge.test.d.ts.map +0 -1
- package/dist/prng/Mt19937.d.ts +0 -29
- package/dist/prng/Mt19937.d.ts.map +0 -1
- package/dist/prng/Xoroshiro128plus.d.ts +0 -27
- package/dist/prng/Xoroshiro128plus.d.ts.map +0 -1
- package/dist/prng/Xorshift32.d.ts +0 -21
- package/dist/prng/Xorshift32.d.ts.map +0 -1
- package/dist/prng-37d48618.cjs +0 -387
- package/dist/prng-37d48618.cjs.map +0 -1
- package/dist/prng.cjs +0 -44
- package/dist/prng.cjs.map +0 -1
- package/dist/prng.d.ts.map +0 -1
- package/dist/prng.test.d.ts +0 -6
- package/dist/prng.test.d.ts.map +0 -1
- package/dist/promise-cda7b9bb.cjs +0 -145
- package/dist/promise-cda7b9bb.cjs.map +0 -1
- package/dist/promise.cjs +0 -22
- package/dist/promise.cjs.map +0 -1
- package/dist/promise.d.ts.map +0 -1
- package/dist/promise.test.d.ts +0 -5
- package/dist/promise.test.d.ts.map +0 -1
- package/dist/queue.cjs +0 -97
- package/dist/queue.cjs.map +0 -1
- package/dist/queue.d.ts.map +0 -1
- package/dist/queue.test.d.ts +0 -3
- package/dist/queue.test.d.ts.map +0 -1
- package/dist/rabin-gf2-polynomial.cjs +0 -440
- package/dist/rabin-gf2-polynomial.cjs.map +0 -1
- package/dist/rabin-uncached.cjs +0 -90
- package/dist/rabin-uncached.cjs.map +0 -1
- package/dist/rabin.cjs +0 -128
- package/dist/rabin.cjs.map +0 -1
- package/dist/random.cjs +0 -48
- package/dist/random.cjs.map +0 -1
- package/dist/random.d.ts.map +0 -1
- package/dist/random.test.d.ts +0 -7
- package/dist/random.test.d.ts.map +0 -1
- package/dist/rollup.config.d.ts +0 -13
- package/dist/rollup.config.d.ts.map +0 -1
- package/dist/rsa-oaep.cjs +0 -112
- package/dist/rsa-oaep.cjs.map +0 -1
- package/dist/schema.cjs +0 -1223
- package/dist/schema.cjs.map +0 -1
- package/dist/schema.d.ts +0 -595
- package/dist/schema.d.ts.map +0 -1
- package/dist/schema.test.d.ts +0 -15
- package/dist/schema.test.d.ts.map +0 -1
- package/dist/set-5b47859e.cjs +0 -45
- package/dist/set-5b47859e.cjs.map +0 -1
- package/dist/set.cjs +0 -13
- package/dist/set.cjs.map +0 -1
- package/dist/set.d.ts.map +0 -1
- package/dist/set.test.d.ts +0 -3
- package/dist/set.test.d.ts.map +0 -1
- package/dist/sha256.cjs +0 -183
- package/dist/sha256.cjs.map +0 -1
- package/dist/sha256.node.cjs +0 -17
- package/dist/sha256.node.cjs.map +0 -1
- package/dist/sort-812cc211.cjs +0 -103
- package/dist/sort-812cc211.cjs.map +0 -1
- package/dist/sort.cjs +0 -13
- package/dist/sort.cjs.map +0 -1
- package/dist/sort.d.ts.map +0 -1
- package/dist/sort.test.d.ts +0 -7
- package/dist/sort.test.d.ts.map +0 -1
- package/dist/statistics-65f6114b.cjs +0 -32
- package/dist/statistics-65f6114b.cjs.map +0 -1
- package/dist/statistics.cjs +0 -12
- package/dist/statistics.cjs.map +0 -1
- package/dist/statistics.d.ts.map +0 -1
- package/dist/statistics.test.d.ts +0 -3
- package/dist/statistics.test.d.ts.map +0 -1
- package/dist/storage.cjs +0 -81
- package/dist/storage.cjs.map +0 -1
- package/dist/storage.d.ts.map +0 -1
- package/dist/storage.test.d.ts +0 -3
- package/dist/storage.test.d.ts.map +0 -1
- package/dist/string-fddc5f8b.cjs +0 -209
- package/dist/string-fddc5f8b.cjs.map +0 -1
- package/dist/string.cjs +0 -32
- package/dist/string.cjs.map +0 -1
- package/dist/string.d.ts +0 -28
- package/dist/string.d.ts.map +0 -1
- package/dist/string.test.d.ts +0 -9
- package/dist/string.test.d.ts.map +0 -1
- package/dist/symbol-9c439012.cjs +0 -29
- package/dist/symbol-9c439012.cjs.map +0 -1
- package/dist/symbol.cjs +0 -11
- package/dist/symbol.cjs.map +0 -1
- package/dist/symbol.d.ts.map +0 -1
- package/dist/symbol.test.d.ts +0 -3
- package/dist/symbol.test.d.ts.map +0 -1
- package/dist/testing.cjs +0 -709
- package/dist/testing.cjs.map +0 -1
- package/dist/testing.d.ts +0 -64
- package/dist/testing.d.ts.map +0 -1
- package/dist/testing.test.d.ts +0 -9
- package/dist/testing.test.d.ts.map +0 -1
- package/dist/time-d8438852.cjs +0 -63
- package/dist/time-d8438852.cjs.map +0 -1
- package/dist/time.cjs +0 -14
- package/dist/time.cjs.map +0 -1
- package/dist/time.d.ts.map +0 -1
- package/dist/time.test.d.ts +0 -4
- package/dist/time.test.d.ts.map +0 -1
- package/dist/trait/equality.d.ts +0 -6
- package/dist/trait/equality.d.ts.map +0 -1
- package/dist/trait/fingerprint.d.ts +0 -13
- package/dist/trait/fingerprint.d.ts.map +0 -1
- package/dist/trait/traits.d.ts +0 -3
- package/dist/trait/traits.d.ts.map +0 -1
- package/dist/trait/traits.test.d.ts +0 -5
- package/dist/trait/traits.test.d.ts.map +0 -1
- package/dist/traits.cjs +0 -31
- package/dist/traits.cjs.map +0 -1
- package/dist/tree-9f3c8837.cjs +0 -557
- package/dist/tree-9f3c8837.cjs.map +0 -1
- package/dist/tree.cjs +0 -10
- package/dist/tree.cjs.map +0 -1
- package/dist/tree.d.ts.map +0 -1
- package/dist/tree.test.d.ts +0 -2
- package/dist/tree.test.d.ts.map +0 -1
- package/dist/url.cjs +0 -46
- package/dist/url.cjs.map +0 -1
- package/dist/url.d.ts.map +0 -1
- package/dist/url.test.d.ts +0 -3
- package/dist/url.test.d.ts.map +0 -1
- package/dist/webcrypto.cjs +0 -12
- package/dist/webcrypto.cjs.map +0 -1
- package/dist/webcrypto.d.ts.map +0 -1
- package/dist/webcrypto.deno.cjs +0 -12
- package/dist/webcrypto.deno.cjs.map +0 -1
- package/dist/webcrypto.deno.d.ts.map +0 -1
- package/dist/webcrypto.node.cjs +0 -12
- package/dist/webcrypto.node.cjs.map +0 -1
- package/dist/webcrypto.node.d.ts.map +0 -1
- package/dist/webcrypto.react-native.cjs +0 -20
- package/dist/webcrypto.react-native.cjs.map +0 -1
- package/dist/webcrypto.react-native.d.ts.map +0 -1
- package/dist/websocket-b073d0fc.cjs +0 -157
- package/dist/websocket-b073d0fc.cjs.map +0 -1
- package/dist/websocket.cjs +0 -17
- package/dist/websocket.cjs.map +0 -1
- package/dist/websocket.d.ts.map +0 -1
- package/dom.d.ts +0 -60
- package/dom.d.ts.map +0 -1
- package/encoding.d.ts +0 -235
- package/encoding.d.ts.map +0 -1
- package/encoding.test.d.ts +0 -50
- package/encoding.test.d.ts.map +0 -1
- package/environment.d.ts.map +0 -1
- package/error.d.ts +0 -5
- package/error.d.ts.map +0 -1
- package/eventloop.d.ts +0 -16
- package/eventloop.d.ts.map +0 -1
- package/eventloop.test.d.ts +0 -10
- package/eventloop.test.d.ts.map +0 -1
- package/function.d.ts.map +0 -1
- package/function.test.d.ts +0 -5
- package/function.test.d.ts.map +0 -1
- package/hash/rabin-gf2-polynomial.d.ts +0 -45
- package/hash/rabin-gf2-polynomial.d.ts.map +0 -1
- package/hash/rabin-uncached.d.ts +0 -29
- package/hash/rabin-uncached.d.ts.map +0 -1
- package/hash/rabin.d.ts +0 -27
- package/hash/rabin.d.ts.map +0 -1
- package/hash/rabin.test.d.ts +0 -8
- package/hash/rabin.test.d.ts.map +0 -1
- package/hash/sha256.d.ts +0 -2
- package/hash/sha256.d.ts.map +0 -1
- package/hash/sha256.node.d.ts +0 -2
- package/hash/sha256.node.d.ts.map +0 -1
- package/hash/sha256.test.d.ts +0 -7
- package/hash/sha256.test.d.ts.map +0 -1
- package/index.d.ts +0 -35
- package/index.d.ts.map +0 -1
- package/index.js +0 -82
- package/indexeddb.d.ts +0 -34
- package/indexeddb.d.ts.map +0 -1
- package/indexeddb.test.d.ts +0 -3
- package/indexeddb.test.d.ts.map +0 -1
- package/indexeddbV2.d.ts +0 -35
- package/indexeddbV2.d.ts.map +0 -1
- package/indexeddbV2.test.d.ts +0 -3
- package/indexeddbV2.test.d.ts.map +0 -1
- package/isomorphic.js +0 -10
- package/iterator.d.ts +0 -5
- package/iterator.d.ts.map +0 -1
- package/json.d.ts +0 -23
- package/json.d.ts.map +0 -1
- package/list.d.ts +0 -55
- package/list.d.ts.map +0 -1
- package/list.test.d.ts +0 -6
- package/list.test.d.ts.map +0 -1
- package/logging.common.d.ts +0 -12
- package/logging.common.d.ts.map +0 -1
- package/logging.d.ts +0 -55
- package/logging.d.ts.map +0 -1
- package/logging.node.d.ts +0 -14
- package/logging.node.d.ts.map +0 -1
- package/logging.test.d.ts +0 -3
- package/logging.test.d.ts.map +0 -1
- package/map.d.ts +0 -8
- package/map.d.ts.map +0 -1
- package/map.test.d.ts +0 -4
- package/map.test.d.ts.map +0 -1
- package/math.d.ts +0 -23
- package/math.d.ts.map +0 -1
- package/math.test.d.ts +0 -3
- package/math.test.d.ts.map +0 -1
- package/metric.d.ts +0 -25
- package/metric.d.ts.map +0 -1
- package/metric.test.d.ts +0 -3
- package/metric.test.d.ts.map +0 -1
- package/mutex.d.ts +0 -3
- package/mutex.d.ts.map +0 -1
- package/mutex.test.d.ts +0 -3
- package/mutex.test.d.ts.map +0 -1
- package/number.d.ts.map +0 -1
- package/number.test.d.ts +0 -4
- package/number.test.d.ts.map +0 -1
- package/object.d.ts +0 -72
- package/object.d.ts.map +0 -1
- package/object.test.d.ts +0 -6
- package/object.test.d.ts.map +0 -1
- package/observable.d.ts +0 -86
- package/observable.d.ts.map +0 -1
- package/observable.test.d.ts +0 -3
- package/observable.test.d.ts.map +0 -1
- package/pair.d.ts +0 -22
- package/pair.d.ts.map +0 -1
- package/pair.test.d.ts +0 -3
- package/pair.test.d.ts.map +0 -1
- package/performance.d.ts +0 -4
- package/performance.d.ts.map +0 -1
- package/performance.node.d.ts +0 -14
- package/performance.node.d.ts.map +0 -1
- package/pledge.d.ts +0 -68
- package/pledge.d.ts.map +0 -1
- package/pledge.test.d.ts +0 -6
- package/pledge.test.d.ts.map +0 -1
- package/prng/Mt19937.d.ts +0 -29
- package/prng/Mt19937.d.ts.map +0 -1
- package/prng/Xoroshiro128plus.d.ts +0 -27
- package/prng/Xoroshiro128plus.d.ts.map +0 -1
- package/prng/Xorshift32.d.ts +0 -21
- package/prng/Xorshift32.d.ts.map +0 -1
- package/prng.d.ts +0 -44
- package/prng.d.ts.map +0 -1
- package/prng.test.d.ts +0 -6
- package/prng.test.d.ts.map +0 -1
- package/promise.d.ts +0 -22
- package/promise.d.ts.map +0 -1
- package/promise.test.d.ts +0 -5
- package/promise.test.d.ts.map +0 -1
- package/queue.d.ts +0 -34
- package/queue.d.ts.map +0 -1
- package/queue.test.d.ts +0 -3
- package/queue.test.d.ts.map +0 -1
- package/random.d.ts +0 -6
- package/random.d.ts.map +0 -1
- package/random.test.d.ts +0 -7
- package/random.test.d.ts.map +0 -1
- package/rollup.config.d.ts +0 -13
- package/rollup.config.d.ts.map +0 -1
- package/schema.d.ts.map +0 -1
- package/schema.test.d.ts +0 -15
- package/schema.test.d.ts.map +0 -1
- package/set.d.ts +0 -5
- package/set.d.ts.map +0 -1
- package/set.test.d.ts +0 -3
- package/set.test.d.ts.map +0 -1
- package/sort.d.ts +0 -4
- package/sort.d.ts.map +0 -1
- package/sort.test.d.ts +0 -7
- package/sort.test.d.ts.map +0 -1
- package/statistics.d.ts +0 -3
- package/statistics.d.ts.map +0 -1
- package/statistics.test.d.ts +0 -3
- package/statistics.test.d.ts.map +0 -1
- package/storage.d.ts +0 -15
- package/storage.d.ts.map +0 -1
- package/storage.test.d.ts +0 -3
- package/storage.test.d.ts.map +0 -1
- package/string.d.ts.map +0 -1
- package/string.test.d.ts +0 -9
- package/string.test.d.ts.map +0 -1
- package/symbol.d.ts +0 -11
- package/symbol.d.ts.map +0 -1
- package/symbol.test.d.ts +0 -3
- package/symbol.test.d.ts.map +0 -1
- package/test.d.ts +0 -2
- package/test.d.ts.map +0 -1
- package/test.html +0 -168
- package/test.js +0 -104
- package/testing.d.ts.map +0 -1
- package/testing.test.d.ts +0 -9
- package/testing.test.d.ts.map +0 -1
- package/time.d.ts +0 -9
- package/time.d.ts.map +0 -1
- package/time.test.d.ts +0 -4
- package/time.test.d.ts.map +0 -1
- package/trait/equality.d.ts +0 -6
- package/trait/equality.d.ts.map +0 -1
- package/trait/fingerprint.d.ts +0 -13
- package/trait/fingerprint.d.ts.map +0 -1
- package/trait/traits.d.ts +0 -3
- package/trait/traits.d.ts.map +0 -1
- package/trait/traits.test.d.ts +0 -5
- package/trait/traits.test.d.ts.map +0 -1
- package/tree.d.ts +0 -96
- package/tree.d.ts.map +0 -1
- package/tree.test.d.ts +0 -2
- package/tree.test.d.ts.map +0 -1
- package/url.d.ts +0 -7
- package/url.d.ts.map +0 -1
- package/url.test.d.ts +0 -3
- package/url.test.d.ts.map +0 -1
- package/webcrypto.d.ts +0 -3
- package/webcrypto.d.ts.map +0 -1
- package/webcrypto.deno.d.ts +0 -3
- package/webcrypto.deno.d.ts.map +0 -1
- package/webcrypto.node.d.ts +0 -3
- package/webcrypto.node.d.ts.map +0 -1
- package/webcrypto.react-native.d.ts +0 -3
- package/webcrypto.react-native.d.ts.map +0 -1
- package/websocket.d.ts +0 -38
- package/websocket.d.ts.map +0 -1
- /package/{bin → src/bin}/0ecdsa-generate-keypair.js +0 -0
- /package/{bin → src/bin}/0serve.js +0 -0
- /package/{bin → src/bin}/gendocs.js +0 -0
- /package/{bin → src/bin}/gentesthtml.js +0 -0
- /package/{broadcastchannel.js → src/broadcastchannel.js} +0 -0
- /package/{buffer.js → src/buffer.js} +0 -0
- /package/{cache.js → src/cache.js} +0 -0
- /package/{component.js → src/component.js} +0 -0
- /package/{conditions.js → src/conditions.js} +0 -0
- /package/{crypto → src/crypto}/aes-gcm.js +0 -0
- /package/{crypto → src/crypto}/common.js +0 -0
- /package/{crypto → src/crypto}/ecdsa.js +0 -0
- /package/{crypto → src/crypto}/jwt.js +0 -0
- /package/{crypto → src/crypto}/rsa-oaep.js +0 -0
- /package/{decoding.js → src/decoding.js} +0 -0
- /package/{delta → src/delta}/binding.js +0 -0
- /package/{delta → src/delta}/readme.md +0 -0
- /package/{diff → src/diff}/patience.js +0 -0
- /package/{diff.js → src/diff.js} +0 -0
- /package/{dom.js → src/dom.js} +0 -0
- /package/{encoding.js → src/encoding.js} +0 -0
- /package/{error.js → src/error.js} +0 -0
- /package/{eventloop.js → src/eventloop.js} +0 -0
- /package/{function.js → src/function.js} +0 -0
- /package/{hash → src/hash}/rabin-gf2-polynomial.js +0 -0
- /package/{hash → src/hash}/rabin-uncached.js +0 -0
- /package/{hash → src/hash}/sha256.js +0 -0
- /package/{hash → src/hash}/sha256.node.js +0 -0
- /package/{indexeddb.js → src/indexeddb.js} +0 -0
- /package/{indexeddbV2.js → src/indexeddbV2.js} +0 -0
- /package/{iterator.js → src/iterator.js} +0 -0
- /package/{json.js → src/json.js} +0 -0
- /package/{list.js → src/list.js} +0 -0
- /package/{logging.common.js → src/logging.common.js} +0 -0
- /package/{logging.js → src/logging.js} +0 -0
- /package/{logging.node.js → src/logging.node.js} +0 -0
- /package/{map.js → src/map.js} +0 -0
- /package/{math.js → src/math.js} +0 -0
- /package/{metric.js → src/metric.js} +0 -0
- /package/{mutex.js → src/mutex.js} +0 -0
- /package/{number.js → src/number.js} +0 -0
- /package/{object.js → src/object.js} +0 -0
- /package/{observable.js → src/observable.js} +0 -0
- /package/{pair.js → src/pair.js} +0 -0
- /package/{performance.js → src/performance.js} +0 -0
- /package/{performance.node.js → src/performance.node.js} +0 -0
- /package/{pledge.js → src/pledge.js} +0 -0
- /package/{prng → src/prng}/Mt19937.js +0 -0
- /package/{prng → src/prng}/Xoroshiro128plus.js +0 -0
- /package/{prng → src/prng}/Xorshift32.js +0 -0
- /package/{prng.js → src/prng.js} +0 -0
- /package/{promise.js → src/promise.js} +0 -0
- /package/{queue.js → src/queue.js} +0 -0
- /package/{random.js → src/random.js} +0 -0
- /package/{set.js → src/set.js} +0 -0
- /package/{sort.js → src/sort.js} +0 -0
- /package/{statistics.js → src/statistics.js} +0 -0
- /package/{storage.js → src/storage.js} +0 -0
- /package/{symbol.js → src/symbol.js} +0 -0
- /package/{time.js → src/time.js} +0 -0
- /package/{trait → src/trait}/equality.js +0 -0
- /package/{trait → src/trait}/fingerprint.js +0 -0
- /package/{trait → src/trait}/traits.js +0 -0
- /package/{tree.js → src/tree.js} +0 -0
- /package/{url.js → src/url.js} +0 -0
- /package/{webcrypto.deno.js → src/webcrypto.deno.js} +0 -0
- /package/{webcrypto.js → src/webcrypto.js} +0 -0
- /package/{webcrypto.node.js → src/webcrypto.node.js} +0 -0
- /package/{webcrypto.react-native.js → src/webcrypto.react-native.js} +0 -0
- /package/{websocket.js → src/websocket.js} +0 -0
- /package/{broadcastchannel.d.ts → types/broadcastchannel.d.ts} +0 -0
- /package/{buffer.d.ts → types/buffer.d.ts} +0 -0
- /package/{cache.d.ts → types/cache.d.ts} +0 -0
- /package/{component.d.ts → types/component.d.ts} +0 -0
- /package/{conditions.d.ts → types/conditions.d.ts} +0 -0
- /package/{decoding.d.ts → types/decoding.d.ts} +0 -0
- /package/{diff.d.ts → types/diff.d.ts} +0 -0
- /package/{dist → types}/dom.d.ts +0 -0
- /package/{dist → types}/encoding.d.ts +0 -0
- /package/{dist → types}/error.d.ts +0 -0
- /package/{dist → types}/eventloop.d.ts +0 -0
- /package/{dist → types}/indexeddb.d.ts +0 -0
- /package/{dist → types}/indexeddbV2.d.ts +0 -0
- /package/{dist → types}/iterator.d.ts +0 -0
- /package/{dist → types}/json.d.ts +0 -0
- /package/{dist → types}/list.d.ts +0 -0
- /package/{dist → types}/logging.common.d.ts +0 -0
- /package/{dist → types}/logging.d.ts +0 -0
- /package/{dist → types}/logging.node.d.ts +0 -0
- /package/{dist → types}/map.d.ts +0 -0
- /package/{dist → types}/math.d.ts +0 -0
- /package/{dist → types}/metric.d.ts +0 -0
- /package/{dist → types}/mutex.d.ts +0 -0
- /package/{dist → types}/object.d.ts +0 -0
- /package/{dist → types}/observable.d.ts +0 -0
- /package/{dist → types}/pair.d.ts +0 -0
- /package/{dist → types}/performance.d.ts +0 -0
- /package/{dist → types}/performance.node.d.ts +0 -0
- /package/{dist → types}/pledge.d.ts +0 -0
- /package/{dist → types}/prng.d.ts +0 -0
- /package/{dist → types}/promise.d.ts +0 -0
- /package/{dist → types}/queue.d.ts +0 -0
- /package/{dist → types}/random.d.ts +0 -0
- /package/{dist → types}/set.d.ts +0 -0
- /package/{dist → types}/sort.d.ts +0 -0
- /package/{dist → types}/statistics.d.ts +0 -0
- /package/{dist → types}/storage.d.ts +0 -0
- /package/{dist → types}/symbol.d.ts +0 -0
- /package/{dist → types}/time.d.ts +0 -0
- /package/{dist → types}/tree.d.ts +0 -0
- /package/{dist → types}/url.d.ts +0 -0
- /package/{dist → types}/webcrypto.d.ts +0 -0
- /package/{dist → types}/webcrypto.deno.d.ts +0 -0
- /package/{dist → types}/webcrypto.node.d.ts +0 -0
- /package/{dist → types}/webcrypto.react-native.d.ts +0 -0
- /package/{dist → types}/websocket.d.ts +0 -0
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"promise.test.d.ts","sourceRoot":"","sources":["../promise.test.js"],"names":[],"mappings":"AA6BO,uCAFI,CAAC,CAAC,QAAQ,iBAmBpB;AAKM,mCAFI,CAAC,CAAC,QAAQ,QAapB;AAKM,iCAFI,CAAC,CAAC,QAAQ,iBAapB;mBA7EkB,cAAc"}
|
package/dist/queue.cjs
DELETED
|
@@ -1,97 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
-
|
|
5
|
-
class QueueNode {
|
|
6
|
-
constructor () {
|
|
7
|
-
/**
|
|
8
|
-
* @type {QueueNode|null}
|
|
9
|
-
*/
|
|
10
|
-
this.next = null;
|
|
11
|
-
}
|
|
12
|
-
}
|
|
13
|
-
|
|
14
|
-
/**
|
|
15
|
-
* @template V
|
|
16
|
-
*/
|
|
17
|
-
class QueueValue extends QueueNode {
|
|
18
|
-
/**
|
|
19
|
-
* @param {V} v
|
|
20
|
-
*/
|
|
21
|
-
constructor (v) {
|
|
22
|
-
super();
|
|
23
|
-
this.v = v;
|
|
24
|
-
}
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
/**
|
|
28
|
-
* @template {QueueNode} N
|
|
29
|
-
*/
|
|
30
|
-
class Queue {
|
|
31
|
-
constructor () {
|
|
32
|
-
/**
|
|
33
|
-
* @type {N | null}
|
|
34
|
-
*/
|
|
35
|
-
this.start = null;
|
|
36
|
-
/**
|
|
37
|
-
* @type {N | null}
|
|
38
|
-
*/
|
|
39
|
-
this.end = null;
|
|
40
|
-
}
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
/**
|
|
44
|
-
* @note The queue implementation is experimental and unfinished.
|
|
45
|
-
* Don't use this in production yet.
|
|
46
|
-
*
|
|
47
|
-
* @template {QueueNode} N
|
|
48
|
-
* @return {Queue<N>}
|
|
49
|
-
*/
|
|
50
|
-
const create = () => new Queue();
|
|
51
|
-
|
|
52
|
-
/**
|
|
53
|
-
* @param {Queue<any>} queue
|
|
54
|
-
*/
|
|
55
|
-
const isEmpty = queue => queue.start === null;
|
|
56
|
-
|
|
57
|
-
/**
|
|
58
|
-
* @template {Queue<any>} Q
|
|
59
|
-
* @param {Q} queue
|
|
60
|
-
* @param {Q extends Queue<infer N> ? N : never} n
|
|
61
|
-
*/
|
|
62
|
-
const enqueue = (queue, n) => {
|
|
63
|
-
if (queue.end !== null) {
|
|
64
|
-
queue.end.next = n;
|
|
65
|
-
queue.end = n;
|
|
66
|
-
} else {
|
|
67
|
-
queue.end = n;
|
|
68
|
-
queue.start = n;
|
|
69
|
-
}
|
|
70
|
-
};
|
|
71
|
-
|
|
72
|
-
/**
|
|
73
|
-
* @template {QueueNode} N
|
|
74
|
-
* @param {Queue<N>} queue
|
|
75
|
-
* @return {N | null}
|
|
76
|
-
*/
|
|
77
|
-
const dequeue = queue => {
|
|
78
|
-
const n = queue.start;
|
|
79
|
-
if (n !== null) {
|
|
80
|
-
// @ts-ignore
|
|
81
|
-
queue.start = n.next;
|
|
82
|
-
if (queue.start === null) {
|
|
83
|
-
queue.end = null;
|
|
84
|
-
}
|
|
85
|
-
return n
|
|
86
|
-
}
|
|
87
|
-
return null
|
|
88
|
-
};
|
|
89
|
-
|
|
90
|
-
exports.Queue = Queue;
|
|
91
|
-
exports.QueueNode = QueueNode;
|
|
92
|
-
exports.QueueValue = QueueValue;
|
|
93
|
-
exports.create = create;
|
|
94
|
-
exports.dequeue = dequeue;
|
|
95
|
-
exports.enqueue = enqueue;
|
|
96
|
-
exports.isEmpty = isEmpty;
|
|
97
|
-
//# sourceMappingURL=queue.cjs.map
|
package/dist/queue.cjs.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"queue.cjs","sources":["../queue.js"],"sourcesContent":["export class QueueNode {\n constructor () {\n /**\n * @type {QueueNode|null}\n */\n this.next = null\n }\n}\n\n/**\n * @template V\n */\nexport class QueueValue extends QueueNode {\n /**\n * @param {V} v\n */\n constructor (v) {\n super()\n this.v = v\n }\n}\n\n/**\n * @template {QueueNode} N\n */\nexport class Queue {\n constructor () {\n /**\n * @type {N | null}\n */\n this.start = null\n /**\n * @type {N | null}\n */\n this.end = null\n }\n}\n\n/**\n * @note The queue implementation is experimental and unfinished.\n * Don't use this in production yet.\n *\n * @template {QueueNode} N\n * @return {Queue<N>}\n */\nexport const create = () => new Queue()\n\n/**\n * @param {Queue<any>} queue\n */\nexport const isEmpty = queue => queue.start === null\n\n/**\n * @template {Queue<any>} Q\n * @param {Q} queue\n * @param {Q extends Queue<infer N> ? N : never} n\n */\nexport const enqueue = (queue, n) => {\n if (queue.end !== null) {\n queue.end.next = n\n queue.end = n\n } else {\n queue.end = n\n queue.start = n\n }\n}\n\n/**\n * @template {QueueNode} N\n * @param {Queue<N>} queue\n * @return {N | null}\n */\nexport const dequeue = queue => {\n const n = queue.start\n if (n !== null) {\n // @ts-ignore\n queue.start = n.next\n if (queue.start === null) {\n queue.end = null\n }\n return n\n }\n return null\n}\n"],"names":[],"mappings":";;;;AAAO,MAAM,SAAS,CAAC;AACvB,EAAE,WAAW,CAAC,GAAG;AACjB;AACA;AACA;AACA,IAAI,IAAI,CAAC,IAAI,GAAG,KAAI;AACpB,GAAG;AACH,CAAC;AACD;AACA;AACA;AACA;AACO,MAAM,UAAU,SAAS,SAAS,CAAC;AAC1C;AACA;AACA;AACA,EAAE,WAAW,CAAC,CAAC,CAAC,EAAE;AAClB,IAAI,KAAK,GAAE;AACX,IAAI,IAAI,CAAC,CAAC,GAAG,EAAC;AACd,GAAG;AACH,CAAC;AACD;AACA;AACA;AACA;AACO,MAAM,KAAK,CAAC;AACnB,EAAE,WAAW,CAAC,GAAG;AACjB;AACA;AACA;AACA,IAAI,IAAI,CAAC,KAAK,GAAG,KAAI;AACrB;AACA;AACA;AACA,IAAI,IAAI,CAAC,GAAG,GAAG,KAAI;AACnB,GAAG;AACH,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACY,MAAC,MAAM,GAAG,MAAM,IAAI,KAAK,GAAE;AACvC;AACA;AACA;AACA;AACY,MAAC,OAAO,GAAG,KAAK,IAAI,KAAK,CAAC,KAAK,KAAK,KAAI;AACpD;AACA;AACA;AACA;AACA;AACA;AACY,MAAC,OAAO,GAAG,CAAC,KAAK,EAAE,CAAC,KAAK;AACrC,EAAE,IAAI,KAAK,CAAC,GAAG,KAAK,IAAI,EAAE;AAC1B,IAAI,KAAK,CAAC,GAAG,CAAC,IAAI,GAAG,EAAC;AACtB,IAAI,KAAK,CAAC,GAAG,GAAG,EAAC;AACjB,GAAG,MAAM;AACT,IAAI,KAAK,CAAC,GAAG,GAAG,EAAC;AACjB,IAAI,KAAK,CAAC,KAAK,GAAG,EAAC;AACnB,GAAG;AACH,EAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACY,MAAC,OAAO,GAAG,KAAK,IAAI;AAChC,EAAE,MAAM,CAAC,GAAG,KAAK,CAAC,MAAK;AACvB,EAAE,IAAI,CAAC,KAAK,IAAI,EAAE;AAClB;AACA,IAAI,KAAK,CAAC,KAAK,GAAG,CAAC,CAAC,KAAI;AACxB,IAAI,IAAI,KAAK,CAAC,KAAK,KAAK,IAAI,EAAE;AAC9B,MAAM,KAAK,CAAC,GAAG,GAAG,KAAI;AACtB,KAAK;AACL,IAAI,OAAO,CAAC;AACZ,GAAG;AACH,EAAE,OAAO,IAAI;AACb;;;;;;;;;;"}
|
package/dist/queue.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"queue.d.ts","sourceRoot":"","sources":["../queue.js"],"names":[],"mappings":"AAAA;IAEI;;OAEG;IACH,MAFU,SAAS,GAAC,IAAI,CAER;CAEnB;AAED;;GAEG;AACH,wBAFa,CAAC;IAGZ;;OAEG;IACH,eAFW,CAAC,EAKX;IADC,KAAU;CAEb;AAED;;GAEG;AACH,mBAFyB,CAAC,SAAZ,SAAU;IAIpB;;OAEG;IACH,OAFU,CAAC,GAAG,IAAI,CAED;IACjB;;OAEG;IACH,KAFU,CAAC,GAAG,IAAI,CAEH;CAElB;AASM,uBAHkB,CAAC,SAAZ,SAAU,KACZ,KAAK,CAAC,CAAC,CAAC,CAEmB;AAKhC,+BAFI,KAAK,CAAC,GAAG,CAAC,WAE+B;AAO7C,wBAJmB,CAAC,SAAb,KAAK,CAAC,GAAG,CAAE,SACd,CAAC,KACD,CAAC,SAAS,KAAK,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,GAAG,KAAK,QAU9C;AAOM,wBAJkB,CAAC,SAAZ,SAAU,SACb,KAAK,CAAC,CAAC,CAAC,GACP,CAAC,GAAG,IAAI,CAanB"}
|
package/dist/queue.test.d.ts
DELETED
package/dist/queue.test.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"queue.test.d.ts","sourceRoot":"","sources":["../queue.test.js"],"names":[],"mappings":"AAMO,wCAFI,CAAC,CAAC,QAAQ,QA8BpB;mBAlCkB,cAAc"}
|
|
@@ -1,440 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
-
|
|
5
|
-
var math = require('./math-96d5e8c4.cjs');
|
|
6
|
-
var webcrypto = require('lib0/webcrypto');
|
|
7
|
-
var array = require('./array-78849c95.cjs');
|
|
8
|
-
var buffer = require('./buffer-3e750729.cjs');
|
|
9
|
-
require('./set-5b47859e.cjs');
|
|
10
|
-
require('./string-fddc5f8b.cjs');
|
|
11
|
-
require('./environment-1c97264d.cjs');
|
|
12
|
-
require('./map-24d263c0.cjs');
|
|
13
|
-
require('./conditions-f5c0c102.cjs');
|
|
14
|
-
require('./storage.cjs');
|
|
15
|
-
require('./function-314580f7.cjs');
|
|
16
|
-
require('./object-c0c9435b.cjs');
|
|
17
|
-
require('./equality.cjs');
|
|
18
|
-
require('./encoding-1a745c43.cjs');
|
|
19
|
-
require('./number-1fb57bba.cjs');
|
|
20
|
-
require('./binary-ac8e39e2.cjs');
|
|
21
|
-
require('./decoding-76e75827.cjs');
|
|
22
|
-
require('./error-0c1f634f.cjs');
|
|
23
|
-
|
|
24
|
-
function _interopNamespace(e) {
|
|
25
|
-
if (e && e.__esModule) return e;
|
|
26
|
-
var n = Object.create(null);
|
|
27
|
-
if (e) {
|
|
28
|
-
Object.keys(e).forEach(function (k) {
|
|
29
|
-
if (k !== 'default') {
|
|
30
|
-
var d = Object.getOwnPropertyDescriptor(e, k);
|
|
31
|
-
Object.defineProperty(n, k, d.get ? d : {
|
|
32
|
-
enumerable: true,
|
|
33
|
-
get: function () { return e[k]; }
|
|
34
|
-
});
|
|
35
|
-
}
|
|
36
|
-
});
|
|
37
|
-
}
|
|
38
|
-
n["default"] = e;
|
|
39
|
-
return Object.freeze(n);
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
var webcrypto__namespace = /*#__PURE__*/_interopNamespace(webcrypto);
|
|
43
|
-
|
|
44
|
-
/**
|
|
45
|
-
* The idea of the Rabin fingerprint algorithm is to represent the binary as a polynomial in a
|
|
46
|
-
* finite field (Galois Field G(2)). The polynomial will then be taken "modulo" by an irreducible
|
|
47
|
-
* polynomial of the desired size.
|
|
48
|
-
*
|
|
49
|
-
* This implementation is inefficient and is solely used to verify the actually performant
|
|
50
|
-
* implementation in `./rabin.js`.
|
|
51
|
-
*
|
|
52
|
-
* @module rabin-gf2-polynomial
|
|
53
|
-
*/
|
|
54
|
-
|
|
55
|
-
/**
|
|
56
|
-
* @param {number} degree
|
|
57
|
-
*/
|
|
58
|
-
const _degreeToMinByteLength = degree => math.floor(degree / 8) + 1;
|
|
59
|
-
|
|
60
|
-
/**
|
|
61
|
-
* This is a GF2 Polynomial abstraction that is not meant for production!
|
|
62
|
-
*
|
|
63
|
-
* It is easy to understand and it's correctness is as obvious as possible. It can be used to verify
|
|
64
|
-
* efficient implementations of algorithms on GF2.
|
|
65
|
-
*/
|
|
66
|
-
class GF2Polynomial {
|
|
67
|
-
constructor () {
|
|
68
|
-
/**
|
|
69
|
-
* @type {Set<number>}
|
|
70
|
-
*/
|
|
71
|
-
this.degrees = new Set();
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
/**
|
|
76
|
-
* From Uint8Array (MSB).
|
|
77
|
-
*
|
|
78
|
-
* @param {Uint8Array} bytes
|
|
79
|
-
*/
|
|
80
|
-
const createFromBytes = bytes => {
|
|
81
|
-
const p = new GF2Polynomial();
|
|
82
|
-
for (let bsi = bytes.length - 1, currDegree = 0; bsi >= 0; bsi--) {
|
|
83
|
-
const currByte = bytes[bsi];
|
|
84
|
-
for (let i = 0; i < 8; i++) {
|
|
85
|
-
if (((currByte >>> i) & 1) === 1) {
|
|
86
|
-
p.degrees.add(currDegree);
|
|
87
|
-
}
|
|
88
|
-
currDegree++;
|
|
89
|
-
}
|
|
90
|
-
}
|
|
91
|
-
return p
|
|
92
|
-
};
|
|
93
|
-
|
|
94
|
-
/**
|
|
95
|
-
* Transform to Uint8Array (MSB).
|
|
96
|
-
*
|
|
97
|
-
* @param {GF2Polynomial} p
|
|
98
|
-
* @param {number} byteLength
|
|
99
|
-
*/
|
|
100
|
-
const toUint8Array = (p, byteLength = _degreeToMinByteLength(getHighestDegree(p))) => {
|
|
101
|
-
const buf = buffer.createUint8ArrayFromLen(byteLength);
|
|
102
|
-
/**
|
|
103
|
-
* @param {number} i
|
|
104
|
-
*/
|
|
105
|
-
const setBit = i => {
|
|
106
|
-
const bi = math.floor(i / 8);
|
|
107
|
-
buf[buf.length - 1 - bi] |= (1 << (i % 8));
|
|
108
|
-
};
|
|
109
|
-
p.degrees.forEach(setBit);
|
|
110
|
-
return buf
|
|
111
|
-
};
|
|
112
|
-
|
|
113
|
-
/**
|
|
114
|
-
* Create from unsigned integer (max 32bit uint) - read most-significant-byte first.
|
|
115
|
-
*
|
|
116
|
-
* @param {number} uint
|
|
117
|
-
*/
|
|
118
|
-
const createFromUint = uint => {
|
|
119
|
-
const buf = new Uint8Array(4);
|
|
120
|
-
for (let i = 0; i < 4; i++) {
|
|
121
|
-
buf[i] = uint >>> 8 * (3 - i);
|
|
122
|
-
}
|
|
123
|
-
return createFromBytes(buf)
|
|
124
|
-
};
|
|
125
|
-
|
|
126
|
-
/**
|
|
127
|
-
* Create a random polynomial of a specified degree.
|
|
128
|
-
*
|
|
129
|
-
* @param {number} degree
|
|
130
|
-
*/
|
|
131
|
-
const createRandom = degree => {
|
|
132
|
-
const bs = new Uint8Array(_degreeToMinByteLength(degree));
|
|
133
|
-
webcrypto__namespace.getRandomValues(bs);
|
|
134
|
-
// Get first byte and explicitly set the bit of "degree" to 1 (the result must have the specified
|
|
135
|
-
// degree).
|
|
136
|
-
const firstByte = bs[0] | 1 << (degree % 8);
|
|
137
|
-
// Find out how many bits of the first byte need to be filled with zeros because they are >degree.
|
|
138
|
-
const zeros = 7 - (degree % 8);
|
|
139
|
-
bs[0] = ((firstByte << zeros) & 0xff) >>> zeros;
|
|
140
|
-
return createFromBytes(bs)
|
|
141
|
-
};
|
|
142
|
-
|
|
143
|
-
/**
|
|
144
|
-
* @param {GF2Polynomial} p
|
|
145
|
-
* @return number
|
|
146
|
-
*/
|
|
147
|
-
const getHighestDegree = p => array.fold(array.from(p.degrees), 0, math.max);
|
|
148
|
-
|
|
149
|
-
/**
|
|
150
|
-
* Add (+) p2 int the p1 polynomial.
|
|
151
|
-
*
|
|
152
|
-
* Addition is defined as xor in F2. Substraction is equivalent to addition in F2.
|
|
153
|
-
*
|
|
154
|
-
* @param {GF2Polynomial} p1
|
|
155
|
-
* @param {GF2Polynomial} p2
|
|
156
|
-
*/
|
|
157
|
-
const addInto = (p1, p2) => {
|
|
158
|
-
p2.degrees.forEach(degree => {
|
|
159
|
-
if (p1.degrees.has(degree)) {
|
|
160
|
-
p1.degrees.delete(degree);
|
|
161
|
-
} else {
|
|
162
|
-
p1.degrees.add(degree);
|
|
163
|
-
}
|
|
164
|
-
});
|
|
165
|
-
};
|
|
166
|
-
|
|
167
|
-
/**
|
|
168
|
-
* Or (|) p2 into the p1 polynomial.
|
|
169
|
-
*
|
|
170
|
-
* Addition is defined as xor in F2. Substraction is equivalent to addition in F2.
|
|
171
|
-
*
|
|
172
|
-
* @param {GF2Polynomial} p1
|
|
173
|
-
* @param {GF2Polynomial} p2
|
|
174
|
-
*/
|
|
175
|
-
const orInto = (p1, p2) => {
|
|
176
|
-
p2.degrees.forEach(degree => {
|
|
177
|
-
p1.degrees.add(degree);
|
|
178
|
-
});
|
|
179
|
-
};
|
|
180
|
-
|
|
181
|
-
/**
|
|
182
|
-
* Add (+) p2 to the p1 polynomial.
|
|
183
|
-
*
|
|
184
|
-
* Addition is defined as xor in F2. Substraction is equivalent to addition in F2.
|
|
185
|
-
*
|
|
186
|
-
* @param {GF2Polynomial} p1
|
|
187
|
-
* @param {GF2Polynomial} p2
|
|
188
|
-
*/
|
|
189
|
-
const add = (p1, p2) => {
|
|
190
|
-
const result = new GF2Polynomial();
|
|
191
|
-
p2.degrees.forEach(degree => {
|
|
192
|
-
if (!p1.degrees.has(degree)) {
|
|
193
|
-
result.degrees.add(degree);
|
|
194
|
-
}
|
|
195
|
-
});
|
|
196
|
-
p1.degrees.forEach(degree => {
|
|
197
|
-
if (!p2.degrees.has(degree)) {
|
|
198
|
-
result.degrees.add(degree);
|
|
199
|
-
}
|
|
200
|
-
});
|
|
201
|
-
return result
|
|
202
|
-
};
|
|
203
|
-
|
|
204
|
-
/**
|
|
205
|
-
* Add (+) p2 to the p1 polynomial.
|
|
206
|
-
*
|
|
207
|
-
* Addition is defined as xor in F2. Substraction is equivalent to addition in F2.
|
|
208
|
-
*
|
|
209
|
-
* @param {GF2Polynomial} p
|
|
210
|
-
*/
|
|
211
|
-
const clone = (p) => {
|
|
212
|
-
const result = new GF2Polynomial();
|
|
213
|
-
p.degrees.forEach(d => result.degrees.add(d));
|
|
214
|
-
return result
|
|
215
|
-
};
|
|
216
|
-
|
|
217
|
-
/**
|
|
218
|
-
* Add (+) p2 to the p1 polynomial.
|
|
219
|
-
*
|
|
220
|
-
* Addition is defined as xor in F2. Substraction is equivalent to addition in F2.
|
|
221
|
-
*
|
|
222
|
-
* @param {GF2Polynomial} p
|
|
223
|
-
* @param {number} degree
|
|
224
|
-
*/
|
|
225
|
-
const addDegreeInto = (p, degree) => {
|
|
226
|
-
if (p.degrees.has(degree)) {
|
|
227
|
-
p.degrees.delete(degree);
|
|
228
|
-
} else {
|
|
229
|
-
p.degrees.add(degree);
|
|
230
|
-
}
|
|
231
|
-
};
|
|
232
|
-
|
|
233
|
-
/**
|
|
234
|
-
* Multiply (•) p1 with p2 and store the result in p1.
|
|
235
|
-
*
|
|
236
|
-
* @param {GF2Polynomial} p1
|
|
237
|
-
* @param {GF2Polynomial} p2
|
|
238
|
-
*/
|
|
239
|
-
const multiply = (p1, p2) => {
|
|
240
|
-
const result = new GF2Polynomial();
|
|
241
|
-
p1.degrees.forEach(degree1 => {
|
|
242
|
-
p2.degrees.forEach(degree2 => {
|
|
243
|
-
addDegreeInto(result, degree1 + degree2);
|
|
244
|
-
});
|
|
245
|
-
});
|
|
246
|
-
return result
|
|
247
|
-
};
|
|
248
|
-
|
|
249
|
-
/**
|
|
250
|
-
* Multiply (•) p1 with p2 and store the result in p1.
|
|
251
|
-
*
|
|
252
|
-
* @param {GF2Polynomial} p
|
|
253
|
-
* @param {number} shift
|
|
254
|
-
*/
|
|
255
|
-
const shiftLeft = (p, shift) => {
|
|
256
|
-
const result = new GF2Polynomial();
|
|
257
|
-
p.degrees.forEach(degree => {
|
|
258
|
-
const r = degree + shift;
|
|
259
|
-
r >= 0 && result.degrees.add(r);
|
|
260
|
-
});
|
|
261
|
-
return result
|
|
262
|
-
};
|
|
263
|
-
|
|
264
|
-
/**
|
|
265
|
-
* Computes p1 % p2. I.e. the remainder of p1/p2.
|
|
266
|
-
*
|
|
267
|
-
* @param {GF2Polynomial} p1
|
|
268
|
-
* @param {GF2Polynomial} p2
|
|
269
|
-
*/
|
|
270
|
-
const mod = (p1, p2) => {
|
|
271
|
-
const maxDeg1 = getHighestDegree(p1);
|
|
272
|
-
const maxDeg2 = getHighestDegree(p2);
|
|
273
|
-
const result = clone(p1);
|
|
274
|
-
for (let i = maxDeg1 - maxDeg2; i >= 0; i--) {
|
|
275
|
-
if (result.degrees.has(maxDeg2 + i)) {
|
|
276
|
-
const shifted = shiftLeft(p2, i);
|
|
277
|
-
addInto(result, shifted);
|
|
278
|
-
}
|
|
279
|
-
}
|
|
280
|
-
return result
|
|
281
|
-
};
|
|
282
|
-
|
|
283
|
-
/**
|
|
284
|
-
* Computes (p^e mod m).
|
|
285
|
-
*
|
|
286
|
-
* http://en.wikipedia.org/wiki/Modular_exponentiation
|
|
287
|
-
*
|
|
288
|
-
* @param {GF2Polynomial} p
|
|
289
|
-
* @param {number} e
|
|
290
|
-
* @param {GF2Polynomial} m
|
|
291
|
-
*/
|
|
292
|
-
const modPow = (p, e, m) => {
|
|
293
|
-
let result = ONE;
|
|
294
|
-
while (true) {
|
|
295
|
-
if ((e & 1) === 1) {
|
|
296
|
-
result = mod(multiply(result, p), m);
|
|
297
|
-
}
|
|
298
|
-
e >>>= 1;
|
|
299
|
-
if (e === 0) {
|
|
300
|
-
return result
|
|
301
|
-
}
|
|
302
|
-
p = mod(multiply(p, p), m);
|
|
303
|
-
}
|
|
304
|
-
};
|
|
305
|
-
|
|
306
|
-
/**
|
|
307
|
-
* Find the greatest common divisor using Euclid's Algorithm.
|
|
308
|
-
*
|
|
309
|
-
* @param {GF2Polynomial} p1
|
|
310
|
-
* @param {GF2Polynomial} p2
|
|
311
|
-
*/
|
|
312
|
-
const gcd = (p1, p2) => {
|
|
313
|
-
while (p2.degrees.size > 0) {
|
|
314
|
-
const modded = mod(p1, p2);
|
|
315
|
-
p1 = p2;
|
|
316
|
-
p2 = modded;
|
|
317
|
-
}
|
|
318
|
-
return p1
|
|
319
|
-
};
|
|
320
|
-
|
|
321
|
-
/**
|
|
322
|
-
* true iff p1 equals p2
|
|
323
|
-
*
|
|
324
|
-
* @param {GF2Polynomial} p1
|
|
325
|
-
* @param {GF2Polynomial} p2
|
|
326
|
-
*/
|
|
327
|
-
const equals = (p1, p2) => {
|
|
328
|
-
if (p1.degrees.size !== p2.degrees.size) return false
|
|
329
|
-
for (const d of p1.degrees) {
|
|
330
|
-
if (!p2.degrees.has(d)) return false
|
|
331
|
-
}
|
|
332
|
-
return true
|
|
333
|
-
};
|
|
334
|
-
|
|
335
|
-
const X = createFromBytes(new Uint8Array([2]));
|
|
336
|
-
const ONE = createFromBytes(new Uint8Array([1]));
|
|
337
|
-
|
|
338
|
-
/**
|
|
339
|
-
* Computes ( x^(2^p) - x ) mod f
|
|
340
|
-
*
|
|
341
|
-
* (shamelessly copied from
|
|
342
|
-
* https://github.com/opendedup/rabinfingerprint/blob/master/src/org/rabinfingerprint/polynomial/Polynomial.java)
|
|
343
|
-
*
|
|
344
|
-
* @param {GF2Polynomial} f
|
|
345
|
-
* @param {number} p
|
|
346
|
-
*/
|
|
347
|
-
const reduceExponent = (f, p) => {
|
|
348
|
-
// compute (x^q^p mod f)
|
|
349
|
-
const q2p = math.pow(2, p);
|
|
350
|
-
const x2q2p = modPow(X, q2p, f);
|
|
351
|
-
// subtract (x mod f)
|
|
352
|
-
return mod(add(x2q2p, X), f)
|
|
353
|
-
};
|
|
354
|
-
|
|
355
|
-
/**
|
|
356
|
-
* BenOr Reducibility Test
|
|
357
|
-
*
|
|
358
|
-
* Tests and Constructions of Irreducible Polynomials over Finite Fields
|
|
359
|
-
* (1997) Shuhong Gao, Daniel Panario
|
|
360
|
-
*
|
|
361
|
-
* http://citeseer.ist.psu.edu/cache/papers/cs/27167/http:zSzzSzwww.math.clemson.eduzSzfacultyzSzGaozSzpaperszSzGP97a.pdf/gao97tests.pdf
|
|
362
|
-
*
|
|
363
|
-
* @param {GF2Polynomial} p
|
|
364
|
-
*/
|
|
365
|
-
const isIrreducibleBenOr = p => {
|
|
366
|
-
const degree = getHighestDegree(p);
|
|
367
|
-
for (let i = 1; i < degree / 2; i++) {
|
|
368
|
-
const b = reduceExponent(p, i);
|
|
369
|
-
const g = gcd(p, b);
|
|
370
|
-
if (!equals(g, ONE)) {
|
|
371
|
-
return false
|
|
372
|
-
}
|
|
373
|
-
}
|
|
374
|
-
return true
|
|
375
|
-
};
|
|
376
|
-
|
|
377
|
-
/**
|
|
378
|
-
* @param {number} degree
|
|
379
|
-
*/
|
|
380
|
-
const createIrreducible = degree => {
|
|
381
|
-
while (true) {
|
|
382
|
-
const p = createRandom(degree);
|
|
383
|
-
if (isIrreducibleBenOr(p)) return p
|
|
384
|
-
}
|
|
385
|
-
};
|
|
386
|
-
|
|
387
|
-
/**
|
|
388
|
-
* Create a fingerprint of buf using the irreducible polynomial m.
|
|
389
|
-
*
|
|
390
|
-
* @param {Uint8Array} buf
|
|
391
|
-
* @param {GF2Polynomial} m
|
|
392
|
-
*/
|
|
393
|
-
const fingerprint = (buf, m) => toUint8Array(mod(createFromBytes(buf), m), _degreeToMinByteLength(getHighestDegree(m) - 1));
|
|
394
|
-
|
|
395
|
-
class RabinPolynomialEncoder {
|
|
396
|
-
/**
|
|
397
|
-
* @param {GF2Polynomial} m The irreducible polynomial
|
|
398
|
-
*/
|
|
399
|
-
constructor (m) {
|
|
400
|
-
this.fingerprint = new GF2Polynomial();
|
|
401
|
-
this.m = m;
|
|
402
|
-
}
|
|
403
|
-
|
|
404
|
-
/**
|
|
405
|
-
* @param {number} b
|
|
406
|
-
*/
|
|
407
|
-
write (b) {
|
|
408
|
-
const bp = createFromBytes(new Uint8Array([b]));
|
|
409
|
-
const fingerprint = shiftLeft(this.fingerprint, 8);
|
|
410
|
-
orInto(fingerprint, bp);
|
|
411
|
-
this.fingerprint = mod(fingerprint, this.m);
|
|
412
|
-
}
|
|
413
|
-
|
|
414
|
-
getFingerprint () {
|
|
415
|
-
return toUint8Array(this.fingerprint, _degreeToMinByteLength(getHighestDegree(this.m) - 1))
|
|
416
|
-
}
|
|
417
|
-
}
|
|
418
|
-
|
|
419
|
-
exports.GF2Polynomial = GF2Polynomial;
|
|
420
|
-
exports.RabinPolynomialEncoder = RabinPolynomialEncoder;
|
|
421
|
-
exports.add = add;
|
|
422
|
-
exports.addDegreeInto = addDegreeInto;
|
|
423
|
-
exports.addInto = addInto;
|
|
424
|
-
exports.clone = clone;
|
|
425
|
-
exports.createFromBytes = createFromBytes;
|
|
426
|
-
exports.createFromUint = createFromUint;
|
|
427
|
-
exports.createIrreducible = createIrreducible;
|
|
428
|
-
exports.createRandom = createRandom;
|
|
429
|
-
exports.equals = equals;
|
|
430
|
-
exports.fingerprint = fingerprint;
|
|
431
|
-
exports.gcd = gcd;
|
|
432
|
-
exports.getHighestDegree = getHighestDegree;
|
|
433
|
-
exports.isIrreducibleBenOr = isIrreducibleBenOr;
|
|
434
|
-
exports.mod = mod;
|
|
435
|
-
exports.modPow = modPow;
|
|
436
|
-
exports.multiply = multiply;
|
|
437
|
-
exports.orInto = orInto;
|
|
438
|
-
exports.shiftLeft = shiftLeft;
|
|
439
|
-
exports.toUint8Array = toUint8Array;
|
|
440
|
-
//# sourceMappingURL=rabin-gf2-polynomial.cjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"rabin-gf2-polynomial.cjs","sources":["../hash/rabin-gf2-polynomial.js"],"sourcesContent":["/**\n * The idea of the Rabin fingerprint algorithm is to represent the binary as a polynomial in a\n * finite field (Galois Field G(2)). The polynomial will then be taken \"modulo\" by an irreducible\n * polynomial of the desired size.\n *\n * This implementation is inefficient and is solely used to verify the actually performant\n * implementation in `./rabin.js`.\n *\n * @module rabin-gf2-polynomial\n */\n\nimport * as math from '../math.js'\nimport * as webcrypto from 'lib0/webcrypto'\nimport * as array from '../array.js'\nimport * as buffer from '../buffer.js'\n\n/**\n * @param {number} degree\n */\nconst _degreeToMinByteLength = degree => math.floor(degree / 8) + 1\n\n/**\n * This is a GF2 Polynomial abstraction that is not meant for production!\n *\n * It is easy to understand and it's correctness is as obvious as possible. It can be used to verify\n * efficient implementations of algorithms on GF2.\n */\nexport class GF2Polynomial {\n constructor () {\n /**\n * @type {Set<number>}\n */\n this.degrees = new Set()\n }\n}\n\n/**\n * From Uint8Array (MSB).\n *\n * @param {Uint8Array} bytes\n */\nexport const createFromBytes = bytes => {\n const p = new GF2Polynomial()\n for (let bsi = bytes.length - 1, currDegree = 0; bsi >= 0; bsi--) {\n const currByte = bytes[bsi]\n for (let i = 0; i < 8; i++) {\n if (((currByte >>> i) & 1) === 1) {\n p.degrees.add(currDegree)\n }\n currDegree++\n }\n }\n return p\n}\n\n/**\n * Transform to Uint8Array (MSB).\n *\n * @param {GF2Polynomial} p\n * @param {number} byteLength\n */\nexport const toUint8Array = (p, byteLength = _degreeToMinByteLength(getHighestDegree(p))) => {\n const buf = buffer.createUint8ArrayFromLen(byteLength)\n /**\n * @param {number} i\n */\n const setBit = i => {\n const bi = math.floor(i / 8)\n buf[buf.length - 1 - bi] |= (1 << (i % 8))\n }\n p.degrees.forEach(setBit)\n return buf\n}\n\n/**\n * Create from unsigned integer (max 32bit uint) - read most-significant-byte first.\n *\n * @param {number} uint\n */\nexport const createFromUint = uint => {\n const buf = new Uint8Array(4)\n for (let i = 0; i < 4; i++) {\n buf[i] = uint >>> 8 * (3 - i)\n }\n return createFromBytes(buf)\n}\n\n/**\n * Create a random polynomial of a specified degree.\n *\n * @param {number} degree\n */\nexport const createRandom = degree => {\n const bs = new Uint8Array(_degreeToMinByteLength(degree))\n webcrypto.getRandomValues(bs)\n // Get first byte and explicitly set the bit of \"degree\" to 1 (the result must have the specified\n // degree).\n const firstByte = bs[0] | 1 << (degree % 8)\n // Find out how many bits of the first byte need to be filled with zeros because they are >degree.\n const zeros = 7 - (degree % 8)\n bs[0] = ((firstByte << zeros) & 0xff) >>> zeros\n return createFromBytes(bs)\n}\n\n/**\n * @param {GF2Polynomial} p\n * @return number\n */\nexport const getHighestDegree = p => array.fold(array.from(p.degrees), 0, math.max)\n\n/**\n * Add (+) p2 int the p1 polynomial.\n *\n * Addition is defined as xor in F2. Substraction is equivalent to addition in F2.\n *\n * @param {GF2Polynomial} p1\n * @param {GF2Polynomial} p2\n */\nexport const addInto = (p1, p2) => {\n p2.degrees.forEach(degree => {\n if (p1.degrees.has(degree)) {\n p1.degrees.delete(degree)\n } else {\n p1.degrees.add(degree)\n }\n })\n}\n\n/**\n * Or (|) p2 into the p1 polynomial.\n *\n * Addition is defined as xor in F2. Substraction is equivalent to addition in F2.\n *\n * @param {GF2Polynomial} p1\n * @param {GF2Polynomial} p2\n */\nexport const orInto = (p1, p2) => {\n p2.degrees.forEach(degree => {\n p1.degrees.add(degree)\n })\n}\n\n/**\n * Add (+) p2 to the p1 polynomial.\n *\n * Addition is defined as xor in F2. Substraction is equivalent to addition in F2.\n *\n * @param {GF2Polynomial} p1\n * @param {GF2Polynomial} p2\n */\nexport const add = (p1, p2) => {\n const result = new GF2Polynomial()\n p2.degrees.forEach(degree => {\n if (!p1.degrees.has(degree)) {\n result.degrees.add(degree)\n }\n })\n p1.degrees.forEach(degree => {\n if (!p2.degrees.has(degree)) {\n result.degrees.add(degree)\n }\n })\n return result\n}\n\n/**\n * Add (+) p2 to the p1 polynomial.\n *\n * Addition is defined as xor in F2. Substraction is equivalent to addition in F2.\n *\n * @param {GF2Polynomial} p\n */\nexport const clone = (p) => {\n const result = new GF2Polynomial()\n p.degrees.forEach(d => result.degrees.add(d))\n return result\n}\n\n/**\n * Add (+) p2 to the p1 polynomial.\n *\n * Addition is defined as xor in F2. Substraction is equivalent to addition in F2.\n *\n * @param {GF2Polynomial} p\n * @param {number} degree\n */\nexport const addDegreeInto = (p, degree) => {\n if (p.degrees.has(degree)) {\n p.degrees.delete(degree)\n } else {\n p.degrees.add(degree)\n }\n}\n\n/**\n * Multiply (•) p1 with p2 and store the result in p1.\n *\n * @param {GF2Polynomial} p1\n * @param {GF2Polynomial} p2\n */\nexport const multiply = (p1, p2) => {\n const result = new GF2Polynomial()\n p1.degrees.forEach(degree1 => {\n p2.degrees.forEach(degree2 => {\n addDegreeInto(result, degree1 + degree2)\n })\n })\n return result\n}\n\n/**\n * Multiply (•) p1 with p2 and store the result in p1.\n *\n * @param {GF2Polynomial} p\n * @param {number} shift\n */\nexport const shiftLeft = (p, shift) => {\n const result = new GF2Polynomial()\n p.degrees.forEach(degree => {\n const r = degree + shift\n r >= 0 && result.degrees.add(r)\n })\n return result\n}\n\n/**\n * Computes p1 % p2. I.e. the remainder of p1/p2.\n *\n * @param {GF2Polynomial} p1\n * @param {GF2Polynomial} p2\n */\nexport const mod = (p1, p2) => {\n const maxDeg1 = getHighestDegree(p1)\n const maxDeg2 = getHighestDegree(p2)\n const result = clone(p1)\n for (let i = maxDeg1 - maxDeg2; i >= 0; i--) {\n if (result.degrees.has(maxDeg2 + i)) {\n const shifted = shiftLeft(p2, i)\n addInto(result, shifted)\n }\n }\n return result\n}\n\n/**\n * Computes (p^e mod m).\n *\n * http://en.wikipedia.org/wiki/Modular_exponentiation\n *\n * @param {GF2Polynomial} p\n * @param {number} e\n * @param {GF2Polynomial} m\n */\nexport const modPow = (p, e, m) => {\n let result = ONE\n while (true) {\n if ((e & 1) === 1) {\n result = mod(multiply(result, p), m)\n }\n e >>>= 1\n if (e === 0) {\n return result\n }\n p = mod(multiply(p, p), m)\n }\n}\n\n/**\n * Find the greatest common divisor using Euclid's Algorithm.\n *\n * @param {GF2Polynomial} p1\n * @param {GF2Polynomial} p2\n */\nexport const gcd = (p1, p2) => {\n while (p2.degrees.size > 0) {\n const modded = mod(p1, p2)\n p1 = p2\n p2 = modded\n }\n return p1\n}\n\n/**\n * true iff p1 equals p2\n *\n * @param {GF2Polynomial} p1\n * @param {GF2Polynomial} p2\n */\nexport const equals = (p1, p2) => {\n if (p1.degrees.size !== p2.degrees.size) return false\n for (const d of p1.degrees) {\n if (!p2.degrees.has(d)) return false\n }\n return true\n}\n\nconst X = createFromBytes(new Uint8Array([2]))\nconst ONE = createFromBytes(new Uint8Array([1]))\n\n/**\n * Computes ( x^(2^p) - x ) mod f\n *\n * (shamelessly copied from\n * https://github.com/opendedup/rabinfingerprint/blob/master/src/org/rabinfingerprint/polynomial/Polynomial.java)\n *\n * @param {GF2Polynomial} f\n * @param {number} p\n */\nconst reduceExponent = (f, p) => {\n // compute (x^q^p mod f)\n const q2p = math.pow(2, p)\n const x2q2p = modPow(X, q2p, f)\n // subtract (x mod f)\n return mod(add(x2q2p, X), f)\n}\n\n/**\n * BenOr Reducibility Test\n *\n * Tests and Constructions of Irreducible Polynomials over Finite Fields\n * (1997) Shuhong Gao, Daniel Panario\n *\n * http://citeseer.ist.psu.edu/cache/papers/cs/27167/http:zSzzSzwww.math.clemson.eduzSzfacultyzSzGaozSzpaperszSzGP97a.pdf/gao97tests.pdf\n *\n * @param {GF2Polynomial} p\n */\nexport const isIrreducibleBenOr = p => {\n const degree = getHighestDegree(p)\n for (let i = 1; i < degree / 2; i++) {\n const b = reduceExponent(p, i)\n const g = gcd(p, b)\n if (!equals(g, ONE)) {\n return false\n }\n }\n return true\n}\n\n/**\n * @param {number} degree\n */\nexport const createIrreducible = degree => {\n while (true) {\n const p = createRandom(degree)\n if (isIrreducibleBenOr(p)) return p\n }\n}\n\n/**\n * Create a fingerprint of buf using the irreducible polynomial m.\n *\n * @param {Uint8Array} buf\n * @param {GF2Polynomial} m\n */\nexport const fingerprint = (buf, m) => toUint8Array(mod(createFromBytes(buf), m), _degreeToMinByteLength(getHighestDegree(m) - 1))\n\nexport class RabinPolynomialEncoder {\n /**\n * @param {GF2Polynomial} m The irreducible polynomial\n */\n constructor (m) {\n this.fingerprint = new GF2Polynomial()\n this.m = m\n }\n\n /**\n * @param {number} b\n */\n write (b) {\n const bp = createFromBytes(new Uint8Array([b]))\n const fingerprint = shiftLeft(this.fingerprint, 8)\n orInto(fingerprint, bp)\n this.fingerprint = mod(fingerprint, this.m)\n }\n\n getFingerprint () {\n return toUint8Array(this.fingerprint, _degreeToMinByteLength(getHighestDegree(this.m) - 1))\n }\n}\n"],"names":["math.floor","buffer.createUint8ArrayFromLen","webcrypto","array.fold","array.from","math.max","math.pow"],"mappings":"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"}
|
package/dist/rabin-uncached.cjs
DELETED
|
@@ -1,90 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
-
|
|
5
|
-
var math = require('./math-96d5e8c4.cjs');
|
|
6
|
-
var buffer = require('./buffer-3e750729.cjs');
|
|
7
|
-
require('./string-fddc5f8b.cjs');
|
|
8
|
-
require('./array-78849c95.cjs');
|
|
9
|
-
require('./set-5b47859e.cjs');
|
|
10
|
-
require('./environment-1c97264d.cjs');
|
|
11
|
-
require('./map-24d263c0.cjs');
|
|
12
|
-
require('./conditions-f5c0c102.cjs');
|
|
13
|
-
require('./storage.cjs');
|
|
14
|
-
require('./function-314580f7.cjs');
|
|
15
|
-
require('./object-c0c9435b.cjs');
|
|
16
|
-
require('./equality.cjs');
|
|
17
|
-
require('./encoding-1a745c43.cjs');
|
|
18
|
-
require('./number-1fb57bba.cjs');
|
|
19
|
-
require('./binary-ac8e39e2.cjs');
|
|
20
|
-
require('./decoding-76e75827.cjs');
|
|
21
|
-
require('./error-0c1f634f.cjs');
|
|
22
|
-
|
|
23
|
-
/**
|
|
24
|
-
* It is not recommended to use this package. This is the uncached implementation of the rabin
|
|
25
|
-
* fingerprint algorithm. However, it can be used to verify the `rabin.js` implementation.
|
|
26
|
-
*
|
|
27
|
-
* @module rabin-uncached
|
|
28
|
-
*/
|
|
29
|
-
|
|
30
|
-
class RabinUncachedEncoder {
|
|
31
|
-
/**
|
|
32
|
-
* @param {Uint8Array} m assert(m[0] === 1)
|
|
33
|
-
*/
|
|
34
|
-
constructor (m) {
|
|
35
|
-
this.m = m;
|
|
36
|
-
this.blen = m.byteLength;
|
|
37
|
-
this.bs = new Uint8Array(this.blen);
|
|
38
|
-
/**
|
|
39
|
-
* This describes the position of the most significant byte (starts with 0 and increases with
|
|
40
|
-
* shift)
|
|
41
|
-
*/
|
|
42
|
-
this.bpos = 0;
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
/**
|
|
46
|
-
* Add/Xor/Substract bytes.
|
|
47
|
-
*
|
|
48
|
-
* Discards bytes that are out of range.
|
|
49
|
-
* @todo put this in function or inline
|
|
50
|
-
*
|
|
51
|
-
* @param {Uint8Array} cs
|
|
52
|
-
*/
|
|
53
|
-
add (cs) {
|
|
54
|
-
const copyLen = math.min(this.blen, cs.byteLength);
|
|
55
|
-
// copy from right to left until max is reached
|
|
56
|
-
for (let i = 0; i < copyLen; i++) {
|
|
57
|
-
this.bs[(this.bpos + this.blen - i - 1) % this.blen] ^= cs[cs.byteLength - i - 1];
|
|
58
|
-
}
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
/**
|
|
62
|
-
* @param {number} byte
|
|
63
|
-
*/
|
|
64
|
-
write (byte) {
|
|
65
|
-
// [0,m1,m2,b]
|
|
66
|
-
// x <- bpos
|
|
67
|
-
// Shift one byte to the left, add b
|
|
68
|
-
this.bs[this.bpos] = byte;
|
|
69
|
-
this.bpos = (this.bpos + 1) % this.blen;
|
|
70
|
-
// mod
|
|
71
|
-
for (let i = 7; i >= 0; i--) {
|
|
72
|
-
if (((this.bs[this.bpos] >>> i) & 1) === 1) {
|
|
73
|
-
this.add(buffer.shiftNBitsLeft(this.m, i));
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
// if (this.bs[this.bpos] !== 0) { error.unexpectedCase() }
|
|
77
|
-
// assert(this.bs[this.bpos] === 0)
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
getFingerprint () {
|
|
81
|
-
const result = new Uint8Array(this.blen - 1);
|
|
82
|
-
for (let i = 0; i < result.byteLength; i++) {
|
|
83
|
-
result[i] = this.bs[(this.bpos + i + 1) % this.blen];
|
|
84
|
-
}
|
|
85
|
-
return result
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
exports.RabinUncachedEncoder = RabinUncachedEncoder;
|
|
90
|
-
//# sourceMappingURL=rabin-uncached.cjs.map
|