From 3af29eda8bc37e3518bde28c4619034a9d8820f2 Mon Sep 17 00:00:00 2001 From: Michele Riva Date: Wed, 11 Dec 2024 15:02:27 +0100 Subject: [PATCH] fix: fixes #858 --- packages/orama/src/methods/insert.ts | 11 ++++------- packages/orama/src/utils.ts | 28 ++++++++++++++++++++++++++++ 2 files changed, 32 insertions(+), 7 deletions(-) diff --git a/packages/orama/src/methods/insert.ts b/packages/orama/src/methods/insert.ts index 65c5862e..de65114e 100644 --- a/packages/orama/src/methods/insert.ts +++ b/packages/orama/src/methods/insert.ts @@ -1,6 +1,6 @@ import type { AnyOrama, PartialSchemaDeep, SortValue, TypedDocument } from '../types.js' import { isArrayType, isGeoPointType, isVectorType } from '../components.js' -import { isAsyncFunction } from '../utils.js' +import { isAsyncFunction, sleep } from '../utils.js' import { runMultipleHook, runSingleHook } from '../components/hooks.js' import { trackInsertion } from '../components/sync-blocking-checker.js' import { createError } from '../errors.js' @@ -316,8 +316,6 @@ async function innerInsertMultipleAsync( const processAllBatches = async (): Promise => { let currentIndex = 0 - const sab = new SharedArrayBuffer(4) - const ia = new Int32Array(sab) while (currentIndex < docs.length) { const startTime = Date.now() @@ -327,7 +325,7 @@ async function innerInsertMultipleAsync( const elapsedTime = Date.now() - startTime const waitTime = timeout - elapsedTime if (waitTime > 0) { - Atomics.wait(ia, 0, 0, waitTime) + sleep(waitTime) } } } @@ -369,8 +367,6 @@ function innerInsertMultipleSync( function processAllBatches() { const startTime = Date.now() - const sab = new SharedArrayBuffer(4) - const ia = new Int32Array(sab) // eslint-disable-next-line no-constant-condition while (true) { @@ -382,7 +378,7 @@ function innerInsertMultipleSync( if (elapsedTime >= timeout) { const remainingTime = timeout - (elapsedTime % timeout) if (remainingTime > 0) { - Atomics.wait(ia, 0, 0, remainingTime) + sleep(remainingTime) } } } @@ -398,6 +394,7 @@ function innerInsertMultipleSync( return ids } + export function innerInsertMultiple( orama: T, docs: PartialSchemaDeep>[], diff --git a/packages/orama/src/utils.ts b/packages/orama/src/utils.ts index 9384cba5..fad828ec 100644 --- a/packages/orama/src/utils.ts +++ b/packages/orama/src/utils.ts @@ -442,3 +442,31 @@ export function setUnion(set1: Set | undefined, set2: Set) { } return new Set([...set1, ...set2]); } + +// This code is taken from https://github.com/davidmarkclements/atomic-sleep, MIT licensed at the time of commit b8149d3ca276c84a54fa8fa1478f9cc79aabc15a. +// All credits go to the original author (David Mark Clements, https://github.com/davidmarkclements). +export function sleep(ms: number) { + if (typeof SharedArrayBuffer !== 'undefined' && typeof Atomics !== 'undefined') { + const nil = new Int32Array(new SharedArrayBuffer(4)) + const valid = ms > 0 && ms < Infinity + if (valid === false) { + if (typeof ms !== 'number' && typeof ms !== 'bigint') { + throw TypeError('sleep: ms must be a number') + } + throw RangeError('sleep: ms must be a number that is greater than 0 but less than Infinity') + } + + Atomics.wait(nil, 0, 0, Number(ms)) + + } else { + const valid = ms > 0 && ms < Infinity + if (valid === false) { + if (typeof ms !== 'number' && typeof ms !== 'bigint') { + throw TypeError('sleep: ms must be a number') + } + throw RangeError('sleep: ms must be a number that is greater than 0 but less than Infinity') + } + const target = Date.now() + Number(ms) + while (target > Date.now()){ /* empty */ } + } +} \ No newline at end of file