Skip to content

Commit

Permalink
[chore] replace deprecated String.prototype.substr()
Browse files Browse the repository at this point in the history
.substr() is deprecated so we replace it with .slice() which works similarily but isn't deprecated

Signed-off-by: Tobias Speicher <[email protected]>
  • Loading branch information
CommanderRoot committed Apr 6, 2022
1 parent 28fe541 commit 10e2c30
Show file tree
Hide file tree
Showing 9 changed files with 14 additions and 10 deletions.
4 changes: 4 additions & 0 deletions .eslintrc.js
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,10 @@ module.exports = {
// project-specific settings
curly: [2, 'all'],
'max-len': 'off', // handled by prettier
'no-restricted-properties': [
'error',
{ property: "substr", message: "Use .slice instead of .substr." },
],
'no-trailing-spaces': 'error',
'one-var': ['error', 'never'],
'@typescript-eslint/no-unused-vars': ['error', { args: 'none' }],
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,7 @@ export function getCompletions(
const lastCharactersBeforePosition = svelteDoc
.getText()
// use last 10 characters, should cover 99% of all cases
.substr(Math.max(offset - 10, 0), Math.min(offset, 10));
.slice(Math.max(offset - 10, 0), Math.max(offset - 10, 0) + 10);
const precededByOpeningBracket = /[\s\S]*{\s*[#:/@]\w*$/.test(lastCharactersBeforePosition);
if (isInStyleOrScript) {
return null;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ export function getHoverInfo(
const charactersAroundOffset = svelteDoc
.getText()
// use last 10 and next 10 characters, should cover 99% of all cases
.substr(offsetStart, 20);
.slice(offsetStart, offsetStart + 20);
const isSvelteTag = tagRegexp.test(charactersAroundOffset);

if (isInStyleOrScript) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -75,7 +75,7 @@ export class HoverProviderImpl implements HoverProvider {
return null;
}

const eventName = possibleEventName.substr('on:'.length);
const eventName = possibleEventName.slice('on:'.length);
const event = component.getEvents().find((event) => event.name === eventName);
if (!event) {
return null;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -283,9 +283,9 @@ export class RenameProviderImpl implements RenameProvider {
) {
const regex = new RegExp(
// no 'export let', only 'let', because that's what it's translated to in svelte2tsx
`\\s+let\\s+(${fragment.text.substr(
`\\s+let\\s+(${fragment.text.slice(
updatePropLocation.textSpan.start,
updatePropLocation.textSpan.length
updatePropLocation.textSpan.start + updatePropLocation.textSpan.length
)})($|\\s|;|:)`
);
const match = fragment.text.match(regex);
Expand Down Expand Up @@ -480,7 +480,7 @@ export class RenameProviderImpl implements RenameProvider {
const originalStart = offsetAt(location.range.start, originalText);

const isShortHandBinding =
originalText.substr(originalStart - bind.length, bind.length) === bind;
originalText.slice(originalStart - bind.length, originalStart) === bind;

const directiveName = (isShortHandBinding ? bind : '') + identifierName;
const prefixText = directiveName + '={';
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,7 @@ function getTagBodyText(tag: ts.JSDocTagInfo): string | undefined {
return (
captionTagMatches[1] +
'\n\n' +
makeCodeblock(text.substr(captionTagMatches[0].length))
makeCodeblock(text.slice(captionTagMatches[0].length))
);
} else {
return makeCodeblock(text);
Expand Down
2 changes: 1 addition & 1 deletion packages/language-server/src/plugins/typescript/utils.ts
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ import { pathToUrl } from '../../utils';
import { SnapshotFragment, SvelteSnapshotFragment } from './DocumentSnapshot';

export function getScriptKindFromFileName(fileName: string): ts.ScriptKind {
const ext = fileName.substr(fileName.lastIndexOf('.'));
const ext = fileName.slice(fileName.lastIndexOf('.'));
switch (ext.toLowerCase()) {
case ts.Extension.Js:
return ts.ScriptKind.JS;
Expand Down
2 changes: 1 addition & 1 deletion packages/svelte2tsx/src/htmlxtojsx/nodes/attribute.ts
Original file line number Diff line number Diff line change
Expand Up @@ -208,7 +208,7 @@ function sanitizeLeadingChars(attrName: string): string {
let sanitizedName = '';
for (let i = 0; i < attrName.length; i++) {
if (/[A-Za-z$_]/.test(attrName[i])) {
sanitizedName += attrName.substr(i);
sanitizedName += attrName.slice(i);
return sanitizedName;
} else {
sanitizedName += '_';
Expand Down
2 changes: 1 addition & 1 deletion packages/svelte2tsx/src/svelte2tsx/addComponentExport.ts
Original file line number Diff line number Diff line change
Expand Up @@ -196,7 +196,7 @@ function classNameFromFilename(filename: string, appendSuffix: boolean): string
// Although _ and $ are valid first characters for classes, they are invalid first characters
// for tag names. For a better import autocompletion experience, we therefore throw them out.
.findIndex((char) => /[A-Za-z]/.test(char));
const withoutLeadingInvalidCharacters = withoutInvalidCharacters.substr(firstValidCharIdx);
const withoutLeadingInvalidCharacters = withoutInvalidCharacters.slice(firstValidCharIdx);
const inPascalCase = pascalCase(withoutLeadingInvalidCharacters);
const finalName = firstValidCharIdx === -1 ? `A${inPascalCase}` : inPascalCase;
return `${finalName}${appendSuffix ? COMPONENT_SUFFIX : ''}`;
Expand Down

0 comments on commit 10e2c30

Please sign in to comment.