12 types derived from PatternSyntax
Microsoft.CodeAnalysis.CSharp (12)
_generated\2\Syntax.xml.Syntax.Generated.cs (12)
5246public sealed partial class DiscardPatternSyntax : PatternSyntax 5284public sealed partial class DeclarationPatternSyntax : PatternSyntax 5339public sealed partial class VarPatternSyntax : PatternSyntax 5381public sealed partial class RecursivePatternSyntax : PatternSyntax 5622public sealed partial class ConstantPatternSyntax : PatternSyntax 5662public sealed partial class ParenthesizedPatternSyntax : PatternSyntax 5707public sealed partial class RelationalPatternSyntax : PatternSyntax 5750public sealed partial class TypePatternSyntax : PatternSyntax 5791public sealed partial class BinaryPatternSyntax : PatternSyntax 5849public sealed partial class UnaryPatternSyntax : PatternSyntax 5891public sealed partial class ListPatternSyntax : PatternSyntax 5961public sealed partial class SlicePatternSyntax : PatternSyntax
249 references to PatternSyntax
Microsoft.CodeAnalysis.CSharp (87)
_generated\0\Syntax.xml.Main.Generated.cs (32)
1782=> node.Update((ExpressionSyntax?)Visit(node.Expression) ?? throw new ArgumentNullException("expression"), VisitToken(node.IsKeyword), (PatternSyntax?)Visit(node.Pattern) ?? throw new ArgumentNullException("pattern")); 1809=> node.Update((BaseExpressionColonSyntax?)Visit(node.ExpressionColon), (PatternSyntax?)Visit(node.Pattern) ?? throw new ArgumentNullException("pattern")); 1815=> node.Update(VisitToken(node.OpenParenToken), (PatternSyntax?)Visit(node.Pattern) ?? throw new ArgumentNullException("pattern"), VisitToken(node.CloseParenToken)); 1824=> node.Update((PatternSyntax?)Visit(node.Left) ?? throw new ArgumentNullException("left"), VisitToken(node.OperatorToken), (PatternSyntax?)Visit(node.Right) ?? throw new ArgumentNullException("right")); 1827=> node.Update(VisitToken(node.OperatorToken), (PatternSyntax?)Visit(node.Pattern) ?? throw new ArgumentNullException("pattern")); 1833=> node.Update(VisitToken(node.DotDotToken), (PatternSyntax?)Visit(node.Pattern)); 1947=> node.Update(VisitToken(node.Keyword), (PatternSyntax?)Visit(node.Pattern) ?? throw new ArgumentNullException("pattern"), (WhenClauseSyntax?)Visit(node.WhenClause), VisitToken(node.ColonToken)); 1959=> 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")); 3712public static IsPatternExpressionSyntax IsPatternExpression(ExpressionSyntax expression, SyntaxToken isKeyword, PatternSyntax pattern) 3721public static IsPatternExpressionSyntax IsPatternExpression(ExpressionSyntax expression, PatternSyntax pattern) 3814public static SubpatternSyntax Subpattern(BaseExpressionColonSyntax? expressionColon, PatternSyntax pattern) 3821public static SubpatternSyntax Subpattern(PatternSyntax pattern) 3832public static ParenthesizedPatternSyntax ParenthesizedPattern(SyntaxToken openParenToken, PatternSyntax pattern, SyntaxToken closeParenToken) 3841public static ParenthesizedPatternSyntax ParenthesizedPattern(PatternSyntax pattern) 3869public static BinaryPatternSyntax BinaryPattern(SyntaxKind kind, PatternSyntax left, SyntaxToken operatorToken, PatternSyntax right) 3889public static BinaryPatternSyntax BinaryPattern(SyntaxKind kind, PatternSyntax left, PatternSyntax right) 3901public static UnaryPatternSyntax UnaryPattern(SyntaxToken operatorToken, PatternSyntax pattern) 3909public static UnaryPatternSyntax UnaryPattern(PatternSyntax pattern) 3913public static ListPatternSyntax ListPattern(SyntaxToken openBracketToken, SeparatedSyntaxList<PatternSyntax> patterns, SyntaxToken closeBracketToken, VariableDesignationSyntax? designation) 3921public static ListPatternSyntax ListPattern(SeparatedSyntaxList<PatternSyntax> patterns, VariableDesignationSyntax? designation) 3925public static ListPatternSyntax ListPattern(SeparatedSyntaxList<PatternSyntax> patterns = default) 3929public static SlicePatternSyntax SlicePattern(SyntaxToken dotDotToken, PatternSyntax? pattern) 3936public static SlicePatternSyntax SlicePattern(PatternSyntax? pattern = default) 4627public static CasePatternSwitchLabelSyntax CasePatternSwitchLabel(SyntaxToken keyword, PatternSyntax pattern, WhenClauseSyntax? whenClause, SyntaxToken colonToken) 4636public static CasePatternSwitchLabelSyntax CasePatternSwitchLabel(PatternSyntax pattern, WhenClauseSyntax? whenClause, SyntaxToken colonToken) 4640public static CasePatternSwitchLabelSyntax CasePatternSwitchLabel(PatternSyntax pattern, SyntaxToken colonToken) 4687public static SwitchExpressionArmSyntax SwitchExpressionArm(PatternSyntax pattern, WhenClauseSyntax? whenClause, SyntaxToken equalsGreaterThanToken, ExpressionSyntax expression) 4696public static SwitchExpressionArmSyntax SwitchExpressionArm(PatternSyntax pattern, WhenClauseSyntax? whenClause, ExpressionSyntax expression) 4700public static SwitchExpressionArmSyntax SwitchExpressionArm(PatternSyntax pattern, ExpressionSyntax expression)
_generated\2\Syntax.xml.Syntax.Generated.cs (41)
5097private PatternSyntax? pattern; 5110public PatternSyntax Pattern => GetRed(ref this.pattern, 2)!; 5131public IsPatternExpressionSyntax Update(ExpressionSyntax expression, SyntaxToken isKeyword, PatternSyntax pattern) 5145public IsPatternExpressionSyntax WithPattern(PatternSyntax pattern) => Update(this.Expression, this.IsKeyword, pattern); 5570private PatternSyntax? pattern; 5579public PatternSyntax Pattern => GetRed(ref this.pattern, 1)!; 5600public SubpatternSyntax Update(BaseExpressionColonSyntax? expressionColon, PatternSyntax pattern) 5613public SubpatternSyntax WithPattern(PatternSyntax pattern) => Update(this.ExpressionColon, pattern); 5664private PatternSyntax? pattern; 5673public PatternSyntax Pattern => GetRed(ref this.pattern, 1)!; 5684public ParenthesizedPatternSyntax Update(SyntaxToken openParenToken, PatternSyntax pattern, SyntaxToken closeParenToken) 5697public ParenthesizedPatternSyntax WithPattern(PatternSyntax pattern) => Update(this.OpenParenToken, pattern, this.CloseParenToken); 5793private PatternSyntax? left; 5794private PatternSyntax? right; 5801public PatternSyntax Left => GetRedAtZero(ref this.left)!; 5805public PatternSyntax Right => GetRed(ref this.right, 2)!; 5826public BinaryPatternSyntax Update(PatternSyntax left, SyntaxToken operatorToken, PatternSyntax right) 5838public BinaryPatternSyntax WithLeft(PatternSyntax left) => Update(left, this.OperatorToken, this.Right); 5840public BinaryPatternSyntax WithRight(PatternSyntax right) => Update(this.Left, this.OperatorToken, right); 5851private PatternSyntax? pattern; 5860public PatternSyntax Pattern => GetRed(ref this.pattern, 1)!; 5869public UnaryPatternSyntax Update(SyntaxToken operatorToken, PatternSyntax pattern) 5882public UnaryPatternSyntax WithPattern(PatternSyntax pattern) => Update(this.OperatorToken, pattern); 5903public SeparatedSyntaxList<PatternSyntax> Patterns 5908return red != null ? new SeparatedSyntaxList<PatternSyntax>(red, GetChildIndex(1)) : default; 5935public ListPatternSyntax Update(SyntaxToken openBracketToken, SeparatedSyntaxList<PatternSyntax> patterns, SyntaxToken closeBracketToken, VariableDesignationSyntax? designation) 5948public ListPatternSyntax WithPatterns(SeparatedSyntaxList<PatternSyntax> patterns) => Update(this.OpenBracketToken, patterns, this.CloseBracketToken, this.Designation); 5952public ListPatternSyntax AddPatterns(params PatternSyntax[] items) => WithPatterns(this.Patterns.AddRange(items)); 5963private PatternSyntax? pattern; 5972public PatternSyntax? Pattern => GetRed(ref this.pattern, 1); 5981public SlicePatternSyntax Update(SyntaxToken dotDotToken, PatternSyntax? pattern) 5994public SlicePatternSyntax WithPattern(PatternSyntax? pattern) => Update(this.DotDotToken, pattern); 8702private PatternSyntax? pattern; 8716public PatternSyntax Pattern => GetRed(ref this.pattern, 1)!; 8741public CasePatternSwitchLabelSyntax Update(SyntaxToken keyword, PatternSyntax pattern, WhenClauseSyntax? whenClause, SyntaxToken colonToken) 8755public CasePatternSwitchLabelSyntax WithPattern(PatternSyntax pattern) => Update(this.Keyword, pattern, this.WhenClause, this.ColonToken); 8939private PatternSyntax? pattern; 8948public PatternSyntax Pattern => GetRedAtZero(ref this.pattern)!; 8977public SwitchExpressionArmSyntax Update(PatternSyntax pattern, WhenClauseSyntax? whenClause, SyntaxToken equalsGreaterThanToken, ExpressionSyntax expression) 8989public SwitchExpressionArmSyntax WithPattern(PatternSyntax pattern) => Update(pattern, this.WhenClause, this.EqualsGreaterThanToken, this.Expression);
Binder\Binder_Patterns.cs (4)
602PatternSyntax node, 708SeparatedSyntaxList<PatternSyntax> subpatterns, 720foreach (PatternSyntax pattern in subpatterns) 2134PatternSyntax 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)
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)
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)