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