12 types derived from PatternSyntax
Microsoft.CodeAnalysis.CSharp (12)
_generated\2\Syntax.xml.Syntax.Generated.cs (12)
5301public sealed partial class DiscardPatternSyntax : PatternSyntax 5339public sealed partial class DeclarationPatternSyntax : PatternSyntax 5394public sealed partial class VarPatternSyntax : PatternSyntax 5436public sealed partial class RecursivePatternSyntax : PatternSyntax 5677public sealed partial class ConstantPatternSyntax : PatternSyntax 5717public sealed partial class ParenthesizedPatternSyntax : PatternSyntax 5762public sealed partial class RelationalPatternSyntax : PatternSyntax 5805public sealed partial class TypePatternSyntax : PatternSyntax 5846public sealed partial class BinaryPatternSyntax : PatternSyntax 5904public sealed partial class UnaryPatternSyntax : PatternSyntax 5946public sealed partial class ListPatternSyntax : PatternSyntax 6016public sealed partial class SlicePatternSyntax : PatternSyntax
249 references to PatternSyntax
Microsoft.CodeAnalysis.CSharp (87)
_generated\0\Syntax.xml.Main.Generated.cs (32)
1794=> node.Update((ExpressionSyntax?)Visit(node.Expression) ?? throw new ArgumentNullException("expression"), VisitToken(node.IsKeyword), (PatternSyntax?)Visit(node.Pattern) ?? throw new ArgumentNullException("pattern")); 1821=> node.Update((BaseExpressionColonSyntax?)Visit(node.ExpressionColon), (PatternSyntax?)Visit(node.Pattern) ?? throw new ArgumentNullException("pattern")); 1827=> node.Update(VisitToken(node.OpenParenToken), (PatternSyntax?)Visit(node.Pattern) ?? throw new ArgumentNullException("pattern"), VisitToken(node.CloseParenToken)); 1836=> node.Update((PatternSyntax?)Visit(node.Left) ?? throw new ArgumentNullException("left"), VisitToken(node.OperatorToken), (PatternSyntax?)Visit(node.Right) ?? throw new ArgumentNullException("right")); 1839=> node.Update(VisitToken(node.OperatorToken), (PatternSyntax?)Visit(node.Pattern) ?? throw new ArgumentNullException("pattern")); 1845=> node.Update(VisitToken(node.DotDotToken), (PatternSyntax?)Visit(node.Pattern)); 1959=> node.Update(VisitToken(node.Keyword), (PatternSyntax?)Visit(node.Pattern) ?? throw new ArgumentNullException("pattern"), (WhenClauseSyntax?)Visit(node.WhenClause), VisitToken(node.ColonToken)); 1971=> 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")); 3740public static IsPatternExpressionSyntax IsPatternExpression(ExpressionSyntax expression, SyntaxToken isKeyword, PatternSyntax pattern) 3749public static IsPatternExpressionSyntax IsPatternExpression(ExpressionSyntax expression, PatternSyntax pattern) 3842public static SubpatternSyntax Subpattern(BaseExpressionColonSyntax? expressionColon, PatternSyntax pattern) 3849public static SubpatternSyntax Subpattern(PatternSyntax pattern) 3860public static ParenthesizedPatternSyntax ParenthesizedPattern(SyntaxToken openParenToken, PatternSyntax pattern, SyntaxToken closeParenToken) 3869public static ParenthesizedPatternSyntax ParenthesizedPattern(PatternSyntax pattern) 3897public static BinaryPatternSyntax BinaryPattern(SyntaxKind kind, PatternSyntax left, SyntaxToken operatorToken, PatternSyntax right) 3917public static BinaryPatternSyntax BinaryPattern(SyntaxKind kind, PatternSyntax left, PatternSyntax right) 3929public static UnaryPatternSyntax UnaryPattern(SyntaxToken operatorToken, PatternSyntax pattern) 3937public static UnaryPatternSyntax UnaryPattern(PatternSyntax pattern) 3941public static ListPatternSyntax ListPattern(SyntaxToken openBracketToken, SeparatedSyntaxList<PatternSyntax> patterns, SyntaxToken closeBracketToken, VariableDesignationSyntax? designation) 3949public static ListPatternSyntax ListPattern(SeparatedSyntaxList<PatternSyntax> patterns, VariableDesignationSyntax? designation) 3953public static ListPatternSyntax ListPattern(SeparatedSyntaxList<PatternSyntax> patterns = default) 3957public static SlicePatternSyntax SlicePattern(SyntaxToken dotDotToken, PatternSyntax? pattern) 3964public static SlicePatternSyntax SlicePattern(PatternSyntax? pattern = default) 4665public static CasePatternSwitchLabelSyntax CasePatternSwitchLabel(SyntaxToken keyword, PatternSyntax pattern, WhenClauseSyntax? whenClause, SyntaxToken colonToken) 4674public static CasePatternSwitchLabelSyntax CasePatternSwitchLabel(PatternSyntax pattern, WhenClauseSyntax? whenClause, SyntaxToken colonToken) 4678public static CasePatternSwitchLabelSyntax CasePatternSwitchLabel(PatternSyntax pattern, SyntaxToken colonToken) 4725public static SwitchExpressionArmSyntax SwitchExpressionArm(PatternSyntax pattern, WhenClauseSyntax? whenClause, SyntaxToken equalsGreaterThanToken, ExpressionSyntax expression) 4734public static SwitchExpressionArmSyntax SwitchExpressionArm(PatternSyntax pattern, WhenClauseSyntax? whenClause, ExpressionSyntax expression) 4738public static SwitchExpressionArmSyntax SwitchExpressionArm(PatternSyntax pattern, ExpressionSyntax expression)
_generated\2\Syntax.xml.Syntax.Generated.cs (41)
5152private PatternSyntax? pattern; 5165public PatternSyntax Pattern => GetRed(ref this.pattern, 2)!; 5186public IsPatternExpressionSyntax Update(ExpressionSyntax expression, SyntaxToken isKeyword, PatternSyntax pattern) 5200public IsPatternExpressionSyntax WithPattern(PatternSyntax pattern) => Update(this.Expression, this.IsKeyword, pattern); 5625private PatternSyntax? pattern; 5634public PatternSyntax Pattern => GetRed(ref this.pattern, 1)!; 5655public SubpatternSyntax Update(BaseExpressionColonSyntax? expressionColon, PatternSyntax pattern) 5668public SubpatternSyntax WithPattern(PatternSyntax pattern) => Update(this.ExpressionColon, pattern); 5719private PatternSyntax? pattern; 5728public PatternSyntax Pattern => GetRed(ref this.pattern, 1)!; 5739public ParenthesizedPatternSyntax Update(SyntaxToken openParenToken, PatternSyntax pattern, SyntaxToken closeParenToken) 5752public ParenthesizedPatternSyntax WithPattern(PatternSyntax pattern) => Update(this.OpenParenToken, pattern, this.CloseParenToken); 5848private PatternSyntax? left; 5849private PatternSyntax? right; 5856public PatternSyntax Left => GetRedAtZero(ref this.left)!; 5860public PatternSyntax Right => GetRed(ref this.right, 2)!; 5881public BinaryPatternSyntax Update(PatternSyntax left, SyntaxToken operatorToken, PatternSyntax right) 5893public BinaryPatternSyntax WithLeft(PatternSyntax left) => Update(left, this.OperatorToken, this.Right); 5895public BinaryPatternSyntax WithRight(PatternSyntax right) => Update(this.Left, this.OperatorToken, right); 5906private PatternSyntax? pattern; 5915public PatternSyntax Pattern => GetRed(ref this.pattern, 1)!; 5924public UnaryPatternSyntax Update(SyntaxToken operatorToken, PatternSyntax pattern) 5937public UnaryPatternSyntax WithPattern(PatternSyntax pattern) => Update(this.OperatorToken, pattern); 5958public SeparatedSyntaxList<PatternSyntax> Patterns 5963return red != null ? new SeparatedSyntaxList<PatternSyntax>(red, GetChildIndex(1)) : default; 5990public ListPatternSyntax Update(SyntaxToken openBracketToken, SeparatedSyntaxList<PatternSyntax> patterns, SyntaxToken closeBracketToken, VariableDesignationSyntax? designation) 6003public ListPatternSyntax WithPatterns(SeparatedSyntaxList<PatternSyntax> patterns) => Update(this.OpenBracketToken, patterns, this.CloseBracketToken, this.Designation); 6007public ListPatternSyntax AddPatterns(params PatternSyntax[] items) => WithPatterns(this.Patterns.AddRange(items)); 6018private PatternSyntax? pattern; 6027public PatternSyntax? Pattern => GetRed(ref this.pattern, 1); 6036public SlicePatternSyntax Update(SyntaxToken dotDotToken, PatternSyntax? pattern) 6049public SlicePatternSyntax WithPattern(PatternSyntax? pattern) => Update(this.DotDotToken, pattern); 8795private PatternSyntax? pattern; 8809public PatternSyntax Pattern => GetRed(ref this.pattern, 1)!; 8834public CasePatternSwitchLabelSyntax Update(SyntaxToken keyword, PatternSyntax pattern, WhenClauseSyntax? whenClause, SyntaxToken colonToken) 8848public CasePatternSwitchLabelSyntax WithPattern(PatternSyntax pattern) => Update(this.Keyword, pattern, this.WhenClause, this.ColonToken); 9032private PatternSyntax? pattern; 9041public PatternSyntax Pattern => GetRedAtZero(ref this.pattern)!; 9070public SwitchExpressionArmSyntax Update(PatternSyntax pattern, WhenClauseSyntax? whenClause, SyntaxToken equalsGreaterThanToken, ExpressionSyntax expression) 9082public SwitchExpressionArmSyntax WithPattern(PatternSyntax pattern) => Update(pattern, this.WhenClause, this.EqualsGreaterThanToken, this.Expression);
Binder\Binder_Patterns.cs (4)
694PatternSyntax node, 800SeparatedSyntaxList<PatternSyntax> subpatterns, 812foreach (PatternSyntax pattern in subpatterns) 2252PatternSyntax 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)) 5052case PatternSyntax pattern:
Compilation\MemberSemanticModel.cs (1)
2308!(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)
1478var 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)
1478var 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)
1478var 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)