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