10 instantiations of RegexCharClass
System.Text.RegularExpressions (10)
System\Text\RegularExpressions\RegexCharClass.cs (1)
1475
var level = new
RegexCharClass
(IsNegated(charClass, pos), ranges, categoriesBuilder, subtraction: null);
System\Text\RegularExpressions\RegexNode.cs (1)
1192
prevCharClass = new
RegexCharClass
();
System\Text\RegularExpressions\RegexParser.cs (4)
585
RegexCharClass? charClass = scanOnly ? null : new
RegexCharClass
();
759
charClass = new
RegexCharClass
();
790
charClass = new
RegexCharClass
();
1206
var cc = new
RegexCharClass
();
System\Text\RegularExpressions\RegexPrefixAnalyzer.cs (3)
957
cc ??= new
RegexCharClass
();
966
cc ??= new
RegexCharClass
();
1003
cc ??= new
RegexCharClass
();
System\Text\RegularExpressions\Symbolic\CharSetSolver.cs (1)
138
var rcc = new
RegexCharClass
();
289 references to RegexCharClass
System.Text.RegularExpressions (289)
System\Text\RegularExpressions\RegexCharClass.cs (10)
189
private
RegexCharClass
? _subtractor;
222
private RegexCharClass(bool negate, List<(char First, char Last)>? ranges, StringBuilder? categories,
RegexCharClass
? subtraction)
242
public void AddCharClass(
RegexCharClass
cc)
260
public bool TryAddCharClass(
RegexCharClass
cc)
298
public void AddSubtraction(
RegexCharClass
sub)
1454
public static
RegexCharClass
Parse(string charClass)
1456
RegexCharClass
? outermost = null;
1457
RegexCharClass
? current = null;
1475
var
level = new RegexCharClass(IsNegated(charClass, pos), ranges, categoriesBuilder, subtraction: null);
1635
RegexCharClass
? current = this;
System\Text\RegularExpressions\RegexCompiler.cs (82)
892
primarySet.Set !=
RegexCharClass
.NotNewLineClass &&
893
primarySet.Set !=
RegexCharClass
.AnyClass;
990
else if (
RegexCharClass
.IsUnicodeCategoryOfSmallCharCount(primarySet.Set, out char[]? setChars, out bool negated, out _))
1008
if (!
RegexCharClass
.CharInClass((char)i, primarySet.Set))
1952
int numChars =
RegexCharClass
.GetSetChars(startingLiteralNode.Str!, setChars);
4054
node.Str ==
RegexCharClass
.AnyClass &&
4582
if (node.IsSetFamily && node.Str ==
RegexCharClass
.AnyClass)
4760
else if (node.IsSetFamily && maxIterations == int.MaxValue && node.Str ==
RegexCharClass
.AnyClass)
5457
if (
RegexCharClass
.TryGetSingleRange(node.Str, out _, out _) ||
5458
RegexCharClass
.GetSetChars(node.Str, setChars) > 0)
5507
bool negated =
RegexCharClass
.IsNegated(node.Str) ^ negate;
5511
if (
RegexCharClass
.TryGetSingleRange(node.Str, out char lowInclusive, out char highInclusive) &&
5528
int setCharsCount =
RegexCharClass
.GetSetChars(node.Str, setChars);
5799
case
RegexCharClass
.AnyClass:
5805
case
RegexCharClass
.DigitClass:
5806
case
RegexCharClass
.NotDigitClass:
5809
NegateIf(charClass ==
RegexCharClass
.NotDigitClass);
5812
case
RegexCharClass
.SpaceClass:
5813
case
RegexCharClass
.NotSpaceClass:
5816
NegateIf(charClass ==
RegexCharClass
.NotSpaceClass);
5819
case
RegexCharClass
.WordClass:
5820
case
RegexCharClass
.NotWordClass:
5823
NegateIf(charClass ==
RegexCharClass
.NotWordClass);
5826
case
RegexCharClass
.ControlClass:
5827
case
RegexCharClass
.NotControlClass:
5830
NegateIf(charClass ==
RegexCharClass
.NotControlClass);
5833
case
RegexCharClass
.LetterClass:
5834
case
RegexCharClass
.NotLetterClass:
5837
NegateIf(charClass ==
RegexCharClass
.NotLetterClass);
5840
case
RegexCharClass
.LetterOrDigitClass:
5841
case
RegexCharClass
.NotLetterOrDigitClass:
5844
NegateIf(charClass ==
RegexCharClass
.NotLetterOrDigitClass);
5847
case
RegexCharClass
.LowerClass:
5848
case
RegexCharClass
.NotLowerClass:
5851
NegateIf(charClass ==
RegexCharClass
.NotLowerClass);
5854
case
RegexCharClass
.UpperClass:
5855
case
RegexCharClass
.NotUpperClass:
5858
NegateIf(charClass ==
RegexCharClass
.NotUpperClass);
5861
case
RegexCharClass
.NumberClass:
5862
case
RegexCharClass
.NotNumberClass:
5865
NegateIf(charClass ==
RegexCharClass
.NotNumberClass);
5868
case
RegexCharClass
.PunctuationClass:
5869
case
RegexCharClass
.NotPunctuationClass:
5872
NegateIf(charClass ==
RegexCharClass
.NotPunctuationClass);
5875
case
RegexCharClass
.SeparatorClass:
5876
case
RegexCharClass
.NotSeparatorClass:
5879
NegateIf(charClass ==
RegexCharClass
.NotSeparatorClass);
5882
case
RegexCharClass
.SymbolClass:
5883
case
RegexCharClass
.NotSymbolClass:
5886
NegateIf(charClass ==
RegexCharClass
.NotSymbolClass);
5889
case
RegexCharClass
.AsciiLetterClass:
5890
case
RegexCharClass
.NotAsciiLetterClass:
5893
NegateIf(charClass ==
RegexCharClass
.NotAsciiLetterClass);
5896
case
RegexCharClass
.AsciiLetterOrDigitClass:
5897
case
RegexCharClass
.NotAsciiLetterOrDigitClass:
5900
NegateIf(charClass ==
RegexCharClass
.NotAsciiLetterOrDigitClass);
5903
case
RegexCharClass
.HexDigitClass:
5904
case
RegexCharClass
.NotHexDigitClass:
5907
NegateIf(charClass ==
RegexCharClass
.NotHexDigitClass);
5910
case
RegexCharClass
.HexDigitLowerClass:
5911
case
RegexCharClass
.NotHexDigitLowerClass:
5914
NegateIf(charClass ==
RegexCharClass
.NotHexDigitLowerClass);
5917
case
RegexCharClass
.HexDigitUpperClass:
5918
case
RegexCharClass
.NotHexDigitUpperClass:
5921
NegateIf(charClass ==
RegexCharClass
.NotHexDigitUpperClass);
5926
if (
RegexCharClass
.TryGetSingleRange(charClass, out char lowInclusive, out char highInclusive))
5944
NegateIf(
RegexCharClass
.IsNegated(charClass));
5955
if (
RegexCharClass
.TryGetOnlyCategories(charClass, categories, out int numCategories, out bool negated))
5973
int numChars =
RegexCharClass
.GetSetChars(charClass, setChars);
5976
if (
RegexCharClass
.DifferByOneBit(setChars[0], setChars[1], out int mask)) // special-case common case of an upper and lowercase ASCII letter combination
6006
NegateIf(
RegexCharClass
.IsNegated(charClass));
6012
if (
RegexCharClass
.TryGetDoubleRange(charClass, out (char LowInclusive, char HighInclusive) rangeLower, out (char LowInclusive, char HighInclusive) rangeUpper) &&
6019
bool negate =
RegexCharClass
.IsNegated(charClass);
6034
RegexCharClass
.CharClassAnalysisResults analysis =
RegexCharClass
.Analyze(charClass);
6045
bool negatedClass =
RegexCharClass
.IsNegated(charClass);
6048
if (
RegexCharClass
.CharInClass((char)i, charClass) ^ negatedClass)
6103
bool negatedClass =
RegexCharClass
.IsNegated(charClass);
6106
if (
RegexCharClass
.CharInClass((char)i, charClass) ^ negatedClass)
6154
if (
RegexCharClass
.TryGetDoubleRange(charClass, out (char LowInclusive, char HighInclusive) range0, out (char LowInclusive, char HighInclusive) range1))
6156
bool negate =
RegexCharClass
.IsNegated(charClass);
6292
if (
RegexCharClass
.CharInClass(c, charClass))
System\Text\RegularExpressions\RegexFindOptimizations.cs (10)
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);
498
if (
RegexCharClass
.CharInClass(span[i], set, ref startingAsciiLookup))
677
if (
RegexCharClass
.CharInClass(span[i], primarySet.Set, ref startingAsciiLookup))
771
if (!
RegexCharClass
.CharInClass(c, nextSet.Set, ref _asciiLookups![i]))
790
if (!
RegexCharClass
.CharInClass(c, primarySet.Set, ref startingAsciiLookup))
799
if (!
RegexCharClass
.CharInClass(c, nextSet.Set, ref _asciiLookups![i]))
841
while ((uint)--prev < (uint)slice.Length &&
RegexCharClass
.CharInClass(slice[prev], loopNode.Str!, ref _asciiLookups![0])) ;
System\Text\RegularExpressions\RegexInterpreter.cs (4)
852
if (!
RegexCharClass
.CharInClass(Forwardcharnext(inputSpan), _code.Strings[operand], ref _code.StringsAsciiLookup[operand]))
944
if (!
RegexCharClass
.CharInClass(Forwardcharnext(inputSpan), set, ref setLookup))
1031
if (!
RegexCharClass
.CharInClass(Forwardcharnext(inputSpan), set, ref setLookup))
1122
if (!
RegexCharClass
.CharInClass(Forwardcharnext(inputSpan), _code.Strings[operand0], ref _code.StringsAsciiLookup[operand0]))
System\Text\RegularExpressions\RegexInterpreterCode.cs (2)
165
sb.Append(Indent()).Append('\'').Append(
RegexCharClass
.DescribeChar((char)Codes[opcodeOffset + 1])).Append('\'');
173
sb.Append(Indent()).Append(
RegexCharClass
.DescribeSet(Strings[Codes[opcodeOffset + 1]]));
System\Text\RegularExpressions\RegexNode.cs (86)
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);
1016
if (
RegexCharClass
.IsEmpty(Str))
1021
else if (
RegexCharClass
.IsSingleton(Str))
1023
Ch =
RegexCharClass
.SingletonChar(Str);
1031
else if (
RegexCharClass
.IsSingletonInverse(Str))
1033
Ch =
RegexCharClass
.SingletonChar(Str);
1046
case
RegexCharClass
.WordNotWordClass:
1047
case
RegexCharClass
.NotWordWordClass:
1048
case
RegexCharClass
.DigitNotDigitClass:
1049
case
RegexCharClass
.NotDigitDigitClass:
1050
case
RegexCharClass
.SpaceNotSpaceClass:
1051
case
RegexCharClass
.NotSpaceSpaceClass:
1052
Str =
RegexCharClass
.AnyClass;
1056
case
RegexCharClass
.NegatedDigitClass: // [^\d]
1057
Str =
RegexCharClass
.NotDigitClass;
1059
case
RegexCharClass
.NegatedSpaceClass: // [^\s]
1060
Str =
RegexCharClass
.NotSpaceClass;
1062
case
RegexCharClass
.NegatedWordClass: // [^\w]
1063
Str =
RegexCharClass
.NotWordClass;
1168
if (!wasLastSet || optionsLast != optionsAt || lastNodeCannotMerge || !
RegexCharClass
.IsMergeable(at.Str!))
1171
lastNodeCannotMerge = !
RegexCharClass
.IsMergeable(at.Str!);
1189
RegexCharClass
prevCharClass;
1197
prevCharClass =
RegexCharClass
.Parse(prev.Str!);
1206
RegexCharClass
atCharClass =
RegexCharClass
.Parse(at.Str!);
1610
if (
RegexCharClass
.IsNegated(startingLiteralNode.Str!) ||
1611
(numChars =
RegexCharClass
.GetSetChars(startingLiteralNode.Str!, setChars)) == 0)
1684
if (
RegexCharClass
.TryGetSingleRange(node.Str!, out char lowInclusive, out char highInclusive) &&
1688
return new StartingLiteralData(range: (lowInclusive, highInclusive), negated:
RegexCharClass
.IsNegated(node.Str!));
1693
if ((numChars =
RegexCharClass
.GetSetChars(node.Str!, setChars)) != 0)
1695
return new StartingLiteralData(setChars: setChars.Slice(0, numChars).ToString(), negated:
RegexCharClass
.IsNegated(node.Str!));
2414
case RegexNodeKind.Set when loopNode.Kind is RegexNodeKind.Setloop &&
RegexCharClass
.IsSubsetOf(literal.Str!, loopNode.Str!): // e.g. \d+[0-9]\s
2440
RegexNodeKind.Setloop =>
RegexCharClass
.CharInClass(ch, loopNode.Str!),
2540
case RegexNodeKind.Set when !
RegexCharClass
.CharInClass(node.Ch, subsequent.Str!):
2543
case RegexNodeKind.Setlazy or RegexNodeKind.Setloop or RegexNodeKind.Setloopatomic when subsequent.M > 0 && !
RegexCharClass
.CharInClass(node.Ch, subsequent.Str!):
2547
case RegexNodeKind.Boundary when node.M > 0 &&
RegexCharClass
.IsBoundaryWordChar(node.Ch):
2548
case RegexNodeKind.NonBoundary when node.M > 0 && !
RegexCharClass
.IsBoundaryWordChar(node.Ch):
2549
case RegexNodeKind.ECMABoundary when node.M > 0 &&
RegexCharClass
.IsECMAWordChar(node.Ch):
2550
case RegexNodeKind.NonECMABoundary when node.M > 0 && !
RegexCharClass
.IsECMAWordChar(node.Ch):
2555
case RegexNodeKind.Setlazy or RegexNodeKind.Setloop or RegexNodeKind.Setloopatomic when subsequent.M == 0 && !
RegexCharClass
.CharInClass(node.Ch, subsequent.Str!):
2587
case RegexNodeKind.One when !
RegexCharClass
.CharInClass(subsequent.Ch, node.Str!):
2588
case RegexNodeKind.Set when !
RegexCharClass
.MayOverlap(node.Str!, subsequent.Str!):
2589
case RegexNodeKind.Onelazy or RegexNodeKind.Oneloop or RegexNodeKind.Oneloopatomic when subsequent.M > 0 && !
RegexCharClass
.CharInClass(subsequent.Ch, node.Str!):
2590
case RegexNodeKind.Setlazy or RegexNodeKind.Setloop or RegexNodeKind.Setloopatomic when subsequent.M > 0 && !
RegexCharClass
.MayOverlap(node.Str!, subsequent.Str!):
2591
case RegexNodeKind.Multi when !
RegexCharClass
.CharInClass(subsequent.Str![0], node.Str!):
2593
case RegexNodeKind.EndZ or RegexNodeKind.Eol when !
RegexCharClass
.CharInClass('\n', node.Str!):
2594
case RegexNodeKind.Boundary when node.M > 0 &&
RegexCharClass
.IsSubsetOf(node.Str!,
RegexCharClass
.WordClass):
2595
case RegexNodeKind.NonBoundary when node.M > 0 && node.Str is
RegexCharClass
.NotWordClass or
RegexCharClass
.NotDigitClass:
2596
case RegexNodeKind.ECMABoundary when node.M > 0 && node.Str is
RegexCharClass
.ECMAWordClass or
RegexCharClass
.ECMADigitClass:
2597
case RegexNodeKind.NonECMABoundary when node.M > 0 && node.Str is
RegexCharClass
.NotECMAWordClass or
RegexCharClass
.NotDigitClass:
2600
case RegexNodeKind.Onelazy or RegexNodeKind.Oneloop or RegexNodeKind.Oneloopatomic when subsequent.M == 0 && !
RegexCharClass
.CharInClass(subsequent.Ch, node.Str!):
2601
case RegexNodeKind.Setlazy or RegexNodeKind.Setloop or RegexNodeKind.Setloopatomic when subsequent.M == 0 && !
RegexCharClass
.MayOverlap(node.Str!, subsequent.Str!):
2621
(node.N > 1 &&
RegexCharClass
.MayOverlap(loopStartingSet, loopEndingSet)))
2627
RegexCharClass
.CharInClass(ch, loopStartingSet) ||
RegexCharClass
.CharInClass(ch, loopEndingSet);
2630
RegexCharClass
.MayOverlap(set, loopStartingSet) ||
RegexCharClass
.MayOverlap(set, loopEndingSet);
2641
case RegexNodeKind.Boundary when node.M > 0 &&
RegexCharClass
.IsSubsetOf(loopStartingSet,
RegexCharClass
.WordClass) &&
RegexCharClass
.IsSubsetOf(loopEndingSet,
RegexCharClass
.WordClass):
2642
case RegexNodeKind.NonBoundary when node.M > 0 && (loopStartingSet is
RegexCharClass
.NotWordClass or
RegexCharClass
.NotDigitClass) && (loopEndingSet is
RegexCharClass
.NotWordClass or
RegexCharClass
.NotDigitClass):
2643
case RegexNodeKind.ECMABoundary when node.M > 0 && (loopStartingSet is
RegexCharClass
.ECMAWordClass or
RegexCharClass
.ECMADigitClass) && (loopEndingSet is
RegexCharClass
.ECMAWordClass or
RegexCharClass
.ECMADigitClass):
2644
case RegexNodeKind.NonECMABoundary when node.M > 0 && (loopStartingSet is
RegexCharClass
.NotECMAWordClass or
RegexCharClass
.NotDigitClass) && (loopEndingSet is
RegexCharClass
.NotECMAWordClass or
RegexCharClass
.NotDigitClass):
2816
RegexCharClass
.IsSubsetOf(set,
RegexCharClass
.WordClass);
3139
RegexCharClass
.ParticipatesInCaseConversion(child.Ch))
3151
RegexCharClass
.ParticipatesInCaseConversion(child.Str.AsSpan()))
3163
if (!
RegexCharClass
.SetContainsAsciiOrdinalIgnoreCaseCharacter(child.Str!, twoChars))
3515
sb.Append(" '").Append(
RegexCharClass
.DescribeChar(Ch)).Append('\'');
3532
sb.Append(
RegexCharClass
.DescribeChar(c));
3540
sb.Append(' ').Append(
RegexCharClass
.DescribeSet(Str!));
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"/>.
System\Text\RegularExpressions\RegexParser.cs (34)
418
_unit = new RegexNode(RegexNodeKind.Set, _options & ~RegexOptions.IgnoreCase,
RegexCharClass
.AnyClass);
422
_unit = new RegexNode(RegexNodeKind.Set, _options & ~RegexOptions.IgnoreCase,
RegexCharClass
.NotAnyNewLineClass);
574
private
RegexCharClass
? ScanCharClass(bool caseInsensitive, bool scanOnly)
583
List<
RegexCharClass
?>? parents = null;
585
RegexCharClass
? charClass = scanOnly ? null : new RegexCharClass();
641
RegexCharClass
? parent = parents[parents.Count - 1];
758
(parents ??= new List<
RegexCharClass
?>()).Add(charClass);
787
(parents ??= new List<
RegexCharClass
?>()).Add(scanOnly ? null : charClass);
935
else if (
RegexCharClass
.IsBoundaryWordChar(ch))
982
else if (
RegexCharClass
.IsBoundaryWordChar(ch))
1037
else if (
RegexCharClass
.IsBoundaryWordChar(ch))
1171
new RegexNode(RegexNodeKind.Set, (_options & ~RegexOptions.IgnoreCase), (_options & RegexOptions.ECMAScript) != 0 ?
RegexCharClass
.ECMAWordClass :
RegexCharClass
.WordClass);
1176
new RegexNode(RegexNodeKind.Set, (_options & ~RegexOptions.IgnoreCase), (_options & RegexOptions.ECMAScript) != 0 ?
RegexCharClass
.NotECMAWordClass :
RegexCharClass
.NotWordClass);
1181
new RegexNode(RegexNodeKind.Set, (_options & ~RegexOptions.IgnoreCase), (_options & RegexOptions.ECMAScript) != 0 ?
RegexCharClass
.ECMASpaceClass :
RegexCharClass
.SpaceClass);
1186
new RegexNode(RegexNodeKind.Set, (_options & ~RegexOptions.IgnoreCase), (_options & RegexOptions.ECMAScript) != 0 ?
RegexCharClass
.NotECMASpaceClass :
RegexCharClass
.NotSpaceClass);
1191
new RegexNode(RegexNodeKind.Set, (_options & ~RegexOptions.IgnoreCase), (_options & RegexOptions.ECMAScript) != 0 ?
RegexCharClass
.ECMADigitClass :
RegexCharClass
.DigitClass);
1196
new RegexNode(RegexNodeKind.Set, (_options & ~RegexOptions.IgnoreCase), (_options & RegexOptions.ECMAScript) != 0 ?
RegexCharClass
.NotECMADigitClass :
RegexCharClass
.NotDigitClass);
1206
var
cc = new RegexCharClass();
1336
else if (angled &&
RegexCharClass
.IsBoundaryWordChar(ch))
1435
else if (angled &&
RegexCharClass
.IsBoundaryWordChar(ch))
1497
if (!
RegexCharClass
.IsBoundaryWordChar(_pattern[_pos++]))
1684
if ((_options & RegexOptions.ECMAScript) == 0 &&
RegexCharClass
.IsBoundaryWordChar(ch))
1710
if (!(
RegexCharClass
.IsBoundaryWordChar(ch) || ch == '-'))
1776
anyNewLineOptEnd.AddChild(new RegexNode(RegexNodeKind.Set, lookaheadOptsNoCase,
RegexCharClass
.AnyNewLineClass).MakeQuantifier(false, 0, 1));
1807
innerAlt.AddChild(new RegexNode(RegexNodeKind.Set, lookaheadOptsNoCase,
RegexCharClass
.AnyNewLineClass));
1833
innerAlt.AddChild(new RegexNode(RegexNodeKind.Set, lookbehindOptsNoCase,
RegexCharClass
.AnyNewLineClass));
1922
if (ch != '0' &&
RegexCharClass
.IsBoundaryWordChar(ch))
2197
case > 1 when (_options & RegexOptions.IgnoreCase) == 0 || isReplacement || !
RegexCharClass
.ParticipatesInCaseConversion(_pattern.AsSpan(pos, cch)):
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!))
System\Text\RegularExpressions\RegexRunner.cs (14)
410
return (index > startpos &&
RegexCharClass
.IsBoundaryWordChar(runtext![index - 1])) !=
411
(index < endpos &&
RegexCharClass
.IsBoundaryWordChar(runtext![index]));
417
return ((uint)indexM1 < (uint)inputSpan.Length &&
RegexCharClass
.IsBoundaryWordChar(inputSpan[indexM1])) !=
418
((uint)index < (uint)inputSpan.Length &&
RegexCharClass
.IsBoundaryWordChar(inputSpan[index]));
427
return (uint)indexMinus1 >= (uint)inputSpan.Length || !
RegexCharClass
.IsBoundaryWordChar(inputSpan[indexMinus1]);
434
(uint)index >= (uint)inputSpan.Length || !
RegexCharClass
.IsBoundaryWordChar(inputSpan[index]);
437
internal static bool IsWordChar(char ch) =>
RegexCharClass
.IsWordChar(ch);
441
return (index > startpos &&
RegexCharClass
.IsECMAWordChar(runtext![index - 1])) !=
442
(index < endpos &&
RegexCharClass
.IsECMAWordChar(runtext![index]));
448
return ((uint)indexM1 < (uint)inputSpan.Length &&
RegexCharClass
.IsECMAWordChar(inputSpan[indexM1])) !=
449
((uint)index < (uint)inputSpan.Length &&
RegexCharClass
.IsECMAWordChar(inputSpan[index]));
455
string charClass =
RegexCharClass
.ConvertOldStringsToClass(set, category);
456
return
RegexCharClass
.CharInClass(ch, charClass);
461
return
RegexCharClass
.CharInClass(ch, charClass);
System\Text\RegularExpressions\Symbolic\CharSetSolver.cs (2)
138
var
rcc = new RegexCharClass();
143
return
RegexCharClass
.DescribeSet(rcc.ToStringClass());
System\Text\RegularExpressions\Symbolic\RegexNodeConverter.cs (9)
22
/// <summary>Cache of BDDs created to represent <see cref="
RegexCharClass
"/> set strings.</summary>
323
/// <summary>Creates a BDD from the <see cref="
RegexCharClass
"/> set string to determine whether a char is in the set.</summary>
355
bool negate =
RegexCharClass
.IsNegated(set);
361
List<(char First, char Last)>? ranges =
RegexCharClass
.ComputeRanges(set);
381
int setLength = set[
RegexCharClass
.SetLengthIndex];
382
int catLength = set[
RegexCharClass
.CategoryLengthIndex];
383
int catStart = setLength +
RegexCharClass
.SetStartIndex;
523
Debug.Assert(Enum.IsDefined(code) || code == (UnicodeCategory)(
RegexCharClass
.SpaceConst - 1), $"Unknown category: {code}");
524
return code == (UnicodeCategory)(
RegexCharClass
.SpaceConst - 1) ?