-
-
Notifications
You must be signed in to change notification settings - Fork 105
Open
Description
Rule details
Compute the Unicode skeleton of declared identifiers and disallow if similar to an identifier already in scope
Related CVE
Example code
const loremIpsum = "latin only";
const lоrеmIрsum = "with Cyrillic ";
const loremIpsum = "with ZWJ";
Participation
- I am willing to submit a pull request to implement this rule.
Additional comments
The Zero-Width Joiner (\u200d
) is a valid identifier character, even though some parsers like the ones used by typescript or Webpack fail to parse correctly.
Cyrillic characters in the example code is one case of confusable unicode character with latin character, but there are a lot of other possibilities, including confusion between non-latin characters. Unicode defines an algorithm to compute the skeleton of text, which we could apply to identifiers, and base the comparison on the skeleton instead of the identifier string.
First reported in eslint/eslint#15240 (comment)
Azarattum
Metadata
Metadata
Assignees
Labels
No labels