From 829c1030337880c5086efa77e0f7f64154513555 Mon Sep 17 00:00:00 2001 From: yassin-kammoun-sonarsource Date: Mon, 30 Oct 2023 13:46:49 +0100 Subject: [PATCH] Improve S5869 (`duplicates-in-character-class`): Mention character class escapes --- .../javascript/rules/javascript/S5869.html | 25 ++++++++++++++++--- 1 file changed, 21 insertions(+), 4 deletions(-) diff --git a/sonar-plugin/javascript-checks/src/main/resources/org/sonar/l10n/javascript/rules/javascript/S5869.html b/sonar-plugin/javascript-checks/src/main/resources/org/sonar/l10n/javascript/rules/javascript/S5869.html index 62cc836db0d..95a3918cf7e 100644 --- a/sonar-plugin/javascript-checks/src/main/resources/org/sonar/l10n/javascript/rules/javascript/S5869.html +++ b/sonar-plugin/javascript-checks/src/main/resources/org/sonar/l10n/javascript/rules/javascript/S5869.html @@ -7,14 +7,31 @@

Why is this an issue?

mistake is trying to use a range like [0-99] to match numbers of up to two digits, when in fact it is equivalent to [0-9]. Another common cause is forgetting to escape the - character, creating an unintended range that overlaps with other characters in the character class.

-

Noncompliant code example

-
+

Character ranges can also create duplicates when used with character class escapes. These are a type of escape sequence used in regular expressions +to represent a specific set of characters. They are denoted by a backslash followed by a specific letter, such as \d for digits, +\w for word characters, or \s for whitespace characters. For example, the character class escape \d is +equivalent to the character range [0-9], and the escape \w is equivalent to [a-zA-Z0-9_].

+

How to fix it

+

Remove the extra character, character range, or character class escape.

+

Code examples

+

Noncompliant code example

+
 /[0-99]/ // Noncompliant, this won't actually match strings with two digits
 /[0-9.-_]/ // Noncompliant, .-_ is a range that already contains 0-9 (as well as various other characters such as capital letters)
+/[a-z0-9\d]/ // Noncompliant, \d matches a digit and is equivalent to [0-9]
 
-

Compliant solution

-
+

Compliant solution

+
 /[0-9]{1,2}/
 /[0-9.\-_]/
+/[a-z\d]/
 
+

Resources

+

Documentation

+