From 6b7d14aa3220afd8cf74ba3f966f44e48a5b7dac Mon Sep 17 00:00:00 2001 From: Richard Hansen Date: Tue, 19 Oct 2021 04:36:13 -0400 Subject: [PATCH] Changeset: Deprecate `oldLen()` and `newLen()` functions --- src/node/handler/PadMessageHandler.js | 4 ++-- src/static/js/Changeset.js | 14 ++++++++++++-- src/static/js/ace2_inner.js | 7 +++---- src/static/js/changesettracker.js | 2 +- 4 files changed, 18 insertions(+), 9 deletions(-) diff --git a/src/node/handler/PadMessageHandler.js b/src/node/handler/PadMessageHandler.js index 4060b748c721..970e94b8fcfb 100644 --- a/src/node/handler/PadMessageHandler.js +++ b/src/node/handler/PadMessageHandler.js @@ -632,10 +632,10 @@ const handleUserChanges = async (socket, message) => { const prevText = pad.text(); - if (Changeset.oldLen(rebasedChangeset) !== prevText.length) { + if (Changeset.unpack(rebasedChangeset).oldLen !== prevText.length) { throw new Error( `Can't apply changeset ${rebasedChangeset} with oldLen ` + - `${Changeset.oldLen(rebasedChangeset)} to document of length ${prevText.length}`); + `${Changeset.unpack(rebasedChangeset).oldLen} to document of length ${prevText.length}`); } await pad.appendRevision(rebasedChangeset, thisSession.author); diff --git a/src/static/js/Changeset.js b/src/static/js/Changeset.js index 0e46757a90ef..d7e999cda40e 100644 --- a/src/static/js/Changeset.js +++ b/src/static/js/Changeset.js @@ -276,18 +276,28 @@ class Changeset { /** * Returns the required length of the text before changeset can be applied. * + * @deprecated Use `Changeset.unpack(cs).oldLen` instead. * @param {string} cs - String representation of the Changeset * @returns {number} oldLen property */ -exports.oldLen = (cs) => Changeset.unpack(cs).oldLen; +exports.oldLen = (cs) => { + padutils.warnWithStack( + 'Changeset.oldLen(cs) is deprecated; use Changeset.unpack(cs).oldLen instead'); + return Changeset.unpack(cs).oldLen; +}; /** * Returns the length of the text after changeset is applied. * + * @deprecated Use `Changeset.unpack(cs).newLen` instead. * @param {string} cs - String representation of the Changeset * @returns {number} newLen property */ -exports.newLen = (cs) => Changeset.unpack(cs).newLen; +exports.newLen = (cs) => { + padutils.warnWithStack( + 'Changeset.newLen(cs) is deprecated; use Changeset.unpack(cs).newLen instead'); + return Changeset.unpack(cs).newLen; +}; /** * Parses a string of serialized changeset operations. diff --git a/src/static/js/ace2_inner.js b/src/static/js/ace2_inner.js index 6f16c7f5be5e..9549e5761e8c 100644 --- a/src/static/js/ace2_inner.js +++ b/src/static/js/ace2_inner.js @@ -1447,11 +1447,10 @@ function Ace2Inner(editorInfo, cssManagers) { }; const doRepApplyChangeset = (changes, insertsAfterSelection) => { - Changeset.unpack(changes).validate(); + const cs = Changeset.unpack(changes).validate(); - if (Changeset.oldLen(changes) !== rep.alltext.length) { - const errMsg = `${Changeset.oldLen(changes)}/${rep.alltext.length}`; - throw new Error(`doRepApplyChangeset length mismatch: ${errMsg}`); + if (cs.oldLen !== rep.alltext.length) { + throw new Error(`doRepApplyChangeset length mismatch: ${cs.oldLen}/${rep.alltext.length}`); } const editEvent = currentCallStack.editEvent; diff --git a/src/static/js/changesettracker.js b/src/static/js/changesettracker.js index 04abe739192e..cfe82f4a3d22 100644 --- a/src/static/js/changesettracker.js +++ b/src/static/js/changesettracker.js @@ -167,7 +167,7 @@ const makeChangesetTracker = (scheduler, apool, aceCallbacksProvider) => { let cs = null; if (toSubmit) { submittedChangeset = toSubmit; - userChangeset = Changeset.identity(Changeset.newLen(toSubmit)); + userChangeset = Changeset.identity(Changeset.unpack(toSubmit).newLen); cs = toSubmit; }