12 types derived from PatternSyntax
Microsoft.CodeAnalysis.CSharp (12)
_generated\2\Syntax.xml.Syntax.Generated.cs (12)
5246
public sealed partial class DiscardPatternSyntax :
PatternSyntax
5284
public sealed partial class DeclarationPatternSyntax :
PatternSyntax
5339
public sealed partial class VarPatternSyntax :
PatternSyntax
5381
public sealed partial class RecursivePatternSyntax :
PatternSyntax
5622
public sealed partial class ConstantPatternSyntax :
PatternSyntax
5662
public sealed partial class ParenthesizedPatternSyntax :
PatternSyntax
5707
public sealed partial class RelationalPatternSyntax :
PatternSyntax
5750
public sealed partial class TypePatternSyntax :
PatternSyntax
5791
public sealed partial class BinaryPatternSyntax :
PatternSyntax
5849
public sealed partial class UnaryPatternSyntax :
PatternSyntax
5891
public sealed partial class ListPatternSyntax :
PatternSyntax
5961
public 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"));
3712
public static IsPatternExpressionSyntax IsPatternExpression(ExpressionSyntax expression, SyntaxToken isKeyword,
PatternSyntax
pattern)
3721
public static IsPatternExpressionSyntax IsPatternExpression(ExpressionSyntax expression,
PatternSyntax
pattern)
3814
public static SubpatternSyntax Subpattern(BaseExpressionColonSyntax? expressionColon,
PatternSyntax
pattern)
3821
public static SubpatternSyntax Subpattern(
PatternSyntax
pattern)
3832
public static ParenthesizedPatternSyntax ParenthesizedPattern(SyntaxToken openParenToken,
PatternSyntax
pattern, SyntaxToken closeParenToken)
3841
public static ParenthesizedPatternSyntax ParenthesizedPattern(
PatternSyntax
pattern)
3869
public static BinaryPatternSyntax BinaryPattern(SyntaxKind kind,
PatternSyntax
left, SyntaxToken operatorToken,
PatternSyntax
right)
3889
public static BinaryPatternSyntax BinaryPattern(SyntaxKind kind,
PatternSyntax
left,
PatternSyntax
right)
3901
public static UnaryPatternSyntax UnaryPattern(SyntaxToken operatorToken,
PatternSyntax
pattern)
3909
public static UnaryPatternSyntax UnaryPattern(
PatternSyntax
pattern)
3913
public static ListPatternSyntax ListPattern(SyntaxToken openBracketToken, SeparatedSyntaxList<
PatternSyntax
> patterns, SyntaxToken closeBracketToken, VariableDesignationSyntax? designation)
3921
public static ListPatternSyntax ListPattern(SeparatedSyntaxList<
PatternSyntax
> patterns, VariableDesignationSyntax? designation)
3925
public static ListPatternSyntax ListPattern(SeparatedSyntaxList<
PatternSyntax
> patterns = default)
3929
public static SlicePatternSyntax SlicePattern(SyntaxToken dotDotToken,
PatternSyntax
? pattern)
3936
public static SlicePatternSyntax SlicePattern(
PatternSyntax
? pattern = default)
4627
public static CasePatternSwitchLabelSyntax CasePatternSwitchLabel(SyntaxToken keyword,
PatternSyntax
pattern, WhenClauseSyntax? whenClause, SyntaxToken colonToken)
4636
public static CasePatternSwitchLabelSyntax CasePatternSwitchLabel(
PatternSyntax
pattern, WhenClauseSyntax? whenClause, SyntaxToken colonToken)
4640
public static CasePatternSwitchLabelSyntax CasePatternSwitchLabel(
PatternSyntax
pattern, SyntaxToken colonToken)
4687
public static SwitchExpressionArmSyntax SwitchExpressionArm(
PatternSyntax
pattern, WhenClauseSyntax? whenClause, SyntaxToken equalsGreaterThanToken, ExpressionSyntax expression)
4696
public static SwitchExpressionArmSyntax SwitchExpressionArm(
PatternSyntax
pattern, WhenClauseSyntax? whenClause, ExpressionSyntax expression)
4700
public static SwitchExpressionArmSyntax SwitchExpressionArm(
PatternSyntax
pattern, ExpressionSyntax expression)
_generated\2\Syntax.xml.Syntax.Generated.cs (41)
5097
private
PatternSyntax
? pattern;
5110
public
PatternSyntax
Pattern => GetRed(ref this.pattern, 2)!;
5131
public IsPatternExpressionSyntax Update(ExpressionSyntax expression, SyntaxToken isKeyword,
PatternSyntax
pattern)
5145
public IsPatternExpressionSyntax WithPattern(
PatternSyntax
pattern) => Update(this.Expression, this.IsKeyword, pattern);
5570
private
PatternSyntax
? pattern;
5579
public
PatternSyntax
Pattern => GetRed(ref this.pattern, 1)!;
5600
public SubpatternSyntax Update(BaseExpressionColonSyntax? expressionColon,
PatternSyntax
pattern)
5613
public SubpatternSyntax WithPattern(
PatternSyntax
pattern) => Update(this.ExpressionColon, pattern);
5664
private
PatternSyntax
? pattern;
5673
public
PatternSyntax
Pattern => GetRed(ref this.pattern, 1)!;
5684
public ParenthesizedPatternSyntax Update(SyntaxToken openParenToken,
PatternSyntax
pattern, SyntaxToken closeParenToken)
5697
public ParenthesizedPatternSyntax WithPattern(
PatternSyntax
pattern) => Update(this.OpenParenToken, pattern, this.CloseParenToken);
5793
private
PatternSyntax
? left;
5794
private
PatternSyntax
? right;
5801
public
PatternSyntax
Left => GetRedAtZero(ref this.left)!;
5805
public
PatternSyntax
Right => GetRed(ref this.right, 2)!;
5826
public BinaryPatternSyntax Update(
PatternSyntax
left, SyntaxToken operatorToken,
PatternSyntax
right)
5838
public BinaryPatternSyntax WithLeft(
PatternSyntax
left) => Update(left, this.OperatorToken, this.Right);
5840
public BinaryPatternSyntax WithRight(
PatternSyntax
right) => Update(this.Left, this.OperatorToken, right);
5851
private
PatternSyntax
? pattern;
5860
public
PatternSyntax
Pattern => GetRed(ref this.pattern, 1)!;
5869
public UnaryPatternSyntax Update(SyntaxToken operatorToken,
PatternSyntax
pattern)
5882
public UnaryPatternSyntax WithPattern(
PatternSyntax
pattern) => Update(this.OperatorToken, pattern);
5903
public SeparatedSyntaxList<
PatternSyntax
> Patterns
5908
return red != null ? new SeparatedSyntaxList<
PatternSyntax
>(red, GetChildIndex(1)) : default;
5935
public ListPatternSyntax Update(SyntaxToken openBracketToken, SeparatedSyntaxList<
PatternSyntax
> patterns, SyntaxToken closeBracketToken, VariableDesignationSyntax? designation)
5948
public ListPatternSyntax WithPatterns(SeparatedSyntaxList<
PatternSyntax
> patterns) => Update(this.OpenBracketToken, patterns, this.CloseBracketToken, this.Designation);
5952
public ListPatternSyntax AddPatterns(params
PatternSyntax
[] items) => WithPatterns(this.Patterns.AddRange(items));
5963
private
PatternSyntax
? pattern;
5972
public
PatternSyntax
? Pattern => GetRed(ref this.pattern, 1);
5981
public SlicePatternSyntax Update(SyntaxToken dotDotToken,
PatternSyntax
? pattern)
5994
public SlicePatternSyntax WithPattern(
PatternSyntax
? pattern) => Update(this.DotDotToken, pattern);
8702
private
PatternSyntax
? pattern;
8716
public
PatternSyntax
Pattern => GetRed(ref this.pattern, 1)!;
8741
public CasePatternSwitchLabelSyntax Update(SyntaxToken keyword,
PatternSyntax
pattern, WhenClauseSyntax? whenClause, SyntaxToken colonToken)
8755
public CasePatternSwitchLabelSyntax WithPattern(
PatternSyntax
pattern) => Update(this.Keyword, pattern, this.WhenClause, this.ColonToken);
8939
private
PatternSyntax
? pattern;
8948
public
PatternSyntax
Pattern => GetRedAtZero(ref this.pattern)!;
8977
public SwitchExpressionArmSyntax Update(
PatternSyntax
pattern, WhenClauseSyntax? whenClause, SyntaxToken equalsGreaterThanToken, ExpressionSyntax expression)
8989
public SwitchExpressionArmSyntax WithPattern(
PatternSyntax
pattern) => Update(pattern, this.WhenClause, this.EqualsGreaterThanToken, this.Expression);
Binder\Binder_Patterns.cs (4)
602
PatternSyntax
node,
708
SeparatedSyntaxList<
PatternSyntax
> subpatterns,
720
foreach (
PatternSyntax
pattern in subpatterns)
2134
PatternSyntax
pattern = p.Pattern;
Binder\ExpressionVariableFinder.cs (2)
346
PatternSyntax
currentPattern = node;
348
var rightPatternStack = ArrayBuilder<
PatternSyntax
>.GetInstance();
BoundTree\BoundTreeVisitors.cs (3)
187
if (syntax is not (ExpressionSyntax or
PatternSyntax
))
189
syntax = syntax.DescendantNodes(n => n is not (ExpressionSyntax or
PatternSyntax
)).FirstOrDefault(n => n is ExpressionSyntax or
PatternSyntax
) ?? syntax;
Compilation\CSharpSemanticModel.cs (2)
952
public TypeInfo GetTypeInfo(
PatternSyntax
pattern, CancellationToken cancellationToken = default(CancellationToken))
5052
case
PatternSyntax
pattern:
Compilation\MemberSemanticModel.cs (1)
2297
!(node is
PatternSyntax
))
Syntax\SubpatternSyntax.cs (2)
16
public SubpatternSyntax Update(NameColonSyntax? nameColon,
PatternSyntax
pattern)
25
public static SubpatternSyntax Subpattern(NameColonSyntax? nameColon,
PatternSyntax
pattern)
Microsoft.CodeAnalysis.CSharp.CodeStyle (22)
src\roslyn\src\Analyzers\CSharp\Analyzers\AddRequiredParentheses\CSharpAddRequiredPatternParenthesesDiagnosticAnalyzer.cs (6)
18
PatternSyntax
, BinaryPatternSyntax, SyntaxKind>(CSharpPatternPrecedenceService.Instance)
28
protected override bool IsBinaryLike(
PatternSyntax
node)
31
protected override (
PatternSyntax
, SyntaxToken,
PatternSyntax
) GetPartsOfBinaryLike(BinaryPatternSyntax binaryPattern)
37
protected override
PatternSyntax
? TryGetAppropriateParent(BinaryPatternSyntax binaryLike)
38
=> binaryLike.Parent as
PatternSyntax
;
src\roslyn\src\Analyzers\CSharp\Analyzers\RemoveUnnecessaryParentheses\CSharpRemoveUnnecessaryPatternParenthesesDiagnosticAnalyzer.cs (2)
47
var
inner = parenthesizedPattern.Pattern;
53
if (parenthesizedPattern.Parent is not
PatternSyntax
)
src\roslyn\src\Analyzers\CSharp\Analyzers\UseNullPropagation\CSharpUseNullPropagationDiagnosticAnalyzer.cs (1)
52
var
pattern = patternExpression.Pattern;
src\roslyn\src\Analyzers\CSharp\Analyzers\UsePatternCombinators\AnalyzedPattern.cs (2)
84
internal sealed class Source(
PatternSyntax
patternSyntax, IOperation target) : AnalyzedPattern(target)
86
public readonly
PatternSyntax
PatternSyntax = patternSyntax;
src\roslyn\src\Analyzers\CSharp\Analyzers\UsePatternCombinators\CSharpUsePatternCombinatorsAnalyzer.cs (1)
64
case IIsPatternOperation { Pattern.Syntax:
PatternSyntax
pattern } op:
src\roslyn\src\Workspaces\SharedUtilitiesAndExtensions\Compiler\CSharp\Extensions\ParenthesizedExpressionSyntaxExtensions.cs (5)
736
var
pattern = node.Pattern;
781
return node.Parent is
PatternSyntax
patternParent &&
786
ParenthesizedPatternSyntax node,
PatternSyntax
parentPattern)
788
var
pattern = node.Pattern;
801
public static OperatorPrecedence GetOperatorPrecedence(this
PatternSyntax
pattern)
src\roslyn\src\Workspaces\SharedUtilitiesAndExtensions\Compiler\CSharp\Services\Precedence\CSharpPatternPrecedenceService.cs (2)
12
internal sealed class CSharpPatternPrecedenceService : AbstractCSharpPrecedenceService<
PatternSyntax
>
20
public override OperatorPrecedence GetOperatorPrecedence(
PatternSyntax
pattern)
src\roslyn\src\Workspaces\SharedUtilitiesAndExtensions\Compiler\CSharp\Services\SyntaxFacts\CSharpSyntaxFacts.cs (2)
1010
return node is
PatternSyntax
? null : node;
1372
=> node is
PatternSyntax
;
src\roslyn\src\Workspaces\SharedUtilitiesAndExtensions\Compiler\CSharp\Simplification\Simplifiers\CastSimplifier.cs (1)
193
if (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)
130
private static
PatternSyntax
GetPattern(SyntaxList<SwitchLabelSyntax> switchLabels, out WhenClauseSyntax? whenClause)
143
var
totalPattern = GetPattern(switchLabels[0], out var whenClauseUnused);
148
var
nextPatternPart = GetPattern(switchLabels[i], out whenClauseUnused);
158
private static
PatternSyntax
GetPattern(SwitchLabelSyntax switchLabel, out WhenClauseSyntax? whenClause)
src\roslyn\src\Analyzers\CSharp\CodeFixes\UsePatternCombinators\CSharpUsePatternCombinatorsCodeFixProvider.cs (5)
83
var
patternSyntax = AsPatternSyntax(pattern).WithAdditionalAnnotations(Formatter.Annotation);
88
private static
PatternSyntax
AsPatternSyntax(AnalyzedPattern pattern)
107
private static
PatternSyntax
ProcessNotPattern(Not notPattern)
110
var
underlyingPattern = AsPatternSyntax(notPattern.Pattern);
111
var
unwrapped = underlyingPattern;
src\roslyn\src\Analyzers\CSharp\CodeFixes\UsePatternMatching\CSharpAsAndMemberAccessCodeFixProvider.cs (2)
114
static (SyntaxToken notKeyword,
PatternSyntax
pattern) CreatePattern(
134
PatternSyntax
pattern = binaryExpression.Kind() switch
src\roslyn\src\Workspaces\SharedUtilitiesAndExtensions\Workspace\CSharp\Extensions\ContextQuery\SyntaxTreeExtensions.cs (2)
1478
var
patternSyntax = leftToken.GetAncestor<
PatternSyntax
>();
src\roslyn\src\Workspaces\SharedUtilitiesAndExtensions\Workspace\CSharp\Extensions\ExpressionSyntaxExtensions.cs (3)
65
public static
PatternSyntax
Parenthesize(
66
this
PatternSyntax
pattern, bool includeElasticTrivia = true, bool addSimplifierAnnotation = true)
68
var
withoutTrivia = pattern.WithoutTrivia();
src\roslyn\src\Workspaces\SharedUtilitiesAndExtensions\Workspace\CSharp\LanguageServices\CSharpSyntaxGeneratorInternal.cs (8)
104
PatternSyntax
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)
1608
private IEnumerable<TypeInferenceInfo> GetPatternTypes(
PatternSyntax
pattern)
Microsoft.CodeAnalysis.CSharp.Features (58)
CodeRefactorings\UseRecursivePatterns\UseRecursivePatternsCodeRefactoringProvider.cs (23)
35
private static readonly
PatternSyntax
s_trueConstantPattern = ConstantPattern(LiteralExpression(TrueLiteralExpression));
36
private static readonly
PatternSyntax
s_falseConstantPattern = ConstantPattern(LiteralExpression(FalseLiteralExpression));
112
var
rightPattern = CreatePattern(rightReceiver, rightTarget, rightFlipped);
113
var
rewrittenPattern = RewriteContainingPattern(containingPattern, rightPattern, rightNamesOpt);
162
private static Func<SyntaxNode, SyntaxNode>? CombineWhenClauseCondition(
PatternSyntax
switchPattern, ExpressionSyntax condition, SemanticModel model)
189
var
generatedPattern = CreatePattern(receiver, target, flipped);
190
var
rewrittenPattern = RewriteContainingPattern(containingPattern, generatedPattern, namesOpt);
196
private static
PatternSyntax
RewriteContainingPattern(
197
PatternSyntax
containingPattern,
198
PatternSyntax
generatedPattern,
203
var
rewrittenPattern = namesOpt.IsDefault
211
static
PatternSyntax
Combine(
PatternSyntax
containingPattern,
PatternSyntax
generatedPattern)
242
static
PatternSyntax
AddSubpattern(
PatternSyntax
containingPattern, SubpatternSyntax subpattern)
268
private static
PatternSyntax
CreatePattern(ExpressionSyntax originalReceiver, ExpressionOrPatternSyntax target, bool flipped)
273
PatternSyntax
pattern => pattern,
303
private static (
PatternSyntax
ContainingPattern, ImmutableArray<IdentifierNameSyntax> NamesOpt)? TryFindVariableDesignation(
304
PatternSyntax
leftPattern,
318
if (designation is not { Parent:
PatternSyntax
(not SyntaxKind.ListPattern) containingPattern })
380
private static SubpatternSyntax CreateSubpattern(ImmutableArray<IdentifierNameSyntax> names,
PatternSyntax
pattern)
400
private static SubpatternSyntax Subpattern(IdentifierNameSyntax name,
PatternSyntax
pattern)
Completion\CompletionProviders\CSharpSuggestionModeCompletionProvider.cs (4)
210
var
patternSyntax = token.GetAncestor<
PatternSyntax
>();
216
for (
var
current = patternSyntax; current != null; current = current.Parent as
PatternSyntax
)
Completion\CompletionProviders\PropertySubPatternCompletionProvider.cs (2)
59
var propertyPatternType = semanticModel.GetTypeInfo((
PatternSyntax
)propertyPatternClause.Parent!, cancellationToken).ConvertedType;
192
return token.Parent is PropertyPatternClauseSyntax { Parent:
PatternSyntax
} propertyPatternClause
Completion\KeywordRecommenders\WhenKeywordRecommender.cs (2)
28
var
pattern = context.TargetToken.GetAncestors<
PatternSyntax
>().LastOrDefault();
ConvertIfToSwitch\CSharpConvertIfToSwitchCodeRefactoringProvider.cs (1)
20
: AbstractConvertIfToSwitchCodeRefactoringProvider<IfStatementSyntax, ExpressionSyntax, BinaryExpressionSyntax,
PatternSyntax
>
ConvertIfToSwitch\CSharpConvertIfToSwitchCodeRefactoringProvider.Rewriting.cs (3)
42
var
pattern = AsPatternSyntax(section.Labels[0].Pattern, feature);
51
var
nextPattern = AsPatternSyntax(label.Pattern, feature);
110
private static
PatternSyntax
AsPatternSyntax(AnalyzedPattern pattern, Feature feature)
src\roslyn\src\Analyzers\CSharp\Analyzers\AddRequiredParentheses\CSharpAddRequiredPatternParenthesesDiagnosticAnalyzer.cs (6)
18
PatternSyntax
, BinaryPatternSyntax, SyntaxKind>(CSharpPatternPrecedenceService.Instance)
28
protected override bool IsBinaryLike(
PatternSyntax
node)
31
protected override (
PatternSyntax
, SyntaxToken,
PatternSyntax
) GetPartsOfBinaryLike(BinaryPatternSyntax binaryPattern)
37
protected override
PatternSyntax
? TryGetAppropriateParent(BinaryPatternSyntax binaryLike)
38
=> binaryLike.Parent as
PatternSyntax
;
src\roslyn\src\Analyzers\CSharp\Analyzers\RemoveUnnecessaryParentheses\CSharpRemoveUnnecessaryPatternParenthesesDiagnosticAnalyzer.cs (2)
47
var
inner = parenthesizedPattern.Pattern;
53
if (parenthesizedPattern.Parent is not
PatternSyntax
)
src\roslyn\src\Analyzers\CSharp\Analyzers\UseNullPropagation\CSharpUseNullPropagationDiagnosticAnalyzer.cs (1)
52
var
pattern = patternExpression.Pattern;
src\roslyn\src\Analyzers\CSharp\Analyzers\UsePatternCombinators\AnalyzedPattern.cs (2)
84
internal sealed class Source(
PatternSyntax
patternSyntax, IOperation target) : AnalyzedPattern(target)
86
public readonly
PatternSyntax
PatternSyntax = patternSyntax;
src\roslyn\src\Analyzers\CSharp\Analyzers\UsePatternCombinators\CSharpUsePatternCombinatorsAnalyzer.cs (1)
64
case IIsPatternOperation { Pattern.Syntax:
PatternSyntax
pattern } op:
src\roslyn\src\Analyzers\CSharp\CodeFixes\ConvertSwitchStatementToExpression\ConvertSwitchStatementToExpressionCodeFixProvider.Rewriter.cs (4)
130
private static
PatternSyntax
GetPattern(SyntaxList<SwitchLabelSyntax> switchLabels, out WhenClauseSyntax? whenClause)
143
var
totalPattern = GetPattern(switchLabels[0], out var whenClauseUnused);
148
var
nextPatternPart = GetPattern(switchLabels[i], out whenClauseUnused);
158
private static
PatternSyntax
GetPattern(SwitchLabelSyntax switchLabel, out WhenClauseSyntax? whenClause)
src\roslyn\src\Analyzers\CSharp\CodeFixes\UsePatternCombinators\CSharpUsePatternCombinatorsCodeFixProvider.cs (5)
83
var
patternSyntax = AsPatternSyntax(pattern).WithAdditionalAnnotations(Formatter.Annotation);
88
private static
PatternSyntax
AsPatternSyntax(AnalyzedPattern pattern)
107
private static
PatternSyntax
ProcessNotPattern(Not notPattern)
110
var
underlyingPattern = AsPatternSyntax(notPattern.Pattern);
111
var
unwrapped = underlyingPattern;
src\roslyn\src\Analyzers\CSharp\CodeFixes\UsePatternMatching\CSharpAsAndMemberAccessCodeFixProvider.cs (2)
114
static (SyntaxToken notKeyword,
PatternSyntax
pattern) CreatePattern(
134
PatternSyntax
pattern = binaryExpression.Kind() switch
Microsoft.CodeAnalysis.CSharp.NetAnalyzers (4)
src\sdk\src\Microsoft.CodeAnalysis.NetAnalyzers\src\Utilities\Compiler.CSharp\Extensions\SyntaxGeneratorExtensions.cs (1)
50
PatternSyntax
pattern => pattern.Parenthesize(includeElasticTrivia, addSimplifierAnnotation),
src\sdk\src\Microsoft.CodeAnalysis.NetAnalyzers\src\Utilities\Compiler.CSharp\Extensions\SyntaxNodeExtensions.cs (3)
78
public static
PatternSyntax
Parenthesize(
79
this
PatternSyntax
pattern, bool includeElasticTrivia = true, bool addSimplifierAnnotation = true)
81
var
withoutTrivia = pattern.WithoutTrivia();
Microsoft.CodeAnalysis.CSharp.Workspaces (29)
ReassignedVariable\CSharpReassignedVariableService.cs (1)
56
if (current is
PatternSyntax
)
Simplification\Reducers\AbstractCSharpReducer.AbstractReductionRewriter.cs (4)
73
PatternSyntax
pattern => GetParentNode(pattern),
96
private static SyntaxNode GetParentNode(
PatternSyntax
pattern)
98
var
lastPattern = pattern;
101
if (current is
PatternSyntax
currentPattern)
src\roslyn\src\Workspaces\SharedUtilitiesAndExtensions\Compiler\CSharp\Extensions\ParenthesizedExpressionSyntaxExtensions.cs (5)
736
var
pattern = node.Pattern;
781
return node.Parent is
PatternSyntax
patternParent &&
786
ParenthesizedPatternSyntax node,
PatternSyntax
parentPattern)
788
var
pattern = node.Pattern;
801
public static OperatorPrecedence GetOperatorPrecedence(this
PatternSyntax
pattern)
src\roslyn\src\Workspaces\SharedUtilitiesAndExtensions\Compiler\CSharp\Services\Precedence\CSharpPatternPrecedenceService.cs (2)
12
internal sealed class CSharpPatternPrecedenceService : AbstractCSharpPrecedenceService<
PatternSyntax
>
20
public override OperatorPrecedence GetOperatorPrecedence(
PatternSyntax
pattern)
src\roslyn\src\Workspaces\SharedUtilitiesAndExtensions\Compiler\CSharp\Services\SyntaxFacts\CSharpSyntaxFacts.cs (2)
1010
return node is
PatternSyntax
? null : node;
1372
=> node is
PatternSyntax
;
src\roslyn\src\Workspaces\SharedUtilitiesAndExtensions\Compiler\CSharp\Simplification\Simplifiers\CastSimplifier.cs (1)
193
if (isDefaultLiteralCast && castNode.WalkUpParentheses().Parent is
PatternSyntax
or CaseSwitchLabelSyntax)
src\roslyn\src\Workspaces\SharedUtilitiesAndExtensions\Workspace\CSharp\Extensions\ContextQuery\SyntaxTreeExtensions.cs (2)
1478
var
patternSyntax = leftToken.GetAncestor<
PatternSyntax
>();
src\roslyn\src\Workspaces\SharedUtilitiesAndExtensions\Workspace\CSharp\Extensions\ExpressionSyntaxExtensions.cs (3)
65
public static
PatternSyntax
Parenthesize(
66
this
PatternSyntax
pattern, bool includeElasticTrivia = true, bool addSimplifierAnnotation = true)
68
var
withoutTrivia = pattern.WithoutTrivia();
src\roslyn\src\Workspaces\SharedUtilitiesAndExtensions\Workspace\CSharp\LanguageServices\CSharpSyntaxGeneratorInternal.cs (8)
104
PatternSyntax
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)
1608
private IEnumerable<TypeInferenceInfo> GetPatternTypes(
PatternSyntax
pattern)
Roslyn.Diagnostics.CSharp.Analyzers (24)
src\roslyn\src\Workspaces\SharedUtilitiesAndExtensions\Compiler\CSharp\Extensions\ParenthesizedExpressionSyntaxExtensions.cs (5)
736
var
pattern = node.Pattern;
781
return node.Parent is
PatternSyntax
patternParent &&
786
ParenthesizedPatternSyntax node,
PatternSyntax
parentPattern)
788
var
pattern = node.Pattern;
801
public static OperatorPrecedence GetOperatorPrecedence(this
PatternSyntax
pattern)
src\roslyn\src\Workspaces\SharedUtilitiesAndExtensions\Compiler\CSharp\Services\Precedence\CSharpPatternPrecedenceService.cs (2)
12
internal sealed class CSharpPatternPrecedenceService : AbstractCSharpPrecedenceService<
PatternSyntax
>
20
public override OperatorPrecedence GetOperatorPrecedence(
PatternSyntax
pattern)
src\roslyn\src\Workspaces\SharedUtilitiesAndExtensions\Compiler\CSharp\Services\SyntaxFacts\CSharpSyntaxFacts.cs (2)
1010
return node is
PatternSyntax
? null : node;
1372
=> node is
PatternSyntax
;
src\roslyn\src\Workspaces\SharedUtilitiesAndExtensions\Compiler\CSharp\Simplification\Simplifiers\CastSimplifier.cs (1)
193
if (isDefaultLiteralCast && castNode.WalkUpParentheses().Parent is
PatternSyntax
or CaseSwitchLabelSyntax)
src\roslyn\src\Workspaces\SharedUtilitiesAndExtensions\Workspace\CSharp\Extensions\ContextQuery\SyntaxTreeExtensions.cs (2)
1478
var
patternSyntax = leftToken.GetAncestor<
PatternSyntax
>();
src\roslyn\src\Workspaces\SharedUtilitiesAndExtensions\Workspace\CSharp\Extensions\ExpressionSyntaxExtensions.cs (3)
65
public static
PatternSyntax
Parenthesize(
66
this
PatternSyntax
pattern, bool includeElasticTrivia = true, bool addSimplifierAnnotation = true)
68
var
withoutTrivia = pattern.WithoutTrivia();
src\roslyn\src\Workspaces\SharedUtilitiesAndExtensions\Workspace\CSharp\LanguageServices\CSharpSyntaxGeneratorInternal.cs (8)
104
PatternSyntax
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)
1608
private IEnumerable<TypeInferenceInfo> GetPatternTypes(
PatternSyntax
pattern)