12 types derived from PatternSyntax
Microsoft.CodeAnalysis.CSharp (12)
_generated\2\Syntax.xml.Syntax.Generated.cs (12)
5245
public sealed partial class DiscardPatternSyntax :
PatternSyntax
5283
public sealed partial class DeclarationPatternSyntax :
PatternSyntax
5338
public sealed partial class VarPatternSyntax :
PatternSyntax
5380
public sealed partial class RecursivePatternSyntax :
PatternSyntax
5621
public sealed partial class ConstantPatternSyntax :
PatternSyntax
5661
public sealed partial class ParenthesizedPatternSyntax :
PatternSyntax
5706
public sealed partial class RelationalPatternSyntax :
PatternSyntax
5749
public sealed partial class TypePatternSyntax :
PatternSyntax
5790
public sealed partial class BinaryPatternSyntax :
PatternSyntax
5848
public sealed partial class UnaryPatternSyntax :
PatternSyntax
5890
public sealed partial class ListPatternSyntax :
PatternSyntax
5960
public sealed partial class SlicePatternSyntax :
PatternSyntax
249 references to PatternSyntax
Microsoft.CodeAnalysis.CSharp (87)
_generated\0\Syntax.xml.Main.Generated.cs (32)
1774
=> node.Update((ExpressionSyntax?)Visit(node.Expression) ?? throw new ArgumentNullException("expression"), VisitToken(node.IsKeyword), (
PatternSyntax
?)Visit(node.Pattern) ?? throw new ArgumentNullException("pattern"));
1801
=> node.Update((BaseExpressionColonSyntax?)Visit(node.ExpressionColon), (
PatternSyntax
?)Visit(node.Pattern) ?? throw new ArgumentNullException("pattern"));
1807
=> node.Update(VisitToken(node.OpenParenToken), (
PatternSyntax
?)Visit(node.Pattern) ?? throw new ArgumentNullException("pattern"), VisitToken(node.CloseParenToken));
1816
=> node.Update((
PatternSyntax
?)Visit(node.Left) ?? throw new ArgumentNullException("left"), VisitToken(node.OperatorToken), (
PatternSyntax
?)Visit(node.Right) ?? throw new ArgumentNullException("right"));
1819
=> node.Update(VisitToken(node.OperatorToken), (
PatternSyntax
?)Visit(node.Pattern) ?? throw new ArgumentNullException("pattern"));
1825
=> node.Update(VisitToken(node.DotDotToken), (
PatternSyntax
?)Visit(node.Pattern));
1939
=> node.Update(VisitToken(node.Keyword), (
PatternSyntax
?)Visit(node.Pattern) ?? throw new ArgumentNullException("pattern"), (WhenClauseSyntax?)Visit(node.WhenClause), VisitToken(node.ColonToken));
1951
=> 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"));
3700
public static IsPatternExpressionSyntax IsPatternExpression(ExpressionSyntax expression, SyntaxToken isKeyword,
PatternSyntax
pattern)
3709
public static IsPatternExpressionSyntax IsPatternExpression(ExpressionSyntax expression,
PatternSyntax
pattern)
3802
public static SubpatternSyntax Subpattern(BaseExpressionColonSyntax? expressionColon,
PatternSyntax
pattern)
3809
public static SubpatternSyntax Subpattern(
PatternSyntax
pattern)
3820
public static ParenthesizedPatternSyntax ParenthesizedPattern(SyntaxToken openParenToken,
PatternSyntax
pattern, SyntaxToken closeParenToken)
3829
public static ParenthesizedPatternSyntax ParenthesizedPattern(
PatternSyntax
pattern)
3857
public static BinaryPatternSyntax BinaryPattern(SyntaxKind kind,
PatternSyntax
left, SyntaxToken operatorToken,
PatternSyntax
right)
3877
public static BinaryPatternSyntax BinaryPattern(SyntaxKind kind,
PatternSyntax
left,
PatternSyntax
right)
3889
public static UnaryPatternSyntax UnaryPattern(SyntaxToken operatorToken,
PatternSyntax
pattern)
3897
public static UnaryPatternSyntax UnaryPattern(
PatternSyntax
pattern)
3901
public static ListPatternSyntax ListPattern(SyntaxToken openBracketToken, SeparatedSyntaxList<
PatternSyntax
> patterns, SyntaxToken closeBracketToken, VariableDesignationSyntax? designation)
3909
public static ListPatternSyntax ListPattern(SeparatedSyntaxList<
PatternSyntax
> patterns, VariableDesignationSyntax? designation)
3913
public static ListPatternSyntax ListPattern(SeparatedSyntaxList<
PatternSyntax
> patterns = default)
3917
public static SlicePatternSyntax SlicePattern(SyntaxToken dotDotToken,
PatternSyntax
? pattern)
3924
public static SlicePatternSyntax SlicePattern(
PatternSyntax
? pattern = default)
4615
public static CasePatternSwitchLabelSyntax CasePatternSwitchLabel(SyntaxToken keyword,
PatternSyntax
pattern, WhenClauseSyntax? whenClause, SyntaxToken colonToken)
4624
public static CasePatternSwitchLabelSyntax CasePatternSwitchLabel(
PatternSyntax
pattern, WhenClauseSyntax? whenClause, SyntaxToken colonToken)
4628
public static CasePatternSwitchLabelSyntax CasePatternSwitchLabel(
PatternSyntax
pattern, SyntaxToken colonToken)
4675
public static SwitchExpressionArmSyntax SwitchExpressionArm(
PatternSyntax
pattern, WhenClauseSyntax? whenClause, SyntaxToken equalsGreaterThanToken, ExpressionSyntax expression)
4684
public static SwitchExpressionArmSyntax SwitchExpressionArm(
PatternSyntax
pattern, WhenClauseSyntax? whenClause, ExpressionSyntax expression)
4688
public static SwitchExpressionArmSyntax SwitchExpressionArm(
PatternSyntax
pattern, ExpressionSyntax expression)
_generated\2\Syntax.xml.Syntax.Generated.cs (41)
5096
private
PatternSyntax
? pattern;
5109
public
PatternSyntax
Pattern => GetRed(ref this.pattern, 2)!;
5130
public IsPatternExpressionSyntax Update(ExpressionSyntax expression, SyntaxToken isKeyword,
PatternSyntax
pattern)
5144
public IsPatternExpressionSyntax WithPattern(
PatternSyntax
pattern) => Update(this.Expression, this.IsKeyword, pattern);
5569
private
PatternSyntax
? pattern;
5578
public
PatternSyntax
Pattern => GetRed(ref this.pattern, 1)!;
5599
public SubpatternSyntax Update(BaseExpressionColonSyntax? expressionColon,
PatternSyntax
pattern)
5612
public SubpatternSyntax WithPattern(
PatternSyntax
pattern) => Update(this.ExpressionColon, pattern);
5663
private
PatternSyntax
? pattern;
5672
public
PatternSyntax
Pattern => GetRed(ref this.pattern, 1)!;
5683
public ParenthesizedPatternSyntax Update(SyntaxToken openParenToken,
PatternSyntax
pattern, SyntaxToken closeParenToken)
5696
public ParenthesizedPatternSyntax WithPattern(
PatternSyntax
pattern) => Update(this.OpenParenToken, pattern, this.CloseParenToken);
5792
private
PatternSyntax
? left;
5793
private
PatternSyntax
? right;
5800
public
PatternSyntax
Left => GetRedAtZero(ref this.left)!;
5804
public
PatternSyntax
Right => GetRed(ref this.right, 2)!;
5825
public BinaryPatternSyntax Update(
PatternSyntax
left, SyntaxToken operatorToken,
PatternSyntax
right)
5837
public BinaryPatternSyntax WithLeft(
PatternSyntax
left) => Update(left, this.OperatorToken, this.Right);
5839
public BinaryPatternSyntax WithRight(
PatternSyntax
right) => Update(this.Left, this.OperatorToken, right);
5850
private
PatternSyntax
? pattern;
5859
public
PatternSyntax
Pattern => GetRed(ref this.pattern, 1)!;
5868
public UnaryPatternSyntax Update(SyntaxToken operatorToken,
PatternSyntax
pattern)
5881
public UnaryPatternSyntax WithPattern(
PatternSyntax
pattern) => Update(this.OperatorToken, pattern);
5902
public SeparatedSyntaxList<
PatternSyntax
> Patterns
5907
return red != null ? new SeparatedSyntaxList<
PatternSyntax
>(red, GetChildIndex(1)) : default;
5934
public ListPatternSyntax Update(SyntaxToken openBracketToken, SeparatedSyntaxList<
PatternSyntax
> patterns, SyntaxToken closeBracketToken, VariableDesignationSyntax? designation)
5947
public ListPatternSyntax WithPatterns(SeparatedSyntaxList<
PatternSyntax
> patterns) => Update(this.OpenBracketToken, patterns, this.CloseBracketToken, this.Designation);
5951
public ListPatternSyntax AddPatterns(params
PatternSyntax
[] items) => WithPatterns(this.Patterns.AddRange(items));
5962
private
PatternSyntax
? pattern;
5971
public
PatternSyntax
? Pattern => GetRed(ref this.pattern, 1);
5980
public SlicePatternSyntax Update(SyntaxToken dotDotToken,
PatternSyntax
? pattern)
5993
public SlicePatternSyntax WithPattern(
PatternSyntax
? pattern) => Update(this.DotDotToken, pattern);
8701
private
PatternSyntax
? pattern;
8715
public
PatternSyntax
Pattern => GetRed(ref this.pattern, 1)!;
8740
public CasePatternSwitchLabelSyntax Update(SyntaxToken keyword,
PatternSyntax
pattern, WhenClauseSyntax? whenClause, SyntaxToken colonToken)
8754
public CasePatternSwitchLabelSyntax WithPattern(
PatternSyntax
pattern) => Update(this.Keyword, pattern, this.WhenClause, this.ColonToken);
8938
private
PatternSyntax
? pattern;
8947
public
PatternSyntax
Pattern => GetRedAtZero(ref this.pattern)!;
8976
public SwitchExpressionArmSyntax Update(
PatternSyntax
pattern, WhenClauseSyntax? whenClause, SyntaxToken equalsGreaterThanToken, ExpressionSyntax expression)
8988
public SwitchExpressionArmSyntax WithPattern(
PatternSyntax
pattern) => Update(pattern, this.WhenClause, this.EqualsGreaterThanToken, this.Expression);
Binder\Binder_Patterns.cs (4)
362
PatternSyntax
node,
468
SeparatedSyntaxList<
PatternSyntax
> subpatterns,
480
foreach (
PatternSyntax
pattern in subpatterns)
1895
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))
5058
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)
1471
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)
1471
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)
1471
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)