Skip to content

Commit

Permalink
fix: remove transaction from __transactions tracking array after tr…
Browse files Browse the repository at this point in the history
…ansaction completion; fixes #354
  • Loading branch information
brettz9 committed Aug 2, 2024
1 parent 941d1e1 commit 5b7d92d
Show file tree
Hide file tree
Showing 23 changed files with 181 additions and 64 deletions.
15 changes: 15 additions & 0 deletions CHANGES.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,20 @@
# CHANGES for indexeddbshim

## 15.0.1

### User-impacting changes

- fix: error in handling `__forceClose` with nullish database name
- fix: typo in `__forceClose` error message
- perf: clear out `__transactions` tracking array after db closes (#354)
- perf: remove transaction from `__transactions` tracking array after
transaction completion (#354)

### Dev-impacting changes

- chore: update typescript
- docs: internal TS issue

## 15.0.0

BREAKING:
Expand Down
13 changes: 10 additions & 3 deletions dist/indexeddbshim-Key.js

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion dist/indexeddbshim-Key.js.map

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion dist/indexeddbshim-Key.min.js

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion dist/indexeddbshim-Key.min.js.map

Large diffs are not rendered by default.

34 changes: 26 additions & 8 deletions dist/indexeddbshim-UnicodeIdentifiers-node.cjs
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
/*! indexeddbshim - v14.0.0 - 7/16/2024 */
/*! indexeddbshim - v15.0.0 - 8/3/2024 */

'use strict';

Expand Down Expand Up @@ -2679,6 +2679,14 @@ const signValues = ['negativeInfinity', 'bigNegative', 'smallNegative', 'smallPo
* @typedef {any} AnyValue
*/

/**
* @type {{
* [key: string]: {
* encode: (param: any, inArray?: boolean) => string,
* decode: (param: string, inArray?: boolean) => any
* }
* }}
*/
const types$1 = {
invalid: {
/**
Expand Down Expand Up @@ -3534,7 +3542,6 @@ function encode$1(key, inArray) {
return null;
}
// array, date, number, string, binary (should already have detected "invalid")
// @ts-expect-error Argument may be ignored
return types$1[getKeyType(key)].encode(key, inArray);
}

Expand Down Expand Up @@ -5077,7 +5084,7 @@ function _toPropertyKey(e) {
if ("object" != typeof e || null === e) return e;
var r = e[Symbol.toPrimitive];
if (void 0 !== r) {
var n = r.call(e, t );
var n = r.call(e, t);
if ("object" != typeof n) return n;
throw new TypeError("@@toPrimitive must return a primitive value.");
}
Expand Down Expand Up @@ -5133,7 +5140,7 @@ e.__typeson__type__ = "TypesonPromise", "undefined" != typeof Symbol && Object.d
var t = Object.hasOwn,
r = Object.getPrototypeOf;
function isThenable(e, t) {
return isObject(e) && "function" == typeof e.then && (!t );
return isObject(e) && "function" == typeof e.then && (!t);
}
function toStringTag(e) {
return Object.prototype.toString.call(e).slice(8, -1);
Expand Down Expand Up @@ -8310,6 +8317,8 @@ const readonlyProperties = ['name', 'version', 'objectStoreNames'];
function IDBDatabase() {
this.__versionTransaction = null;
this.__objectStores = null;
/** @type {import('./IDBTransaction.js').IDBTransactionFull[]} */
this.__transactions = [];
throw new TypeError('Illegal constructor');
}
const IDBDatabaseAlias = IDBDatabase;
Expand Down Expand Up @@ -8372,6 +8381,8 @@ IDBDatabase.__createInstance = function (db, name, oldVersion, version, storePro
this.__setOptions({
legacyOutputDidListenersThrowFlag: true // Event hook for IndexedB
});

/** @type {import('./IDBTransaction.js').IDBTransactionFull[]} */
this.__transactions = [];

/** @type {{[key: string]: IDBObjectStore}} */
Expand Down Expand Up @@ -8501,6 +8512,7 @@ IDBDatabase.prototype.close = function () {
if (this.__unblocking) {
this.__unblocking.check();
}
this.__transactions = [];
};

/**
Expand Down Expand Up @@ -8598,6 +8610,7 @@ IDBDatabase.prototype.__forceClose = function (msg) {
};
trans.__abortTransaction(createDOMException('AbortError', 'The connection was force-closed: ' + (msg || '')));
});
me.__transactions = [];
};
defineOuterInterface(IDBDatabase.prototype, listeners);
defineReadonlyOuterInterface(IDBDatabase.prototype, readonlyProperties);
Expand Down Expand Up @@ -9197,6 +9210,10 @@ IDBFactory.prototype.open = function (name /* , version */) {

// eslint-disable-next-line camelcase -- Clear API
req.transaction.on__complete = function () {
const pos = connection.__transactions.indexOf(req.transaction);
if (pos > -1) {
connection.__transactions.splice(pos, 1);
}
if ( /** @type {import('./IDBDatabase.js').IDBDatabaseFull} */req.__result.__closePending) {
req.__transaction = null;
const err = createDOMException('AbortError', 'The connection has been closed.');
Expand Down Expand Up @@ -9581,9 +9598,10 @@ IDBFactory.prototype.__forceClose = function (dbName, connIdx, msg) {
conn.__forceClose(msg);
}
if (isNullish(dbName)) {
Object.values(me.__connections).forEach(conn => {
// @ts-expect-error It's ok
forceClose(conn);
Object.values(me.__connections).forEach(connections => {
connections.forEach(connection => {
forceClose(connection);
});
});
} else if (!me.__connections[dbName]) {
console.log('No database connections with that name to force close');
Expand All @@ -9592,7 +9610,7 @@ IDBFactory.prototype.__forceClose = function (dbName, connIdx, msg) {
forceClose(conn);
});
} else if (!Number.isInteger(connIdx) || connIdx < 0 || connIdx > me.__connections[dbName].length - 1) {
throw new TypeError('If providing an argument, __forceClose must be called with a ' + 'numeric index to indicate a specific connection to lose');
throw new TypeError('If providing an argument, __forceClose must be called with a ' + 'numeric index to indicate a specific connection to close');
} else {
forceClose(me.__connections[dbName][connIdx]);
}
Expand Down
2 changes: 1 addition & 1 deletion dist/indexeddbshim-UnicodeIdentifiers-node.cjs.map

Large diffs are not rendered by default.

36 changes: 27 additions & 9 deletions dist/indexeddbshim-UnicodeIdentifiers.js

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion dist/indexeddbshim-UnicodeIdentifiers.js.map

Large diffs are not rendered by default.

4 changes: 2 additions & 2 deletions dist/indexeddbshim-UnicodeIdentifiers.min.js

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion dist/indexeddbshim-UnicodeIdentifiers.min.js.map

Large diffs are not rendered by default.

Loading

0 comments on commit 5b7d92d

Please sign in to comment.