From c83b820d82dce5b0a8068b9c6c3141166e7640c2 Mon Sep 17 00:00:00 2001 From: Bailey Pearson Date: Fri, 21 Oct 2022 15:44:59 -0400 Subject: [PATCH] fix: initialization of cursors with values --- src/cursor/abstract_cursor.ts | 18 ++++++++---------- 1 file changed, 8 insertions(+), 10 deletions(-) diff --git a/src/cursor/abstract_cursor.ts b/src/cursor/abstract_cursor.ts index 19c0a0f4c4..8aa59aa651 100644 --- a/src/cursor/abstract_cursor.ts +++ b/src/cursor/abstract_cursor.ts @@ -692,7 +692,7 @@ export abstract class AbstractCursor< * a significant refactor. */ [kInit](callback: Callback): void { - this._initialize(this[kSession], (err, state) => { + this._initialize(this[kSession], (error, state) => { if (state) { const response = state.response; this[kServer] = state.server; @@ -724,8 +724,12 @@ export abstract class AbstractCursor< // the cursor is now initialized, even if an error occurred or it is dead this[kInitialized] = true; - if (err || cursorIsDead(this)) { - return cleanupCursor(this, { error: err }, () => callback(err, nextDocument(this))); + if (error) { + return cleanupCursor(this, { error }, () => callback(error, undefined)); + } + + if (cursorIsDead(this)) { + return cleanupCursor(this, undefined, () => callback()); } callback(); @@ -778,14 +782,8 @@ export function next( if (cursorId == null) { // All cursors must operate within a session, one must be made implicitly if not explicitly provided - cursor[kInit]((err, value) => { + cursor[kInit](err => { if (err) return callback(err); - // Intentional strict null check, because users can map cursors to falsey values. - // We allow mapping to all values except for null. - // eslint-disable-next-line no-restricted-syntax - if (value !== null) { - return callback(undefined, value); - } return next(cursor, blocking, callback); });