9 instantiations of RegexCharClass
System.Text.RegularExpressions.Generator (9)
src\libraries\System.Text.RegularExpressions\src\System\Text\RegularExpressions\RegexCharClass.cs (1)
1455
var level = new
RegexCharClass
(IsNegated(charClass, pos), ranges, categoriesBuilder, subtraction: null);
src\libraries\System.Text.RegularExpressions\src\System\Text\RegularExpressions\RegexNode.cs (1)
1137
prevCharClass = new
RegexCharClass
();
src\libraries\System.Text.RegularExpressions\src\System\Text\RegularExpressions\RegexParser.cs (4)
562
RegexCharClass? charClass = scanOnly ? null : new
RegexCharClass
();
736
charClass = new
RegexCharClass
();
767
charClass = new
RegexCharClass
();
1178
var cc = new
RegexCharClass
();
src\libraries\System.Text.RegularExpressions\src\System\Text\RegularExpressions\RegexPrefixAnalyzer.cs (3)
957
cc ??= new
RegexCharClass
();
966
cc ??= new
RegexCharClass
();
1003
cc ??= new
RegexCharClass
();
305 references to RegexCharClass
System.Text.RegularExpressions.Generator (305)
RegexGenerator.Emitter.cs (145)
640
if (!
RegexCharClass
.CharInClass((char)i, set))
649
RegexCharClass
.DigitClass => "IndexOfAnyDigit",
650
RegexCharClass
.ControlClass => "IndexOfAnyControl",
651
RegexCharClass
.LetterClass => "IndexOfAnyLetter",
652
RegexCharClass
.LetterOrDigitClass => "IndexOfAnyLetterOrDigit",
653
RegexCharClass
.LowerClass => "IndexOfAnyLower",
654
RegexCharClass
.NumberClass => "IndexOfAnyNumber",
655
RegexCharClass
.PunctuationClass => "IndexOfAnyPunctuation",
656
RegexCharClass
.SeparatorClass => "IndexOfAnySeparator",
657
RegexCharClass
.SpaceClass => "IndexOfAnyWhiteSpace",
658
RegexCharClass
.SymbolClass => "IndexOfAnySymbol",
659
RegexCharClass
.UpperClass => "IndexOfAnyUpper",
660
RegexCharClass
.WordClass => "IndexOfAnyWordChar",
662
RegexCharClass
.NotDigitClass => "IndexOfAnyExceptDigit",
663
RegexCharClass
.NotControlClass => "IndexOfAnyExceptControl",
664
RegexCharClass
.NotLetterClass => "IndexOfAnyExceptLetter",
665
RegexCharClass
.NotLetterOrDigitClass => "IndexOfAnyExceptLetterOrDigit",
666
RegexCharClass
.NotLowerClass => "IndexOfAnyExceptLower",
667
RegexCharClass
.NotNumberClass => "IndexOfAnyExceptNumber",
668
RegexCharClass
.NotPunctuationClass => "IndexOfAnyExceptPunctuation",
669
RegexCharClass
.NotSeparatorClass => "IndexOfAnyExceptSeparator",
670
RegexCharClass
.NotSpaceClass => "IndexOfAnyExceptWhiteSpace",
671
RegexCharClass
.NotSymbolClass => "IndexOfAnyExceptSymbol",
672
RegexCharClass
.NotUpperClass => "IndexOfAnyExceptUpper",
673
RegexCharClass
.NotWordClass => "IndexOfAnyExceptWordChar",
682
if (
RegexCharClass
.TryGetOnlyCategories(set, categories, out int numCategories, out bool negatedCategory))
1296
primarySet.Set !=
RegexCharClass
.NotNewLineClass &&
1297
primarySet.Set !=
RegexCharClass
.AnyClass;
1362
else if (
RegexCharClass
.IsUnicodeCategoryOfSmallCharCount(primarySet.Set, out char[]? setChars, out bool negated, out string? description))
1894
int numChars =
RegexCharClass
.GetSetChars(startingLiteralNode.Str!, setChars);
3706
node.Str ==
RegexCharClass
.AnyClass &&
4115
else if (node.IsSetFamily && node.Str ==
RegexCharClass
.AnyClass)
4230
if (node.IsSetFamily && maxIterations == int.MaxValue && node.Str ==
RegexCharClass
.AnyClass)
4253
else if (node.IsSetFamily && maxIterations == int.MaxValue && node.Str ==
RegexCharClass
.AnyClass)
5040
bool negated =
RegexCharClass
.IsNegated(node.Str) ^ negate;
5044
if (
RegexCharClass
.TryGetSingleRange(node.Str, out char lowInclusive, out char highInclusive) &&
5059
setChars = setChars.Slice(0,
RegexCharClass
.GetSetChars(node.Str, setChars));
5098
case
RegexCharClass
.AnyClass:
5101
case
RegexCharClass
.DigitClass:
5102
case
RegexCharClass
.NotDigitClass:
5103
negate ^= charClass ==
RegexCharClass
.NotDigitClass;
5106
case
RegexCharClass
.SpaceClass:
5107
case
RegexCharClass
.NotSpaceClass:
5108
negate ^= charClass ==
RegexCharClass
.NotSpaceClass;
5111
case
RegexCharClass
.WordClass:
5112
case
RegexCharClass
.NotWordClass:
5114
negate ^= charClass ==
RegexCharClass
.NotWordClass;
5117
case
RegexCharClass
.ControlClass:
5118
case
RegexCharClass
.NotControlClass:
5119
negate ^= charClass ==
RegexCharClass
.NotControlClass;
5122
case
RegexCharClass
.LetterClass:
5123
case
RegexCharClass
.NotLetterClass:
5124
negate ^= charClass ==
RegexCharClass
.NotLetterClass;
5127
case
RegexCharClass
.LetterOrDigitClass:
5128
case
RegexCharClass
.NotLetterOrDigitClass:
5129
negate ^= charClass ==
RegexCharClass
.NotLetterOrDigitClass;
5132
case
RegexCharClass
.LowerClass:
5133
case
RegexCharClass
.NotLowerClass:
5134
negate ^= charClass ==
RegexCharClass
.NotLowerClass;
5137
case
RegexCharClass
.UpperClass:
5138
case
RegexCharClass
.NotUpperClass:
5139
negate ^= charClass ==
RegexCharClass
.NotUpperClass;
5142
case
RegexCharClass
.NumberClass:
5143
case
RegexCharClass
.NotNumberClass:
5144
negate ^= charClass ==
RegexCharClass
.NotNumberClass;
5147
case
RegexCharClass
.PunctuationClass:
5148
case
RegexCharClass
.NotPunctuationClass:
5149
negate ^= charClass ==
RegexCharClass
.NotPunctuationClass;
5152
case
RegexCharClass
.SeparatorClass:
5153
case
RegexCharClass
.NotSeparatorClass:
5154
negate ^= charClass ==
RegexCharClass
.NotSeparatorClass;
5157
case
RegexCharClass
.SymbolClass:
5158
case
RegexCharClass
.NotSymbolClass:
5159
negate ^= charClass ==
RegexCharClass
.NotSymbolClass;
5162
case
RegexCharClass
.AsciiLetterClass:
5163
case
RegexCharClass
.NotAsciiLetterClass:
5164
negate ^= charClass ==
RegexCharClass
.NotAsciiLetterClass;
5167
case
RegexCharClass
.AsciiLetterOrDigitClass:
5168
case
RegexCharClass
.NotAsciiLetterOrDigitClass:
5169
negate ^= charClass ==
RegexCharClass
.NotAsciiLetterOrDigitClass;
5172
case
RegexCharClass
.HexDigitClass:
5173
case
RegexCharClass
.NotHexDigitClass:
5174
negate ^= charClass ==
RegexCharClass
.NotHexDigitClass;
5177
case
RegexCharClass
.HexDigitLowerClass:
5178
case
RegexCharClass
.NotHexDigitLowerClass:
5179
negate ^= charClass ==
RegexCharClass
.NotHexDigitLowerClass;
5182
case
RegexCharClass
.HexDigitUpperClass:
5183
case
RegexCharClass
.NotHexDigitUpperClass:
5184
negate ^= charClass ==
RegexCharClass
.NotHexDigitUpperClass;
5189
if (
RegexCharClass
.TryGetSingleRange(charClass, out char lowInclusive, out char highInclusive))
5191
negate ^=
RegexCharClass
.IsNegated(charClass);
5211
if (
RegexCharClass
.TryGetOnlyCategories(charClass, categories, out int numCategories, out bool negated))
5231
switch (
RegexCharClass
.GetSetChars(charClass, setChars))
5234
negate ^=
RegexCharClass
.IsNegated(charClass);
5235
if (
RegexCharClass
.DifferByOneBit(setChars[0], setChars[1], out mask))
5245
negate ^=
RegexCharClass
.IsNegated(charClass);
5247
return (negate,
RegexCharClass
.DifferByOneBit(setChars[0], setChars[1], out mask)) switch
5258
if (
RegexCharClass
.TryGetDoubleRange(charClass, out (char LowInclusive, char HighInclusive) rangeLower, out (char LowInclusive, char HighInclusive) rangeUpper) &&
5265
negate ^=
RegexCharClass
.IsNegated(charClass);
5270
RegexCharClass
.CharClassAnalysisResults analysis =
RegexCharClass
.Analyze(charClass);
5282
bool negatedClass =
RegexCharClass
.IsNegated(charClass);
5286
if (
RegexCharClass
.CharInClass((char)i, charClass) ^ negatedClass)
5317
bool negatedClass =
RegexCharClass
.IsNegated(charClass);
5321
if (
RegexCharClass
.CharInClass((char)i, charClass) ^ negatedClass)
5341
if (
RegexCharClass
.TryGetDoubleRange(charClass, out (char LowInclusive, char HighInclusive) range0, out (char LowInclusive, char HighInclusive) range1))
5343
negate ^=
RegexCharClass
.IsNegated(charClass);
5396
if (
RegexCharClass
.CharInClass(c, charClass))
5609
RegexCharClass
.AnyClass => "any character",
5610
RegexCharClass
.AsciiLetterClass => "an ASCII letter",
5611
RegexCharClass
.AsciiLetterOrDigitClass => "an ASCII letter or digit",
5612
RegexCharClass
.ECMASpaceClass => "a whitespace character (ECMA)",
5613
RegexCharClass
.ECMAWordClass => "a word character (ECMA)",
5614
RegexCharClass
.HexDigitClass => "a hexadecimal digit",
5615
RegexCharClass
.HexDigitLowerClass => "a lowercase hexadecimal digit",
5616
RegexCharClass
.HexDigitUpperClass => "an uppercase hexadecimal digit",
5617
RegexCharClass
.LetterClass => "a Unicode letter",
5618
RegexCharClass
.LetterOrDigitClass => "a Unicode letter or digit",
5619
RegexCharClass
.NotAsciiLetterClass => "any character other than an ASCII letter",
5620
RegexCharClass
.NotAsciiLetterOrDigitClass => "any character other than an ASCII letter or digit",
5621
RegexCharClass
.NotControlClass => "any character other than a Unicode control character",
5622
RegexCharClass
.NotDigitClass => "any character other than a Unicode digit",
5623
RegexCharClass
.NotECMASpaceClass => "any character other than a whitespace character (ECMA)",
5624
RegexCharClass
.NotECMAWordClass => "any character other than a word character (ECMA)",
5625
RegexCharClass
.NotHexDigitClass => "any character other than a hexadecimal digit",
5626
RegexCharClass
.NotHexDigitLowerClass => "any character other than a lowercase hexadecimal digit",
5627
RegexCharClass
.NotHexDigitUpperClass => "any character other than an uppercase hexadecimal digit",
5628
RegexCharClass
.NotLetterClass => "any character other than a Unicode letter",
5629
RegexCharClass
.NotLetterOrDigitClass => "any character other than a Unicode letter or digit",
5630
RegexCharClass
.NotLowerClass => "any character other than a Unicode lowercase letter",
5631
RegexCharClass
.NotNumberClass => "any character other than a Unicode number",
5632
RegexCharClass
.NotPunctuationClass => "any character other than a Unicode punctuation character",
5633
RegexCharClass
.NotSeparatorClass => "any character other than a Unicode separator",
5634
RegexCharClass
.NotSpaceClass => "any character other than a whitespace character",
5635
RegexCharClass
.NotSymbolClass => "any character other than a Unicode symbol",
5636
RegexCharClass
.NotUpperClass => "any character other than a Unicode uppercase letter",
5637
RegexCharClass
.NotWordClass => "any character other than a word character",
5638
RegexCharClass
.NumberClass => "a Unicode number",
5639
RegexCharClass
.PunctuationClass => "a Unicode punctuation character",
5640
RegexCharClass
.SeparatorClass => "a Unicode separator",
5641
RegexCharClass
.SpaceClass => "a whitespace character",
5642
RegexCharClass
.SymbolClass => "a Unicode symbol",
5643
RegexCharClass
.WordClass => "a word character",
5653
if (
RegexCharClass
.TryGetOnlyCategories(charClass, categories, out int numCategories, out bool negatedCategories) &&
5700
return $"a character in the set {
RegexCharClass
.DescribeSet(charClass)}";
src\libraries\System.Text.RegularExpressions\src\System\Text\RegularExpressions\RegexCharClass.cs (10)
186
private
RegexCharClass
? _subtractor;
219
private RegexCharClass(bool negate, List<(char First, char Last)>? ranges, StringBuilder? categories,
RegexCharClass
? subtraction)
239
public void AddCharClass(
RegexCharClass
cc)
257
public bool TryAddCharClass(
RegexCharClass
cc)
295
public void AddSubtraction(
RegexCharClass
sub)
1434
public static
RegexCharClass
Parse(string charClass)
1436
RegexCharClass
? outermost = null;
1437
RegexCharClass
? current = null;
1455
var
level = new RegexCharClass(IsNegated(charClass, pos), ranges, categoriesBuilder, subtraction: null);
1615
RegexCharClass
? current = this;
src\libraries\System.Text.RegularExpressions\src\System\Text\RegularExpressions\RegexFindOptimizations.cs (4)
131
if (!
RegexCharClass
.IsNegated(charClass) &&
132
(scratchCount =
RegexCharClass
.GetSetChars(charClass, scratch)) > 0)
142
Debug.Assert(!
RegexCharClass
.IsNegated(charClass));
149
Debug.Assert(!
RegexCharClass
.IsNegated(charClass) || chars is null);
src\libraries\System.Text.RegularExpressions\src\System\Text\RegularExpressions\RegexNode.cs (80)
26
/// <remarks>For a <see cref="RegexNodeKind.Multi"/>, this is the string from the expression. For an <see cref="IsSetFamily"/> node, this is the character class string from <see cref="
RegexCharClass
"/>.</remarks>
126
string stringSet =
RegexCharClass
.CharsToStringClass(equivalences);
961
if (
RegexCharClass
.IsEmpty(Str))
966
else if (
RegexCharClass
.IsSingleton(Str))
968
Ch =
RegexCharClass
.SingletonChar(Str);
976
else if (
RegexCharClass
.IsSingletonInverse(Str))
978
Ch =
RegexCharClass
.SingletonChar(Str);
991
case
RegexCharClass
.WordNotWordClass:
992
case
RegexCharClass
.NotWordWordClass:
993
case
RegexCharClass
.DigitNotDigitClass:
994
case
RegexCharClass
.NotDigitDigitClass:
995
case
RegexCharClass
.SpaceNotSpaceClass:
996
case
RegexCharClass
.NotSpaceSpaceClass:
997
Str =
RegexCharClass
.AnyClass;
1001
case
RegexCharClass
.NegatedDigitClass: // [^\d]
1002
Str =
RegexCharClass
.NotDigitClass;
1004
case
RegexCharClass
.NegatedSpaceClass: // [^\s]
1005
Str =
RegexCharClass
.NotSpaceClass;
1007
case
RegexCharClass
.NegatedWordClass: // [^\w]
1008
Str =
RegexCharClass
.NotWordClass;
1113
if (!wasLastSet || optionsLast != optionsAt || lastNodeCannotMerge || !
RegexCharClass
.IsMergeable(at.Str!))
1116
lastNodeCannotMerge = !
RegexCharClass
.IsMergeable(at.Str!);
1134
RegexCharClass
prevCharClass;
1142
prevCharClass =
RegexCharClass
.Parse(prev.Str!);
1151
RegexCharClass
atCharClass =
RegexCharClass
.Parse(at.Str!);
1552
if (
RegexCharClass
.IsNegated(startingLiteralNode.Str!) ||
1553
(numChars =
RegexCharClass
.GetSetChars(startingLiteralNode.Str!, setChars)) == 0)
1626
if (
RegexCharClass
.TryGetSingleRange(node.Str!, out char lowInclusive, out char highInclusive) &&
1630
return new StartingLiteralData(range: (lowInclusive, highInclusive), negated:
RegexCharClass
.IsNegated(node.Str!));
1635
if ((numChars =
RegexCharClass
.GetSetChars(node.Str!, setChars)) != 0)
1637
return new StartingLiteralData(setChars: setChars.Slice(0, numChars).ToString(), negated:
RegexCharClass
.IsNegated(node.Str!));
2424
case RegexNodeKind.Set when !
RegexCharClass
.CharInClass(node.Ch, subsequent.Str!):
2427
case RegexNodeKind.Setlazy or RegexNodeKind.Setloop or RegexNodeKind.Setloopatomic when subsequent.M > 0 && !
RegexCharClass
.CharInClass(node.Ch, subsequent.Str!):
2431
case RegexNodeKind.Boundary when node.M > 0 &&
RegexCharClass
.IsBoundaryWordChar(node.Ch):
2432
case RegexNodeKind.NonBoundary when node.M > 0 && !
RegexCharClass
.IsBoundaryWordChar(node.Ch):
2433
case RegexNodeKind.ECMABoundary when node.M > 0 &&
RegexCharClass
.IsECMAWordChar(node.Ch):
2434
case RegexNodeKind.NonECMABoundary when node.M > 0 && !
RegexCharClass
.IsECMAWordChar(node.Ch):
2439
case RegexNodeKind.Setlazy or RegexNodeKind.Setloop or RegexNodeKind.Setloopatomic when subsequent.M == 0 && !
RegexCharClass
.CharInClass(node.Ch, subsequent.Str!):
2471
case RegexNodeKind.One when !
RegexCharClass
.CharInClass(subsequent.Ch, node.Str!):
2472
case RegexNodeKind.Set when !
RegexCharClass
.MayOverlap(node.Str!, subsequent.Str!):
2473
case RegexNodeKind.Onelazy or RegexNodeKind.Oneloop or RegexNodeKind.Oneloopatomic when subsequent.M > 0 && !
RegexCharClass
.CharInClass(subsequent.Ch, node.Str!):
2474
case RegexNodeKind.Setlazy or RegexNodeKind.Setloop or RegexNodeKind.Setloopatomic when subsequent.M > 0 && !
RegexCharClass
.MayOverlap(node.Str!, subsequent.Str!):
2475
case RegexNodeKind.Multi when !
RegexCharClass
.CharInClass(subsequent.Str![0], node.Str!):
2477
case RegexNodeKind.EndZ or RegexNodeKind.Eol when !
RegexCharClass
.CharInClass('\n', node.Str!):
2478
case RegexNodeKind.Boundary when node.M > 0 &&
RegexCharClass
.IsKnownWordClassSubset(node.Str!):
2479
case RegexNodeKind.NonBoundary when node.M > 0 && node.Str is
RegexCharClass
.NotWordClass or
RegexCharClass
.NotDigitClass:
2480
case RegexNodeKind.ECMABoundary when node.M > 0 && node.Str is
RegexCharClass
.ECMAWordClass or
RegexCharClass
.ECMADigitClass:
2481
case RegexNodeKind.NonECMABoundary when node.M > 0 && node.Str is
RegexCharClass
.NotECMAWordClass or
RegexCharClass
.NotDigitClass:
2484
case RegexNodeKind.Onelazy or RegexNodeKind.Oneloop or RegexNodeKind.Oneloopatomic when subsequent.M == 0 && !
RegexCharClass
.CharInClass(subsequent.Ch, node.Str!):
2485
case RegexNodeKind.Setlazy or RegexNodeKind.Setloop or RegexNodeKind.Setloopatomic when subsequent.M == 0 && !
RegexCharClass
.MayOverlap(node.Str!, subsequent.Str!):
2505
(node.N > 1 &&
RegexCharClass
.MayOverlap(loopStartingSet, loopEndingSet)))
2511
RegexCharClass
.CharInClass(ch, loopStartingSet) ||
RegexCharClass
.CharInClass(ch, loopEndingSet);
2514
RegexCharClass
.MayOverlap(set, loopStartingSet) ||
RegexCharClass
.MayOverlap(set, loopEndingSet);
2525
case RegexNodeKind.Boundary when node.M > 0 &&
RegexCharClass
.IsKnownWordClassSubset(loopStartingSet) &&
RegexCharClass
.IsKnownWordClassSubset(loopEndingSet):
2526
case RegexNodeKind.NonBoundary when node.M > 0 && (loopStartingSet is
RegexCharClass
.NotWordClass or
RegexCharClass
.NotDigitClass) && (loopEndingSet is
RegexCharClass
.NotWordClass or
RegexCharClass
.NotDigitClass):
2527
case RegexNodeKind.ECMABoundary when node.M > 0 && (loopStartingSet is
RegexCharClass
.ECMAWordClass or
RegexCharClass
.ECMADigitClass) && (loopEndingSet is
RegexCharClass
.ECMAWordClass or
RegexCharClass
.ECMADigitClass):
2528
case RegexNodeKind.NonECMABoundary when node.M > 0 && (loopStartingSet is
RegexCharClass
.NotECMAWordClass or
RegexCharClass
.NotDigitClass) && (loopEndingSet is
RegexCharClass
.NotECMAWordClass or
RegexCharClass
.NotDigitClass):
2679
RegexCharClass
.IsKnownWordClassSubset(set);
2979
RegexCharClass
.ParticipatesInCaseConversion(child.Ch))
2991
RegexCharClass
.ParticipatesInCaseConversion(child.Str.AsSpan()))
3003
if (!
RegexCharClass
.SetContainsAsciiOrdinalIgnoreCaseCharacter(child.Str!, twoChars))
3327
sb.Append(" '").Append(
RegexCharClass
.DescribeChar(Ch)).Append('\'');
3344
sb.Append(
RegexCharClass
.DescribeChar(c));
3352
sb.Append(' ').Append(
RegexCharClass
.DescribeSet(Str!));
src\libraries\System.Text.RegularExpressions\src\System\Text\RegularExpressions\RegexNodeKind.cs (4)
22
/// <remarks>The <see cref="
RegexCharClass
"/> set string is specified in <see cref="RegexNode.Str"/>.</remarks>
40
/// <remarks>The <see cref="
RegexCharClass
"/> set string is specified in <see cref="RegexNode.Str"/>, the minimum number of iterations in <see cref="RegexNode.M"/>, and the maximum number of iterations in <see cref="RegexNode.N"/>.</remarks>
53
/// <remarks>The <see cref="
RegexCharClass
"/> set string is specified in <see cref="RegexNode.Str"/>, the minimum number of iterations in <see cref="RegexNode.M"/>, and the maximum number of iterations in <see cref="RegexNode.N"/>.</remarks>
71
/// The <see cref="
RegexCharClass
"/> set string is specified in <see cref="RegexNode.Str"/>, the minimum number of iterations in <see cref="RegexNode.M"/>, and the maximum number of iterations in <see cref="RegexNode.N"/>.
src\libraries\System.Text.RegularExpressions\src\System\Text\RegularExpressions\RegexParser.cs (30)
403
new RegexNode(RegexNodeKind.Set, _options & ~RegexOptions.IgnoreCase,
RegexCharClass
.AnyClass) :
551
private
RegexCharClass
? ScanCharClass(bool caseInsensitive, bool scanOnly)
560
List<
RegexCharClass
?>? parents = null;
562
RegexCharClass
? charClass = scanOnly ? null : new RegexCharClass();
618
RegexCharClass
? parent = parents[parents.Count - 1];
735
(parents ??= new List<
RegexCharClass
?>()).Add(charClass);
764
(parents ??= new List<
RegexCharClass
?>()).Add(scanOnly ? null : charClass);
912
else if (
RegexCharClass
.IsBoundaryWordChar(ch))
959
else if (
RegexCharClass
.IsBoundaryWordChar(ch))
1014
else if (
RegexCharClass
.IsBoundaryWordChar(ch))
1143
new RegexNode(RegexNodeKind.Set, (_options & ~RegexOptions.IgnoreCase), (_options & RegexOptions.ECMAScript) != 0 ?
RegexCharClass
.ECMAWordClass :
RegexCharClass
.WordClass);
1148
new RegexNode(RegexNodeKind.Set, (_options & ~RegexOptions.IgnoreCase), (_options & RegexOptions.ECMAScript) != 0 ?
RegexCharClass
.NotECMAWordClass :
RegexCharClass
.NotWordClass);
1153
new RegexNode(RegexNodeKind.Set, (_options & ~RegexOptions.IgnoreCase), (_options & RegexOptions.ECMAScript) != 0 ?
RegexCharClass
.ECMASpaceClass :
RegexCharClass
.SpaceClass);
1158
new RegexNode(RegexNodeKind.Set, (_options & ~RegexOptions.IgnoreCase), (_options & RegexOptions.ECMAScript) != 0 ?
RegexCharClass
.NotECMASpaceClass :
RegexCharClass
.NotSpaceClass);
1163
new RegexNode(RegexNodeKind.Set, (_options & ~RegexOptions.IgnoreCase), (_options & RegexOptions.ECMAScript) != 0 ?
RegexCharClass
.ECMADigitClass :
RegexCharClass
.DigitClass);
1168
new RegexNode(RegexNodeKind.Set, (_options & ~RegexOptions.IgnoreCase), (_options & RegexOptions.ECMAScript) != 0 ?
RegexCharClass
.NotECMADigitClass :
RegexCharClass
.NotDigitClass);
1178
var
cc = new RegexCharClass();
1308
else if (angled &&
RegexCharClass
.IsBoundaryWordChar(ch))
1407
else if (angled &&
RegexCharClass
.IsBoundaryWordChar(ch))
1469
if (!
RegexCharClass
.IsBoundaryWordChar(_pattern[_pos++]))
1656
if ((_options & RegexOptions.ECMAScript) == 0 &&
RegexCharClass
.IsBoundaryWordChar(ch))
1682
if (!(
RegexCharClass
.IsBoundaryWordChar(ch) || ch == '-'))
1775
if (ch != '0' &&
RegexCharClass
.IsBoundaryWordChar(ch))
2050
case > 1 when (_options & RegexOptions.IgnoreCase) == 0 || isReplacement || !
RegexCharClass
.ParticipatesInCaseConversion(_pattern.AsSpan(pos, cch)):
src\libraries\System.Text.RegularExpressions\src\System\Text\RegularExpressions\RegexPrefixAnalyzer.cs (32)
112
case RegexNodeKind.One or RegexNodeKind.Oneloop or RegexNodeKind.Onelazy or RegexNodeKind.Oneloopatomic when !ignoreCase || !
RegexCharClass
.ParticipatesInCaseConversion(node.Ch):
138
if (
RegexCharClass
.ParticipatesInCaseConversion(c))
156
case RegexNodeKind.Set or RegexNodeKind.Setloop or RegexNodeKind.Setlazy or RegexNodeKind.Setloopatomic when !
RegexCharClass
.IsNegated(node.Str!): // negated sets are too complex to analyze
158
int charCount =
RegexCharClass
.GetSetChars(node.Str!, setChars);
197
if (!
RegexCharClass
.SetContainsAsciiOrdinalIgnoreCaseCharacter(node.Str!, setChars))
530
if (results[i].Set ==
RegexCharClass
.AnyClass)
532
results.RemoveAll(s => s.Set ==
RegexCharClass
.AnyClass);
543
charClass ==
RegexCharClass
.AnyClass) // weed out match-all, same as above
557
result.Negated =
RegexCharClass
.IsNegated(result.Set);
559
if (
RegexCharClass
.TryGetSingleRange(result.Set, out char lowInclusive, out char highInclusive) &&
566
int count =
RegexCharClass
.GetSetChars(result.Set, scratch);
603
string setString =
RegexCharClass
.OneToStringClass(node.Ch);
611
string setString =
RegexCharClass
.OneToStringClass(node.Ch);
627
string setString =
RegexCharClass
.OneToStringClass(s[i]);
714
var combined = new Dictionary<int, (
RegexCharClass
Set, int Count)>();
742
if (combined.TryGetValue(fixedSet.Distance, out (
RegexCharClass
Set, int Count) value))
744
if (value.Set.TryAddCharClass(
RegexCharClass
.Parse(fixedSet.Set)))
752
combined[fixedSet.Distance] = (
RegexCharClass
.Parse(fixedSet.Set), 1);
757
foreach (KeyValuePair<int, (
RegexCharClass
Set, int Count)> pair in combined)
924
RegexCharClass
? cc = null;
942
static bool? TryFindFirstOrLastCharClass(RegexNode node, bool findFirst, ref
RegexCharClass
? cc)
986
cc =
RegexCharClass
.Parse(node.Str!);
989
else if (cc.CanMerge &&
RegexCharClass
.Parse(node.Str!) is { CanMerge: true } setCc)
1184
RegexCharClass
.CharInClass(prefix[0], firstChild.Str!) ? null :
1200
!
RegexCharClass
.ParticipatesInCaseConversion(ordinalCaseInsensitivePrefix[0]) ||
1203
if (
RegexCharClass
.ParticipatesInCaseConversion(ordinalCaseInsensitivePrefix[0]))
1205
if (
RegexCharClass
.CharInClass((char)(ordinalCaseInsensitivePrefix[0] | 0x20), firstChild.Str!) ||
1206
RegexCharClass
.CharInClass((char)(ordinalCaseInsensitivePrefix[0] & ~0x20), firstChild.Str!))
1211
else if (
RegexCharClass
.CharInClass(ordinalCaseInsensitivePrefix[0], firstChild.Str!))
1232
!
RegexCharClass
.IsNegated(nextChild.Str!) &&
1236
chars = chars.Slice(0,
RegexCharClass
.GetSetChars(nextChild.Str!, chars));
1241
if (
RegexCharClass
.CharInClass(c, firstChild.Str!))