12 types derived from PatternSyntax
Microsoft.CodeAnalysis.CSharp (12)
_generated\2\Syntax.xml.Syntax.Generated.cs (12)
5245public sealed partial class DiscardPatternSyntax : PatternSyntax 5283public sealed partial class DeclarationPatternSyntax : PatternSyntax 5338public sealed partial class VarPatternSyntax : PatternSyntax 5380public sealed partial class RecursivePatternSyntax : PatternSyntax 5621public sealed partial class ConstantPatternSyntax : PatternSyntax 5661public sealed partial class ParenthesizedPatternSyntax : PatternSyntax 5706public sealed partial class RelationalPatternSyntax : PatternSyntax 5749public sealed partial class TypePatternSyntax : PatternSyntax 5790public sealed partial class BinaryPatternSyntax : PatternSyntax 5848public sealed partial class UnaryPatternSyntax : PatternSyntax 5890public sealed partial class ListPatternSyntax : PatternSyntax 5960public sealed partial class SlicePatternSyntax : PatternSyntax
249 references to PatternSyntax
Microsoft.CodeAnalysis.CSharp (87)
_generated\0\Syntax.xml.Main.Generated.cs (32)
1774=> node.Update((ExpressionSyntax?)Visit(node.Expression) ?? throw new ArgumentNullException("expression"), VisitToken(node.IsKeyword), (PatternSyntax?)Visit(node.Pattern) ?? throw new ArgumentNullException("pattern")); 1801=> node.Update((BaseExpressionColonSyntax?)Visit(node.ExpressionColon), (PatternSyntax?)Visit(node.Pattern) ?? throw new ArgumentNullException("pattern")); 1807=> node.Update(VisitToken(node.OpenParenToken), (PatternSyntax?)Visit(node.Pattern) ?? throw new ArgumentNullException("pattern"), VisitToken(node.CloseParenToken)); 1816=> node.Update((PatternSyntax?)Visit(node.Left) ?? throw new ArgumentNullException("left"), VisitToken(node.OperatorToken), (PatternSyntax?)Visit(node.Right) ?? throw new ArgumentNullException("right")); 1819=> node.Update(VisitToken(node.OperatorToken), (PatternSyntax?)Visit(node.Pattern) ?? throw new ArgumentNullException("pattern")); 1825=> node.Update(VisitToken(node.DotDotToken), (PatternSyntax?)Visit(node.Pattern)); 1939=> node.Update(VisitToken(node.Keyword), (PatternSyntax?)Visit(node.Pattern) ?? throw new ArgumentNullException("pattern"), (WhenClauseSyntax?)Visit(node.WhenClause), VisitToken(node.ColonToken)); 1951=> node.Update((PatternSyntax?)Visit(node.Pattern) ?? throw new ArgumentNullException("pattern"), (WhenClauseSyntax?)Visit(node.WhenClause), VisitToken(node.EqualsGreaterThanToken), (ExpressionSyntax?)Visit(node.Expression) ?? throw new ArgumentNullException("expression")); 3700public static IsPatternExpressionSyntax IsPatternExpression(ExpressionSyntax expression, SyntaxToken isKeyword, PatternSyntax pattern) 3709public static IsPatternExpressionSyntax IsPatternExpression(ExpressionSyntax expression, PatternSyntax pattern) 3802public static SubpatternSyntax Subpattern(BaseExpressionColonSyntax? expressionColon, PatternSyntax pattern) 3809public static SubpatternSyntax Subpattern(PatternSyntax pattern) 3820public static ParenthesizedPatternSyntax ParenthesizedPattern(SyntaxToken openParenToken, PatternSyntax pattern, SyntaxToken closeParenToken) 3829public static ParenthesizedPatternSyntax ParenthesizedPattern(PatternSyntax pattern) 3857public static BinaryPatternSyntax BinaryPattern(SyntaxKind kind, PatternSyntax left, SyntaxToken operatorToken, PatternSyntax right) 3877public static BinaryPatternSyntax BinaryPattern(SyntaxKind kind, PatternSyntax left, PatternSyntax right) 3889public static UnaryPatternSyntax UnaryPattern(SyntaxToken operatorToken, PatternSyntax pattern) 3897public static UnaryPatternSyntax UnaryPattern(PatternSyntax pattern) 3901public static ListPatternSyntax ListPattern(SyntaxToken openBracketToken, SeparatedSyntaxList<PatternSyntax> patterns, SyntaxToken closeBracketToken, VariableDesignationSyntax? designation) 3909public static ListPatternSyntax ListPattern(SeparatedSyntaxList<PatternSyntax> patterns, VariableDesignationSyntax? designation) 3913public static ListPatternSyntax ListPattern(SeparatedSyntaxList<PatternSyntax> patterns = default) 3917public static SlicePatternSyntax SlicePattern(SyntaxToken dotDotToken, PatternSyntax? pattern) 3924public static SlicePatternSyntax SlicePattern(PatternSyntax? pattern = default) 4615public static CasePatternSwitchLabelSyntax CasePatternSwitchLabel(SyntaxToken keyword, PatternSyntax pattern, WhenClauseSyntax? whenClause, SyntaxToken colonToken) 4624public static CasePatternSwitchLabelSyntax CasePatternSwitchLabel(PatternSyntax pattern, WhenClauseSyntax? whenClause, SyntaxToken colonToken) 4628public static CasePatternSwitchLabelSyntax CasePatternSwitchLabel(PatternSyntax pattern, SyntaxToken colonToken) 4675public static SwitchExpressionArmSyntax SwitchExpressionArm(PatternSyntax pattern, WhenClauseSyntax? whenClause, SyntaxToken equalsGreaterThanToken, ExpressionSyntax expression) 4684public static SwitchExpressionArmSyntax SwitchExpressionArm(PatternSyntax pattern, WhenClauseSyntax? whenClause, ExpressionSyntax expression) 4688public static SwitchExpressionArmSyntax SwitchExpressionArm(PatternSyntax pattern, ExpressionSyntax expression)
_generated\2\Syntax.xml.Syntax.Generated.cs (41)
5096private PatternSyntax? pattern; 5109public PatternSyntax Pattern => GetRed(ref this.pattern, 2)!; 5130public IsPatternExpressionSyntax Update(ExpressionSyntax expression, SyntaxToken isKeyword, PatternSyntax pattern) 5144public IsPatternExpressionSyntax WithPattern(PatternSyntax pattern) => Update(this.Expression, this.IsKeyword, pattern); 5569private PatternSyntax? pattern; 5578public PatternSyntax Pattern => GetRed(ref this.pattern, 1)!; 5599public SubpatternSyntax Update(BaseExpressionColonSyntax? expressionColon, PatternSyntax pattern) 5612public SubpatternSyntax WithPattern(PatternSyntax pattern) => Update(this.ExpressionColon, pattern); 5663private PatternSyntax? pattern; 5672public PatternSyntax Pattern => GetRed(ref this.pattern, 1)!; 5683public ParenthesizedPatternSyntax Update(SyntaxToken openParenToken, PatternSyntax pattern, SyntaxToken closeParenToken) 5696public ParenthesizedPatternSyntax WithPattern(PatternSyntax pattern) => Update(this.OpenParenToken, pattern, this.CloseParenToken); 5792private PatternSyntax? left; 5793private PatternSyntax? right; 5800public PatternSyntax Left => GetRedAtZero(ref this.left)!; 5804public PatternSyntax Right => GetRed(ref this.right, 2)!; 5825public BinaryPatternSyntax Update(PatternSyntax left, SyntaxToken operatorToken, PatternSyntax right) 5837public BinaryPatternSyntax WithLeft(PatternSyntax left) => Update(left, this.OperatorToken, this.Right); 5839public BinaryPatternSyntax WithRight(PatternSyntax right) => Update(this.Left, this.OperatorToken, right); 5850private PatternSyntax? pattern; 5859public PatternSyntax Pattern => GetRed(ref this.pattern, 1)!; 5868public UnaryPatternSyntax Update(SyntaxToken operatorToken, PatternSyntax pattern) 5881public UnaryPatternSyntax WithPattern(PatternSyntax pattern) => Update(this.OperatorToken, pattern); 5902public SeparatedSyntaxList<PatternSyntax> Patterns 5907return red != null ? new SeparatedSyntaxList<PatternSyntax>(red, GetChildIndex(1)) : default; 5934public ListPatternSyntax Update(SyntaxToken openBracketToken, SeparatedSyntaxList<PatternSyntax> patterns, SyntaxToken closeBracketToken, VariableDesignationSyntax? designation) 5947public ListPatternSyntax WithPatterns(SeparatedSyntaxList<PatternSyntax> patterns) => Update(this.OpenBracketToken, patterns, this.CloseBracketToken, this.Designation); 5951public ListPatternSyntax AddPatterns(params PatternSyntax[] items) => WithPatterns(this.Patterns.AddRange(items)); 5962private PatternSyntax? pattern; 5971public PatternSyntax? Pattern => GetRed(ref this.pattern, 1); 5980public SlicePatternSyntax Update(SyntaxToken dotDotToken, PatternSyntax? pattern) 5993public SlicePatternSyntax WithPattern(PatternSyntax? pattern) => Update(this.DotDotToken, pattern); 8701private PatternSyntax? pattern; 8715public PatternSyntax Pattern => GetRed(ref this.pattern, 1)!; 8740public CasePatternSwitchLabelSyntax Update(SyntaxToken keyword, PatternSyntax pattern, WhenClauseSyntax? whenClause, SyntaxToken colonToken) 8754public CasePatternSwitchLabelSyntax WithPattern(PatternSyntax pattern) => Update(this.Keyword, pattern, this.WhenClause, this.ColonToken); 8938private PatternSyntax? pattern; 8947public PatternSyntax Pattern => GetRedAtZero(ref this.pattern)!; 8976public SwitchExpressionArmSyntax Update(PatternSyntax pattern, WhenClauseSyntax? whenClause, SyntaxToken equalsGreaterThanToken, ExpressionSyntax expression) 8988public SwitchExpressionArmSyntax WithPattern(PatternSyntax pattern) => Update(pattern, this.WhenClause, this.EqualsGreaterThanToken, this.Expression);
Binder\Binder_Patterns.cs (4)
362PatternSyntax node, 468SeparatedSyntaxList<PatternSyntax> subpatterns, 480foreach (PatternSyntax pattern in subpatterns) 1895PatternSyntax pattern = p.Pattern;
Binder\ExpressionVariableFinder.cs (2)
346PatternSyntax currentPattern = node; 348var rightPatternStack = ArrayBuilder<PatternSyntax>.GetInstance();
BoundTree\BoundTreeVisitors.cs (3)
187if (syntax is not (ExpressionSyntax or PatternSyntax)) 189syntax = syntax.DescendantNodes(n => n is not (ExpressionSyntax or PatternSyntax)).FirstOrDefault(n => n is ExpressionSyntax or PatternSyntax) ?? syntax;
Compilation\CSharpSemanticModel.cs (2)
952public TypeInfo GetTypeInfo(PatternSyntax pattern, CancellationToken cancellationToken = default(CancellationToken)) 5058case PatternSyntax pattern:
Compilation\MemberSemanticModel.cs (1)
2297!(node is PatternSyntax))
Syntax\SubpatternSyntax.cs (2)
16public SubpatternSyntax Update(NameColonSyntax? nameColon, PatternSyntax pattern) 25public static SubpatternSyntax Subpattern(NameColonSyntax? nameColon, PatternSyntax pattern)
Microsoft.CodeAnalysis.CSharp.CodeStyle (22)
src\roslyn\src\Analyzers\CSharp\Analyzers\AddRequiredParentheses\CSharpAddRequiredPatternParenthesesDiagnosticAnalyzer.cs (6)
18PatternSyntax, BinaryPatternSyntax, SyntaxKind>(CSharpPatternPrecedenceService.Instance) 28protected override bool IsBinaryLike(PatternSyntax node) 31protected override (PatternSyntax, SyntaxToken, PatternSyntax) GetPartsOfBinaryLike(BinaryPatternSyntax binaryPattern) 37protected override PatternSyntax? TryGetAppropriateParent(BinaryPatternSyntax binaryLike) 38=> binaryLike.Parent as PatternSyntax;
src\roslyn\src\Analyzers\CSharp\Analyzers\RemoveUnnecessaryParentheses\CSharpRemoveUnnecessaryPatternParenthesesDiagnosticAnalyzer.cs (2)
47var inner = parenthesizedPattern.Pattern; 53if (parenthesizedPattern.Parent is not PatternSyntax)
src\roslyn\src\Analyzers\CSharp\Analyzers\UseNullPropagation\CSharpUseNullPropagationDiagnosticAnalyzer.cs (1)
52var pattern = patternExpression.Pattern;
src\roslyn\src\Analyzers\CSharp\Analyzers\UsePatternCombinators\AnalyzedPattern.cs (2)
84internal sealed class Source(PatternSyntax patternSyntax, IOperation target) : AnalyzedPattern(target) 86public readonly PatternSyntax PatternSyntax = patternSyntax;
src\roslyn\src\Analyzers\CSharp\Analyzers\UsePatternCombinators\CSharpUsePatternCombinatorsAnalyzer.cs (1)
64case IIsPatternOperation { Pattern.Syntax: PatternSyntax pattern } op:
src\roslyn\src\Workspaces\SharedUtilitiesAndExtensions\Compiler\CSharp\Extensions\ParenthesizedExpressionSyntaxExtensions.cs (5)
736var pattern = node.Pattern; 781return node.Parent is PatternSyntax patternParent && 786ParenthesizedPatternSyntax node, PatternSyntax parentPattern) 788var pattern = node.Pattern; 801public static OperatorPrecedence GetOperatorPrecedence(this PatternSyntax pattern)
src\roslyn\src\Workspaces\SharedUtilitiesAndExtensions\Compiler\CSharp\Services\Precedence\CSharpPatternPrecedenceService.cs (2)
12internal sealed class CSharpPatternPrecedenceService : AbstractCSharpPrecedenceService<PatternSyntax> 20public override OperatorPrecedence GetOperatorPrecedence(PatternSyntax pattern)
src\roslyn\src\Workspaces\SharedUtilitiesAndExtensions\Compiler\CSharp\Services\SyntaxFacts\CSharpSyntaxFacts.cs (2)
1010return node is PatternSyntax ? null : node; 1372=> node is PatternSyntax;
src\roslyn\src\Workspaces\SharedUtilitiesAndExtensions\Compiler\CSharp\Simplification\Simplifiers\CastSimplifier.cs (1)
193if (isDefaultLiteralCast && castNode.WalkUpParentheses().Parent is PatternSyntax or CaseSwitchLabelSyntax)
Microsoft.CodeAnalysis.CSharp.CodeStyle.Fixes (25)
src\roslyn\src\Analyzers\CSharp\CodeFixes\ConvertSwitchStatementToExpression\ConvertSwitchStatementToExpressionCodeFixProvider.Rewriter.cs (4)
130private static PatternSyntax GetPattern(SyntaxList<SwitchLabelSyntax> switchLabels, out WhenClauseSyntax? whenClause) 143var totalPattern = GetPattern(switchLabels[0], out var whenClauseUnused); 148var nextPatternPart = GetPattern(switchLabels[i], out whenClauseUnused); 158private static PatternSyntax GetPattern(SwitchLabelSyntax switchLabel, out WhenClauseSyntax? whenClause)
src\roslyn\src\Analyzers\CSharp\CodeFixes\UsePatternCombinators\CSharpUsePatternCombinatorsCodeFixProvider.cs (5)
83var patternSyntax = AsPatternSyntax(pattern).WithAdditionalAnnotations(Formatter.Annotation); 88private static PatternSyntax AsPatternSyntax(AnalyzedPattern pattern) 107private static PatternSyntax ProcessNotPattern(Not notPattern) 110var underlyingPattern = AsPatternSyntax(notPattern.Pattern); 111var unwrapped = underlyingPattern;
src\roslyn\src\Analyzers\CSharp\CodeFixes\UsePatternMatching\CSharpAsAndMemberAccessCodeFixProvider.cs (2)
114static (SyntaxToken notKeyword, PatternSyntax pattern) CreatePattern( 134PatternSyntax pattern = binaryExpression.Kind() switch
src\roslyn\src\Workspaces\SharedUtilitiesAndExtensions\Workspace\CSharp\Extensions\ContextQuery\SyntaxTreeExtensions.cs (2)
1471var patternSyntax = leftToken.GetAncestor<PatternSyntax>();
src\roslyn\src\Workspaces\SharedUtilitiesAndExtensions\Workspace\CSharp\Extensions\ExpressionSyntaxExtensions.cs (3)
65public static PatternSyntax Parenthesize( 66this PatternSyntax pattern, bool includeElasticTrivia = true, bool addSimplifierAnnotation = true) 68var withoutTrivia = pattern.WithoutTrivia();
src\roslyn\src\Workspaces\SharedUtilitiesAndExtensions\Workspace\CSharp\LanguageServices\CSharpSyntaxGeneratorInternal.cs (8)
104PatternSyntax pattern => pattern.Parenthesize(includeElasticTrivia, addSimplifierAnnotation), 213(PatternSyntax)pattern); 216=> SyntaxFactory.BinaryPattern(SyntaxKind.AndPattern, (PatternSyntax)ParenthesizeNonSimple(left), (PatternSyntax)ParenthesizeNonSimple(right)); 239=> SyntaxFactory.UnaryPattern(NotKeyword, (PatternSyntax)ParenthesizeNonSimple(pattern)); 242=> SyntaxFactory.BinaryPattern(SyntaxKind.OrPattern, (PatternSyntax)ParenthesizeNonSimple(left), (PatternSyntax)ParenthesizeNonSimple(right)); 251=> SyntaxFactory.UnaryPattern(operatorToken, (PatternSyntax)ParenthesizeNonSimple(pattern));
src\roslyn\src\Workspaces\SharedUtilitiesAndExtensions\Workspace\CSharp\LanguageServices\CSharpTypeInferenceService.TypeInferrer.cs (1)
1608private IEnumerable<TypeInferenceInfo> GetPatternTypes(PatternSyntax pattern)
Microsoft.CodeAnalysis.CSharp.Features (58)
CodeRefactorings\UseRecursivePatterns\UseRecursivePatternsCodeRefactoringProvider.cs (23)
35private static readonly PatternSyntax s_trueConstantPattern = ConstantPattern(LiteralExpression(TrueLiteralExpression)); 36private static readonly PatternSyntax s_falseConstantPattern = ConstantPattern(LiteralExpression(FalseLiteralExpression)); 112var rightPattern = CreatePattern(rightReceiver, rightTarget, rightFlipped); 113var rewrittenPattern = RewriteContainingPattern(containingPattern, rightPattern, rightNamesOpt); 162private static Func<SyntaxNode, SyntaxNode>? CombineWhenClauseCondition(PatternSyntax switchPattern, ExpressionSyntax condition, SemanticModel model) 189var generatedPattern = CreatePattern(receiver, target, flipped); 190var rewrittenPattern = RewriteContainingPattern(containingPattern, generatedPattern, namesOpt); 196private static PatternSyntax RewriteContainingPattern( 197PatternSyntax containingPattern, 198PatternSyntax generatedPattern, 203var rewrittenPattern = namesOpt.IsDefault 211static PatternSyntax Combine(PatternSyntax containingPattern, PatternSyntax generatedPattern) 242static PatternSyntax AddSubpattern(PatternSyntax containingPattern, SubpatternSyntax subpattern) 268private static PatternSyntax CreatePattern(ExpressionSyntax originalReceiver, ExpressionOrPatternSyntax target, bool flipped) 273PatternSyntax pattern => pattern, 303private static (PatternSyntax ContainingPattern, ImmutableArray<IdentifierNameSyntax> NamesOpt)? TryFindVariableDesignation( 304PatternSyntax leftPattern, 318if (designation is not { Parent: PatternSyntax(not SyntaxKind.ListPattern) containingPattern }) 380private static SubpatternSyntax CreateSubpattern(ImmutableArray<IdentifierNameSyntax> names, PatternSyntax pattern) 400private static SubpatternSyntax Subpattern(IdentifierNameSyntax name, PatternSyntax pattern)
Completion\CompletionProviders\CSharpSuggestionModeCompletionProvider.cs (4)
210var patternSyntax = token.GetAncestor<PatternSyntax>(); 216for (var current = patternSyntax; current != null; current = current.Parent as PatternSyntax)
Completion\CompletionProviders\PropertySubPatternCompletionProvider.cs (2)
59var propertyPatternType = semanticModel.GetTypeInfo((PatternSyntax)propertyPatternClause.Parent!, cancellationToken).ConvertedType; 192return token.Parent is PropertyPatternClauseSyntax { Parent: PatternSyntax } propertyPatternClause
Completion\KeywordRecommenders\WhenKeywordRecommender.cs (2)
28var pattern = context.TargetToken.GetAncestors<PatternSyntax>().LastOrDefault();
ConvertIfToSwitch\CSharpConvertIfToSwitchCodeRefactoringProvider.cs (1)
20: AbstractConvertIfToSwitchCodeRefactoringProvider<IfStatementSyntax, ExpressionSyntax, BinaryExpressionSyntax, PatternSyntax>
ConvertIfToSwitch\CSharpConvertIfToSwitchCodeRefactoringProvider.Rewriting.cs (3)
42var pattern = AsPatternSyntax(section.Labels[0].Pattern, feature); 51var nextPattern = AsPatternSyntax(label.Pattern, feature); 110private static PatternSyntax AsPatternSyntax(AnalyzedPattern pattern, Feature feature)
src\roslyn\src\Analyzers\CSharp\Analyzers\AddRequiredParentheses\CSharpAddRequiredPatternParenthesesDiagnosticAnalyzer.cs (6)
18PatternSyntax, BinaryPatternSyntax, SyntaxKind>(CSharpPatternPrecedenceService.Instance) 28protected override bool IsBinaryLike(PatternSyntax node) 31protected override (PatternSyntax, SyntaxToken, PatternSyntax) GetPartsOfBinaryLike(BinaryPatternSyntax binaryPattern) 37protected override PatternSyntax? TryGetAppropriateParent(BinaryPatternSyntax binaryLike) 38=> binaryLike.Parent as PatternSyntax;
src\roslyn\src\Analyzers\CSharp\Analyzers\RemoveUnnecessaryParentheses\CSharpRemoveUnnecessaryPatternParenthesesDiagnosticAnalyzer.cs (2)
47var inner = parenthesizedPattern.Pattern; 53if (parenthesizedPattern.Parent is not PatternSyntax)
src\roslyn\src\Analyzers\CSharp\Analyzers\UseNullPropagation\CSharpUseNullPropagationDiagnosticAnalyzer.cs (1)
52var pattern = patternExpression.Pattern;
src\roslyn\src\Analyzers\CSharp\Analyzers\UsePatternCombinators\AnalyzedPattern.cs (2)
84internal sealed class Source(PatternSyntax patternSyntax, IOperation target) : AnalyzedPattern(target) 86public readonly PatternSyntax PatternSyntax = patternSyntax;
src\roslyn\src\Analyzers\CSharp\Analyzers\UsePatternCombinators\CSharpUsePatternCombinatorsAnalyzer.cs (1)
64case IIsPatternOperation { Pattern.Syntax: PatternSyntax pattern } op:
src\roslyn\src\Analyzers\CSharp\CodeFixes\ConvertSwitchStatementToExpression\ConvertSwitchStatementToExpressionCodeFixProvider.Rewriter.cs (4)
130private static PatternSyntax GetPattern(SyntaxList<SwitchLabelSyntax> switchLabels, out WhenClauseSyntax? whenClause) 143var totalPattern = GetPattern(switchLabels[0], out var whenClauseUnused); 148var nextPatternPart = GetPattern(switchLabels[i], out whenClauseUnused); 158private static PatternSyntax GetPattern(SwitchLabelSyntax switchLabel, out WhenClauseSyntax? whenClause)
src\roslyn\src\Analyzers\CSharp\CodeFixes\UsePatternCombinators\CSharpUsePatternCombinatorsCodeFixProvider.cs (5)
83var patternSyntax = AsPatternSyntax(pattern).WithAdditionalAnnotations(Formatter.Annotation); 88private static PatternSyntax AsPatternSyntax(AnalyzedPattern pattern) 107private static PatternSyntax ProcessNotPattern(Not notPattern) 110var underlyingPattern = AsPatternSyntax(notPattern.Pattern); 111var unwrapped = underlyingPattern;
src\roslyn\src\Analyzers\CSharp\CodeFixes\UsePatternMatching\CSharpAsAndMemberAccessCodeFixProvider.cs (2)
114static (SyntaxToken notKeyword, PatternSyntax pattern) CreatePattern( 134PatternSyntax pattern = binaryExpression.Kind() switch
Microsoft.CodeAnalysis.CSharp.NetAnalyzers (4)
src\sdk\src\Microsoft.CodeAnalysis.NetAnalyzers\src\Utilities\Compiler.CSharp\Extensions\SyntaxGeneratorExtensions.cs (1)
50PatternSyntax pattern => pattern.Parenthesize(includeElasticTrivia, addSimplifierAnnotation),
src\sdk\src\Microsoft.CodeAnalysis.NetAnalyzers\src\Utilities\Compiler.CSharp\Extensions\SyntaxNodeExtensions.cs (3)
78public static PatternSyntax Parenthesize( 79this PatternSyntax pattern, bool includeElasticTrivia = true, bool addSimplifierAnnotation = true) 81var withoutTrivia = pattern.WithoutTrivia();
Microsoft.CodeAnalysis.CSharp.Workspaces (29)
ReassignedVariable\CSharpReassignedVariableService.cs (1)
56if (current is PatternSyntax)
Simplification\Reducers\AbstractCSharpReducer.AbstractReductionRewriter.cs (4)
73PatternSyntax pattern => GetParentNode(pattern), 96private static SyntaxNode GetParentNode(PatternSyntax pattern) 98var lastPattern = pattern; 101if (current is PatternSyntax currentPattern)
src\roslyn\src\Workspaces\SharedUtilitiesAndExtensions\Compiler\CSharp\Extensions\ParenthesizedExpressionSyntaxExtensions.cs (5)
736var pattern = node.Pattern; 781return node.Parent is PatternSyntax patternParent && 786ParenthesizedPatternSyntax node, PatternSyntax parentPattern) 788var pattern = node.Pattern; 801public static OperatorPrecedence GetOperatorPrecedence(this PatternSyntax pattern)
src\roslyn\src\Workspaces\SharedUtilitiesAndExtensions\Compiler\CSharp\Services\Precedence\CSharpPatternPrecedenceService.cs (2)
12internal sealed class CSharpPatternPrecedenceService : AbstractCSharpPrecedenceService<PatternSyntax> 20public override OperatorPrecedence GetOperatorPrecedence(PatternSyntax pattern)
src\roslyn\src\Workspaces\SharedUtilitiesAndExtensions\Compiler\CSharp\Services\SyntaxFacts\CSharpSyntaxFacts.cs (2)
1010return node is PatternSyntax ? null : node; 1372=> node is PatternSyntax;
src\roslyn\src\Workspaces\SharedUtilitiesAndExtensions\Compiler\CSharp\Simplification\Simplifiers\CastSimplifier.cs (1)
193if (isDefaultLiteralCast && castNode.WalkUpParentheses().Parent is PatternSyntax or CaseSwitchLabelSyntax)
src\roslyn\src\Workspaces\SharedUtilitiesAndExtensions\Workspace\CSharp\Extensions\ContextQuery\SyntaxTreeExtensions.cs (2)
1471var patternSyntax = leftToken.GetAncestor<PatternSyntax>();
src\roslyn\src\Workspaces\SharedUtilitiesAndExtensions\Workspace\CSharp\Extensions\ExpressionSyntaxExtensions.cs (3)
65public static PatternSyntax Parenthesize( 66this PatternSyntax pattern, bool includeElasticTrivia = true, bool addSimplifierAnnotation = true) 68var withoutTrivia = pattern.WithoutTrivia();
src\roslyn\src\Workspaces\SharedUtilitiesAndExtensions\Workspace\CSharp\LanguageServices\CSharpSyntaxGeneratorInternal.cs (8)
104PatternSyntax pattern => pattern.Parenthesize(includeElasticTrivia, addSimplifierAnnotation), 213(PatternSyntax)pattern); 216=> SyntaxFactory.BinaryPattern(SyntaxKind.AndPattern, (PatternSyntax)ParenthesizeNonSimple(left), (PatternSyntax)ParenthesizeNonSimple(right)); 239=> SyntaxFactory.UnaryPattern(NotKeyword, (PatternSyntax)ParenthesizeNonSimple(pattern)); 242=> SyntaxFactory.BinaryPattern(SyntaxKind.OrPattern, (PatternSyntax)ParenthesizeNonSimple(left), (PatternSyntax)ParenthesizeNonSimple(right)); 251=> SyntaxFactory.UnaryPattern(operatorToken, (PatternSyntax)ParenthesizeNonSimple(pattern));
src\roslyn\src\Workspaces\SharedUtilitiesAndExtensions\Workspace\CSharp\LanguageServices\CSharpTypeInferenceService.TypeInferrer.cs (1)
1608private IEnumerable<TypeInferenceInfo> GetPatternTypes(PatternSyntax pattern)
Roslyn.Diagnostics.CSharp.Analyzers (24)
src\roslyn\src\Workspaces\SharedUtilitiesAndExtensions\Compiler\CSharp\Extensions\ParenthesizedExpressionSyntaxExtensions.cs (5)
736var pattern = node.Pattern; 781return node.Parent is PatternSyntax patternParent && 786ParenthesizedPatternSyntax node, PatternSyntax parentPattern) 788var pattern = node.Pattern; 801public static OperatorPrecedence GetOperatorPrecedence(this PatternSyntax pattern)
src\roslyn\src\Workspaces\SharedUtilitiesAndExtensions\Compiler\CSharp\Services\Precedence\CSharpPatternPrecedenceService.cs (2)
12internal sealed class CSharpPatternPrecedenceService : AbstractCSharpPrecedenceService<PatternSyntax> 20public override OperatorPrecedence GetOperatorPrecedence(PatternSyntax pattern)
src\roslyn\src\Workspaces\SharedUtilitiesAndExtensions\Compiler\CSharp\Services\SyntaxFacts\CSharpSyntaxFacts.cs (2)
1010return node is PatternSyntax ? null : node; 1372=> node is PatternSyntax;
src\roslyn\src\Workspaces\SharedUtilitiesAndExtensions\Compiler\CSharp\Simplification\Simplifiers\CastSimplifier.cs (1)
193if (isDefaultLiteralCast && castNode.WalkUpParentheses().Parent is PatternSyntax or CaseSwitchLabelSyntax)
src\roslyn\src\Workspaces\SharedUtilitiesAndExtensions\Workspace\CSharp\Extensions\ContextQuery\SyntaxTreeExtensions.cs (2)
1471var patternSyntax = leftToken.GetAncestor<PatternSyntax>();
src\roslyn\src\Workspaces\SharedUtilitiesAndExtensions\Workspace\CSharp\Extensions\ExpressionSyntaxExtensions.cs (3)
65public static PatternSyntax Parenthesize( 66this PatternSyntax pattern, bool includeElasticTrivia = true, bool addSimplifierAnnotation = true) 68var withoutTrivia = pattern.WithoutTrivia();
src\roslyn\src\Workspaces\SharedUtilitiesAndExtensions\Workspace\CSharp\LanguageServices\CSharpSyntaxGeneratorInternal.cs (8)
104PatternSyntax pattern => pattern.Parenthesize(includeElasticTrivia, addSimplifierAnnotation), 213(PatternSyntax)pattern); 216=> SyntaxFactory.BinaryPattern(SyntaxKind.AndPattern, (PatternSyntax)ParenthesizeNonSimple(left), (PatternSyntax)ParenthesizeNonSimple(right)); 239=> SyntaxFactory.UnaryPattern(NotKeyword, (PatternSyntax)ParenthesizeNonSimple(pattern)); 242=> SyntaxFactory.BinaryPattern(SyntaxKind.OrPattern, (PatternSyntax)ParenthesizeNonSimple(left), (PatternSyntax)ParenthesizeNonSimple(right)); 251=> SyntaxFactory.UnaryPattern(operatorToken, (PatternSyntax)ParenthesizeNonSimple(pattern));
src\roslyn\src\Workspaces\SharedUtilitiesAndExtensions\Workspace\CSharp\LanguageServices\CSharpTypeInferenceService.TypeInferrer.cs (1)
1608private IEnumerable<TypeInferenceInfo> GetPatternTypes(PatternSyntax pattern)