forked from Vendicated/Vencord
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
refactor: identifier escapes + "self" group (Vendicated#339)
Co-authored-by: Ven <[email protected]>
- Loading branch information
1 parent
4974c53
commit 989bd36
Showing
10 changed files
with
157 additions
and
30 deletions.
There are no files selected for viewing
This file contains 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
This file contains 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
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -62,7 +62,8 @@ | |
"packageManager": "[email protected]", | ||
"pnpm": { | ||
"patchedDependencies": { | ||
"[email protected]": "patches/[email protected]" | ||
"[email protected]": "patches/[email protected]", | ||
"[email protected]": "patches/[email protected]" | ||
} | ||
}, | ||
"webExt": { | ||
|
This file contains 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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,45 @@ | ||
diff --git a/lib/rules/no-useless-escape.js b/lib/rules/no-useless-escape.js | ||
index 2046a148a17fd1d5f3a4bbc9f45f7700259d11fa..f4898c6b57355a4fd72c43a9f32bf1a36a6ccf4a 100644 | ||
--- a/lib/rules/no-useless-escape.js | ||
+++ b/lib/rules/no-useless-escape.js | ||
@@ -97,12 +97,30 @@ module.exports = { | ||
escapeBackslash: "Replace the `\\` with `\\\\` to include the actual backslash character." | ||
}, | ||
|
||
- schema: [] | ||
+ schema: [{ | ||
+ type: "object", | ||
+ properties: { | ||
+ extra: { | ||
+ type: "string", | ||
+ default: "" | ||
+ }, | ||
+ extraCharClass: { | ||
+ type: "string", | ||
+ default: "" | ||
+ }, | ||
+ }, | ||
+ additionalProperties: false | ||
+ }] | ||
}, | ||
|
||
create(context) { | ||
+ const options = context.options[0] || {}; | ||
+ const { extra, extraCharClass } = options || '' | ||
const sourceCode = context.getSourceCode(); | ||
|
||
+ const NON_CHARCLASS_ESCAPES = union(REGEX_NON_CHARCLASS_ESCAPES, new Set(extra)) | ||
+ const CHARCLASS_ESCAPES = union(REGEX_GENERAL_ESCAPES, new Set(extraCharClass)) | ||
+ | ||
/** | ||
* Reports a node | ||
* @param {ASTNode} node The node to report | ||
@@ -238,7 +256,7 @@ module.exports = { | ||
.filter(charInfo => charInfo.escaped) | ||
|
||
// Filter out characters that are valid to escape, based on their position in the regular expression. | ||
- .filter(charInfo => !(charInfo.inCharClass ? REGEX_GENERAL_ESCAPES : REGEX_NON_CHARCLASS_ESCAPES).has(charInfo.text)) | ||
+ .filter(charInfo => !(charInfo.inCharClass ? CHARCLASS_ESCAPES : NON_CHARCLASS_ESCAPES).has(charInfo.text)) | ||
|
||
// Report all the remaining characters. | ||
.forEach(charInfo => report(node, charInfo.index, charInfo.text)); |
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
This file contains 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
This file contains 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
9 changes: 6 additions & 3 deletions
9
src/plugins/shikiCodeblocks/style.css → src/plugins/shikiCodeblocks/shiki.css
This file contains 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
This file contains 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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,55 @@ | ||
/* | ||
* Vencord, a modification for Discord's desktop app | ||
* Copyright (c) 2022 Vendicated and contributors | ||
* | ||
* This program is free software: you can redistribute it and/or modify | ||
* it under the terms of the GNU General Public License as published by | ||
* the Free Software Foundation, either version 3 of the License, or | ||
* (at your option) any later version. | ||
* | ||
* This program is distributed in the hope that it will be useful, | ||
* but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
* GNU General Public License for more details. | ||
* | ||
* You should have received a copy of the GNU General Public License | ||
* along with this program. If not, see <https://www.gnu.org/licenses/>. | ||
*/ | ||
|
||
import { PatchReplacement } from "./types"; | ||
|
||
export type ReplaceFn = (match: string, ...groups: string[]) => string; | ||
|
||
export function canonicalizeMatch(match: RegExp | string) { | ||
if (typeof match === "string") return match; | ||
const canonSource = match.source | ||
.replaceAll("\\i", "[A-Za-z_$][\\w$]*"); | ||
return new RegExp(canonSource, match.flags); | ||
} | ||
|
||
export function canonicalizeReplace(replace: string | ReplaceFn, pluginName: string) { | ||
if (typeof replace === "function") return replace; | ||
return replace.replaceAll("$self", `Vencord.Plugins.plugins.${pluginName}`); | ||
} | ||
|
||
export function canonicalizeDescriptor<T>(descriptor: TypedPropertyDescriptor<T>, canonicalize: (value: T) => T) { | ||
if (descriptor.get) { | ||
const original = descriptor.get; | ||
descriptor.get = function () { | ||
return canonicalize(original.call(this)); | ||
}; | ||
} else if (descriptor.value) { | ||
descriptor.value = canonicalize(descriptor.value); | ||
} | ||
return descriptor; | ||
} | ||
|
||
export function canonicalizeReplacement(replacement: Pick<PatchReplacement, "match" | "replace">, plugin: string) { | ||
const descriptors = Object.getOwnPropertyDescriptors(replacement); | ||
descriptors.match = canonicalizeDescriptor(descriptors.match, canonicalizeMatch); | ||
descriptors.replace = canonicalizeDescriptor( | ||
descriptors.replace, | ||
replace => canonicalizeReplace(replace, plugin), | ||
); | ||
Object.defineProperties(replacement, descriptors); | ||
} |
This file contains 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
This file contains 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