12 types derived from PatternSyntax
Microsoft.CodeAnalysis.CSharp (12)
Syntax.xml.Syntax.Generated.cs (12)
5200
public sealed partial class DiscardPatternSyntax :
PatternSyntax
5238
public sealed partial class DeclarationPatternSyntax :
PatternSyntax
5293
public sealed partial class VarPatternSyntax :
PatternSyntax
5335
public sealed partial class RecursivePatternSyntax :
PatternSyntax
5576
public sealed partial class ConstantPatternSyntax :
PatternSyntax
5616
public sealed partial class ParenthesizedPatternSyntax :
PatternSyntax
5661
public sealed partial class RelationalPatternSyntax :
PatternSyntax
5704
public sealed partial class TypePatternSyntax :
PatternSyntax
5745
public sealed partial class BinaryPatternSyntax :
PatternSyntax
5803
public sealed partial class UnaryPatternSyntax :
PatternSyntax
5845
public sealed partial class ListPatternSyntax :
PatternSyntax
5915
public sealed partial class SlicePatternSyntax :
PatternSyntax
256 references to PatternSyntax
Microsoft.CodeAnalysis.CSharp (87)
Binder\Binder_Patterns.cs (4)
165
PatternSyntax
node,
260
SeparatedSyntaxList<
PatternSyntax
> subpatterns,
270
foreach (
PatternSyntax
pattern in subpatterns)
1473
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)
939
public TypeInfo GetTypeInfo(
PatternSyntax
pattern, CancellationToken cancellationToken = default(CancellationToken))
4995
case
PatternSyntax
pattern:
Compilation\MemberSemanticModel.cs (1)
2259
!(node is
PatternSyntax
))
Syntax.xml.Main.Generated.cs (32)
1762
=> node.Update((ExpressionSyntax?)Visit(node.Expression) ?? throw new ArgumentNullException("expression"), VisitToken(node.IsKeyword), (
PatternSyntax
?)Visit(node.Pattern) ?? throw new ArgumentNullException("pattern"));
1789
=> node.Update((BaseExpressionColonSyntax?)Visit(node.ExpressionColon), (
PatternSyntax
?)Visit(node.Pattern) ?? throw new ArgumentNullException("pattern"));
1795
=> node.Update(VisitToken(node.OpenParenToken), (
PatternSyntax
?)Visit(node.Pattern) ?? throw new ArgumentNullException("pattern"), VisitToken(node.CloseParenToken));
1804
=> node.Update((
PatternSyntax
?)Visit(node.Left) ?? throw new ArgumentNullException("left"), VisitToken(node.OperatorToken), (
PatternSyntax
?)Visit(node.Right) ?? throw new ArgumentNullException("right"));
1807
=> node.Update(VisitToken(node.OperatorToken), (
PatternSyntax
?)Visit(node.Pattern) ?? throw new ArgumentNullException("pattern"));
1813
=> node.Update(VisitToken(node.DotDotToken), (
PatternSyntax
?)Visit(node.Pattern));
1927
=> node.Update(VisitToken(node.Keyword), (
PatternSyntax
?)Visit(node.Pattern) ?? throw new ArgumentNullException("pattern"), (WhenClauseSyntax?)Visit(node.WhenClause), VisitToken(node.ColonToken));
1939
=> 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"));
3674
public static IsPatternExpressionSyntax IsPatternExpression(ExpressionSyntax expression, SyntaxToken isKeyword,
PatternSyntax
pattern)
3683
public static IsPatternExpressionSyntax IsPatternExpression(ExpressionSyntax expression,
PatternSyntax
pattern)
3776
public static SubpatternSyntax Subpattern(BaseExpressionColonSyntax? expressionColon,
PatternSyntax
pattern)
3783
public static SubpatternSyntax Subpattern(
PatternSyntax
pattern)
3794
public static ParenthesizedPatternSyntax ParenthesizedPattern(SyntaxToken openParenToken,
PatternSyntax
pattern, SyntaxToken closeParenToken)
3803
public static ParenthesizedPatternSyntax ParenthesizedPattern(
PatternSyntax
pattern)
3831
public static BinaryPatternSyntax BinaryPattern(SyntaxKind kind,
PatternSyntax
left, SyntaxToken operatorToken,
PatternSyntax
right)
3851
public static BinaryPatternSyntax BinaryPattern(SyntaxKind kind,
PatternSyntax
left,
PatternSyntax
right)
3863
public static UnaryPatternSyntax UnaryPattern(SyntaxToken operatorToken,
PatternSyntax
pattern)
3871
public static UnaryPatternSyntax UnaryPattern(
PatternSyntax
pattern)
3875
public static ListPatternSyntax ListPattern(SyntaxToken openBracketToken, SeparatedSyntaxList<
PatternSyntax
> patterns, SyntaxToken closeBracketToken, VariableDesignationSyntax? designation)
3883
public static ListPatternSyntax ListPattern(SeparatedSyntaxList<
PatternSyntax
> patterns, VariableDesignationSyntax? designation)
3887
public static ListPatternSyntax ListPattern(SeparatedSyntaxList<
PatternSyntax
> patterns = default)
3891
public static SlicePatternSyntax SlicePattern(SyntaxToken dotDotToken,
PatternSyntax
? pattern)
3898
public static SlicePatternSyntax SlicePattern(
PatternSyntax
? pattern = default)
4589
public static CasePatternSwitchLabelSyntax CasePatternSwitchLabel(SyntaxToken keyword,
PatternSyntax
pattern, WhenClauseSyntax? whenClause, SyntaxToken colonToken)
4598
public static CasePatternSwitchLabelSyntax CasePatternSwitchLabel(
PatternSyntax
pattern, WhenClauseSyntax? whenClause, SyntaxToken colonToken)
4602
public static CasePatternSwitchLabelSyntax CasePatternSwitchLabel(
PatternSyntax
pattern, SyntaxToken colonToken)
4649
public static SwitchExpressionArmSyntax SwitchExpressionArm(
PatternSyntax
pattern, WhenClauseSyntax? whenClause, SyntaxToken equalsGreaterThanToken, ExpressionSyntax expression)
4658
public static SwitchExpressionArmSyntax SwitchExpressionArm(
PatternSyntax
pattern, WhenClauseSyntax? whenClause, ExpressionSyntax expression)
4662
public static SwitchExpressionArmSyntax SwitchExpressionArm(
PatternSyntax
pattern, ExpressionSyntax expression)
Syntax.xml.Syntax.Generated.cs (41)
5051
private
PatternSyntax
? pattern;
5064
public
PatternSyntax
Pattern => GetRed(ref this.pattern, 2)!;
5085
public IsPatternExpressionSyntax Update(ExpressionSyntax expression, SyntaxToken isKeyword,
PatternSyntax
pattern)
5099
public IsPatternExpressionSyntax WithPattern(
PatternSyntax
pattern) => Update(this.Expression, this.IsKeyword, pattern);
5524
private
PatternSyntax
? pattern;
5533
public
PatternSyntax
Pattern => GetRed(ref this.pattern, 1)!;
5554
public SubpatternSyntax Update(BaseExpressionColonSyntax? expressionColon,
PatternSyntax
pattern)
5567
public SubpatternSyntax WithPattern(
PatternSyntax
pattern) => Update(this.ExpressionColon, pattern);
5618
private
PatternSyntax
? pattern;
5627
public
PatternSyntax
Pattern => GetRed(ref this.pattern, 1)!;
5638
public ParenthesizedPatternSyntax Update(SyntaxToken openParenToken,
PatternSyntax
pattern, SyntaxToken closeParenToken)
5651
public ParenthesizedPatternSyntax WithPattern(
PatternSyntax
pattern) => Update(this.OpenParenToken, pattern, this.CloseParenToken);
5747
private
PatternSyntax
? left;
5748
private
PatternSyntax
? right;
5755
public
PatternSyntax
Left => GetRedAtZero(ref this.left)!;
5759
public
PatternSyntax
Right => GetRed(ref this.right, 2)!;
5780
public BinaryPatternSyntax Update(
PatternSyntax
left, SyntaxToken operatorToken,
PatternSyntax
right)
5792
public BinaryPatternSyntax WithLeft(
PatternSyntax
left) => Update(left, this.OperatorToken, this.Right);
5794
public BinaryPatternSyntax WithRight(
PatternSyntax
right) => Update(this.Left, this.OperatorToken, right);
5805
private
PatternSyntax
? pattern;
5814
public
PatternSyntax
Pattern => GetRed(ref this.pattern, 1)!;
5823
public UnaryPatternSyntax Update(SyntaxToken operatorToken,
PatternSyntax
pattern)
5836
public UnaryPatternSyntax WithPattern(
PatternSyntax
pattern) => Update(this.OperatorToken, pattern);
5857
public SeparatedSyntaxList<
PatternSyntax
> Patterns
5862
return red != null ? new SeparatedSyntaxList<
PatternSyntax
>(red, GetChildIndex(1)) : default;
5889
public ListPatternSyntax Update(SyntaxToken openBracketToken, SeparatedSyntaxList<
PatternSyntax
> patterns, SyntaxToken closeBracketToken, VariableDesignationSyntax? designation)
5902
public ListPatternSyntax WithPatterns(SeparatedSyntaxList<
PatternSyntax
> patterns) => Update(this.OpenBracketToken, patterns, this.CloseBracketToken, this.Designation);
5906
public ListPatternSyntax AddPatterns(params
PatternSyntax
[] items) => WithPatterns(this.Patterns.AddRange(items));
5917
private
PatternSyntax
? pattern;
5926
public
PatternSyntax
? Pattern => GetRed(ref this.pattern, 1);
5935
public SlicePatternSyntax Update(SyntaxToken dotDotToken,
PatternSyntax
? pattern)
5948
public SlicePatternSyntax WithPattern(
PatternSyntax
? pattern) => Update(this.DotDotToken, pattern);
8655
private
PatternSyntax
? pattern;
8669
public
PatternSyntax
Pattern => GetRed(ref this.pattern, 1)!;
8694
public CasePatternSwitchLabelSyntax Update(SyntaxToken keyword,
PatternSyntax
pattern, WhenClauseSyntax? whenClause, SyntaxToken colonToken)
8708
public CasePatternSwitchLabelSyntax WithPattern(
PatternSyntax
pattern) => Update(this.Keyword, pattern, this.WhenClause, this.ColonToken);
8892
private
PatternSyntax
? pattern;
8901
public
PatternSyntax
Pattern => GetRedAtZero(ref this.pattern)!;
8930
public SwitchExpressionArmSyntax Update(
PatternSyntax
pattern, WhenClauseSyntax? whenClause, SyntaxToken equalsGreaterThanToken, ExpressionSyntax expression)
8942
public SwitchExpressionArmSyntax WithPattern(
PatternSyntax
pattern) => Update(pattern, this.WhenClause, this.EqualsGreaterThanToken, this.Expression);
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\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\Analyzers\CSharp\Analyzers\RemoveUnnecessaryParentheses\CSharpRemoveUnnecessaryPatternParenthesesDiagnosticAnalyzer.cs (2)
46
var
inner = parenthesizedPattern.Pattern;
51
if (parenthesizedPattern.Parent is not
PatternSyntax
)
src\Analyzers\CSharp\Analyzers\UseNullPropagation\CSharpUseNullPropagationDiagnosticAnalyzer.cs (1)
51
var
pattern = patternExpression.Pattern;
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\Analyzers\CSharp\Analyzers\UsePatternCombinators\CSharpUsePatternCombinatorsAnalyzer.cs (1)
64
case IIsPatternOperation { Pattern.Syntax:
PatternSyntax
pattern } op:
src\Workspaces\SharedUtilitiesAndExtensions\Compiler\CSharp\Extensions\ParenthesizedExpressionSyntaxExtensions.cs (5)
714
var
pattern = node.Pattern;
759
return node.Parent is
PatternSyntax
patternParent &&
764
ParenthesizedPatternSyntax node,
PatternSyntax
parentPattern)
766
var
pattern = node.Pattern;
779
public static OperatorPrecedence GetOperatorPrecedence(this
PatternSyntax
pattern)
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\Workspaces\SharedUtilitiesAndExtensions\Compiler\CSharp\Services\SyntaxFacts\CSharpSyntaxFacts.cs (2)
993
return node is
PatternSyntax
? null : node;
1395
=> node is
PatternSyntax
;
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\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\Analyzers\CSharp\CodeFixes\UsePatternCombinators\CSharpUsePatternCombinatorsCodeFixProvider.cs (5)
85
var
patternSyntax = AsPatternSyntax(pattern).WithAdditionalAnnotations(Formatter.Annotation);
90
private static
PatternSyntax
AsPatternSyntax(AnalyzedPattern pattern)
109
private static
PatternSyntax
ProcessNotPattern(Not notPattern)
112
var
underlyingPattern = AsPatternSyntax(notPattern.Pattern);
113
var
unwrapped = underlyingPattern;
src\Analyzers\CSharp\CodeFixes\UsePatternMatching\CSharpAsAndMemberAccessCodeFixProvider.cs (2)
117
static (SyntaxToken notKeyword,
PatternSyntax
pattern) CreatePattern(
137
PatternSyntax
pattern = binaryExpression.Kind() switch
src\Workspaces\SharedUtilitiesAndExtensions\Workspace\CSharp\Extensions\ContextQuery\SyntaxTreeExtensions.cs (2)
1471
var
patternSyntax = leftToken.GetAncestor<
PatternSyntax
>();
src\Workspaces\SharedUtilitiesAndExtensions\Workspace\CSharp\Extensions\ExpressionSyntaxExtensions.cs (3)
69
public static
PatternSyntax
Parenthesize(
70
this
PatternSyntax
pattern, bool includeElasticTrivia = true, bool addSimplifierAnnotation = true)
72
var
withoutTrivia = pattern.WithoutTrivia();
src\Workspaces\SharedUtilitiesAndExtensions\Workspace\CSharp\LanguageServices\CSharpSyntaxGeneratorInternal.cs (8)
93
PatternSyntax
pattern => pattern.Parenthesize(includeElasticTrivia, addSimplifierAnnotation),
202
(
PatternSyntax
)pattern);
205
=> SyntaxFactory.BinaryPattern(SyntaxKind.AndPattern, (
PatternSyntax
)Parenthesize(left), (
PatternSyntax
)Parenthesize(right));
228
=> SyntaxFactory.UnaryPattern(NotKeyword, (
PatternSyntax
)Parenthesize(pattern));
231
=> SyntaxFactory.BinaryPattern(SyntaxKind.OrPattern, (
PatternSyntax
)Parenthesize(left), (
PatternSyntax
)Parenthesize(right));
240
=> SyntaxFactory.UnaryPattern(operatorToken, (
PatternSyntax
)Parenthesize(pattern));
src\Workspaces\SharedUtilitiesAndExtensions\Workspace\CSharp\LanguageServices\CSharpTypeInferenceService.TypeInferrer.cs (1)
1530
private IEnumerable<TypeInferenceInfo> GetPatternTypes(
PatternSyntax
pattern)
Microsoft.CodeAnalysis.CSharp.Emit3.UnitTests (9)
Semantics\PatternMatchingTests2.cs (5)
2160
foreach (
var
pat in tree.GetRoot().DescendantNodesAndSelf().OfType<
PatternSyntax
>())
2251
var patterns = tree.GetRoot().DescendantNodesAndSelf().OfType<
PatternSyntax
>().ToArray();
2295
var patterns = tree.GetRoot().DescendantNodesAndSelf().OfType<
PatternSyntax
>().ToArray();
2341
var patterns = tree.GetRoot().DescendantNodesAndSelf().OfType<
PatternSyntax
>().ToArray();
Semantics\PatternMatchingTests3.cs (4)
4107
var patterns = tree.GetRoot().DescendantNodes().OfType<
PatternSyntax
>().ToArray();
4111
var
pattern = patterns[i];
4334
var patterns = tree.GetRoot().DescendantNodes().OfType<
PatternSyntax
>().ToArray();
4338
var
pattern = patterns[i];
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)
58
var propertyPatternType = semanticModel.GetTypeInfo((
PatternSyntax
)propertyPatternClause.Parent!, cancellationToken).ConvertedType;
181
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);
95
private static
PatternSyntax
AsPatternSyntax(AnalyzedPattern pattern, Feature feature)
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\Analyzers\CSharp\Analyzers\RemoveUnnecessaryParentheses\CSharpRemoveUnnecessaryPatternParenthesesDiagnosticAnalyzer.cs (2)
46
var
inner = parenthesizedPattern.Pattern;
51
if (parenthesizedPattern.Parent is not
PatternSyntax
)
src\Analyzers\CSharp\Analyzers\UseNullPropagation\CSharpUseNullPropagationDiagnosticAnalyzer.cs (1)
51
var
pattern = patternExpression.Pattern;
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\Analyzers\CSharp\Analyzers\UsePatternCombinators\CSharpUsePatternCombinatorsAnalyzer.cs (1)
64
case IIsPatternOperation { Pattern.Syntax:
PatternSyntax
pattern } op:
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\Analyzers\CSharp\CodeFixes\UsePatternCombinators\CSharpUsePatternCombinatorsCodeFixProvider.cs (5)
85
var
patternSyntax = AsPatternSyntax(pattern).WithAdditionalAnnotations(Formatter.Annotation);
90
private static
PatternSyntax
AsPatternSyntax(AnalyzedPattern pattern)
109
private static
PatternSyntax
ProcessNotPattern(Not notPattern)
112
var
underlyingPattern = AsPatternSyntax(notPattern.Pattern);
113
var
unwrapped = underlyingPattern;
src\Analyzers\CSharp\CodeFixes\UsePatternMatching\CSharpAsAndMemberAccessCodeFixProvider.cs (2)
117
static (SyntaxToken notKeyword,
PatternSyntax
pattern) CreatePattern(
137
PatternSyntax
pattern = binaryExpression.Kind() switch
Microsoft.CodeAnalysis.CSharp.Syntax.UnitTests (2)
Generated\Syntax.Test.xml.Generated.cs (2)
10667
=> SyntaxFactory.ListPattern(SyntaxFactory.Token(SyntaxKind.OpenBracketToken), new SeparatedSyntaxList<
PatternSyntax
>(), SyntaxFactory.Token(SyntaxKind.CloseBracketToken), default(VariableDesignationSyntax));
10670
=> SyntaxFactory.SlicePattern(SyntaxFactory.Token(SyntaxKind.DotDotToken), default(
PatternSyntax
));
Microsoft.CodeAnalysis.CSharp.Test.Utilities (1)
CompilationTestUtils.cs (1)
271
else if (node is
PatternSyntax
pattern)
Microsoft.CodeAnalysis.CSharp.Workspaces (28)
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\Workspaces\SharedUtilitiesAndExtensions\Compiler\CSharp\Extensions\ParenthesizedExpressionSyntaxExtensions.cs (5)
714
var
pattern = node.Pattern;
759
return node.Parent is
PatternSyntax
patternParent &&
764
ParenthesizedPatternSyntax node,
PatternSyntax
parentPattern)
766
var
pattern = node.Pattern;
779
public static OperatorPrecedence GetOperatorPrecedence(this
PatternSyntax
pattern)
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\Workspaces\SharedUtilitiesAndExtensions\Compiler\CSharp\Services\SyntaxFacts\CSharpSyntaxFacts.cs (2)
993
return node is
PatternSyntax
? null : node;
1395
=> node is
PatternSyntax
;
src\Workspaces\SharedUtilitiesAndExtensions\Compiler\CSharp\Simplification\Simplifiers\CastSimplifier.cs (1)
193
if (isDefaultLiteralCast && castNode.WalkUpParentheses().Parent is
PatternSyntax
or CaseSwitchLabelSyntax)
src\Workspaces\SharedUtilitiesAndExtensions\Workspace\CSharp\Extensions\ContextQuery\SyntaxTreeExtensions.cs (2)
1471
var
patternSyntax = leftToken.GetAncestor<
PatternSyntax
>();
src\Workspaces\SharedUtilitiesAndExtensions\Workspace\CSharp\Extensions\ExpressionSyntaxExtensions.cs (3)
69
public static
PatternSyntax
Parenthesize(
70
this
PatternSyntax
pattern, bool includeElasticTrivia = true, bool addSimplifierAnnotation = true)
72
var
withoutTrivia = pattern.WithoutTrivia();
src\Workspaces\SharedUtilitiesAndExtensions\Workspace\CSharp\LanguageServices\CSharpSyntaxGeneratorInternal.cs (8)
93
PatternSyntax
pattern => pattern.Parenthesize(includeElasticTrivia, addSimplifierAnnotation),
202
(
PatternSyntax
)pattern);
205
=> SyntaxFactory.BinaryPattern(SyntaxKind.AndPattern, (
PatternSyntax
)Parenthesize(left), (
PatternSyntax
)Parenthesize(right));
228
=> SyntaxFactory.UnaryPattern(NotKeyword, (
PatternSyntax
)Parenthesize(pattern));
231
=> SyntaxFactory.BinaryPattern(SyntaxKind.OrPattern, (
PatternSyntax
)Parenthesize(left), (
PatternSyntax
)Parenthesize(right));
240
=> SyntaxFactory.UnaryPattern(operatorToken, (
PatternSyntax
)Parenthesize(pattern));
src\Workspaces\SharedUtilitiesAndExtensions\Workspace\CSharp\LanguageServices\CSharpTypeInferenceService.TypeInferrer.cs (1)
1530
private IEnumerable<TypeInferenceInfo> GetPatternTypes(
PatternSyntax
pattern)
Roslyn.Diagnostics.CSharp.Analyzers (24)
src\Workspaces\SharedUtilitiesAndExtensions\Compiler\CSharp\Extensions\ParenthesizedExpressionSyntaxExtensions.cs (5)
714
var
pattern = node.Pattern;
759
return node.Parent is
PatternSyntax
patternParent &&
764
ParenthesizedPatternSyntax node,
PatternSyntax
parentPattern)
766
var
pattern = node.Pattern;
779
public static OperatorPrecedence GetOperatorPrecedence(this
PatternSyntax
pattern)
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\Workspaces\SharedUtilitiesAndExtensions\Compiler\CSharp\Services\SyntaxFacts\CSharpSyntaxFacts.cs (2)
993
return node is
PatternSyntax
? null : node;
1395
=> node is
PatternSyntax
;
src\Workspaces\SharedUtilitiesAndExtensions\Compiler\CSharp\Simplification\Simplifiers\CastSimplifier.cs (1)
193
if (isDefaultLiteralCast && castNode.WalkUpParentheses().Parent is
PatternSyntax
or CaseSwitchLabelSyntax)
src\Workspaces\SharedUtilitiesAndExtensions\Workspace\CSharp\Extensions\ContextQuery\SyntaxTreeExtensions.cs (2)
1471
var
patternSyntax = leftToken.GetAncestor<
PatternSyntax
>();
src\Workspaces\SharedUtilitiesAndExtensions\Workspace\CSharp\Extensions\ExpressionSyntaxExtensions.cs (3)
69
public static
PatternSyntax
Parenthesize(
70
this
PatternSyntax
pattern, bool includeElasticTrivia = true, bool addSimplifierAnnotation = true)
72
var
withoutTrivia = pattern.WithoutTrivia();
src\Workspaces\SharedUtilitiesAndExtensions\Workspace\CSharp\LanguageServices\CSharpSyntaxGeneratorInternal.cs (8)
93
PatternSyntax
pattern => pattern.Parenthesize(includeElasticTrivia, addSimplifierAnnotation),
202
(
PatternSyntax
)pattern);
205
=> SyntaxFactory.BinaryPattern(SyntaxKind.AndPattern, (
PatternSyntax
)Parenthesize(left), (
PatternSyntax
)Parenthesize(right));
228
=> SyntaxFactory.UnaryPattern(NotKeyword, (
PatternSyntax
)Parenthesize(pattern));
231
=> SyntaxFactory.BinaryPattern(SyntaxKind.OrPattern, (
PatternSyntax
)Parenthesize(left), (
PatternSyntax
)Parenthesize(right));
240
=> SyntaxFactory.UnaryPattern(operatorToken, (
PatternSyntax
)Parenthesize(pattern));
src\Workspaces\SharedUtilitiesAndExtensions\Workspace\CSharp\LanguageServices\CSharpTypeInferenceService.TypeInferrer.cs (1)
1530
private IEnumerable<TypeInferenceInfo> GetPatternTypes(
PatternSyntax
pattern)