refactor: replace deprecated String.prototype.substr() with substring()#2181
Open
fauzan171 wants to merge 1 commit into
Open
refactor: replace deprecated String.prototype.substr() with substring()#2181fauzan171 wants to merge 1 commit into
fauzan171 wants to merge 1 commit into
Conversation
String.prototype.substr() is deprecated and may be removed in future JavaScript engine versions (Annex B of the ECMAScript specification). Replaced all occurrences in the codebase with String.prototype.substring(): - src/algorithms/string/rabin-karp/rabinKarp.js - src/algorithms/cryptography/polynomial-hash/__test__/SimplePolynomialHash.test.js - src/algorithms/cryptography/polynomial-hash/__test__/PolynomialHash.test.js The behavior is identical since all substr(start, length) calls are converted to substring(start, start + length) with the same arguments. All existing tests pass.
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
Problem
String.prototype.substr()is a legacy feature defined in Annex B of the ECMAScript specification and is deprecated. It may be removed from future JavaScript engine versions.The codebase uses
substr()in 5 places across 3 files.Fix
Replaced all
substr(start, length)calls withsubstring(start, start + length), which is the modern, standard alternative. The behavior is identical for all cases in this codebase.Files changed:
src/algorithms/string/rabin-karp/rabinKarp.js— source codesrc/algorithms/cryptography/polynomial-hash/__test__/SimplePolynomialHash.test.js— testsrc/algorithms/cryptography/polynomial-hash/__test__/PolynomialHash.test.js— testConversion pattern:
All 7 affected tests pass.