@speckle/objectloader2 2.25.7 → 2.25.9
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/dist/commonjs/{operations → core}/interfaces.d.ts +2 -2
- package/dist/commonjs/core/interfaces.d.ts.map +1 -0
- package/dist/commonjs/core/interfaces.js.map +1 -0
- package/dist/commonjs/{operations → core}/objectLoader2.d.ts +1 -1
- package/dist/commonjs/core/objectLoader2.d.ts.map +1 -0
- package/dist/commonjs/core/objectLoader2.js +128 -0
- package/dist/commonjs/core/objectLoader2.js.map +1 -0
- package/dist/commonjs/{operations → core}/objectLoader2Factory.d.ts +4 -2
- package/dist/commonjs/core/objectLoader2Factory.d.ts.map +1 -0
- package/dist/commonjs/core/objectLoader2Factory.js +74 -0
- package/dist/commonjs/core/objectLoader2Factory.js.map +1 -0
- package/dist/{esm/operations → commonjs/core}/options.d.ts +2 -1
- package/dist/commonjs/core/options.d.ts.map +1 -0
- package/dist/commonjs/{operations → core}/options.js.map +1 -1
- package/dist/commonjs/core/stages/ItemStore.d.ts +37 -0
- package/dist/commonjs/core/stages/ItemStore.d.ts.map +1 -0
- package/dist/commonjs/core/stages/ItemStore.js +167 -0
- package/dist/commonjs/core/stages/ItemStore.js.map +1 -0
- package/dist/commonjs/core/stages/cacheReader.d.ts +18 -0
- package/dist/commonjs/core/stages/cacheReader.d.ts.map +1 -0
- package/dist/commonjs/core/stages/cacheReader.js +72 -0
- package/dist/commonjs/core/stages/cacheReader.js.map +1 -0
- package/dist/commonjs/core/stages/cacheWriter.d.ts +15 -0
- package/dist/commonjs/core/stages/cacheWriter.d.ts.map +1 -0
- package/dist/commonjs/core/stages/cacheWriter.js +50 -0
- package/dist/commonjs/core/stages/cacheWriter.js.map +1 -0
- package/dist/commonjs/{operations/databases → core/stages}/indexedDatabase.d.ts +2 -9
- package/dist/commonjs/core/stages/indexedDatabase.d.ts.map +1 -0
- package/dist/commonjs/core/stages/indexedDatabase.js +31 -0
- package/dist/commonjs/core/stages/indexedDatabase.js.map +1 -0
- package/dist/{esm/operations/databases → commonjs/core/stages/memory}/memoryDatabase.d.ts +4 -4
- package/dist/commonjs/core/stages/memory/memoryDatabase.d.ts.map +1 -0
- package/dist/commonjs/{operations/databases → core/stages/memory}/memoryDatabase.js +4 -1
- package/dist/commonjs/core/stages/memory/memoryDatabase.js.map +1 -0
- package/dist/commonjs/{operations/downloaders → core/stages/memory}/memoryDownloader.d.ts +3 -3
- package/dist/commonjs/core/stages/memory/memoryDownloader.d.ts.map +1 -0
- package/dist/commonjs/core/stages/memory/memoryDownloader.js.map +1 -0
- package/dist/{esm/operations/downloaders → commonjs/core/stages}/serverDownloader.d.ts +4 -5
- package/dist/commonjs/core/stages/serverDownloader.d.ts.map +1 -0
- package/dist/commonjs/{operations/downloaders → core/stages}/serverDownloader.js +81 -31
- package/dist/commonjs/core/stages/serverDownloader.js.map +1 -0
- package/dist/commonjs/core/traverser.d.ts.map +1 -0
- package/dist/commonjs/{operations → core}/traverser.js +7 -7
- package/dist/commonjs/core/traverser.js.map +1 -0
- package/dist/commonjs/deferment/MemoryCache.d.ts +35 -0
- package/dist/commonjs/deferment/MemoryCache.d.ts.map +1 -0
- package/dist/commonjs/deferment/MemoryCache.js +162 -0
- package/dist/commonjs/deferment/MemoryCache.js.map +1 -0
- package/dist/commonjs/deferment/MemoryCache.test.d.ts +2 -0
- package/dist/commonjs/deferment/MemoryCache.test.d.ts.map +1 -0
- package/dist/commonjs/deferment/MemoryCache.test.js +153 -0
- package/dist/commonjs/deferment/MemoryCache.test.js.map +1 -0
- package/dist/commonjs/deferment/defermentManager.d.ts +16 -0
- package/dist/commonjs/deferment/defermentManager.d.ts.map +1 -0
- package/dist/commonjs/deferment/defermentManager.js +58 -0
- package/dist/commonjs/deferment/defermentManager.js.map +1 -0
- package/dist/commonjs/deferment/defermentManager.test.d.ts +2 -0
- package/dist/commonjs/deferment/defermentManager.test.d.ts.map +1 -0
- package/dist/commonjs/deferment/defermentManager.test.js +188 -0
- package/dist/commonjs/deferment/defermentManager.test.js.map +1 -0
- package/dist/commonjs/deferment/deferredBase.d.ts +12 -0
- package/dist/commonjs/deferment/deferredBase.d.ts.map +1 -0
- package/dist/commonjs/deferment/deferredBase.js +27 -0
- package/dist/commonjs/deferment/deferredBase.js.map +1 -0
- package/dist/commonjs/index.d.ts +3 -2
- package/dist/commonjs/index.d.ts.map +1 -1
- package/dist/commonjs/index.js +6 -3
- package/dist/commonjs/index.js.map +1 -1
- package/dist/commonjs/{helpers → queues}/aggregateQueue.d.ts +2 -1
- package/dist/commonjs/queues/aggregateQueue.d.ts.map +1 -0
- package/dist/commonjs/{helpers → queues}/aggregateQueue.js +4 -0
- package/dist/commonjs/queues/aggregateQueue.js.map +1 -0
- package/dist/{esm/helpers → commonjs/queues}/asyncGeneratorQueue.d.ts +1 -1
- package/dist/commonjs/queues/asyncGeneratorQueue.d.ts.map +1 -0
- package/dist/commonjs/{helpers → queues}/asyncGeneratorQueue.js +2 -1
- package/dist/commonjs/queues/asyncGeneratorQueue.js.map +1 -0
- package/dist/{esm/helpers → commonjs/queues}/batchedPool.d.ts +2 -1
- package/dist/commonjs/queues/batchedPool.d.ts.map +1 -0
- package/dist/commonjs/queues/batchedPool.js.map +1 -0
- package/dist/{esm/helpers → commonjs/queues}/batchingQueue.d.ts +4 -1
- package/dist/commonjs/queues/batchingQueue.d.ts.map +1 -0
- package/dist/commonjs/queues/batchingQueue.dispose.test.d.ts +2 -0
- package/dist/commonjs/queues/batchingQueue.dispose.test.d.ts.map +1 -0
- package/dist/commonjs/queues/batchingQueue.dispose.test.js +64 -0
- package/dist/commonjs/queues/batchingQueue.dispose.test.js.map +1 -0
- package/dist/commonjs/queues/batchingQueue.js +123 -0
- package/dist/commonjs/queues/batchingQueue.js.map +1 -0
- package/dist/commonjs/queues/batchingQueue.test.d.ts +2 -0
- package/dist/commonjs/queues/batchingQueue.test.d.ts.map +1 -0
- package/dist/commonjs/queues/batchingQueue.test.js +138 -0
- package/dist/commonjs/queues/batchingQueue.test.js.map +1 -0
- package/dist/{esm/helpers → commonjs/queues}/bufferQueue.d.ts +1 -0
- package/dist/commonjs/queues/bufferQueue.d.ts.map +1 -0
- package/dist/commonjs/{helpers → queues}/bufferQueue.js +3 -0
- package/dist/commonjs/queues/bufferQueue.js.map +1 -0
- package/dist/commonjs/{helpers → queues}/keyedQueue.d.ts +1 -0
- package/dist/commonjs/queues/keyedQueue.d.ts.map +1 -0
- package/dist/commonjs/{helpers → queues}/keyedQueue.js +11 -0
- package/dist/commonjs/queues/keyedQueue.js.map +1 -0
- package/dist/commonjs/queues/queue.d.ts +5 -0
- package/dist/commonjs/queues/queue.d.ts.map +1 -0
- package/dist/commonjs/{helpers → queues}/queue.js.map +1 -1
- package/dist/commonjs/types/functions.d.ts +21 -0
- package/dist/commonjs/types/functions.d.ts.map +1 -0
- package/dist/commonjs/types/functions.js +92 -0
- package/dist/commonjs/types/functions.js.map +1 -0
- package/dist/commonjs/types/types.d.ts +1 -7
- package/dist/commonjs/types/types.d.ts.map +1 -1
- package/dist/commonjs/types/types.js +0 -36
- package/dist/commonjs/types/types.js.map +1 -1
- package/dist/esm/{operations → core}/interfaces.d.ts +2 -2
- package/dist/esm/core/interfaces.d.ts.map +1 -0
- package/dist/esm/core/interfaces.js.map +1 -0
- package/dist/esm/{operations → core}/objectLoader2.d.ts +1 -1
- package/dist/esm/core/objectLoader2.d.ts.map +1 -0
- package/dist/esm/core/objectLoader2.js +121 -0
- package/dist/esm/core/objectLoader2.js.map +1 -0
- package/dist/esm/{operations → core}/objectLoader2Factory.d.ts +4 -2
- package/dist/esm/core/objectLoader2Factory.d.ts.map +1 -0
- package/dist/esm/core/objectLoader2Factory.js +67 -0
- package/dist/esm/core/objectLoader2Factory.js.map +1 -0
- package/dist/{commonjs/operations → esm/core}/options.d.ts +2 -1
- package/dist/esm/core/options.d.ts.map +1 -0
- package/dist/esm/{operations → core}/options.js.map +1 -1
- package/dist/esm/core/stages/ItemStore.d.ts +37 -0
- package/dist/esm/core/stages/ItemStore.d.ts.map +1 -0
- package/dist/esm/core/stages/ItemStore.js +163 -0
- package/dist/esm/core/stages/ItemStore.js.map +1 -0
- package/dist/esm/core/stages/cacheReader.d.ts +18 -0
- package/dist/esm/core/stages/cacheReader.d.ts.map +1 -0
- package/dist/esm/core/stages/cacheReader.js +65 -0
- package/dist/esm/core/stages/cacheReader.js.map +1 -0
- package/dist/esm/core/stages/cacheWriter.d.ts +15 -0
- package/dist/esm/core/stages/cacheWriter.d.ts.map +1 -0
- package/dist/esm/core/stages/cacheWriter.js +43 -0
- package/dist/esm/core/stages/cacheWriter.js.map +1 -0
- package/dist/esm/{operations/databases → core/stages}/indexedDatabase.d.ts +2 -9
- package/dist/esm/core/stages/indexedDatabase.d.ts.map +1 -0
- package/dist/esm/core/stages/indexedDatabase.js +28 -0
- package/dist/esm/core/stages/indexedDatabase.js.map +1 -0
- package/dist/{commonjs/operations/databases → esm/core/stages/memory}/memoryDatabase.d.ts +4 -4
- package/dist/esm/core/stages/memory/memoryDatabase.d.ts.map +1 -0
- package/dist/esm/{operations/databases → core/stages/memory}/memoryDatabase.js +4 -1
- package/dist/esm/core/stages/memory/memoryDatabase.js.map +1 -0
- package/dist/esm/{operations/downloaders → core/stages/memory}/memoryDownloader.d.ts +3 -3
- package/dist/esm/core/stages/memory/memoryDownloader.d.ts.map +1 -0
- package/dist/esm/core/stages/memory/memoryDownloader.js.map +1 -0
- package/dist/{commonjs/operations/downloaders → esm/core/stages}/serverDownloader.d.ts +4 -5
- package/dist/esm/core/stages/serverDownloader.d.ts.map +1 -0
- package/dist/esm/{operations/downloaders → core/stages}/serverDownloader.js +80 -30
- package/dist/esm/core/stages/serverDownloader.js.map +1 -0
- package/dist/esm/core/traverser.d.ts.map +1 -0
- package/dist/esm/{operations → core}/traverser.js +1 -1
- package/dist/esm/core/traverser.js.map +1 -0
- package/dist/esm/deferment/MemoryCache.d.ts +35 -0
- package/dist/esm/deferment/MemoryCache.d.ts.map +1 -0
- package/dist/esm/deferment/MemoryCache.js +157 -0
- package/dist/esm/deferment/MemoryCache.js.map +1 -0
- package/dist/esm/deferment/MemoryCache.test.d.ts +2 -0
- package/dist/esm/deferment/MemoryCache.test.d.ts.map +1 -0
- package/dist/esm/deferment/MemoryCache.test.js +151 -0
- package/dist/esm/deferment/MemoryCache.test.js.map +1 -0
- package/dist/esm/deferment/defermentManager.d.ts +16 -0
- package/dist/esm/deferment/defermentManager.d.ts.map +1 -0
- package/dist/esm/deferment/defermentManager.js +54 -0
- package/dist/esm/deferment/defermentManager.js.map +1 -0
- package/dist/esm/deferment/defermentManager.test.d.ts +2 -0
- package/dist/esm/deferment/defermentManager.test.d.ts.map +1 -0
- package/dist/esm/deferment/defermentManager.test.js +186 -0
- package/dist/esm/deferment/defermentManager.test.js.map +1 -0
- package/dist/esm/deferment/deferredBase.d.ts +12 -0
- package/dist/esm/deferment/deferredBase.d.ts.map +1 -0
- package/dist/esm/deferment/deferredBase.js +23 -0
- package/dist/esm/deferment/deferredBase.js.map +1 -0
- package/dist/esm/index.d.ts +3 -2
- package/dist/esm/index.d.ts.map +1 -1
- package/dist/esm/index.js +3 -2
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/{helpers → queues}/aggregateQueue.d.ts +2 -1
- package/dist/esm/queues/aggregateQueue.d.ts.map +1 -0
- package/dist/esm/{helpers → queues}/aggregateQueue.js +4 -0
- package/dist/esm/queues/aggregateQueue.js.map +1 -0
- package/dist/{commonjs/helpers → esm/queues}/asyncGeneratorQueue.d.ts +1 -1
- package/dist/esm/queues/asyncGeneratorQueue.d.ts.map +1 -0
- package/dist/esm/{helpers → queues}/asyncGeneratorQueue.js +2 -1
- package/dist/esm/queues/asyncGeneratorQueue.js.map +1 -0
- package/dist/{commonjs/helpers → esm/queues}/batchedPool.d.ts +2 -1
- package/dist/esm/queues/batchedPool.d.ts.map +1 -0
- package/dist/esm/queues/batchedPool.js.map +1 -0
- package/dist/{commonjs/helpers → esm/queues}/batchingQueue.d.ts +4 -1
- package/dist/esm/queues/batchingQueue.d.ts.map +1 -0
- package/dist/esm/queues/batchingQueue.dispose.test.d.ts +2 -0
- package/dist/esm/queues/batchingQueue.dispose.test.d.ts.map +1 -0
- package/dist/esm/queues/batchingQueue.dispose.test.js +59 -0
- package/dist/esm/queues/batchingQueue.dispose.test.js.map +1 -0
- package/dist/esm/queues/batchingQueue.js +117 -0
- package/dist/esm/queues/batchingQueue.js.map +1 -0
- package/dist/esm/queues/batchingQueue.test.d.ts +2 -0
- package/dist/esm/queues/batchingQueue.test.d.ts.map +1 -0
- package/dist/esm/queues/batchingQueue.test.js +133 -0
- package/dist/esm/queues/batchingQueue.test.js.map +1 -0
- package/dist/{commonjs/helpers → esm/queues}/bufferQueue.d.ts +1 -0
- package/dist/esm/queues/bufferQueue.d.ts.map +1 -0
- package/dist/esm/{helpers → queues}/bufferQueue.js +3 -0
- package/dist/esm/queues/bufferQueue.js.map +1 -0
- package/dist/esm/{helpers → queues}/keyedQueue.d.ts +1 -0
- package/dist/esm/queues/keyedQueue.d.ts.map +1 -0
- package/dist/esm/{helpers → queues}/keyedQueue.js +11 -0
- package/dist/esm/queues/keyedQueue.js.map +1 -0
- package/dist/esm/queues/queue.d.ts +5 -0
- package/dist/esm/queues/queue.d.ts.map +1 -0
- package/dist/esm/{helpers → queues}/queue.js.map +1 -1
- package/dist/esm/types/functions.d.ts +21 -0
- package/dist/esm/types/functions.d.ts.map +1 -0
- package/dist/esm/types/functions.js +83 -0
- package/dist/esm/types/functions.js.map +1 -0
- package/dist/esm/types/types.d.ts +1 -7
- package/dist/esm/types/types.d.ts.map +1 -1
- package/dist/esm/types/types.js +1 -32
- package/dist/esm/types/types.js.map +1 -1
- package/package.json +2 -3
- package/readme.md +64 -16
- package/src/{operations → core}/interfaces.ts +2 -2
- package/src/{operations → core}/objectLoader2.spec.ts +22 -9
- package/src/core/objectLoader2.ts +162 -0
- package/src/core/objectLoader2Factory.ts +87 -0
- package/src/{operations → core}/options.ts +2 -1
- package/src/core/stages/ItemStore.ts +196 -0
- package/src/{operations/databases → core/stages}/__snapshots__/indexedDatabase.spec.ts.snap +4 -4
- package/src/{operations/downloaders → core/stages}/__snapshots__/serverDownloader.spec.ts.snap +25 -0
- package/src/{helpers → core/stages}/cacheReader.spec.ts +12 -7
- package/src/core/stages/cacheReader.ts +88 -0
- package/src/core/stages/cacheWriter.spec.ts +213 -0
- package/src/core/stages/cacheWriter.ts +64 -0
- package/src/{operations/databases → core/stages}/indexedDatabase.spec.ts +7 -3
- package/src/core/stages/indexedDatabase.ts +49 -0
- package/src/{operations/databases → core/stages/memory}/memoryDatabase.spec.ts +5 -5
- package/src/{operations/databases → core/stages/memory}/memoryDatabase.ts +7 -4
- package/src/{operations/downloaders → core/stages/memory}/memoryDownloader.spec.ts +3 -3
- package/src/{operations/downloaders → core/stages/memory}/memoryDownloader.ts +3 -3
- package/src/{operations/downloaders → core/stages}/serverDownloader.spec.ts +102 -11
- package/src/{operations/downloaders → core/stages}/serverDownloader.ts +87 -30
- package/src/{operations → core}/traverser.ts +2 -1
- package/src/deferment/MemoryCache.test.ts +187 -0
- package/src/deferment/MemoryCache.ts +189 -0
- package/src/deferment/defermentManager.test.ts +220 -0
- package/src/deferment/defermentManager.ts +59 -0
- package/src/deferment/deferredBase.ts +29 -0
- package/src/index.ts +3 -2
- package/src/{helpers → queues}/aggregateQueue.ts +5 -1
- package/src/{helpers → queues}/asyncGeneratorQueue.ts +2 -1
- package/src/{helpers → queues}/batchedPool.ts +3 -1
- package/src/queues/batchingQueue.dispose.test.ts +74 -0
- package/src/queues/batchingQueue.test.ts +149 -0
- package/src/queues/batchingQueue.ts +138 -0
- package/src/{helpers → queues}/bufferQueue.ts +3 -0
- package/src/{helpers → queues}/keyedQueue.ts +12 -0
- package/src/{helpers → queues}/queue.ts +1 -0
- package/src/test/e2e.spec.ts +2 -2
- package/src/types/functions.spec.ts +155 -0
- package/src/types/functions.ts +118 -0
- package/src/types/types.ts +1 -51
- package/dist/commonjs/helpers/aggregateQueue.d.ts.map +0 -1
- package/dist/commonjs/helpers/aggregateQueue.js.map +0 -1
- package/dist/commonjs/helpers/asyncGeneratorQueue.d.ts.map +0 -1
- package/dist/commonjs/helpers/asyncGeneratorQueue.js.map +0 -1
- package/dist/commonjs/helpers/batchedPool.d.ts.map +0 -1
- package/dist/commonjs/helpers/batchedPool.js.map +0 -1
- package/dist/commonjs/helpers/batchingQueue.d.ts.map +0 -1
- package/dist/commonjs/helpers/batchingQueue.js +0 -77
- package/dist/commonjs/helpers/batchingQueue.js.map +0 -1
- package/dist/commonjs/helpers/bufferQueue.d.ts.map +0 -1
- package/dist/commonjs/helpers/bufferQueue.js.map +0 -1
- package/dist/commonjs/helpers/cachePump.d.ts +0 -22
- package/dist/commonjs/helpers/cachePump.d.ts.map +0 -1
- package/dist/commonjs/helpers/cachePump.js +0 -86
- package/dist/commonjs/helpers/cachePump.js.map +0 -1
- package/dist/commonjs/helpers/cacheReader.d.ts +0 -14
- package/dist/commonjs/helpers/cacheReader.d.ts.map +0 -1
- package/dist/commonjs/helpers/cacheReader.js +0 -58
- package/dist/commonjs/helpers/cacheReader.js.map +0 -1
- package/dist/commonjs/helpers/defermentManager.d.ts +0 -28
- package/dist/commonjs/helpers/defermentManager.d.ts.map +0 -1
- package/dist/commonjs/helpers/defermentManager.js +0 -150
- package/dist/commonjs/helpers/defermentManager.js.map +0 -1
- package/dist/commonjs/helpers/deferredBase.d.ts +0 -19
- package/dist/commonjs/helpers/deferredBase.d.ts.map +0 -1
- package/dist/commonjs/helpers/deferredBase.js +0 -51
- package/dist/commonjs/helpers/deferredBase.js.map +0 -1
- package/dist/commonjs/helpers/keyedQueue.d.ts.map +0 -1
- package/dist/commonjs/helpers/keyedQueue.js.map +0 -1
- package/dist/commonjs/helpers/memoryPump.d.ts +0 -15
- package/dist/commonjs/helpers/memoryPump.d.ts.map +0 -1
- package/dist/commonjs/helpers/memoryPump.js +0 -34
- package/dist/commonjs/helpers/memoryPump.js.map +0 -1
- package/dist/commonjs/helpers/pump.d.ts +0 -8
- package/dist/commonjs/helpers/pump.d.ts.map +0 -1
- package/dist/commonjs/helpers/pump.js +0 -3
- package/dist/commonjs/helpers/pump.js.map +0 -1
- package/dist/commonjs/helpers/queue.d.ts +0 -4
- package/dist/commonjs/helpers/queue.d.ts.map +0 -1
- package/dist/commonjs/operations/databases/indexedDatabase.d.ts.map +0 -1
- package/dist/commonjs/operations/databases/indexedDatabase.js +0 -98
- package/dist/commonjs/operations/databases/indexedDatabase.js.map +0 -1
- package/dist/commonjs/operations/databases/memoryDatabase.d.ts.map +0 -1
- package/dist/commonjs/operations/databases/memoryDatabase.js.map +0 -1
- package/dist/commonjs/operations/downloaders/memoryDownloader.d.ts.map +0 -1
- package/dist/commonjs/operations/downloaders/memoryDownloader.js.map +0 -1
- package/dist/commonjs/operations/downloaders/serverDownloader.d.ts.map +0 -1
- package/dist/commonjs/operations/downloaders/serverDownloader.js.map +0 -1
- package/dist/commonjs/operations/interfaces.d.ts.map +0 -1
- package/dist/commonjs/operations/interfaces.js.map +0 -1
- package/dist/commonjs/operations/objectLoader2.d.ts.map +0 -1
- package/dist/commonjs/operations/objectLoader2.js +0 -101
- package/dist/commonjs/operations/objectLoader2.js.map +0 -1
- package/dist/commonjs/operations/objectLoader2Factory.d.ts.map +0 -1
- package/dist/commonjs/operations/objectLoader2Factory.js +0 -68
- package/dist/commonjs/operations/objectLoader2Factory.js.map +0 -1
- package/dist/commonjs/operations/options.d.ts.map +0 -1
- package/dist/commonjs/operations/traverser.d.ts.map +0 -1
- package/dist/commonjs/operations/traverser.js.map +0 -1
- package/dist/esm/helpers/aggregateQueue.d.ts.map +0 -1
- package/dist/esm/helpers/aggregateQueue.js.map +0 -1
- package/dist/esm/helpers/asyncGeneratorQueue.d.ts.map +0 -1
- package/dist/esm/helpers/asyncGeneratorQueue.js.map +0 -1
- package/dist/esm/helpers/batchedPool.d.ts.map +0 -1
- package/dist/esm/helpers/batchedPool.js.map +0 -1
- package/dist/esm/helpers/batchingQueue.d.ts.map +0 -1
- package/dist/esm/helpers/batchingQueue.js +0 -71
- package/dist/esm/helpers/batchingQueue.js.map +0 -1
- package/dist/esm/helpers/bufferQueue.d.ts.map +0 -1
- package/dist/esm/helpers/bufferQueue.js.map +0 -1
- package/dist/esm/helpers/cachePump.d.ts +0 -22
- package/dist/esm/helpers/cachePump.d.ts.map +0 -1
- package/dist/esm/helpers/cachePump.js +0 -79
- package/dist/esm/helpers/cachePump.js.map +0 -1
- package/dist/esm/helpers/cacheReader.d.ts +0 -14
- package/dist/esm/helpers/cacheReader.d.ts.map +0 -1
- package/dist/esm/helpers/cacheReader.js +0 -51
- package/dist/esm/helpers/cacheReader.js.map +0 -1
- package/dist/esm/helpers/defermentManager.d.ts +0 -28
- package/dist/esm/helpers/defermentManager.d.ts.map +0 -1
- package/dist/esm/helpers/defermentManager.js +0 -146
- package/dist/esm/helpers/defermentManager.js.map +0 -1
- package/dist/esm/helpers/deferredBase.d.ts +0 -19
- package/dist/esm/helpers/deferredBase.d.ts.map +0 -1
- package/dist/esm/helpers/deferredBase.js +0 -47
- package/dist/esm/helpers/deferredBase.js.map +0 -1
- package/dist/esm/helpers/keyedQueue.d.ts.map +0 -1
- package/dist/esm/helpers/keyedQueue.js.map +0 -1
- package/dist/esm/helpers/memoryPump.d.ts +0 -15
- package/dist/esm/helpers/memoryPump.d.ts.map +0 -1
- package/dist/esm/helpers/memoryPump.js +0 -30
- package/dist/esm/helpers/memoryPump.js.map +0 -1
- package/dist/esm/helpers/pump.d.ts +0 -8
- package/dist/esm/helpers/pump.d.ts.map +0 -1
- package/dist/esm/helpers/pump.js +0 -2
- package/dist/esm/helpers/pump.js.map +0 -1
- package/dist/esm/helpers/queue.d.ts +0 -4
- package/dist/esm/helpers/queue.d.ts.map +0 -1
- package/dist/esm/operations/databases/indexedDatabase.d.ts.map +0 -1
- package/dist/esm/operations/databases/indexedDatabase.js +0 -93
- package/dist/esm/operations/databases/indexedDatabase.js.map +0 -1
- package/dist/esm/operations/databases/memoryDatabase.d.ts.map +0 -1
- package/dist/esm/operations/databases/memoryDatabase.js.map +0 -1
- package/dist/esm/operations/downloaders/memoryDownloader.d.ts.map +0 -1
- package/dist/esm/operations/downloaders/memoryDownloader.js.map +0 -1
- package/dist/esm/operations/downloaders/serverDownloader.d.ts.map +0 -1
- package/dist/esm/operations/downloaders/serverDownloader.js.map +0 -1
- package/dist/esm/operations/interfaces.d.ts.map +0 -1
- package/dist/esm/operations/interfaces.js.map +0 -1
- package/dist/esm/operations/objectLoader2.d.ts.map +0 -1
- package/dist/esm/operations/objectLoader2.js +0 -94
- package/dist/esm/operations/objectLoader2.js.map +0 -1
- package/dist/esm/operations/objectLoader2Factory.d.ts.map +0 -1
- package/dist/esm/operations/objectLoader2Factory.js +0 -61
- package/dist/esm/operations/objectLoader2Factory.js.map +0 -1
- package/dist/esm/operations/options.d.ts.map +0 -1
- package/dist/esm/operations/traverser.d.ts.map +0 -1
- package/dist/esm/operations/traverser.js.map +0 -1
- package/src/helpers/__snapshots__/cachePump.spec.ts.snap +0 -31
- package/src/helpers/__snapshots__/defermentManager.spec.ts.snap +0 -8
- package/src/helpers/batchingQueue.ts +0 -85
- package/src/helpers/cachePump.disposal.spec.ts +0 -51
- package/src/helpers/cachePump.spec.ts +0 -104
- package/src/helpers/cachePump.ts +0 -107
- package/src/helpers/cacheReader.ts +0 -64
- package/src/helpers/defermentManager.defermentTotals.spec.ts +0 -53
- package/src/helpers/defermentManager.disposal.spec.ts +0 -28
- package/src/helpers/defermentManager.spec.ts +0 -37
- package/src/helpers/defermentManager.ts +0 -160
- package/src/helpers/deferredBase.ts +0 -55
- package/src/helpers/memoryPump.ts +0 -40
- package/src/helpers/pump.ts +0 -8
- package/src/operations/databases/indexedDatabase.ts +0 -126
- package/src/operations/objectLoader2.ts +0 -119
- package/src/operations/objectLoader2Factory.ts +0 -78
- package/dist/commonjs/{operations → core}/interfaces.js +0 -0
- package/dist/commonjs/{operations → core}/options.js +0 -0
- package/dist/commonjs/{operations/downloaders → core/stages/memory}/memoryDownloader.js +0 -0
- package/dist/commonjs/{operations → core}/traverser.d.ts +0 -0
- package/dist/commonjs/{helpers → queues}/batchedPool.js +0 -0
- package/dist/commonjs/{helpers → queues}/queue.js +0 -0
- package/dist/esm/{operations → core}/interfaces.js +0 -0
- package/dist/esm/{operations → core}/options.js +0 -0
- package/dist/esm/{operations/downloaders → core/stages/memory}/memoryDownloader.js +0 -0
- package/dist/esm/{operations → core}/traverser.d.ts +0 -0
- package/dist/esm/{helpers → queues}/batchedPool.js +0 -0
- package/dist/esm/{helpers → queues}/queue.js +0 -0
- package/src/{operations → core}/__snapshots__/objectLoader2.spec.ts.snap +0 -0
- package/src/{operations → core}/__snapshots__/traverser.spec.ts.snap +0 -0
- package/src/{helpers → core/stages}/__snapshots__/cacheReader.spec.ts.snap +0 -0
- package/src/{operations/downloaders → core/stages/memory}/__snapshots__/memoryDownloader.spec.ts.snap +0 -0
- package/src/{operations → core}/traverser.spec.ts +1 -1
|
@@ -1,94 +0,0 @@
|
|
|
1
|
-
import AsyncGeneratorQueue from '../helpers/asyncGeneratorQueue.js';
|
|
2
|
-
import { DefermentManager } from '../helpers/defermentManager.js';
|
|
3
|
-
import { CacheReader } from '../helpers/cacheReader.js';
|
|
4
|
-
import { CachePump } from '../helpers/cachePump.js';
|
|
5
|
-
import AggregateQueue from '../helpers/aggregateQueue.js';
|
|
6
|
-
import { ObjectLoader2Factory } from './objectLoader2Factory.js';
|
|
7
|
-
export class ObjectLoader2 {
|
|
8
|
-
#rootId;
|
|
9
|
-
#logger;
|
|
10
|
-
#database;
|
|
11
|
-
#downloader;
|
|
12
|
-
#pump;
|
|
13
|
-
#cache;
|
|
14
|
-
#deferments;
|
|
15
|
-
#gathered;
|
|
16
|
-
#root = undefined;
|
|
17
|
-
constructor(options) {
|
|
18
|
-
this.#rootId = options.rootId;
|
|
19
|
-
this.#logger = options.logger || console.log;
|
|
20
|
-
const cacheOptions = {
|
|
21
|
-
logger: this.#logger,
|
|
22
|
-
maxCacheReadSize: 10_000,
|
|
23
|
-
maxCacheWriteSize: 10_000,
|
|
24
|
-
maxWriteQueueSize: 40_000,
|
|
25
|
-
maxCacheBatchWriteWait: 3_000,
|
|
26
|
-
maxCacheBatchReadWait: 3_000
|
|
27
|
-
};
|
|
28
|
-
this.#gathered = new AsyncGeneratorQueue();
|
|
29
|
-
this.#database = options.database;
|
|
30
|
-
this.#deferments = new DefermentManager({
|
|
31
|
-
maxSizeInMb: 2_000, // 2 GBs
|
|
32
|
-
ttlms: 15_000, // 15 seconds
|
|
33
|
-
logger: this.#logger
|
|
34
|
-
});
|
|
35
|
-
this.#cache = new CacheReader(this.#database, this.#deferments, cacheOptions);
|
|
36
|
-
this.#pump = new CachePump(this.#database, this.#gathered, this.#deferments, cacheOptions);
|
|
37
|
-
this.#downloader = options.downloader;
|
|
38
|
-
}
|
|
39
|
-
async disposeAsync() {
|
|
40
|
-
await Promise.all([
|
|
41
|
-
this.#downloader.disposeAsync(),
|
|
42
|
-
this.#cache.disposeAsync(),
|
|
43
|
-
this.#pump.disposeAsync()
|
|
44
|
-
]);
|
|
45
|
-
this.#deferments.dispose();
|
|
46
|
-
}
|
|
47
|
-
async getRootObject() {
|
|
48
|
-
if (!this.#root) {
|
|
49
|
-
this.#root = (await this.#database.getAll([this.#rootId]))[0];
|
|
50
|
-
if (!this.#root) {
|
|
51
|
-
this.#root = await this.#downloader.downloadSingle();
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
return this.#root;
|
|
55
|
-
}
|
|
56
|
-
async getObject(params) {
|
|
57
|
-
return await this.#cache.getObject({ id: params.id });
|
|
58
|
-
}
|
|
59
|
-
async getTotalObjectCount() {
|
|
60
|
-
const rootObj = await this.getRootObject();
|
|
61
|
-
const totalChildrenCount = Object.keys(rootObj?.base.__closure || {}).length;
|
|
62
|
-
return totalChildrenCount + 1; //count the root
|
|
63
|
-
}
|
|
64
|
-
async *getObjectIterator() {
|
|
65
|
-
const rootItem = await this.getRootObject();
|
|
66
|
-
if (rootItem === undefined) {
|
|
67
|
-
this.#logger('No root object found!');
|
|
68
|
-
return;
|
|
69
|
-
}
|
|
70
|
-
//only for root
|
|
71
|
-
this.#pump.add(rootItem);
|
|
72
|
-
yield rootItem.base;
|
|
73
|
-
if (!rootItem.base.__closure)
|
|
74
|
-
return;
|
|
75
|
-
//sort the closures by their values descending
|
|
76
|
-
const sortedClosures = Object.entries(rootItem.base.__closure).sort((a, b) => b[1] - a[1]);
|
|
77
|
-
const children = sortedClosures.map((x) => x[0]);
|
|
78
|
-
const total = children.length;
|
|
79
|
-
this.#downloader.initializePool({
|
|
80
|
-
results: new AggregateQueue(this.#gathered, this.#pump),
|
|
81
|
-
total
|
|
82
|
-
});
|
|
83
|
-
for await (const item of this.#pump.gather(children, this.#downloader)) {
|
|
84
|
-
yield item.base;
|
|
85
|
-
}
|
|
86
|
-
}
|
|
87
|
-
static createFromObjects(objects) {
|
|
88
|
-
return ObjectLoader2Factory.createFromObjects(objects);
|
|
89
|
-
}
|
|
90
|
-
static createFromJSON(json) {
|
|
91
|
-
return ObjectLoader2Factory.createFromJSON(json);
|
|
92
|
-
}
|
|
93
|
-
}
|
|
94
|
-
//# sourceMappingURL=objectLoader2.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"objectLoader2.js","sourceRoot":"","sources":["../../../src/operations/objectLoader2.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"objectLoader2Factory.d.ts","sourceRoot":"","sources":["../../../src/operations/objectLoader2Factory.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAA;AAKtD,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAA;AAElD,MAAM,WAAW,2BAA2B;IAC1C,cAAc,CAAC,EAAE,OAAO,CAAA;IAExB,QAAQ,CAAC,EAAE;QAAE,KAAK,EAAE,QAAQ,CAAC;QAAC,UAAU,EAAE,QAAQ,CAAC;QAAC,UAAU,EAAE,QAAQ,CAAA;KAAE,CAAA;IAC1E,SAAS,CAAC,EAAE,UAAU,CAAA;IACtB,MAAM,CAAC,EAAE,YAAY,CAAA;CACtB;AAED,qBAAa,oBAAoB;IAC/B,MAAM,CAAC,iBAAiB,CAAC,OAAO,EAAE,IAAI,EAAE,GAAG,aAAa;IAcxD,MAAM,CAAC,cAAc,CAAC,IAAI,EAAE,MAAM,GAAG,aAAa;IAKlD,MAAM,CAAC,aAAa,CAAC,MAAM,EAAE;QAC3B,SAAS,EAAE,MAAM,CAAA;QACjB,QAAQ,EAAE,MAAM,CAAA;QAChB,QAAQ,EAAE,MAAM,CAAA;QAChB,KAAK,CAAC,EAAE,MAAM,CAAA;QACd,OAAO,CAAC,EAAE,OAAO,CAAA;QACjB,OAAO,CAAC,EAAE,2BAA2B,CAAA;KACtC,GAAG,aAAa;CAmClB"}
|
|
@@ -1,61 +0,0 @@
|
|
|
1
|
-
import IndexedDatabase from './databases/indexedDatabase.js';
|
|
2
|
-
import { MemoryDatabase } from './databases/memoryDatabase.js';
|
|
3
|
-
import { MemoryDownloader } from './downloaders/memoryDownloader.js';
|
|
4
|
-
import ServerDownloader from './downloaders/serverDownloader.js';
|
|
5
|
-
import { ObjectLoader2 } from './objectLoader2.js';
|
|
6
|
-
export class ObjectLoader2Factory {
|
|
7
|
-
static createFromObjects(objects) {
|
|
8
|
-
const root = objects[0];
|
|
9
|
-
const records = new Map();
|
|
10
|
-
objects.forEach((element) => {
|
|
11
|
-
records.set(element.id, element);
|
|
12
|
-
});
|
|
13
|
-
const loader = new ObjectLoader2({
|
|
14
|
-
rootId: root.id,
|
|
15
|
-
database: new MemoryDatabase({ items: records }),
|
|
16
|
-
downloader: new MemoryDownloader(root.id, records)
|
|
17
|
-
});
|
|
18
|
-
return loader;
|
|
19
|
-
}
|
|
20
|
-
static createFromJSON(json) {
|
|
21
|
-
const jsonObj = JSON.parse(json);
|
|
22
|
-
return this.createFromObjects(jsonObj);
|
|
23
|
-
}
|
|
24
|
-
static createFromUrl(params) {
|
|
25
|
-
let loader;
|
|
26
|
-
if (params.options?.useMemoryCache) {
|
|
27
|
-
loader = new ObjectLoader2({
|
|
28
|
-
rootId: params.objectId,
|
|
29
|
-
downloader: new ServerDownloader({
|
|
30
|
-
serverUrl: params.serverUrl,
|
|
31
|
-
streamId: params.streamId,
|
|
32
|
-
objectId: params.objectId,
|
|
33
|
-
token: params.token,
|
|
34
|
-
headers: params.headers
|
|
35
|
-
}),
|
|
36
|
-
database: new MemoryDatabase({
|
|
37
|
-
items: new Map()
|
|
38
|
-
})
|
|
39
|
-
});
|
|
40
|
-
}
|
|
41
|
-
else {
|
|
42
|
-
loader = new ObjectLoader2({
|
|
43
|
-
rootId: params.objectId,
|
|
44
|
-
downloader: new ServerDownloader({
|
|
45
|
-
serverUrl: params.serverUrl,
|
|
46
|
-
streamId: params.streamId,
|
|
47
|
-
objectId: params.objectId,
|
|
48
|
-
token: params.token,
|
|
49
|
-
headers: params.headers
|
|
50
|
-
}),
|
|
51
|
-
database: new IndexedDatabase({
|
|
52
|
-
logger: params.options?.logger,
|
|
53
|
-
indexedDB: params.options?.indexedDB,
|
|
54
|
-
keyRange: params.options?.keyRange
|
|
55
|
-
})
|
|
56
|
-
});
|
|
57
|
-
}
|
|
58
|
-
return loader;
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
//# sourceMappingURL=objectLoader2Factory.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"objectLoader2Factory.js","sourceRoot":"","sources":["../../../src/operations/objectLoader2Factory.ts"],"names":[],"mappings":"AACA,OAAO,eAAe,MAAM,gCAAgC,CAAA;AAC5D,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAA;AAC9D,OAAO,EAAE,gBAAgB,EAAE,MAAM,mCAAmC,CAAA;AACpE,OAAO,gBAAgB,MAAM,mCAAmC,CAAA;AAChE,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAA;AAUlD,MAAM,OAAO,oBAAoB;IAC/B,MAAM,CAAC,iBAAiB,CAAC,OAAe;QACtC,MAAM,IAAI,GAAG,OAAO,CAAC,CAAC,CAAC,CAAA;QACvB,MAAM,OAAO,GAAsB,IAAI,GAAG,EAAgB,CAAA;QAC1D,OAAO,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;YAC1B,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,EAAE,OAAO,CAAC,CAAA;QAClC,CAAC,CAAC,CAAA;QACF,MAAM,MAAM,GAAG,IAAI,aAAa,CAAC;YAC/B,MAAM,EAAE,IAAI,CAAC,EAAE;YACf,QAAQ,EAAE,IAAI,cAAc,CAAC,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC;YAChD,UAAU,EAAE,IAAI,gBAAgB,CAAC,IAAI,CAAC,EAAE,EAAE,OAAO,CAAC;SACnD,CAAC,CAAA;QACF,OAAO,MAAM,CAAA;IACf,CAAC;IAED,MAAM,CAAC,cAAc,CAAC,IAAY;QAChC,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAW,CAAA;QAC1C,OAAO,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAA;IACxC,CAAC;IAED,MAAM,CAAC,aAAa,CAAC,MAOpB;QACC,IAAI,MAAqB,CAAA;QACzB,IAAI,MAAM,CAAC,OAAO,EAAE,cAAc,EAAE,CAAC;YACnC,MAAM,GAAG,IAAI,aAAa,CAAC;gBACzB,MAAM,EAAE,MAAM,CAAC,QAAQ;gBACvB,UAAU,EAAE,IAAI,gBAAgB,CAAC;oBAC/B,SAAS,EAAE,MAAM,CAAC,SAAS;oBAC3B,QAAQ,EAAE,MAAM,CAAC,QAAQ;oBACzB,QAAQ,EAAE,MAAM,CAAC,QAAQ;oBACzB,KAAK,EAAE,MAAM,CAAC,KAAK;oBACnB,OAAO,EAAE,MAAM,CAAC,OAAO;iBACxB,CAAC;gBACF,QAAQ,EAAE,IAAI,cAAc,CAAC;oBAC3B,KAAK,EAAE,IAAI,GAAG,EAAgB;iBAC/B,CAAC;aACH,CAAC,CAAA;QACJ,CAAC;aAAM,CAAC;YACN,MAAM,GAAG,IAAI,aAAa,CAAC;gBACzB,MAAM,EAAE,MAAM,CAAC,QAAQ;gBACvB,UAAU,EAAE,IAAI,gBAAgB,CAAC;oBAC/B,SAAS,EAAE,MAAM,CAAC,SAAS;oBAC3B,QAAQ,EAAE,MAAM,CAAC,QAAQ;oBACzB,QAAQ,EAAE,MAAM,CAAC,QAAQ;oBACzB,KAAK,EAAE,MAAM,CAAC,KAAK;oBACnB,OAAO,EAAE,MAAM,CAAC,OAAO;iBACxB,CAAC;gBACF,QAAQ,EAAE,IAAI,eAAe,CAAC;oBAC5B,MAAM,EAAE,MAAM,CAAC,OAAO,EAAE,MAAM;oBAC9B,SAAS,EAAE,MAAM,CAAC,OAAO,EAAE,SAAS;oBACpC,QAAQ,EAAE,MAAM,CAAC,OAAO,EAAE,QAAQ;iBACnC,CAAC;aACH,CAAC,CAAA;QACJ,CAAC;QACD,OAAO,MAAM,CAAA;IACf,CAAC;CACF"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"options.d.ts","sourceRoot":"","sources":["../../../src/operations/options.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAA;AACtD,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAA;AAEtD,MAAM,WAAW,oBAAoB;IACnC,MAAM,EAAE,MAAM,CAAA;IACd,UAAU,EAAE,UAAU,CAAA;IACtB,QAAQ,EAAE,QAAQ,CAAA;IAClB,MAAM,CAAC,EAAE,YAAY,CAAA;CACtB;AAED,MAAM,WAAW,YAAY;IAC3B,MAAM,CAAC,EAAE,YAAY,CAAA;IACrB,gBAAgB,EAAE,MAAM,CAAA;IACxB,iBAAiB,EAAE,MAAM,CAAA;IACzB,sBAAsB,EAAE,MAAM,CAAA;IAC9B,qBAAqB,EAAE,MAAM,CAAA;IAC7B,iBAAiB,EAAE,MAAM,CAAA;CAC1B;AAED,MAAM,WAAW,qBAAqB;IACpC,MAAM,CAAC,EAAE,YAAY,CAAA;IACrB,KAAK,CAAC,EAAE,GAAG,CAAC,MAAM,EAAE,IAAI,CAAC,CAAA;CAC1B;AAED,MAAM,WAAW,uBAAuB;IACtC,MAAM,CAAC,EAAE,YAAY,CAAA;IACrB,WAAW,EAAE,MAAM,CAAA;IACnB,KAAK,EAAE,MAAM,CAAA;CACd"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"traverser.d.ts","sourceRoot":"","sources":["../../../src/operations/traverser.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAA4C,MAAM,mBAAmB,CAAA;AAClF,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAA;AAElD,MAAM,MAAM,aAAa,GAAG,UAAU,GAAG,cAAc,CAAA;AACvD,MAAM,MAAM,UAAU,GAAG,CAAC,CAAC,EAAE;IAC3B,KAAK,EAAE,aAAa,CAAA;IACpB,OAAO,EAAE,MAAM,CAAA;IACf,KAAK,EAAE,MAAM,CAAA;CACd,KAAK,IAAI,CAAA;AAEV,MAAM,WAAW,gBAAgB;IAC/B,YAAY,CAAC,EAAE,MAAM,EAAE,CAAA;CACxB;AAED,MAAM,CAAC,OAAO,OAAO,SAAS;;gBAOhB,MAAM,EAAE,aAAa,EAAE,OAAO,CAAC,EAAE,gBAAgB;IAKvD,QAAQ,CAAC,UAAU,CAAC,EAAE,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC;IAehD,aAAa,CAAC,KAAK,EAAE,KAAK,CAAC,OAAO,CAAC,EAAE,UAAU,CAAC,EAAE,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC;IAe5E,YAAY,CAAC,IAAI,EAAE,IAAI,EAAE,UAAU,CAAC,EAAE,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC;CAuDvE"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"traverser.js","sourceRoot":"","sources":["../../../src/operations/traverser.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,31 +0,0 @@
|
|
|
1
|
-
// Vitest Snapshot v1, https://vitest.dev/guide/snapshot.html
|
|
2
|
-
|
|
3
|
-
exports[`CachePump testing > write two items to queue use pumpItems that are NOT found 1`] = `[]`;
|
|
4
|
-
|
|
5
|
-
exports[`CachePump testing > write two items to queue use pumpItems that are NOT found 2`] = `
|
|
6
|
-
[
|
|
7
|
-
"id1",
|
|
8
|
-
"id2",
|
|
9
|
-
]
|
|
10
|
-
`;
|
|
11
|
-
|
|
12
|
-
exports[`CachePump testing > write two items to queue use pumpItems that are found 1`] = `
|
|
13
|
-
[
|
|
14
|
-
{
|
|
15
|
-
"base": {
|
|
16
|
-
"id": "id",
|
|
17
|
-
"speckle_type": "type",
|
|
18
|
-
},
|
|
19
|
-
"baseId": "id1",
|
|
20
|
-
},
|
|
21
|
-
{
|
|
22
|
-
"base": {
|
|
23
|
-
"id": "id",
|
|
24
|
-
"speckle_type": "type",
|
|
25
|
-
},
|
|
26
|
-
"baseId": "id2",
|
|
27
|
-
},
|
|
28
|
-
]
|
|
29
|
-
`;
|
|
30
|
-
|
|
31
|
-
exports[`CachePump testing > write two items to queue use pumpItems that are found 2`] = `[]`;
|
|
@@ -1,85 +0,0 @@
|
|
|
1
|
-
import KeyedQueue from './keyedQueue.js'
|
|
2
|
-
|
|
3
|
-
export default class BatchingQueue<T> {
|
|
4
|
-
#queue: KeyedQueue<string, T> = new KeyedQueue<string, T>()
|
|
5
|
-
#batchSize: number
|
|
6
|
-
#processFunction: (batch: T[]) => Promise<void>
|
|
7
|
-
|
|
8
|
-
#baseInterval: number
|
|
9
|
-
#minInterval: number
|
|
10
|
-
#maxInterval: number
|
|
11
|
-
|
|
12
|
-
#processingLoop: Promise<void>
|
|
13
|
-
#disposed = false
|
|
14
|
-
|
|
15
|
-
constructor(params: {
|
|
16
|
-
batchSize: number
|
|
17
|
-
maxWaitTime?: number
|
|
18
|
-
processFunction: (batch: T[]) => Promise<void>
|
|
19
|
-
}) {
|
|
20
|
-
this.#batchSize = params.batchSize
|
|
21
|
-
this.#baseInterval = Math.min(params.maxWaitTime ?? 200, 200) // Initial batch time (ms)
|
|
22
|
-
this.#minInterval = Math.min(params.maxWaitTime ?? 100, 100) // Minimum batch time
|
|
23
|
-
this.#maxInterval = Math.min(params.maxWaitTime ?? 3000, 3000) // Maximum batch time
|
|
24
|
-
this.#processFunction = params.processFunction
|
|
25
|
-
this.#processingLoop = this.#loop()
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
async disposeAsync(): Promise<void> {
|
|
29
|
-
this.#disposed = true
|
|
30
|
-
await this.#processingLoop
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
add(key: string, item: T): void {
|
|
34
|
-
this.#queue.enqueue(key, item)
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
get(id: string): T | undefined {
|
|
38
|
-
return this.#queue.get(id)
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
count(): number {
|
|
42
|
-
return this.#queue.size
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
isDisposed(): boolean {
|
|
46
|
-
return this.#disposed
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
#getBatch(batchSize: number): T[] {
|
|
50
|
-
return this.#queue.spliceValues(0, Math.min(batchSize, this.#queue.size))
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
async #loop(): Promise<void> {
|
|
54
|
-
let interval = this.#baseInterval
|
|
55
|
-
while (!this.#disposed || this.#queue.size > 0) {
|
|
56
|
-
const startTime = performance.now()
|
|
57
|
-
if (this.#queue.size > 0) {
|
|
58
|
-
const batch = this.#getBatch(this.#batchSize)
|
|
59
|
-
//console.log('running with queue size of ' + this.#queue.length)
|
|
60
|
-
await this.#processFunction(batch)
|
|
61
|
-
}
|
|
62
|
-
if (this.#queue.size < this.#batchSize / 2) {
|
|
63
|
-
//refigure interval
|
|
64
|
-
const endTime = performance.now()
|
|
65
|
-
const duration = endTime - startTime
|
|
66
|
-
if (duration > interval) {
|
|
67
|
-
interval = Math.min(interval * 1.5, this.#maxInterval) // Increase if slow or empty
|
|
68
|
-
} else {
|
|
69
|
-
interval = Math.max(interval * 0.8, this.#minInterval) // Decrease if fast
|
|
70
|
-
}
|
|
71
|
-
/*console.log(
|
|
72
|
-
'queue is waiting ' +
|
|
73
|
-
interval / 1000 +
|
|
74
|
-
' with queue size of ' +
|
|
75
|
-
this.#queue.length
|
|
76
|
-
)*/
|
|
77
|
-
await this.#delay(interval)
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
#delay(ms: number): Promise<void> {
|
|
83
|
-
return new Promise((resolve) => setTimeout(resolve, ms))
|
|
84
|
-
}
|
|
85
|
-
}
|
|
@@ -1,51 +0,0 @@
|
|
|
1
|
-
import { describe, expect, test } from 'vitest'
|
|
2
|
-
import { CachePump } from './cachePump.js'
|
|
3
|
-
import { Database } from '../operations/interfaces.js'
|
|
4
|
-
import AsyncGeneratorQueue from './asyncGeneratorQueue.js'
|
|
5
|
-
import { Item } from '../types/types.js'
|
|
6
|
-
import { DefermentManager } from './defermentManager.js'
|
|
7
|
-
|
|
8
|
-
const makeDatabase = (): Database =>
|
|
9
|
-
({
|
|
10
|
-
cacheSaveBatch: async (): Promise<void> => {},
|
|
11
|
-
getAll: async (): Promise<(Item | undefined)[]> => Promise.resolve([]),
|
|
12
|
-
getItem: async (): Promise<Item | undefined> => Promise.resolve(undefined),
|
|
13
|
-
disposeAsync: async (): Promise<void> => {}
|
|
14
|
-
} as unknown as Database)
|
|
15
|
-
const makeGathered = (): AsyncGeneratorQueue<Item> =>
|
|
16
|
-
({
|
|
17
|
-
add: () => {},
|
|
18
|
-
async *consume() {}
|
|
19
|
-
} as unknown as AsyncGeneratorQueue<Item>)
|
|
20
|
-
const makeDeferments = (): DefermentManager =>
|
|
21
|
-
({
|
|
22
|
-
undefer: () => {}
|
|
23
|
-
} as unknown as DefermentManager)
|
|
24
|
-
describe('CachePump disposal', () => {
|
|
25
|
-
test('disposeAsync is idempotent and always resolves', async () => {
|
|
26
|
-
const pump = new CachePump(makeDatabase(), makeGathered(), makeDeferments(), {
|
|
27
|
-
maxCacheWriteSize: 2,
|
|
28
|
-
maxCacheBatchWriteWait: 100,
|
|
29
|
-
maxCacheBatchReadWait: 1,
|
|
30
|
-
maxWriteQueueSize: 2,
|
|
31
|
-
maxCacheReadSize: 2
|
|
32
|
-
})
|
|
33
|
-
await pump.disposeAsync()
|
|
34
|
-
await expect(pump.disposeAsync()).resolves.toBeUndefined()
|
|
35
|
-
})
|
|
36
|
-
|
|
37
|
-
test('should not throw on add after dispose if writeQueue was never created', async () => {
|
|
38
|
-
const pump = new CachePump(makeDatabase(), makeGathered(), makeDeferments(), {
|
|
39
|
-
maxCacheWriteSize: 2,
|
|
40
|
-
maxCacheBatchWriteWait: 100,
|
|
41
|
-
maxCacheBatchReadWait: 1,
|
|
42
|
-
maxWriteQueueSize: 2,
|
|
43
|
-
maxCacheReadSize: 2
|
|
44
|
-
})
|
|
45
|
-
await pump.disposeAsync()
|
|
46
|
-
// Should not throw, but will not add anything
|
|
47
|
-
expect(() =>
|
|
48
|
-
pump.add({ baseId: 'a', base: { id: 'b', speckle_type: 'type' } })
|
|
49
|
-
).not.toThrow()
|
|
50
|
-
})
|
|
51
|
-
})
|
|
@@ -1,104 +0,0 @@
|
|
|
1
|
-
import { describe, expect, test } from 'vitest'
|
|
2
|
-
import { CachePump } from './cachePump.js'
|
|
3
|
-
import { Base, Item } from '../types/types.js'
|
|
4
|
-
import BufferQueue from './bufferQueue.js'
|
|
5
|
-
import AsyncGeneratorQueue from './asyncGeneratorQueue.js'
|
|
6
|
-
import { DefermentManager } from './defermentManager.js'
|
|
7
|
-
import { MemoryDatabase } from '../operations/databases/memoryDatabase.js'
|
|
8
|
-
import { Database } from '../operations/interfaces.js'
|
|
9
|
-
|
|
10
|
-
describe('CachePump testing', () => {
|
|
11
|
-
test('write two items to queue use pumpItems that are NOT found', async () => {
|
|
12
|
-
const i1: Item = { baseId: 'id1', base: { id: 'id', speckle_type: 'type' } }
|
|
13
|
-
const i2: Item = { baseId: 'id2', base: { id: 'id', speckle_type: 'type' } }
|
|
14
|
-
|
|
15
|
-
const gathered = new AsyncGeneratorQueue<Item>()
|
|
16
|
-
const deferments = new DefermentManager({ maxSizeInMb: 1, ttlms: 1 })
|
|
17
|
-
const cachePump = new CachePump(new MemoryDatabase({}), gathered, deferments, {
|
|
18
|
-
maxCacheReadSize: 1,
|
|
19
|
-
maxCacheWriteSize: 1,
|
|
20
|
-
maxCacheBatchWriteWait: 1,
|
|
21
|
-
maxCacheBatchReadWait: 1,
|
|
22
|
-
maxWriteQueueSize: 1
|
|
23
|
-
})
|
|
24
|
-
|
|
25
|
-
const foundItems = new BufferQueue<Item>()
|
|
26
|
-
const notFoundItems = new BufferQueue<string>()
|
|
27
|
-
|
|
28
|
-
await cachePump.pumpItems({
|
|
29
|
-
ids: [i1.baseId, i2.baseId],
|
|
30
|
-
foundItems,
|
|
31
|
-
notFoundItems
|
|
32
|
-
})
|
|
33
|
-
|
|
34
|
-
expect(foundItems.values()).toMatchSnapshot()
|
|
35
|
-
expect(notFoundItems.values()).toMatchSnapshot()
|
|
36
|
-
await cachePump.disposeAsync()
|
|
37
|
-
})
|
|
38
|
-
|
|
39
|
-
test('write two items to queue use pumpItems that are found', async () => {
|
|
40
|
-
const i1: Item = { baseId: 'id1', base: { id: 'id', speckle_type: 'type' } }
|
|
41
|
-
const i2: Item = { baseId: 'id2', base: { id: 'id', speckle_type: 'type' } }
|
|
42
|
-
|
|
43
|
-
const db = new Map<string, Base>()
|
|
44
|
-
db.set(i1.baseId, i1.base)
|
|
45
|
-
db.set(i2.baseId, i2.base)
|
|
46
|
-
|
|
47
|
-
const gathered = new AsyncGeneratorQueue<Item>()
|
|
48
|
-
const deferments = new DefermentManager({ maxSizeInMb: 1, ttlms: 1 })
|
|
49
|
-
const cachePump = new CachePump(
|
|
50
|
-
new MemoryDatabase({ items: db }),
|
|
51
|
-
gathered,
|
|
52
|
-
deferments,
|
|
53
|
-
{
|
|
54
|
-
maxCacheReadSize: 1,
|
|
55
|
-
maxCacheWriteSize: 1,
|
|
56
|
-
maxCacheBatchWriteWait: 1,
|
|
57
|
-
maxCacheBatchReadWait: 1,
|
|
58
|
-
maxWriteQueueSize: 1
|
|
59
|
-
}
|
|
60
|
-
)
|
|
61
|
-
|
|
62
|
-
const foundItems = new BufferQueue<Item>()
|
|
63
|
-
const notFoundItems = new BufferQueue<string>()
|
|
64
|
-
|
|
65
|
-
await cachePump.pumpItems({
|
|
66
|
-
ids: [i1.baseId, i2.baseId],
|
|
67
|
-
foundItems,
|
|
68
|
-
notFoundItems
|
|
69
|
-
})
|
|
70
|
-
|
|
71
|
-
expect(foundItems.values()).toMatchSnapshot()
|
|
72
|
-
expect(notFoundItems.values()).toMatchSnapshot()
|
|
73
|
-
await cachePump.disposeAsync()
|
|
74
|
-
})
|
|
75
|
-
|
|
76
|
-
test('can dispose while waiting and not wait', async () => {
|
|
77
|
-
const i1: Item = { baseId: 'id1', base: { id: 'id', speckle_type: 'type' } }
|
|
78
|
-
const i2: Item = { baseId: 'id2', base: { id: 'id', speckle_type: 'type' } }
|
|
79
|
-
|
|
80
|
-
const db: Database = {
|
|
81
|
-
getAll: async () => Promise.resolve([]),
|
|
82
|
-
disposeAsync: async (): Promise<void> => {}
|
|
83
|
-
} as unknown as Database
|
|
84
|
-
const gathered = new AsyncGeneratorQueue<Item>()
|
|
85
|
-
const deferments = new DefermentManager({ maxSizeInMb: 1, ttlms: 1 })
|
|
86
|
-
const cachePump = new CachePump(db, gathered, deferments, {
|
|
87
|
-
maxCacheReadSize: 1,
|
|
88
|
-
maxCacheWriteSize: 1,
|
|
89
|
-
maxCacheBatchWriteWait: 1,
|
|
90
|
-
maxCacheBatchReadWait: 1,
|
|
91
|
-
maxWriteQueueSize: 1
|
|
92
|
-
})
|
|
93
|
-
|
|
94
|
-
const foundItems = new BufferQueue<Item>()
|
|
95
|
-
const notFoundItems = new BufferQueue<string>()
|
|
96
|
-
|
|
97
|
-
await cachePump.disposeAsync()
|
|
98
|
-
await cachePump.pumpItems({
|
|
99
|
-
ids: [i1.baseId, i2.baseId],
|
|
100
|
-
foundItems,
|
|
101
|
-
notFoundItems
|
|
102
|
-
})
|
|
103
|
-
})
|
|
104
|
-
})
|
package/src/helpers/cachePump.ts
DELETED
|
@@ -1,107 +0,0 @@
|
|
|
1
|
-
import { TIME } from '@speckle/shared'
|
|
2
|
-
import { Database } from '../operations/interfaces.js'
|
|
3
|
-
import { CacheOptions } from '../operations/options.js'
|
|
4
|
-
import { CustomLogger, Item } from '../types/types.js'
|
|
5
|
-
import BatchingQueue from './batchingQueue.js'
|
|
6
|
-
import Queue from './queue.js'
|
|
7
|
-
import { Downloader } from '../operations/interfaces.js'
|
|
8
|
-
import { DefermentManager } from './defermentManager.js'
|
|
9
|
-
import AsyncGeneratorQueue from './asyncGeneratorQueue.js'
|
|
10
|
-
import { Pump } from './pump.js'
|
|
11
|
-
|
|
12
|
-
export class CachePump implements Pump {
|
|
13
|
-
#writeQueue: BatchingQueue<Item> | undefined
|
|
14
|
-
#database: Database
|
|
15
|
-
#logger: CustomLogger
|
|
16
|
-
#deferments: DefermentManager
|
|
17
|
-
|
|
18
|
-
#gathered: AsyncGeneratorQueue<Item>
|
|
19
|
-
|
|
20
|
-
#options: CacheOptions
|
|
21
|
-
|
|
22
|
-
#disposed = false
|
|
23
|
-
|
|
24
|
-
constructor(
|
|
25
|
-
database: Database,
|
|
26
|
-
gathered: AsyncGeneratorQueue<Item>,
|
|
27
|
-
deferments: DefermentManager,
|
|
28
|
-
options: CacheOptions
|
|
29
|
-
) {
|
|
30
|
-
this.#database = database
|
|
31
|
-
this.#gathered = gathered
|
|
32
|
-
this.#deferments = deferments
|
|
33
|
-
this.#options = options
|
|
34
|
-
this.#logger = options.logger || ((): void => {})
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
add(item: Item): void {
|
|
38
|
-
if (!this.#writeQueue) {
|
|
39
|
-
this.#writeQueue = new BatchingQueue({
|
|
40
|
-
batchSize: this.#options.maxCacheWriteSize,
|
|
41
|
-
maxWaitTime: this.#options.maxCacheBatchWriteWait,
|
|
42
|
-
processFunction: (batch: Item[]): Promise<void> =>
|
|
43
|
-
this.#database.cacheSaveBatch({ batch })
|
|
44
|
-
})
|
|
45
|
-
}
|
|
46
|
-
this.#writeQueue.add(item.baseId, item)
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
async disposeAsync(): Promise<void> {
|
|
50
|
-
await this.#writeQueue?.disposeAsync()
|
|
51
|
-
await this.#database.disposeAsync()
|
|
52
|
-
this.#disposed = true
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
get isDisposed(): boolean {
|
|
56
|
-
return this.#disposed
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
async pumpItems(params: {
|
|
60
|
-
ids: string[]
|
|
61
|
-
foundItems: Queue<Item>
|
|
62
|
-
notFoundItems: Queue<string>
|
|
63
|
-
}): Promise<void> {
|
|
64
|
-
const { ids, foundItems, notFoundItems } = params
|
|
65
|
-
const maxCacheReadSize = this.#options.maxCacheReadSize
|
|
66
|
-
|
|
67
|
-
for (let i = 0; i < ids.length; ) {
|
|
68
|
-
if (this.isDisposed) break
|
|
69
|
-
if ((this.#writeQueue?.count() ?? 0) > this.#options.maxWriteQueueSize) {
|
|
70
|
-
this.#logger(
|
|
71
|
-
'pausing reads (# in write queue: ' + this.#writeQueue?.count() + ')'
|
|
72
|
-
)
|
|
73
|
-
await new Promise((resolve) => setTimeout(resolve, TIME.second)) // Pause for 1 second, protects against out of memory
|
|
74
|
-
continue
|
|
75
|
-
}
|
|
76
|
-
const batch = ids.slice(i, i + maxCacheReadSize)
|
|
77
|
-
const cachedData = await this.#database.getAll(batch)
|
|
78
|
-
for (let i = 0; i < cachedData.length; i++) {
|
|
79
|
-
if (cachedData[i]) {
|
|
80
|
-
foundItems.add(cachedData[i]!)
|
|
81
|
-
} else {
|
|
82
|
-
notFoundItems.add(batch[i])
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
i += maxCacheReadSize
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
async *gather(ids: string[], downloader: Downloader): AsyncGenerator<Item> {
|
|
90
|
-
const total = ids.length
|
|
91
|
-
const pumpPromise = this.pumpItems({
|
|
92
|
-
ids,
|
|
93
|
-
foundItems: this.#gathered,
|
|
94
|
-
notFoundItems: downloader
|
|
95
|
-
})
|
|
96
|
-
let count = 0
|
|
97
|
-
for await (const item of this.#gathered.consume()) {
|
|
98
|
-
this.#deferments.undefer(item)
|
|
99
|
-
yield item
|
|
100
|
-
count++
|
|
101
|
-
if (count >= total) {
|
|
102
|
-
this.#gathered.dispose()
|
|
103
|
-
}
|
|
104
|
-
}
|
|
105
|
-
await pumpPromise
|
|
106
|
-
}
|
|
107
|
-
}
|
|
@@ -1,64 +0,0 @@
|
|
|
1
|
-
import { Database } from '../operations/interfaces.js'
|
|
2
|
-
import { CacheOptions } from '../operations/options.js'
|
|
3
|
-
import { Base, CustomLogger, Item } from '../types/types.js'
|
|
4
|
-
import BatchingQueue from './batchingQueue.js'
|
|
5
|
-
import { DefermentManager } from './defermentManager.js'
|
|
6
|
-
|
|
7
|
-
export class CacheReader {
|
|
8
|
-
#database: Database
|
|
9
|
-
#defermentManager: DefermentManager
|
|
10
|
-
#logger: CustomLogger
|
|
11
|
-
#options: CacheOptions
|
|
12
|
-
#readQueue: BatchingQueue<string> | undefined
|
|
13
|
-
|
|
14
|
-
constructor(
|
|
15
|
-
database: Database,
|
|
16
|
-
defermentManager: DefermentManager,
|
|
17
|
-
options: CacheOptions
|
|
18
|
-
) {
|
|
19
|
-
this.#database = database
|
|
20
|
-
this.#defermentManager = defermentManager
|
|
21
|
-
this.#options = options
|
|
22
|
-
this.#logger = options.logger || ((): void => {})
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
async getObject(params: { id: string }): Promise<Base> {
|
|
26
|
-
if (!this.#defermentManager.isDeferred(params.id)) {
|
|
27
|
-
this.#getItem(params.id)
|
|
28
|
-
}
|
|
29
|
-
return await this.#defermentManager.defer({ id: params.id })
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
#getItem(id: string): void {
|
|
33
|
-
if (!this.#readQueue) {
|
|
34
|
-
this.#readQueue = new BatchingQueue({
|
|
35
|
-
batchSize: this.#options.maxCacheReadSize,
|
|
36
|
-
maxWaitTime: this.#options.maxCacheBatchReadWait,
|
|
37
|
-
processFunction: this.#processBatch
|
|
38
|
-
})
|
|
39
|
-
}
|
|
40
|
-
if (!this.#readQueue.get(id)) {
|
|
41
|
-
this.#readQueue.add(id, id)
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
async getAll(keys: string[]): Promise<(Item | undefined)[]> {
|
|
46
|
-
return this.#database.getAll(keys)
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
#processBatch = async (batch: string[]): Promise<void> => {
|
|
50
|
-
const items = await this.#database.getAll(batch)
|
|
51
|
-
for (let i = 0; i < items.length; i++) {
|
|
52
|
-
if (items[i]) {
|
|
53
|
-
this.#defermentManager.undefer(items[i]!)
|
|
54
|
-
} else {
|
|
55
|
-
//this is okay!
|
|
56
|
-
//this.#logger(`Item ${batch[i]} not found in cache`)
|
|
57
|
-
}
|
|
58
|
-
}
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
async disposeAsync(): Promise<void> {
|
|
62
|
-
await this.#readQueue?.disposeAsync()
|
|
63
|
-
}
|
|
64
|
-
}
|