src\Analyzers\Core\Analyzers\RemoveUnusedParametersAndValues\AbstractRemoveUnusedParametersAndValuesDiagnosticAnalyzer.SymbolStartAnalyzer.BlockAnalyzer.cs (2)
544case RefKind.Out:
551case RefKind.Ref:
src\Analyzers\Core\CodeFixes\GenerateParameterizedMember\AbstractGenerateDeconstructMethodService.State.cs (1)
76refKind: RefKind.None,
src\Analyzers\Core\CodeFixes\GenerateParameterizedMember\AbstractGenerateMethodService.State.cs (1)
255refKind: RefKind.None,
src\Analyzers\Core\CodeFixes\GenerateVariable\AbstractGenerateVariableService.cs (8)
144document, state, generateProperty: false, isReadonly: false, isConstant: true, refKind: RefKind.None));
158document, state, generateProperty: false, isReadonly: true, isConstant: false, refKind: RefKind.None));
172document, state, generateProperty: false, isReadonly: false, isConstant: false, refKind: RefKind.None));
220parameter.RefKind is RefKind.Out ||
245private static RefKind GetRefKindFromContext(State state)
249return RefKind.Ref;
253return RefKind.RefReadOnly;
257return RefKind.None;
src\Analyzers\Core\CodeFixes\GenerateVariable\AbstractGenerateVariableService.GenerateParameterCodeAction.cs (1)
49RefKind.None,
src\Workspaces\SharedUtilitiesAndExtensions\Workspace\Core\CodeGeneration\CodeGenerationSymbolFactory.cs (10)
53RefKind refKind,
84ITypeSymbol type, RefKind refKind, ImmutableArray<IPropertySymbol> explicitInterfaceImplementations, string name,
158RefKind refKind,
180RefKind refKind,
270=> CreateParameterSymbol(RefKind.None, type, name);
272public static IParameterSymbol CreateParameterSymbol(RefKind refKind, ITypeSymbol type, string name)
282ImmutableArray<AttributeData> attributes, RefKind refKind, bool isParams, ITypeSymbol type, string name, bool isOptional = false, bool hasDefaultValue = false, object? defaultValue = null)
293RefKind? refKind = null,
397refKind: RefKind.None,
469RefKind refKind,
src\Workspaces\SharedUtilitiesAndExtensions\Workspace\Core\CodeGeneration\Symbols\CodeGenerationConstructorSymbol.cs (1)
27refKind: RefKind.None,
src\Workspaces\SharedUtilitiesAndExtensions\Workspace\Core\CodeGeneration\Symbols\CodeGenerationConversionSymbol.cs (1)
31refKind: RefKind.None,
src\Workspaces\SharedUtilitiesAndExtensions\Workspace\Core\CodeGeneration\Symbols\CodeGenerationDestructorSymbol.cs (1)
18refKind: RefKind.None,
src\Workspaces\SharedUtilitiesAndExtensions\Workspace\Core\CodeGeneration\Symbols\CodeGenerationOperatorSymbol.cs (1)
32refKind: RefKind.None,
src\Workspaces\SharedUtilitiesAndExtensions\Workspace\Core\Extensions\SyntaxGeneratorExtensions_CreateEqualsMethod.cs (1)
56refKind: RefKind.None,
Binder\Binder.ValueChecks.cs (126)
53Method is { RefKind: not RefKind.None, ReturnType: { } returnType } &&
154internal RefKind RefKind { get; }
156internal EscapeArgument(ParameterSymbol? parameter, BoundExpression argument, RefKind refKind, bool isArgList = false)
164public void Deconstruct(out ParameterSymbol? parameter, out BoundExpression argument, out RefKind refKind)
363if (indexerAccess.Indexer.RefKind != RefKind.None)
386var useSetAccessor = coreValueKind == BindValueKind.Assignable && indexerAccess.Indexer.RefKind != RefKind.Ref;
395ArrayBuilder<RefKind>? refKindsBuilderOpt;
398refKindsBuilderOpt = ArrayBuilder<RefKind>.GetInstance(accessorForDefaultArguments.ParameterCount);
1037if (localSymbol.RefKind == RefKind.RefReadOnly ||
1038(localSymbol.RefKind == RefKind.None && !localSymbol.IsWritableVariable))
1046if (localSymbol.RefKind == RefKind.None)
1078if (localSymbol.RefKind == RefKind.None)
1119if (parameterSymbol.RefKind is RefKind.In or RefKind.RefReadOnlyParameter && RequiresAssignableVariable(valueKind))
1124else if (parameterSymbol.RefKind == RefKind.None && RequiresRefAssignableVariable(valueKind))
1130Debug.Assert(parameterSymbol.RefKind != RefKind.None || !RequiresRefAssignableVariable(valueKind));
1134if (parameterSymbol.RefKind == RefKind.None &&
1138Debug.Assert(backingField.RefKind == RefKind.None);
1143Debug.Assert(backingField.RefKind == RefKind.None);
1233{ RefKind: RefKind.Out, UseUpdatedEscapeRules: true } => SafeContext.ReturnOnly,
1245{ RefKind: RefKind.None } => SafeContext.CurrentMethod,
1247{ HasUnscopedRefAttribute: true, UseUpdatedEscapeRules: true, RefKind: RefKind.Out } => SafeContext.ReturnOnly,
1280Debug.Assert(parameterSymbol.RefKind == RefKind.None || isRefScoped || refSafeToEscape.IsReturnOnly);
1330if ((fieldSymbol.RefKind == RefKind.None ? RequiresAssignableVariable(valueKind) : RequiresRefAssignableVariable(valueKind)) &&
1342case RefKind.None:
1344case RefKind.Ref:
1346case RefKind.RefReadOnly:
1367case RefKind.None:
1370case RefKind.Ref:
1371case RefKind.RefReadOnly:
1382case RefKind.None:
1384case RefKind.Ref:
1385case RefKind.RefReadOnly:
1485if (fieldSymbol.RefKind != RefKind.None)
1509if (fieldSymbol.RefKind != RefKind.None)
1645if (RequiresVariable(valueKind) && methodSymbol.RefKind == RefKind.None)
1660if (RequiresAssignableVariable(valueKind) && methodSymbol.RefKind == RefKind.RefReadOnly)
1691propertySymbol.RefKind == RefKind.None)
1715if (RequiresAssignableVariable(valueKind) && propertySymbol.RefKind == RefKind.RefReadOnly)
1721var requiresSet = RequiresAssignableVariable(valueKind) && propertySymbol.RefKind == RefKind.None;
1790var requiresGet = !RequiresAssignmentOnly(valueKind) || propertySymbol.RefKind != RefKind.None;
1963ImmutableArray<RefKind> argRefKindsOpt,
2052ImmutableArray<RefKind> argRefKindsOpt,
2082(param is { RefKind: not RefKind.None, Type: { } type } && type.IsRefLikeOrAllowsRefLikeType())) &&
2117ImmutableArray<RefKind> argRefKindsOpt,
2174var valid = effectiveRefKind != RefKind.None && isRefEscape ?
2210ImmutableArray<RefKind> argRefKindsOpt,
2243(param is { RefKind: not RefKind.None, Type: { } type } && type.IsRefLikeOrAllowsRefLikeType())) &&
2283ImmutableArray<RefKind> argRefKindsOpt,
2344var refKind = parameter?.RefKind ?? RefKind.None;
2349if (refKind == RefKind.None &&
2350parameter?.RefKind is RefKind.In or RefKind.RefReadOnlyParameter)
2385if (getArgument.RefKind == RefKind.Ref)
2391if (setArgument.RefKind == RefKind.Ref)
2407return new EscapeArgument(parameter: null, receiver, RefKind.None);
2410var refKind = RefKind.None;
2430ImmutableArray<RefKind> argRefKindsOpt,
2437var refKind = argRefKindsOpt.IsDefault ? RefKind.None : argRefKindsOpt[argIndex];
2440if (refKind == RefKind.Ref && mixableArguments is not null)
2460ImmutableArray<RefKind> argRefKindsOpt,
2530ImmutableArray<RefKind> argRefKindsOpt,
2585ImmutableArray<RefKind> argRefKindsOpt,
2615if (refKind != RefKind.None)
2628if (parameter.Type.IsRefLikeOrAllowsRefLikeType() && parameter.RefKind != RefKind.Out && GetParameterValEscapeLevel(parameter) is { } valEscapeLevel)
2635if (parameter.RefKind != RefKind.None && GetParameterRefEscapeLevel(parameter) is { } refEscapeLevel)
2661ImmutableArray<RefKind> argRefKindsOpt,
2704if (parameter.RefKind != RefKind.None)
2775ImmutableArray<RefKind> argRefKindsOpt,
2875ImmutableArray<RefKind> argRefKindsOpt,
2992Debug.Assert(underlyingParameter.RefKind != RefKind.Out); // Shouldn't get here for a constructor
3002public override RefKind RefKind
3006if (_underlyingParameter.RefKind is not RefKind.None and var underlyingRefKind)
3013return RefKind.None;
3018return RefKind.Ref;
3226Debug.Assert(field.RefKind == RefKind.None ? RequiresAssignableVariable(kind) : RequiresRefAssignableVariable(kind));
3423if (methodSymbol.RefKind == RefKind.None)
3445if (methodSymbol.RefKind == RefKind.None)
3506if (methodSymbol.RefKind == RefKind.None)
3533Debug.Assert(GetInlineArrayAccessEquivalentSignatureMethod(elementAccess, out _, out _).RefKind == RefKind.None);
3538ImmutableArray<RefKind> refKinds;
3541Debug.Assert(equivalentSignatureMethod.RefKind != RefKind.None);
3585conversion.Conversion.Method.RefKind == RefKind.None));
3592unaryMethod.RefKind == RefKind.None));
3599binaryMethod.RefKind == RefKind.None));
3605logicalOperator.LogicalOperator.RefKind == RefKind.None));
3612compoundMethod.RefKind == RefKind.None));
3740if (methodSymbol.RefKind == RefKind.None)
3766if (indexerSymbol.RefKind == RefKind.None)
3797if (indexerSymbol.RefKind == RefKind.None)
3823if (methodSymbol.RefKind == RefKind.None)
3854Debug.Assert(GetInlineArrayAccessEquivalentSignatureMethod(elementAccess, out _, out _).RefKind == RefKind.None);
3859ImmutableArray<RefKind> refKinds;
3862Debug.Assert(equivalentSignatureMethod.RefKind != RefKind.None);
3884if (signature.RefKind == RefKind.None)
3908if (propertySymbol.RefKind == RefKind.None)
3955conversion.Conversion.Method.RefKind == RefKind.None);
3962unaryMethod.RefKind == RefKind.None));
3969binaryMethod.RefKind == RefKind.None));
3975logicalOperator.LogicalOperator.RefKind == RefKind.None));
3982compoundMethod.RefKind == RefKind.None));
4226ImmutableArray<RefKind> refKinds;
4339ImmutableArray<RefKind> refKinds;
4539if (constructMethod is not { Parameters: [{ RefKind: RefKind.None } parameter] })
4680var accessorKind = property.RefKind == RefKind.None ? AccessorKind.Set : AccessorKind.Get;
4965ImmutableArray<RefKind> refKinds;
5119ImmutableArray<RefKind> refKinds;
5439private SignatureOnlyMethodSymbol GetInlineArrayAccessEquivalentSignatureMethod(BoundInlineArrayAccess elementAccess, out ImmutableArray<BoundExpression> arguments, out ImmutableArray<RefKind> refKinds)
5441RefKind resultRefKind;
5442RefKind parameterRefKind;
5453resultRefKind = RefKind.None;
5454parameterRefKind = RefKind.None;
5458resultRefKind = elementAccess.GetItemOrSliceHelper is WellKnownMember.System_ReadOnlySpan_T__get_Item ? RefKind.In : RefKind.Ref;
5467resultRefKind = RefKind.None;
5468parameterRefKind = elementAccess.GetItemOrSliceHelper is WellKnownMember.System_ReadOnlySpan_T__Slice_Int_Int ? RefKind.In : RefKind.Ref;
5501private SignatureOnlyMethodSymbol GetInlineArrayConversionEquivalentSignatureMethod(BoundConversion conversion, out ImmutableArray<BoundExpression> arguments, out ImmutableArray<RefKind> refKinds)
5507private SignatureOnlyMethodSymbol GetInlineArrayConversionEquivalentSignatureMethod(BoundExpression inlineArray, TypeSymbol resultType, out ImmutableArray<BoundExpression> arguments, out ImmutableArray<RefKind> refKinds)
5513RefKind parameterRefKind = resultType.OriginalDefinition.Equals(_compilation.GetWellKnownType(WellKnownType.System_ReadOnlySpan_T), TypeCompareKind.AllIgnoreOptions) ? RefKind.In : RefKind.Ref;
5528RefKind.None,
Binder\Binder_Expressions.cs (64)
454if (field is { IsStatic: false, RefKind: RefKind.None, ContainingSymbol: SourceMemberContainerTypeSymbol { PrimaryConstructor: { } primaryConstructor } } &&
466RefKind refKind,
1963private bool IsBadLocalOrParameterCapture(Symbol symbol, TypeSymbol type, RefKind refKind)
1965if (refKind != RefKind.None || type.IsRestrictedType())
2089if (localSymbol.RefKind == RefKind.None && type.IsRestrictedType(ignoreSpanLikeTypes: true))
2129if (parameter.RefKind != RefKind.None)
2149(parameter.RefKind != RefKind.None || parameter.Type.IsRestrictedType()) &&
2152if (parameter.RefKind != RefKind.None)
2166else if (primaryCtor is { ThisParameter.RefKind: not RefKind.None } &&
2527if (thisSymbol is not null && thisSymbol.ContainingSymbol != ContainingMemberOrLambda && thisSymbol.RefKind != RefKind.None)
3081RefKind origRefKind = argumentSyntax.RefOrOutKeyword.Kind().GetRefKind();
3085RefKind refKind = origRefKind == RefKind.None || RefMustBeObeyed(isDelegateCreation, argumentSyntax) ? origRefKind : RefKind.None;
3098if (!hadError && isDelegateCreation && origRefKind != RefKind.None && result.Arguments.Count == 1)
3105var requiredValueKind = origRefKind == RefKind.In ? BindValueKind.ReadonlyRef : BindValueKind.RefOrOut;
3117private BoundExpression BindArgumentValue(BindingDiagnosticBag diagnostics, ArgumentSyntax argumentSyntax, bool allowArglist, RefKind refKind)
3318RefKind refKind)
3326if (refKind != RefKind.None)
3336result.RefKinds.Add(RefKind.None);
3384private BoundExpression BindArgumentExpression(BindingDiagnosticBag diagnostics, ExpressionSyntax argumentExpression, RefKind refKind, bool allowArglist)
3387refKind == RefKind.None ?
3389refKind == RefKind.In ?
3440var argRefKind = analyzedArguments.RefKind(arg);
3446if (argRefKind is RefKind.None or RefKind.In &&
3447getCorrespondingParameter(in result, parameters, arg).RefKind == RefKind.RefReadOnlyParameter)
3458if (argRefKind == RefKind.Ref)
3460if (getCorrespondingParameter(in result, parameters, arg).RefKind == RefKind.In)
3470else if (argRefKind == RefKind.None &&
3471getCorrespondingParameter(in result, parameters, arg).RefKind == RefKind.RefReadOnlyParameter)
3823var argumentRefKindsBuilder = ArrayBuilder<RefKind>.GetInstance(handlerArgumentIndexes.Length);
3833RefKind refKind;
3839refKind = RefKind.None;
3917argumentRefKindsBuilder.Add(refKind == RefKind.RefReadOnlyParameter ? RefKind.In : refKind);
5011if (analyzedArguments.RefKind(i) is (RefKind.Ref or RefKind.Out))
5528ArrayBuilder<RefKind> refKinds,
5721var rhsExpr = initializer.Right.CheckAndUnwrapRefExpression(diagnostics, out RefKind refKind);
5722bool isRef = refKind == RefKind.Ref;
5895ImmutableArray<RefKind> argumentRefKindsOpt = default;
8242extensionMethodArguments.RefKinds.Add(RefKind.None);
8376RefKind returnRefKind,
8638fieldSymbol.RefKind != RefKind.None)
9600RefKind refKind = analyzedArguments.RefKind(i);
9601if (refKind != RefKind.None)
9700default(ImmutableArray<RefKind>),
9818ImmutableArray<RefKind> argumentRefKinds = analyzedArguments.RefKinds.ToImmutableOrNull();
10069original.Parameters[0] is { Type.SpecialType: SpecialType.System_Int32, RefKind: RefKind.None })
10167original.Parameters[0] is { Type.SpecialType: SpecialType.System_Int32, RefKind: RefKind.None } &&
10168original.Parameters[1] is { Type.SpecialType: SpecialType.System_Int32, RefKind: RefKind.None };
10231getMethod.RefKind == RefKind.None &&
10274RefKind returnRefKind = default,
10295RefKind returnRefKind = default,
10322RefKind returnRefKind,
10343RefKind returnRefKind = default,
10413RefKind returnRefKind = default,
10828RefKind? returnRefKindOverride = null,
10835var returnRefKind = returnRefKindOverride ?? methodSymbol.RefKind;
10853if (returnsVoid && returnRefKind != RefKind.None)
10867returnRefKind == RefKind.None &&
10869(parameterRefKinds.IsDefault || parameterRefKinds.All(refKind => refKind == RefKind.None)) &&
10903parameterRefKinds.IsDefault ? RefKind.None : parameterRefKinds[i],
Binder\Binder_Query.cs (3)
696return lambdaBodyBinder.CreateBlockFromExpression(node, ImmutableArray<LocalSymbol>.Empty, RefKind.None, construction, null, d);
776return this.CreateBlockFromExpression(expression, locals, RefKind.None, result, expression, diagnostics);
818new AnonymousTypeField(fieldName, fieldValue.Syntax.Location, TypeWithAnnotations.Create(TypeOrError(fieldValue)), RefKind.None, ScopedKind.None);
Binder\Binder_Statements.cs (48)
863internal BoundExpression BindInferredVariableInitializer(BindingDiagnosticBag diagnostics, RefKind refKind, EqualsValueClauseSyntax initializer,
912RefKind variableRefKind,
917RefKind expressionRefKind = RefKind.None;
919if (variableRefKind == RefKind.None)
922if (expressionRefKind == RefKind.Ref)
930valueKind = variableRefKind == RefKind.RefReadOnly
939else if (expressionRefKind != RefKind.Ref)
1000if (localSymbol.RefKind != RefKind.None)
1066localSymbol.RefKind != RefKind.None ? ConversionForAssignmentFlags.RefAssignment : ConversionForAssignmentFlags.None);
1415var rhsExpr = node.Right.CheckAndUnwrapRefExpression(diagnostics, out var refKind);
1416var isRef = refKind == RefKind.Ref;
1445var lhsRefKind = boundLeft.GetRefKind();
1446if (lhsRefKind is RefKind.Ref or RefKind.Out)
2155var delegateRefKind = delegateParameters[i].RefKind;
2156var lambdaRefKind = anonymousFunction.RefKind(i);
2164if (delegateRefKind == RefKind.None)
2213var lambdaRefKind = anonymousFunction.RefKind(i);
2215var delegateRefKind = delegateParameters[i].RefKind;
2982protected virtual TypeSymbol GetCurrentReturnType(out RefKind refKind)
2999refKind = RefKind.None;
3005var refKind = RefKind.None;
3023RefKind sigRefKind;
3034if (refKind != RefKind.None)
3046else if ((object)retType != null && (refKind != RefKind.None) != (sigRefKind != RefKind.None))
3048var errorCode = refKind != RefKind.None
3146RefKind returnRefKind,
3156Debug.Assert(returnRefKind == RefKind.None);
3178if (returnRefKind != RefKind.None)
3194RefKind unusedRefKind;
3464internal BoundBlock CreateBlockFromExpression(CSharpSyntaxNode node, ImmutableArray<LocalSymbol> locals, RefKind refKind, BoundExpression expression, ExpressionSyntax expressionSyntax, BindingDiagnosticBag diagnostics)
3466RefKind returnRefKind;
3471if (IsInAsyncMethod() && refKind != RefKind.None)
3480if ((refKind != RefKind.None) != (returnRefKind != RefKind.None) && expression.Kind != BoundKind.ThrowExpression)
3482var errorCode = refKind != RefKind.None
3487statement = new BoundReturnStatement(syntax, RefKind.None, expression, @checked: CheckOverflowAtRuntime) { WasCompilerGenerated = true };
3591RefKind refKind;
3607RefKind refKind;
3620return bodyBinder.CreateBlockFromExpression(body, bodyBinder.GetDeclaredLocalsForScope(body), RefKind.None, expression, body, diagnostics);
3623private BindValueKind GetRequiredReturnValueKind(RefKind refKind)
3626if (refKind != RefKind.None)
3628GetCurrentReturnType(out var sigRefKind);
3629requiredValueKind = sigRefKind == RefKind.Ref ?
3980argumentRefKindsOpt: ImmutableArray<RefKind>.Empty,
Binder\Semantics\OverloadResolution\OverloadResolution.cs (78)
144RefKind returnRefKind = default,
192RefKind returnRefKind = default,
433RefKind returnRefKind,
839RefKind? returnRefKind,
864else if (returnRefKind == RefKind.None)
2167var type1 = getParameterTypeAndRefKind(i, m1.Result, m1LeastOverriddenParameters, m1.Result.ParamsElementTypeOpt, out RefKind parameter1RefKind);
2169var type2 = getParameterTypeAndRefKind(i, m2.Result, m2LeastOverriddenParameters, m2.Result.ParamsElementTypeOpt, out RefKind parameter2RefKind);
2558static TypeSymbol getParameterTypeAndRefKind(int i, MemberAnalysisResult result, ImmutableArray<ParameterSymbol> parameters, TypeWithAnnotations paramsElementTypeOpt, out RefKind parameter1RefKind)
2629if (p1.RefKind == RefKind.None && isAcceptableRefMismatch(p2.RefKind, isInterpolatedStringHandlerConversion))
2640else if (p2.RefKind == RefKind.None && isAcceptableRefMismatch(p1.RefKind, isInterpolatedStringHandlerConversion))
2656static bool isAcceptableRefMismatch(RefKind refKind, bool isInterpolatedStringHandlerConversion)
2659RefKind.In or RefKind.RefReadOnlyParameter => true,
2660RefKind.Ref when isInterpolatedStringHandlerConversion => true,
2836RefKind refKind1,
2839RefKind refKind2,
2864Debug.Assert(refKind1 == RefKind.None || refKind1 == RefKind.Ref);
2865Debug.Assert(refKind2 == RefKind.None || refKind2 == RefKind.Ref);
2869if (refKind1 == RefKind.None)
2878else if (refKind1 == RefKind.Ref)
3802ArrayBuilder<RefKind> argumentRefKinds,
3808out ImmutableArray<RefKind> parameterRefKinds)
3824internal readonly ImmutableArray<RefKind> ParameterRefKinds;
3827internal EffectiveParameters(ImmutableArray<TypeWithAnnotations> types, ImmutableArray<RefKind> refKinds, int firstParamsElementIndex)
3841ArrayBuilder<RefKind> argumentRefKinds,
3856ImmutableArray<RefKind> parameterRefKinds = member.GetParameterRefKinds();
3864ArrayBuilder<RefKind> refs = null;
3878RefKind argRefKind = hasAnyRefArg ? argumentRefKinds[arg] : RefKind.None;
3879RefKind paramRefKind = GetEffectiveParameterRefKind(parameter, argRefKind, options, binder, ref hasAnyRefOmittedArgument);
3883if (paramRefKind != RefKind.None)
3885refs = ArrayBuilder<RefKind>.GetInstance(arg, RefKind.None);
3895var refKinds = refs != null ? refs.ToImmutableAndFree() : default(ImmutableArray<RefKind>);
3899private static RefKind GetEffectiveParameterRefKind(
3901RefKind argRefKind,
3906var paramRefKind = parameter.RefKind;
3915if (paramRefKind == RefKind.In)
3917if (argRefKind == RefKind.None)
3919return RefKind.None;
3922if (argRefKind == RefKind.Ref && binder.Compilation.IsFeatureEnabled(MessageID.IDS_FeatureRefReadonlyParameters))
3924return RefKind.Ref;
3927else if (paramRefKind == RefKind.RefReadOnlyParameter && argRefKind is RefKind.None or RefKind.Ref or RefKind.In)
3940if ((options & Options.AllowRefOmittedArguments) != 0 && paramRefKind == RefKind.Ref && argRefKind == RefKind.None && !binder.InAttributeArgument)
3943return RefKind.None;
3952internal static bool AreRefsCompatibleForMethodConversion(RefKind candidateMethodParameterRefKind, RefKind delegateParameterRefKind, CSharpCompilation compilation)
3962(RefKind.RefReadOnlyParameter, RefKind.Ref) or
3963(RefKind.RefReadOnlyParameter, RefKind.In) or
3964(RefKind.In, RefKind.RefReadOnlyParameter))
3970(candidateMethodParameterRefKind, delegateParameterRefKind) is (RefKind.In, RefKind.Ref))
3982ArrayBuilder<RefKind> argumentRefKinds,
3993ArrayBuilder<RefKind> argumentRefKinds,
4001var refs = ArrayBuilder<RefKind>.GetInstance();
4031var argRefKind = hasAnyRefArg ? argumentRefKinds[arg] : RefKind.None;
4032var paramRefKind = GetEffectiveParameterRefKind(parameter, argRefKind, options, binder, ref hasAnyRefOmittedArgument);
4035if (paramRefKind != RefKind.None)
4041var refKinds = anyRef ? refs.ToImmutable() : default(ImmutableArray<RefKind>);
4468RefKind argumentRefKind = arguments.RefKind(argumentPosition);
4469RefKind parameterRefKind = parameters.ParameterRefKinds.IsDefault ? RefKind.None : parameters.ParameterRefKinds[argumentPosition];
4474Debug.Assert(argumentRefKind == RefKind.None);
4475if (parameterRefKind == RefKind.Ref)
4489&& parameterRefKind == RefKind.Ref
4585RefKind argRefKind,
4587RefKind parRefKind,
4624Debug.Assert(argRefKind != RefKind.None);
4630if (argRefKind == RefKind.None || hasInterpolatedStringRefMismatch)
BoundTree\BoundObjectCreationExpression.cs (3)
13ImmutableArray<RefKind> argumentRefKindsOpt, bool expanded, ImmutableArray<int> argsToParamsOpt, BitVector defaultArguments, ConstantValue? constantValueOpt,
18public BoundObjectCreationExpression Update(MethodSymbol constructor, ImmutableArray<BoundExpression> arguments, ImmutableArray<string?> argumentNamesOpt, ImmutableArray<RefKind> argumentRefKindsOpt, bool expanded,
25ImmutableArray<string?> argumentNamesOpt, ImmutableArray<RefKind> argumentRefKindsOpt, bool expanded, ImmutableArray<int> argsToParamsOpt,
BoundTree\Constructors.cs (28)
63fieldSymbol.RefKind != RefKind.None ||
93ImmutableArray<RefKind> argumentRefKindsOpt,
111ImmutableArray<RefKind> argumentRefKindsOpt,
127ImmutableArray<RefKind> refKinds,
183public static BoundCall Synthesized(SyntaxNode syntax, BoundExpression? receiverOpt, ThreeState initialBindingReceiverIsSubjectToCloning, MethodSymbol method, ImmutableArray<BoundExpression> arguments, ImmutableArray<RefKind> argumentRefKindsOpt = default)
192var parameterRefKind = method.ParameterRefKinds.IsDefault ? RefKind.None : method.ParameterRefKinds[i];
193var argumentRefKind = argumentRefKindsOpt.IsDefault ? RefKind.None : argumentRefKindsOpt[i];
194Debug.Assert(argumentRefKind is RefKind.None or RefKind.Ref or RefKind.In or RefKind.Out or RefKindExtensions.StrictIn &&
198RefKind.In => argumentRefKind == RefKindExtensions.StrictIn,
199RefKind.RefReadOnlyParameter => argumentRefKind is RefKind.In or RefKindExtensions.StrictIn,
230static ImmutableArray<RefKind> getArgumentRefKinds(MethodSymbol method)
234if (!result.IsDefaultOrEmpty && result.Contains(RefKind.RefReadOnlyParameter))
236var builder = ArrayBuilder<RefKind>.GetInstance(result.Length);
238foreach (var refKind in result)
240builder.Add(refKind == RefKind.RefReadOnlyParameter ? RefKind.In : refKind);
254: this(syntax, constructor, ImmutableArray.Create<BoundExpression>(arguments), default(ImmutableArray<string?>), default(ImmutableArray<RefKind>), false, default(ImmutableArray<int>), default(BitVector), null, null, constructor.ContainingType)
258: this(syntax, constructor, arguments, default(ImmutableArray<string?>), default(ImmutableArray<RefKind>), false, default(ImmutableArray<int>), default(BitVector), null, null, constructor.ContainingType)
271ImmutableArray<RefKind> refKinds,
297ImmutableArray<RefKind> argumentRefKindsOpt,
312ImmutableArray<RefKind> argumentRefKindsOpt,
604public static BoundReturnStatement Synthesized(SyntaxNode syntax, RefKind refKind, BoundExpression expression, bool hasErrors = false)
BoundTree\UnboundLambda.cs (49)
43internal readonly RefKind RefKind;
53RefKind refKind,
171ImmutableArray<RefKind> parameterRefKinds,
172RefKind refKind)
177parameterRefKinds.IsDefault ? Enumerable.Repeat(RefKind.None, parameterTypes.Length).ToImmutableArray() : parameterRefKinds,
207RefKind refKind = RefKind.None;
210RefKind rk = returnStatement.RefKind;
211if (rk != RefKind.None)
394RefKind returnRefKind,
397ImmutableArray<RefKind> refKinds,
462public bool HasExplicitReturnType(out RefKind refKind, out TypeWithAnnotations returnType)
487public RefKind RefKind(int index) { return Data.RefKind(index); }
577public abstract bool HasExplicitReturnType(out RefKind refKind, out TypeWithAnnotations returnType);
584public abstract RefKind RefKind(int index);
659private static TypeWithAnnotations DelegateReturnTypeWithAnnotations(MethodSymbol? invokeMethod, out RefKind refKind)
663refKind = CodeAnalysis.RefKind.None;
670internal (ImmutableArray<RefKind>, ArrayBuilder<ScopedKind>, ImmutableArray<TypeWithAnnotations>, bool) CollectParameterProperties()
672var parameterRefKindsBuilder = ArrayBuilder<RefKind>.GetInstance(ParameterCount);
679var refKind = RefKind(i);
736if (!HasExplicitReturnType(out var returnRefKind, out var returnType))
800var returnType = DelegateReturnTypeWithAnnotations(invokeMethod, out RefKind refKind);
819refKind == CodeAnalysis.RefKind.None &&
839if (lambdaSymbol.RefKind == CodeAnalysis.RefKind.RefReadOnly)
906ImmutableArray<RefKind> parameterRefKinds,
907RefKind refKind)
921var returnType = DelegateReturnTypeWithAnnotations(invokeMethod, out RefKind refKind);
954ImmutableArray<RefKind> parameterRefKinds)
956bool hasExplicitReturnType = HasExplicitReturnType(out var refKind, out var returnType);
1011ImmutableArray<RefKind> parameterRefKinds,
1013RefKind refKind)
1047public readonly ImmutableArray<RefKind> ParameterRefKinds;
1050public static readonly ReturnInferenceCacheKey Empty = new ReturnInferenceCacheKey(ImmutableArray<TypeWithAnnotations>.Empty, ImmutableArray<RefKind>.Empty, null);
1052private ReturnInferenceCacheKey(ImmutableArray<TypeWithAnnotations> parameterTypes, ImmutableArray<RefKind> parameterRefKinds, NamedTypeSymbol? taskLikeReturnTypeOpt)
1113out ImmutableArray<RefKind> parameterRefKinds,
1119parameterRefKinds = ImmutableArray<RefKind>.Empty;
1128var refKindsBuilder = ArrayBuilder<RefKind>.GetInstance(parameterCount);
1204?? rebind(ReallyInferReturnType(delegateType: null, ImmutableArray<TypeWithAnnotations>.Empty, ImmutableArray<RefKind>.Empty));
1221ImmutableArray<RefKind> parameterRefKinds)
1224var refKind = inferredReturnType.RefKind;
1236refKind = CodeAnalysis.RefKind.None;
1449private readonly RefKind _returnRefKind;
1455private readonly ImmutableArray<RefKind> _parameterRefKinds;
1464RefKind returnRefKind,
1470ImmutableArray<RefKind> parameterRefKinds,
1495public override bool HasExplicitReturnType(out RefKind refKind, out TypeWithAnnotations returnType)
1555public override RefKind RefKind(int index)
1558return _parameterRefKinds.IsDefault ? Microsoft.CodeAnalysis.RefKind.None : _parameterRefKinds[index];
1592statements[0] is BoundReturnStatement { RefKind: Microsoft.CodeAnalysis.RefKind.None, ExpressionOpt: BoundExpression expr })
CodeGen\EmitExpression.cs (53)
710RefKind refKind = expression.ArgumentRefKindsOpt.IsDefaultOrEmpty ? RefKind.None : expression.ArgumentRefKindsOpt[i];
715private void EmitArgument(BoundExpression argument, RefKind refKind)
719case RefKind.None:
723case RefKind.In:
729Debug.Assert(refKind is RefKind.Ref or RefKind.Out or RefKindExtensions.StrictIn);
737Debug.Assert(argument.Type.IsDynamic() || argument is BoundFieldAccess { FieldSymbol.RefKind: not RefKind.None }, "passing args byref should not clone them into temps");
779if (expression.RefKind == RefKind.None)
946private void EmitArguments(ImmutableArray<BoundExpression> arguments, ImmutableArray<ParameterSymbol> parameters, ImmutableArray<RefKind> argRefKindsOpt)
951Debug.Assert(parameters.All(p => p.RefKind == RefKind.None) || !argRefKindsOpt.IsDefault, "there are nontrivial parameters, so we must have argRefKinds");
958RefKind argRefKind = GetArgumentRefKind(arguments, parameters, argRefKindsOpt, i);
967internal static RefKind GetArgumentRefKind(ImmutableArray<BoundExpression> arguments, ImmutableArray<ParameterSymbol> parameters, ImmutableArray<RefKind> argRefKindsOpt, int i)
969RefKind argRefKind;
980RefKind.In => argRefKind == RefKindExtensions.StrictIn,
981RefKind.RefReadOnlyParameter => argRefKind is RefKind.In or RefKindExtensions.StrictIn,
988Debug.Assert(parameters[i].RefKind != RefKind.RefReadOnlyParameter,
994RefKind.RefReadOnlyParameter => RefKind.In, // should not happen, asserted above
1003argRefKind = RefKind.None;
1132if (!field.IsVolatile && !field.IsStatic && fieldAccess.ReceiverOpt.Type.IsVerifierValue() && field.RefKind == RefKind.None)
1144if (field.RefKind != RefKind.None)
1288return ((BoundParameter)receiver).ParameterSymbol.RefKind != RefKind.None;
1292return ((BoundLocal)receiver).LocalSymbol.RefKind != RefKind.None;
1301if (field.IsStatic || field.RefKind != RefKind.None)
1392bool isRefLocal = local.LocalSymbol.RefKind != RefKind.None;
1424if (parameter.ParameterSymbol.RefKind != RefKind.None)
1739var methodRefKind = call.Method.RefKind;
2214return ((BoundLocal)receiver).LocalSymbol.RefKind != RefKind.None;
2217return ((BoundParameter)receiver).ParameterSymbol.RefKind != RefKind.None;
2220return ((BoundCall)receiver).Method.RefKind != RefKind.None;
2223return ((BoundFunctionPointerInvocation)receiver).FunctionPointer.Signature.RefKind != RefKind.None;
2226return ((BoundDup)receiver).RefKind != RefKind.None;
2633if (System.Linq.ImmutableArrayExtensions.All(ctor.Parameters, p => p.RefKind == RefKind.None) &&
2757return ((BoundParameter)left).ParameterSymbol.RefKind == RefKind.None;
2762return ((BoundLocal)left).LocalSymbol.RefKind == RefKind.None;
2782if (left.FieldSymbol.RefKind != RefKind.None &&
2800if (left.ParameterSymbol.RefKind != RefKind.None &&
2832if (left.LocalSymbol.RefKind != RefKind.None && !assignmentOperator.IsRef)
2931Debug.Assert(left.Method.RefKind != RefKind.None);
2942Debug.Assert(left.FunctionPointer.Signature.RefKind != RefKind.None);
2994LocalDefinition temp = EmitAddress(assignmentOperator.Right, lhs.GetRefKind() is RefKind.RefReadOnly or RefKindExtensions.StrictIn or RefKind.RefReadOnlyParameter ? AddressKind.ReadOnlyStrict : AddressKind.Writeable);
3077if (local.LocalSymbol.RefKind != RefKind.None && !assignment.IsRef)
3110Debug.Assert(((BoundDup)expression).RefKind != RefKind.None);
3133Debug.Assert(((BoundCall)expression).Method.RefKind != RefKind.None);
3138Debug.Assert(((BoundFunctionPointerInvocation)expression).FunctionPointer.Signature.RefKind != RefKind.None);
3282if (field.RefKind != RefKind.None && !refAssign)
3297if (parameter.ParameterSymbol.RefKind != RefKind.None && !refAssign)
4114if (useKind == UseKind.UsedAsValue && method.RefKind != RefKind.None)
4120Debug.Assert(method.RefKind != RefKind.None);
CodeGen\Optimizer.cs (23)
858if (node.LocalSymbol.RefKind != RefKind.None)
878if (node.LocalSymbol.RefKind != RefKind.None)
986if (localSymbol.RefKind is RefKind.RefReadOnly or RefKindExtensions.StrictIn &&
1031(lhs.Kind is BoundKind.Local or BoundKind.Parameter or BoundKind.FieldAccess && lhs.GetRefKind() != RefKind.None),
1041if (((BoundParameter)lhs).ParameterSymbol.RefKind != RefKind.None)
1049if (((BoundLocal)lhs).LocalSymbol.RefKind != RefKind.None)
1057Debug.Assert(((BoundCall)lhs).Method.RefKind == RefKind.Ref, "only ref returning methods are assignable");
1061Debug.Assert(((BoundFunctionPointerInvocation)lhs).FunctionPointer.Signature.RefKind == RefKind.Ref, "only ref returning function pointers are assignable");
1221if (unwrappedSequence is BoundLocal { LocalSymbol: { RefKind: not RefKind.None } localSymbol })
1255private ImmutableArray<BoundExpression> VisitArguments(ImmutableArray<BoundExpression> arguments, ImmutableArray<ParameterSymbol> parameters, ImmutableArray<RefKind> argRefKindsOpt)
1265RefKind argRefKind = CodeGenerator.GetArgumentRefKind(arguments, parameters, argRefKindsOpt, i);
1272private void VisitArgument(ImmutableArray<BoundExpression> arguments, ref ArrayBuilder<BoundExpression> rewrittenArguments, int i, RefKind argRefKind)
1274ExprContext context = (argRefKind == RefKind.None) ? ExprContext.Value : ExprContext.Address;
1296ImmutableArray<RefKind> argRefKindsOpt = node.ArgumentRefKindsOpt;
1300RefKind refKind = argRefKindsOpt.IsDefaultOrEmpty ? RefKind.None : argRefKindsOpt[i];
1428if (localSym.RefKind == RefKind.None)
1874Debug.Assert(local.RefKind == RefKind.None, "cannot take a ref of a ref");
1935return top.Item2 == (local.RefKind == RefKind.None ? ExprContext.Value : ExprContext.Address) &&
2162var isIndirectLocalStore = left.LocalSymbol.RefKind != RefKind.None && !node.IsRef;
2191left.LocalSymbol.RefKind == RefKind.Ref &&
2428public override RefKind RefKind
2430get { return RefKind.None; }
Compiler\MethodBodySynthesizer.cs (5)
50argumentRefKindsOpt: ImmutableArray<RefKind>.Empty,
193statement = new BoundReturnStatement(accessor.SyntaxNode, RefKind.None, fieldAccess, @checked: false);
311BoundStatement returnStatement = BoundReturnStatement.Synthesized(syntax, RefKind.None, processHandlerCall);
321BoundStatement returnStatement = new BoundReturnStatement(syntax, RefKind.None, expressionOpt: null, @checked: false);
358refKind: RefKind.None,
FlowAnalysis\AbstractFlowPass.cs (36)
1132VisitArguments(node.Arguments, default(ImmutableArray<RefKind>), null);
1293VisitRvalue(node.InitializerOpt, isKnownToBeAnLvalue: node.LocalSymbol.RefKind != RefKind.None);
1296if (node.LocalSymbol.RefKind != RefKind.None)
1436WriteArgument(receiverOpt, RefKind.Ref, method: null);
1442var thisRefKind = thisParameter.RefKind;
1516protected virtual void VisitArguments(ImmutableArray<BoundExpression> arguments, ImmutableArray<RefKind> refKindsOpt, MethodSymbol method)
1523private void VisitArgumentsBeforeCall(ImmutableArray<BoundExpression> arguments, ImmutableArray<RefKind> refKindsOpt)
1528RefKind refKind = GetRefKind(refKindsOpt, i);
1529if (refKind != RefKind.Out)
1531VisitRvalue(arguments[i], isKnownToBeAnLvalue: refKind != RefKind.None);
1543private void VisitArgumentsAfterCall(ImmutableArray<BoundExpression> arguments, ImmutableArray<RefKind> refKindsOpt, MethodSymbol method)
1547RefKind refKind = GetRefKind(refKindsOpt, i);
1550case RefKind.None:
1551case RefKind.In:
1552case RefKind.RefReadOnlyParameter:
1555case RefKind.Ref:
1556case RefKind.Out:
1566protected static RefKind GetRefKind(ImmutableArray<RefKind> refKindsOpt, int index)
1568return refKindsOpt.IsDefault || refKindsOpt.Length <= index ? RefKind.None : refKindsOpt[index];
1571protected virtual void WriteArgument(BoundExpression arg, RefKind refKind, MethodSymbol method)
2026VisitRvalue(node.ExpressionOpt, isKnownToBeAnLvalue: node.RefKind != RefKind.None);
2029if (node.RefKind != RefKind.None)
2139if (property.RefKind == RefKind.None)
2157var refKind = node.Left.Kind == BoundKind.BadExpression
2158? RefKind.Ref
2194if (property.RefKind == RefKind.None)
2213if (property.RefKind == RefKind.None)
2809if (property.RefKind == RefKind.None)
3311WriteArgument(operand, RefKind.Ref, method: null);
3497this.WriteArgument(operand, RefKind.Out, null); //Out because we know it will definitely be assigned.
3538VisitArguments(node.Arguments, default(ImmutableArray<RefKind>), node.Constructor);
3622VisitArguments(node.Arguments, default(ImmutableArray<RefKind>), node.AddMethod);
3628VisitArguments(node.Arguments, default(ImmutableArray<RefKind>), node.AddMethod);
3636VisitArguments(node.Arguments, default(ImmutableArray<RefKind>), method: null);
3718property.RefKind == RefKind.None)
FlowAnalysis\DefiniteAssignment.cs (20)
349NoteWrite(parameter, value: null, read: true, isRef: parameter.RefKind != RefKind.None);
859write: field.RefKind == RefKind.None || isRef);
971write: field.RefKind == RefKind.None || isRef);
1234((ParameterSymbol)symbol).RefKind == RefKind.Out)
1334if (fieldSymbol.RefKind != RefKind.None)
1518if (!isRef && node is BoundFieldAccess { FieldSymbol.RefKind: not RefKind.None } fieldAccess)
1571if (local.LocalSymbol.RefKind != RefKind.None && !isRef)
1622if (isRef && param.RefKind == RefKind.Out)
1640write: field.RefKind == RefKind.None || isRef);
1814if (parameter.RefKind != RefKind.Out)
1826if (thisParameter.RefKind != RefKind.Out)
1849if (current is not MethodSymbol && parameter.RefKind == RefKind.Out)
1879if (parameter.RefKind == RefKind.Out && !(this.CurrentSymbol is MethodSymbol currentMethod && currentMethod.IsAsync)) // out parameters not allowed in async
1887NoteWrite(parameter, value: null, read: true, isRef: parameter.RefKind != RefKind.None);
1945if (!parameter.IsThis && parameter.RefKind != RefKind.Out && parameter.ContainingSymbol is SynthesizedPrimaryConstructor primaryCtor)
1957if (parameter.RefKind != RefKind.None)
2567protected override void WriteArgument(BoundExpression arg, RefKind refKind, MethodSymbol method)
2569if (refKind == RefKind.Ref)
2583if (refKind != RefKind.None && ((object)method == null || method.IsExtern) && arg.Type is TypeSymbol type)
2771NoteWrite(iterationVariable, null, read: true, isRef: iterationVariable.RefKind != RefKind.None);
FlowAnalysis\NullableWalker.cs (53)
1318var refKind = parameter.RefKind;
1319if (refKind != RefKind.Out && refKind != RefKind.Ref)
2433RefKind refKind,
2443if (refKind == RefKind.Ref)
2446return AreParameterAnnotationsCompatible(RefKind.None, overriddenType, overriddenAnnotations, overridingType, overridingAnnotations, forRef: true) &&
2447AreParameterAnnotationsCompatible(RefKind.Out, overriddenType, overriddenAnnotations, overridingType, overridingAnnotations);
2450if (refKind is RefKind.None or RefKind.In or RefKind.RefReadOnlyParameter)
2480if (refKind == RefKind.Out)
2885if (parameter.RefKind != RefKind.Out)
2958if (node.RefKind == RefKind.None &&
2967if (node.RefKind == RefKind.None)
6286var refKind = GetRefKind(node.ArgumentRefKindsOpt, 0);
6344ImmutableArray<RefKind> refKindsOpt = node.ArgumentRefKindsOpt;
6774protected override void VisitArguments(ImmutableArray<BoundExpression> arguments, ImmutableArray<RefKind> refKindsOpt, MethodSymbol method)
6783ImmutableArray<RefKind> refKindsOpt,
6796ImmutableArray<RefKind> refKindsOpt,
6811ImmutableArray<RefKind> refKindsOpt,
6832ImmutableArray<RefKind> refKindsOpt,
6873ImmutableArray<RefKind> refKindsOpt,
7043ImmutableArray<RefKind> refKindsOpt,
7061static void expandParamsCollection(ref ImmutableArray<BoundExpression> arguments, ref ImmutableArray<RefKind> refKindsOpt, ImmutableArray<ParameterSymbol> parametersOpt, ref ImmutableArray<int> argsToParamsOpt, ref BitVector defaultArguments)
7121var refKindsBuilder = ArrayBuilder<RefKind>.GetInstance(refKindsOpt.Length + elements.Length - 1);
7123refKindsBuilder.AddMany(RefKind.None, elements.Length);
7290ImmutableArray<RefKind> refKindsOpt,
7351private VisitResult VisitArgumentEvaluate(BoundExpression argument, RefKind refKind, FlowAnalysisAnnotations annotations)
7363private VisitResult VisitArgumentEvaluateEpilogue(BoundExpression argument, RefKind refKind, FlowAnalysisAnnotations annotations)
7369case RefKind.Ref:
7372case RefKind.None:
7373case RefKind.In:
7395case RefKind.Out:
7418RefKind refKind,
7433case RefKind.None:
7434case RefKind.In:
7472case RefKind.Ref:
7492case RefKind.Out:
7555RefKind refKind,
7568case RefKind.None:
7569case RefKind.In:
7575case RefKind.Ref:
7602case RefKind.Out:
7808ImmutableArray<RefKind> refKindsOpt)
7819RefKind refKind = GetRefKind(refKindsOpt, i);
7822if (refKind == RefKind.None)
7890ImmutableArray<RefKind> argumentRefKindsOpt,
7899var refKinds = ArrayBuilder<RefKind>.GetInstance();
7920parameterRefKinds: out ImmutableArray<RefKind> parameterRefKinds);
10159case BoundLocal { LocalSymbol.RefKind: RefKind.None }:
10160case BoundParameter { ParameterSymbol: { RefKind: RefKind.None } parameter } when
12067TypeWithAnnotations elementType = InMethodBinder.GetIteratorElementTypeFromReturnType(compilation, RefKind.None,
12107VisitArguments(node, node.ConstructorArguments, ImmutableArray<RefKind>.Empty, node.Constructor, argsToParamsOpt: node.ConstructorArgumentsToParamsOpt, defaultArguments: node.ConstructorDefaultArguments,
Generated\BoundNodes.xml.Generated.cs (37)
921public BoundDup(SyntaxNode syntax, RefKind refKind, TypeSymbol? type, bool hasErrors)
927public BoundDup(SyntaxNode syntax, RefKind refKind, TypeSymbol? type)
933public RefKind RefKind { get; }
938public BoundDup Update(RefKind refKind, TypeSymbol? type)
1446public BoundFunctionPointerInvocation(SyntaxNode syntax, BoundExpression invokedExpression, ImmutableArray<BoundExpression> arguments, ImmutableArray<RefKind> argumentRefKindsOpt, LookupResultKind resultKind, TypeSymbol type, bool hasErrors = false)
1463public ImmutableArray<RefKind> ArgumentRefKindsOpt { get; }
1469public BoundFunctionPointerInvocation Update(BoundExpression invokedExpression, ImmutableArray<BoundExpression> arguments, ImmutableArray<RefKind> argumentRefKindsOpt, LookupResultKind resultKind, TypeSymbol type)
3062public BoundArgListOperator(SyntaxNode syntax, ImmutableArray<BoundExpression> arguments, ImmutableArray<RefKind> argumentRefKindsOpt, TypeSymbol? type, bool hasErrors = false)
3074public ImmutableArray<RefKind> ArgumentRefKindsOpt { get; }
3079public BoundArgListOperator Update(ImmutableArray<BoundExpression> arguments, ImmutableArray<RefKind> argumentRefKindsOpt, TypeSymbol? type)
3568public BoundReturnStatement(SyntaxNode syntax, RefKind refKind, BoundExpression? expressionOpt, bool @checked, bool hasErrors = false)
3576public RefKind RefKind { get; }
3583public BoundReturnStatement Update(RefKind refKind, BoundExpression? expressionOpt, bool @checked)
5892public BoundDynamicInvocation(SyntaxNode syntax, ImmutableArray<string?> argumentNamesOpt, ImmutableArray<RefKind> argumentRefKindsOpt, ImmutableArray<MethodSymbol> applicableMethods, BoundExpression expression, ImmutableArray<BoundExpression> arguments, TypeSymbol type, bool hasErrors = false)
5908public ImmutableArray<RefKind> ArgumentRefKindsOpt { get; }
5914public BoundDynamicInvocation Update(ImmutableArray<string?> argumentNamesOpt, ImmutableArray<RefKind> argumentRefKindsOpt, ImmutableArray<MethodSymbol> applicableMethods, BoundExpression expression, ImmutableArray<BoundExpression> arguments, TypeSymbol type)
6142public BoundCall(SyntaxNode syntax, BoundExpression? receiverOpt, ThreeState initialBindingReceiverIsSubjectToCloning, MethodSymbol method, ImmutableArray<BoundExpression> arguments, ImmutableArray<string?> argumentNamesOpt, ImmutableArray<RefKind> argumentRefKindsOpt, bool isDelegateCall, bool expanded, bool invokedAsExtensionMethod, ImmutableArray<int> argsToParamsOpt, BitVector defaultArguments, LookupResultKind resultKind, ImmutableArray<MethodSymbol> originalMethodsOpt, TypeSymbol type, bool hasErrors = false)
6171public ImmutableArray<RefKind> ArgumentRefKindsOpt { get; }
6183public BoundCall Update(BoundExpression? receiverOpt, ThreeState initialBindingReceiverIsSubjectToCloning, MethodSymbol method, ImmutableArray<BoundExpression> arguments, ImmutableArray<string?> argumentNamesOpt, ImmutableArray<RefKind> argumentRefKindsOpt, bool isDelegateCall, bool expanded, bool invokedAsExtensionMethod, ImmutableArray<int> argsToParamsOpt, BitVector defaultArguments, LookupResultKind resultKind, ImmutableArray<MethodSymbol> originalMethodsOpt, TypeSymbol type)
6281public BoundUnconvertedObjectCreationExpression(SyntaxNode syntax, ImmutableArray<BoundExpression> arguments, ImmutableArray<(string Name, Location Location)?> argumentNamesOpt, ImmutableArray<RefKind> argumentRefKindsOpt, InitializerExpressionSyntax? initializerOpt, Binder binder, bool hasErrors = false)
6298public ImmutableArray<RefKind> ArgumentRefKindsOpt { get; }
6305public BoundUnconvertedObjectCreationExpression Update(ImmutableArray<BoundExpression> arguments, ImmutableArray<(string Name, Location Location)?> argumentNamesOpt, ImmutableArray<RefKind> argumentRefKindsOpt, InitializerExpressionSyntax? initializerOpt, Binder binder)
6340public BoundObjectCreationExpression(SyntaxNode syntax, MethodSymbol constructor, ImmutableArray<MethodSymbol> constructorsGroup, ImmutableArray<BoundExpression> arguments, ImmutableArray<string?> argumentNamesOpt, ImmutableArray<RefKind> argumentRefKindsOpt, bool expanded, ImmutableArray<int> argsToParamsOpt, BitVector defaultArguments, ConstantValue? constantValueOpt, BoundObjectInitializerExpressionBase? initializerExpressionOpt, bool wasTargetTyped, TypeSymbol type, bool hasErrors = false)
6366public override ImmutableArray<RefKind> ArgumentRefKindsOpt { get; }
6377public BoundObjectCreationExpression Update(MethodSymbol constructor, ImmutableArray<MethodSymbol> constructorsGroup, ImmutableArray<BoundExpression> arguments, ImmutableArray<string?> argumentNamesOpt, ImmutableArray<RefKind> argumentRefKindsOpt, bool expanded, ImmutableArray<int> argsToParamsOpt, BitVector defaultArguments, ConstantValue? constantValueOpt, BoundObjectInitializerExpressionBase? initializerExpressionOpt, bool wasTargetTyped, TypeSymbol type)
6620public BoundDynamicObjectCreationExpression(SyntaxNode syntax, string name, ImmutableArray<BoundExpression> arguments, ImmutableArray<string?> argumentNamesOpt, ImmutableArray<RefKind> argumentRefKindsOpt, BoundObjectInitializerExpressionBase? initializerExpressionOpt, ImmutableArray<MethodSymbol> applicableMethods, bool wasTargetTyped, TypeSymbol type, bool hasErrors = false)
6641public override ImmutableArray<RefKind> ArgumentRefKindsOpt { get; }
6649public BoundDynamicObjectCreationExpression Update(string name, ImmutableArray<BoundExpression> arguments, ImmutableArray<string?> argumentNamesOpt, ImmutableArray<RefKind> argumentRefKindsOpt, BoundObjectInitializerExpressionBase? initializerExpressionOpt, ImmutableArray<MethodSymbol> applicableMethods, bool wasTargetTyped, TypeSymbol type)
6742public BoundObjectInitializerMember(SyntaxNode syntax, Symbol? memberSymbol, ImmutableArray<BoundExpression> arguments, ImmutableArray<string?> argumentNamesOpt, ImmutableArray<RefKind> argumentRefKindsOpt, bool expanded, ImmutableArray<int> argsToParamsOpt, BitVector defaultArguments, LookupResultKind resultKind, AccessorKind accessorKind, TypeSymbol receiverType, TypeSymbol type, bool hasErrors = false)
6766public ImmutableArray<RefKind> ArgumentRefKindsOpt { get; }
6777public BoundObjectInitializerMember Update(Symbol? memberSymbol, ImmutableArray<BoundExpression> arguments, ImmutableArray<string?> argumentNamesOpt, ImmutableArray<RefKind> argumentRefKindsOpt, bool expanded, ImmutableArray<int> argsToParamsOpt, BitVector defaultArguments, LookupResultKind resultKind, AccessorKind accessorKind, TypeSymbol receiverType, TypeSymbol type)
7410public BoundIndexerAccess(SyntaxNode syntax, BoundExpression? receiverOpt, ThreeState initialBindingReceiverIsSubjectToCloning, PropertySymbol indexer, ImmutableArray<BoundExpression> arguments, ImmutableArray<string?> argumentNamesOpt, ImmutableArray<RefKind> argumentRefKindsOpt, bool expanded, AccessorKind accessorKind, ImmutableArray<int> argsToParamsOpt, BitVector defaultArguments, ImmutableArray<PropertySymbol> originalIndexersOpt, TypeSymbol type, bool hasErrors = false)
7437public ImmutableArray<RefKind> ArgumentRefKindsOpt { get; }
7447public BoundIndexerAccess Update(BoundExpression? receiverOpt, ThreeState initialBindingReceiverIsSubjectToCloning, PropertySymbol indexer, ImmutableArray<BoundExpression> arguments, ImmutableArray<string?> argumentNamesOpt, ImmutableArray<RefKind> argumentRefKindsOpt, bool expanded, AccessorKind accessorKind, ImmutableArray<int> argsToParamsOpt, BitVector defaultArguments, ImmutableArray<PropertySymbol> originalIndexersOpt, TypeSymbol type)
7551public BoundDynamicIndexerAccess(SyntaxNode syntax, BoundExpression receiver, ImmutableArray<BoundExpression> arguments, ImmutableArray<string?> argumentNamesOpt, ImmutableArray<RefKind> argumentRefKindsOpt, ImmutableArray<PropertySymbol> applicableIndexers, TypeSymbol type, bool hasErrors = false)
7571public ImmutableArray<RefKind> ArgumentRefKindsOpt { get; }
7577public BoundDynamicIndexerAccess Update(BoundExpression receiver, ImmutableArray<BoundExpression> arguments, ImmutableArray<string?> argumentNamesOpt, ImmutableArray<RefKind> argumentRefKindsOpt, ImmutableArray<PropertySymbol> applicableIndexers, TypeSymbol type)
Lowering\LocalRewriter\LocalRewriter_Call.cs (81)
139ref ImmutableArray<RefKind> argumentRefKindsOpt,
284var thisRefKind = methodThisParameter.RefKind;
287if (thisRefKind != RefKind.None
290thisRefKind == RefKind.Ref ? CodeGenerator.AddressKind.Writeable : CodeGenerator.AddressKind.ReadOnlyStrict,
304if (argumentRefKindsOpt.IsDefault && thisRefKind != RefKind.None)
385ImmutableArray<RefKind> argRefKindsOpt = node.ArgumentRefKindsOpt;
443ImmutableArray<RefKind> argumentRefKinds,
530argumentRefKinds: default(ImmutableArray<RefKind>),
535private static bool IsSafeForReordering(BoundExpression expression, RefKind kind)
561return kind != RefKind.None;
659ImmutableArray<RefKind> argumentRefKindsOpt,
679RefKind refKind;
691refKind = rewrittenReceiver.Type.IsValueType || rewrittenReceiver.Type.Kind == SymbolKind.TypeParameter ? RefKind.Ref : RefKind.None;
697refKind = RefKind.None;
703if (refKind == RefKind.None &&
710refKind = RefKind.Ref;
879RefKind argRefKind = argumentRefKindsOpt.RefKinds(argIndex);
880RefKind paramRefKind = parameters[paramIndex].RefKind;
882local = _factory.StoreToTemp(visitedArgument, out var store, refKind: paramRefKind is RefKind.In or RefKind.RefReadOnlyParameter ? RefKind.In : argRefKind);
951var intermediateRef = _factory.Local(_factory.SynthesizedLocal(receiverType, refKind: RefKind.Ref));
1002ref ImmutableArray<RefKind> argumentRefKindsOpt,
1085ArrayBuilder<RefKind> refKinds = ArrayBuilder<RefKind>.GetInstance(parameters.Length, RefKind.None);
1155private static ImmutableArray<RefKind> GetEffectiveArgumentRefKinds(ImmutableArray<RefKind> argumentRefKindsOpt, ImmutableArray<ParameterSymbol> parameters)
1157ArrayBuilder<RefKind>? refKindsBuilder = null;
1160var paramRefKind = parameters[i].RefKind;
1161if (paramRefKind is RefKind.In or RefKind.RefReadOnlyParameter)
1163var argRefKind = argumentRefKindsOpt.IsDefault ? RefKind.None : argumentRefKindsOpt[i];
1165refKindsBuilder[i] = argRefKind == RefKind.None ? RefKind.In : RefKindExtensions.StrictIn;
1167else if (paramRefKind == RefKind.Ref)
1169var argRefKind = argumentRefKindsOpt.IsDefault ? RefKind.None : argumentRefKindsOpt[i];
1170if (argRefKind == RefKind.None)
1176refKindsBuilder[i] = RefKind.Ref;
1190static void fillRefKindsBuilder(ImmutableArray<RefKind> argumentRefKindsOpt, ImmutableArray<ParameterSymbol> parameters, [NotNull] ref ArrayBuilder<RefKind>? refKindsBuilder)
1197refKindsBuilder = ArrayBuilder<RefKind>.GetInstance(parameters.Length);
1202refKindsBuilder = ArrayBuilder<RefKind>.GetInstance(parameters.Length, fillWithValue: RefKind.None);
1243private static ImmutableArray<RefKind> GetRefKindsOrNull(ArrayBuilder<RefKind> refKinds)
1247if (refKind != RefKind.None)
1252return default(ImmutableArray<RefKind>);
1305ImmutableArray<RefKind> argumentRefKinds,
1309/* out */ ArrayBuilder<RefKind> refKinds,
1321RefKind argRefKind = argumentRefKinds.RefKinds(a);
1322RefKind paramRefKind = parameters[p].RefKind;
1330Debug.Assert(argRefKind == RefKind.None);
1346arg.rewriter.StoreArgumentToTempIfNecessary(arg.forceLambdaSpilling, arg.storesToTemps, element, RefKind.None, RefKind.None),
1363if (paramRefKind is RefKind.In or RefKind.RefReadOnlyParameter)
1365Debug.Assert(argRefKind is RefKind.None or RefKind.In or RefKind.Ref);
1366argRefKind = argRefKind == RefKind.None ? RefKind.In : RefKindExtensions.StrictIn;
1375private BoundExpression StoreArgumentToTempIfNecessary(bool forceLambdaSpilling, ArrayBuilder<BoundAssignmentOperator> storesToTemps, BoundExpression argument, RefKind argRefKind, RefKind paramRefKind)
1387refKind: paramRefKind is RefKind.In or RefKind.RefReadOnlyParameter
1388? (argRefKind == RefKind.None ? RefKind.In : RefKindExtensions.StrictIn)
1442default(ImmutableArray<RefKind>),
1602ArrayBuilder<RefKind> argsRefKindsBuilder,
1615RefKind paramRefKind = parameters[argIndex].RefKind;
1616RefKind argRefKind = argsRefKindsBuilder[argIndex];
1620if (argRefKind != RefKind.None || paramRefKind != RefKind.Ref)
1628var localRefKind = ((BoundLocal)argument).LocalSymbol.RefKind;
1629if (localRefKind == RefKind.Ref)
1635Debug.Assert(localRefKind == RefKind.None);
1647argsRefKindsBuilder[argIndex] = RefKind.Ref;
Lowering\LocalRewriter\LocalRewriter_ForEachStatement.cs (5)
619RefKind collectionTempRefKind = RefKind.None;
707private delegate BoundStatement? GetForEachStatementAsForPreamble(LocalRewriter rewriter, SyntaxNode syntax, ForEachEnumeratorInfo enumeratorInfo, ref BoundExpression rewrittenExpression, out LocalSymbol? preambleLocal, out RefKind collectionTempRefKind);
746return static (LocalRewriter rewriter, SyntaxNode syntax, ForEachEnumeratorInfo enumeratorInfo, ref BoundExpression rewrittenExpression, out LocalSymbol? preambleLocal, out RefKind collectionTempRefKind) =>
760collectionTempRefKind = enumeratorInfo.InlineArraySpanType == WellKnownType.System_Span_T ? RefKind.Ref : RefKindExtensions.StrictIn;
Lowering\LocalRewriter\LocalRewriter_ObjectOrCollectionInitializerExpression.cs (13)
132default(ImmutableArray<RefKind>),
147.All(p => p.RefKind is RefKind.None or RefKind.In or RefKind.RefReadOnlyParameter));
163var argumentRefKindsOpt = default(ImmutableArray<RefKind>);
164if (addMethod.Parameters[0].RefKind == RefKind.Ref)
169var builder = ArrayBuilder<RefKind>.GetInstance(addMethod.Parameters.Length, RefKind.None);
170builder[0] = RefKind.Ref;
307memberInit.MemberSymbol?.GetParameterRefKinds() ?? default(ImmutableArray<RefKind>),
589ImmutableArray<RefKind> paramRefKindsOpt,
609elementArg.rewriter.EvaluateSideEffects(element, RefKind.None, elementArg.sideeffects, ref elementArg.temps),
637private BoundExpression EvaluateSideEffects(BoundExpression arg, RefKind refKind, ArrayBuilder<BoundExpression> sideeffects, ref ArrayBuilder<LocalSymbol>? temps)
Lowering\LocalRewriter\LoweredDynamicOperationFactory.cs (54)
111return MakeDynamicOperation(binderConstruction, null, RefKind.None, loweredArguments, default(ImmutableArray<RefKind>), null, resultType);
147return MakeDynamicOperation(binderConstruction, null, RefKind.None, loweredArguments, default(ImmutableArray<RefKind>), null, resultType);
190return MakeDynamicOperation(binderConstruction, null, RefKind.None, loweredArguments, default(ImmutableArray<RefKind>), null, resultType);
199ImmutableArray<RefKind> refKinds,
223RefKind receiverRefKind;
228receiverRefKind = RefKind.None;
292return MakeDynamicOperation(binderConstruction, loweredReceiver, RefKind.None, loweredArguments, default(ImmutableArray<RefKind>), loweredHandler, resultType);
299ImmutableArray<RefKind> refKinds,
329return MakeDynamicOperation(binderConstruction, loweredReceiver, RefKind.None, loweredArguments, refKinds, null, resultType);
337ImmutableArray<RefKind> refKinds)
356return MakeDynamicOperation(binderConstruction, loweredReceiver, RefKind.None, loweredArguments, refKinds, null, type);
391return MakeDynamicOperation(binderConstruction, loweredReceiver, RefKind.None, loweredArguments, default(ImmutableArray<RefKind>), null, resultType);
432return MakeDynamicOperation(binderConstruction, loweredReceiver, RefKind.None, loweredArguments, default(ImmutableArray<RefKind>), loweredRight, AssemblySymbol.DynamicType);
439ImmutableArray<RefKind> refKinds)
458return MakeDynamicOperation(binderConstruction, loweredReceiver, RefKind.None, loweredArguments, refKinds, null, resultType);
465ImmutableArray<RefKind> refKinds,
481var loweredReceiverRefKind = GetReceiverRefKind(loweredReceiver);
516return MakeDynamicOperation(binderConstruction, loweredReceiver, RefKind.None, ImmutableArray<BoundExpression>.Empty, default(ImmutableArray<RefKind>), null, resultType);
542internal RefKind GetReceiverRefKind(BoundExpression loweredReceiver)
547return RefKind.None;
555return hasHome ? RefKind.Ref : RefKind.None;
562ImmutableArray<RefKind> refKinds = default(ImmutableArray<RefKind>),
564RefKind receiverRefKind = RefKind.None,
571Debug.Assert(!receiverIsStaticType || receiverRefKind == RefKind.None);
586refKinds.IsDefault ? RefKind.None : refKinds[i],
592infos[j++] = GetArgumentInfo(argumentInfoFactory, loweredRight, NoName, RefKind.None, isStaticType: false);
601RefKind receiverRefKind,
603ImmutableArray<RefKind> refKinds,
720RefKind receiverRefKind,
722ImmutableArray<RefKind> refKinds,
736bool hasByRefs = receiverRefKind != RefKind.None || !refKinds.IsDefaultOrEmpty;
776byRefs[j++] = RefKind.None;
791static RefKind getRefKind(RefKind refKind)
793Debug.Assert(refKind != RefKind.RefReadOnlyParameter);
794return refKind == RefKind.None ? RefKind.None : RefKind.Ref;
802RefKind refKind,
817Debug.Assert(refKind == RefKind.None || refKind == RefKind.Ref || refKind == RefKind.Out, "unexpected refKind in dynamic");
820if (refKind == RefKind.Out)
824else if (refKind == RefKind.Ref)
Lowering\SpillSequenceSpiller.cs (42)
305RefKind refKind = RefKind.None,
317Debug.Assert(refKind == RefKind.None);
324Debug.Assert(refKind == RefKind.None);
337if (refKind != RefKind.None || expression.Type?.IsRefLikeOrAllowsRefLikeType() == true)
370var left = Spill(builder, assignment.Left, RefKind.Ref);
371var right = Spill(builder, assignment.Right, RefKind.Ref);
380if (refKind != RefKind.None || expression.Type.IsReferenceType)
388if (refKind != RefKind.None)
397if (local.LocalSymbol.SynthesizedKind == SynthesizedLocalKind.Spill || refKind != RefKind.None)
410if (refKind != RefKind.None || fieldSymbol.IsReadOnly)
417if (refKind == RefKind.None) goto default;
419var receiver = Spill(builder, field.ReceiverOpt, fieldSymbol.ContainingType.IsValueType ? refKind : RefKind.None);
437if (refKind != RefKind.None)
482if (refKind == RefKind.None &&
489[Spill(builder, objectCreationExpression.Arguments[0], argRefKinds.IsDefault ? RefKind.None : argRefKinds[0])],
538Left: BoundLocal { LocalSymbol: { SynthesizedKind: SynthesizedLocalKind.LoweringTemp, RefKind: RefKind.Ref } receiverRefLocal },
541ValueTypeReceiver: BoundLocal { LocalSymbol: { SynthesizedKind: SynthesizedLocalKind.LoweringTemp, RefKind: RefKind.Ref } } valueTypeReceiver,
550Left: BoundLocal { LocalSymbol: { SynthesizedKind: SynthesizedLocalKind.LoweringTemp, RefKind: RefKind.None } referenceTypeClone },
551Right: BoundLocal { LocalSymbol: { SynthesizedKind: SynthesizedLocalKind.LoweringTemp, RefKind: RefKind.Ref } originalReceiverReference }
554Value: BoundLocal { LocalSymbol: { SynthesizedKind: SynthesizedLocalKind.LoweringTemp, RefKind: RefKind.None } } referenceTypeReceiver
586ImmutableArray<RefKind> refKinds = default(ImmutableArray<RefKind>),
634var refKind = refKinds.IsDefault ? RefKind.None : refKinds[i];
892expression = Spill(leftBuilder, expression, RefKind.None);
907left = Spill(leftBuilder, VisitExpression(ref leftBuilder, left), RefKind.Ref);
939expression = Spill(leftBuilder, expression, RefKind.None);
954receiver = Spill(leftBuilder, VisitExpression(ref leftBuilder, field.ReceiverOpt), RefKind.Ref);
1032RefKind refKind = ReceiverSpillRefKind(receiver);
1034Debug.Assert(refKind == RefKind.None || !receiver.Type.IsReferenceType);
1038if (refKind != RefKind.None &&
1071private static RefKind ReceiverSpillRefKind(BoundExpression receiver)
1073var result = RefKind.None;
1076result = receiver.Type.IsReadOnly ? RefKind.In : RefKind.Ref;
1265var receiverRefKind = ReceiverSpillRefKind(node.Receiver);
1286if (receiver.Type.IsReferenceType || receiver.Type.IsValueType || receiverRefKind == RefKind.None)
1289receiver = Spill(receiverBuilder, receiver, RefKind.None);
1304receiver = Spill(receiverBuilder, receiver, RefKind.Ref);
1306var clone = _F.SynthesizedLocal(receiver.Type, _F.Syntax, refKind: RefKind.None, kind: SynthesizedLocalKind.Spill);
Lowering\StateMachineRewriter\MethodToStateMachineRewriter.cs (20)
313if (local.RefKind != RefKind.None)
558var sacrificialTemp = F.SynthesizedLocal(type, refKind: RefKind.Ref);
578RefKind refKind,
588BoundExpression expression = HoistExpression(array.Expression, awaitSyntaxOpt, syntaxOffset, RefKind.None, sideEffects, hoistedFields, ref needsSacrificialEvaluation);
592indices.Add(HoistExpression(index, awaitSyntaxOpt, syntaxOffset, RefKind.None, sideEffects, hoistedFields, ref needsSacrificialEvaluation));
605if (refKind != RefKind.None || field.FieldSymbol.IsReadOnly) return expr;
609if (refKind == RefKind.None)
617isFieldOfStruct ? refKind : RefKind.None, sideEffects, hoistedFields, ref needsSacrificialEvaluation);
639if (refKind != RefKind.None && refKind != RefKind.In)
641Debug.Assert(refKind is RefKindExtensions.StrictIn or RefKind.Ref or RefKind.Out);
642Debug.Assert(call.Method.RefKind != RefKind.None);
646refKind = RefKind.None;
657if (refKind != RefKind.None && refKind != RefKind.RefReadOnly)
659Debug.Assert(refKind is RefKindExtensions.StrictIn or RefKind.Ref or RefKind.In);
664refKind = RefKind.None;
673if (refKind != RefKind.None)
Lowering\SyntheticBoundNodeFactory.cs (25)
569Debug.Assert(CurrentFunction.RefKind == RefKind.None);
594RefKind refKind = RefKind.None,
634return SynthesizedParameterSymbol.Create(container, TypeWithAnnotations.Create(type), ordinal, RefKind.None, name);
757public BoundObjectCreationExpression New(MethodSymbol constructor, ImmutableArray<BoundExpression> arguments, ImmutableArray<RefKind> argumentRefKinds)
866static ImmutableArray<RefKind> getArgumentRefKinds(MethodSymbol method, bool useStrictArgumentRefKinds)
870if (!result.IsDefaultOrEmpty && (result.Contains(RefKind.RefReadOnlyParameter) ||
871(useStrictArgumentRefKinds && result.Contains(RefKind.In))))
873var builder = ArrayBuilder<RefKind>.GetInstance(result.Length);
875foreach (var refKind in result)
879RefKind.In or RefKind.RefReadOnlyParameter when useStrictArgumentRefKinds => RefKindExtensions.StrictIn,
880RefKind.RefReadOnlyParameter => RefKind.In,
892public BoundCall Call(BoundExpression? receiver, MethodSymbol method, ImmutableArray<RefKind> refKinds, ImmutableArray<BoundExpression> args)
1641RefKind refKind = RefKind.None,
1658case RefKind.Out:
1659refKind = RefKind.Ref;
1662case RefKind.In:
1671Debug.Assert(argument.GetRefKind() != RefKind.In);
1672refKind = RefKind.None;
1676case RefKind.None:
1677case RefKind.Ref:
1708isRef: refKind != RefKind.None);
Symbols\Compilation_WellKnownMembers.cs (13)
775internal SynthesizedAttributeData? SynthesizeDynamicAttribute(TypeSymbol type, int customModifiersCount, RefKind refKindOpt = RefKind.None)
780if (type.IsDynamic() && refKindOpt == RefKind.None && customModifiersCount == 0)
889internal static ImmutableArray<TypedConstant> Encode(TypeSymbol type, RefKind refKind, int customModifiersCount, TypeSymbol booleanType)
901internal static ImmutableArray<bool> Encode(TypeSymbol type, RefKind refKind, int customModifiersCount)
908internal static ImmutableArray<bool> EncodeWithoutCustomModifierFlags(TypeSymbol type, RefKind refKind)
915internal static void Encode(TypeSymbol type, int customModifiersCount, RefKind refKind, ArrayBuilder<bool> transformFlagsBuilder, bool addCustomModifierFlags)
919if (refKind != RefKind.None)
1010void handle(RefKind refKind, ImmutableArray<CustomModifier> customModifiers, TypeWithAnnotations twa)
1017if (refKind != RefKind.None)
1172return parameter.RefKind != RefKind.None;
1177return method.RefKind != RefKind.None;
1182return property.RefKind != RefKind.None;
Symbols\FunctionPointers\FunctionPointerMethodSymbol.cs (48)
28RefKind refKind = RefKind.None;
44case SyntaxKind.RefKeyword when refKind == RefKind.None:
48refKind = RefKind.RefReadOnly;
53refKind = RefKind.Ref;
59Debug.Assert(refKind != RefKind.None);
73if (returnType.IsVoidType() && refKind != RefKind.None)
88if (refKind != RefKind.None)
247RefKind returnRefKind,
250ImmutableArray<RefKind> parameterRefKinds,
271RefKind returnRefKind,
273ImmutableArray<RefKind> parameterRefKinds,
285if (returnRefKind == RefKind.None)
310private static CustomModifier? GetCustomModifierForRefKind(RefKind refKind, CSharpCompilation compilation)
312Debug.Assert(refKind is RefKind.None or RefKind.In or RefKind.Ref or RefKind.Out);
316RefKind.In => compilation.GetWellKnownType(WellKnownType.System_Runtime_InteropServices_InAttribute),
317RefKind.Out => compilation.GetWellKnownType(WellKnownType.System_Runtime_InteropServices_OutAttribute),
323Debug.Assert(refKind != RefKind.Out && refKind != RefKind.In);
351var returnVariance = RefKind == RefKind.None ? variance : VarianceKind.None;
366(VarianceKind.In, RefKind.None) => VarianceKind.Out,
367(VarianceKind.Out, RefKind.None) => VarianceKind.In,
443RefKind refKind,
488RefKind refKind,
493ImmutableArray<RefKind> parameterRefKinds,
496Debug.Assert(refKind != RefKind.Out);
497Debug.Assert(refCustomModifiers.IsDefaultOrEmpty || refKind != RefKind.None);
509Debug.Assert(refCustomModifiers.IsEmpty || refKind != RefKind.None);
513static ImmutableArray<CustomModifier> getCustomModifierArrayForRefKind(RefKind refKind, CSharpCompilation compilation)
519RefKind refKind,
553RefKind = getRefKind(retInfo, RefCustomModifiers, RefKind.RefReadOnly, RefKind.Ref, requiresLocationAllowed: false);
554Debug.Assert(RefKind != RefKind.Out);
569RefKind paramRefKind = getRefKind(param, paramRefCustomMods, RefKind.In, RefKind.Out, requiresLocationAllowed: true);
581static RefKind getRefKind(ParamInfo<TypeSymbol> param, ImmutableArray<CustomModifier> paramRefCustomMods, RefKind hasInRefKind, RefKind hasOutRefKind, bool requiresLocationAllowed)
585false => RefKind.None,
588true when requiresLocationAllowed && CustomModifierUtils.HasRequiresLocationAttributeModifier(paramRefCustomMods) => RefKind.RefReadOnlyParameter,
589true => RefKind.Ref,
648var modifiersToSearch = RefKind != RefKind.None ? RefCustomModifiers : ReturnTypeWithAnnotations.CustomModifiers;
671var modifiersToSearch = RefKind != RefKind.None ? RefCustomModifiers : ReturnTypeWithAnnotations.CustomModifiers;
767public override RefKind RefKind { get; }
Symbols\Source\ParameterHelpers.cs (35)
42ParameterSyntax syntax, RefKind refKind, int ordinal,
82FunctionPointerParameterSyntax syntax, RefKind refKind, int ordinal,
92RefKind.In => CreateInModifiers(binder, diagnostics, syntax),
93RefKind.RefReadOnlyParameter => CreateRefReadonlyParameterModifiers(binder, diagnostics, syntax),
94RefKind.Out => CreateOutModifiers(binder, diagnostics, syntax),
124Func<Binder, TOwningSymbol, TypeWithAnnotations, TParameterSyntax, RefKind, int, SyntaxToken, SyntaxToken, bool, ScopedKind, BindingDiagnosticBag, TParameterSymbol> parameterCreationFunc,
144var refKind = GetModifiers(parameterSyntax.Modifiers, out SyntaxToken refnessKeyword, out SyntaxToken paramsKeyword, out SyntaxToken thisKeyword, out ScopedKind scope);
183if (!allowRefOrOut && (refKind == RefKind.Ref || refKind == RefKind.Out))
243if (parameter.RefKind == RefKind.In)
254else if (parameter.RefKind == RefKind.RefReadOnlyParameter)
339internal static bool IsRefScopedByDefault(bool useUpdatedEscapeRules, RefKind refKind)
341return useUpdatedEscapeRules && refKind == RefKind.Out;
660RefKind refKind,
698else if (refKind != RefKind.None &&
748var refKind = GetModifiers(parameterSyntax.Modifiers, out SyntaxToken refnessKeyword, out SyntaxToken paramsKeyword, out SyntaxToken thisKeyword, out _);
754if (refKind == RefKind.Ref || refKind == RefKind.Out)
863if (refKind == RefKind.RefReadOnlyParameter)
929internal static RefKind GetModifiers(SyntaxTokenList modifiers, out SyntaxToken refnessKeyword, out SyntaxToken paramsKeyword, out SyntaxToken thisKeyword, out ScopedKind scope)
931var refKind = RefKind.None;
943if (refKind == RefKind.None)
946refKind = RefKind.Out;
950if (refKind == RefKind.None)
953refKind = RefKind.Ref;
957if (refKind == RefKind.None)
960refKind = RefKind.In;
970Debug.Assert(refKind == RefKind.None);
974if (refKind == RefKind.Ref && refnessKeyword.GetNextToken() == modifier)
976refKind = RefKind.RefReadOnlyParameter;
984scope = (refKind == RefKind.None) ? ScopedKind.ScopedValue : ScopedKind.ScopedRef;
994internal static ImmutableArray<CustomModifier> ConditionallyCreateInModifiers(RefKind refKind, bool addRefReadOnlyModifier, Binder binder, BindingDiagnosticBag diagnostics, SyntaxNode syntax)
996if (addRefReadOnlyModifier && refKind is RefKind.In or RefKind.RefReadOnlyParameter)
Symbols\Source\SourceDelegateMethodSymbol.cs (13)
27RefKind refKind,
55returnTypeSyntax = returnTypeSyntax.SkipScoped(out _).SkipRefInLocalOrReturn(diagnostics, out RefKind refKind);
217: base(delegateType, voidType, syntax, MethodKind.Constructor, RefKind.None, DeclarationModifiers.Public)
220SynthesizedParameterSymbol.Create(this, objectType, 0, RefKind.None, "object"),
221SynthesizedParameterSymbol.Create(this, intPtrType, 1, RefKind.None, "method")));
257RefKind refKind,
280if (this.RefKind == RefKind.RefReadOnly)
319if (this.RefKind == RefKind.RefReadOnly)
355: base((SourceNamedTypeSymbol)invoke.ContainingType, iAsyncResultType, syntax, MethodKind.Ordinary, RefKind.None, DeclarationModifiers.Virtual | DeclarationModifiers.Public)
365parameters.Add(SynthesizedParameterSymbol.Create(this, asyncCallbackType, paramCount, RefKind.None, GetUniqueParameterName(parameters, "callback")));
366parameters.Add(SynthesizedParameterSymbol.Create(this, objectType, paramCount + 1, RefKind.None, GetUniqueParameterName(parameters, "object")));
402if (p.RefKind != RefKind.None)
409parameters.Add(SynthesizedParameterSymbol.Create(this, iAsyncResultType, ordinal++, RefKind.None, GetUniqueParameterName(parameters, "result")));
Symbols\Source\SourceMemberContainerSymbol.cs (18)
2156var refKind1 = method1.Parameters[i].RefKind;
2157var refKind2 = method2.Parameters[i].RefKind;
4155if (methodParam.RefKind != RefKind.None)
4178methodParams[0].RefKind == RefKind.None &&
4503RefKind.Out
4505RefKind.None,
4551RefKind.None
4553RefKind.None,
4600RefKind.None)),
4601RefKind.None,
4656RefKind.None,
4735RefKind.None,
4830RefKind.None,
4861RefKind.None,
4927RefKind.None
4929RefKind.None,
5128_ = fieldSyntax.Declaration.Type.SkipScoped(out _).SkipRefInField(out var refKind);
5137var modifiers = SourceMemberFieldSymbol.MakeModifiers(this, fieldSyntax.Declaration.Variables[0].Identifier, fieldSyntax.Modifiers, isRefField: refKind != RefKind.None, diagnostics, out modifierErrors);
Symbols\Synthesized\Records\SynthesizedPrimaryConstructor.cs (1)
43RefKind.None,
Symbols\Synthesized\Records\SynthesizedRecordDeconstruct.cs (1)
41RefKind.Out,
Symbols\Synthesized\Records\SynthesizedRecordEqualityContractProperty.cs (1)
41RefKind.None,
Symbols\Synthesized\Records\SynthesizedRecordPropertySymbol.cs (1)
39RefKind.None,
Symbols\Synthesized\RefKindVector.cs (11)
39internal RefKind this[int index]
46(false, false, false) => RefKind.None,
47(false, false, true) => RefKind.Ref,
48(false, true, false) => RefKind.Out,
49(false, true, true) => RefKind.RefReadOnly,
50(true, false, false) => RefKind.RefReadOnlyParameter,
59RefKind.None => (false, false, false),
60RefKind.Ref => (false, false, true),
61RefKind.Out => (false, true, false),
62RefKind.RefReadOnly => (false, true, true),
63RefKind.RefReadOnlyParameter => (true, false, false),
Symbols\Synthesized\SynthesizedDelegateSymbol.cs (6)
21SynthesizedParameterSymbol.Create(this, TypeWithAnnotations.Create(objectType), 0, RefKind.None, "object"),
22SynthesizedParameterSymbol.Create(this, TypeWithAnnotations.Create(intPtrType), 1, RefKind.None, "method"));
35internal ParameterDescription(TypeWithAnnotations type, RefKind refKind, ScopedKind scope, ConstantValue? defaultValue, bool isParams, bool hasUnscopedRefAttribute)
46internal readonly RefKind RefKind;
59RefKind refKind)
163public override RefKind RefKind { get; }
Symbols\Synthesized\SynthesizedEntryPointSymbol.cs (10)
115public override RefKind RefKind
117get { return RefKind.None; }
300default(ImmutableArray<RefKind>),
363argumentRefKindsOpt: default(ImmutableArray<RefKind>),
411refKind: RefKind.None,
429refKind: RefKind.None,
522RefKind.None,
541TypeWithAnnotations.Create(submissionArrayType), 0, RefKind.None, "submissionArray"));
592argumentRefKindsOpt: default(ImmutableArray<RefKind>),
613RefKind.None,
InitializeParameter\CSharpInitializeMemberFromPrimaryConstructorParameterCodeRefactoringProvider.cs (1)
251RefKind.None,
GenerateType\AbstractGenerateTypeService.GenerateNamedType.cs (1)
50RefKind.None,
InitializeParameter\AbstractInitializeMemberFromParameterCodeRefactoringProviderMemberCreation.cs (1)
342RefKind.None,
src\Analyzers\Core\Analyzers\RemoveUnusedParametersAndValues\AbstractRemoveUnusedParametersAndValuesDiagnosticAnalyzer.SymbolStartAnalyzer.BlockAnalyzer.cs (2)
544case RefKind.Out:
551case RefKind.Ref:
src\Analyzers\Core\CodeFixes\GenerateParameterizedMember\AbstractGenerateDeconstructMethodService.State.cs (1)
76refKind: RefKind.None,
src\Analyzers\Core\CodeFixes\GenerateParameterizedMember\AbstractGenerateMethodService.State.cs (1)
255refKind: RefKind.None,
src\Analyzers\Core\CodeFixes\GenerateVariable\AbstractGenerateVariableService.cs (8)
144document, state, generateProperty: false, isReadonly: false, isConstant: true, refKind: RefKind.None));
158document, state, generateProperty: false, isReadonly: true, isConstant: false, refKind: RefKind.None));
172document, state, generateProperty: false, isReadonly: false, isConstant: false, refKind: RefKind.None));
220parameter.RefKind is RefKind.Out ||
245private static RefKind GetRefKindFromContext(State state)
249return RefKind.Ref;
253return RefKind.RefReadOnly;
257return RefKind.None;
src\Analyzers\Core\CodeFixes\GenerateVariable\AbstractGenerateVariableService.GenerateParameterCodeAction.cs (1)
49RefKind.None,
src\Workspaces\SharedUtilitiesAndExtensions\Workspace\Core\CodeGeneration\CodeGenerationSymbolFactory.cs (10)
53RefKind refKind,
84ITypeSymbol type, RefKind refKind, ImmutableArray<IPropertySymbol> explicitInterfaceImplementations, string name,
158RefKind refKind,
180RefKind refKind,
270=> CreateParameterSymbol(RefKind.None, type, name);
272public static IParameterSymbol CreateParameterSymbol(RefKind refKind, ITypeSymbol type, string name)
282ImmutableArray<AttributeData> attributes, RefKind refKind, bool isParams, ITypeSymbol type, string name, bool isOptional = false, bool hasDefaultValue = false, object? defaultValue = null)
293RefKind? refKind = null,
397refKind: RefKind.None,
469RefKind refKind,
src\Workspaces\SharedUtilitiesAndExtensions\Workspace\Core\CodeGeneration\Symbols\CodeGenerationConstructorSymbol.cs (1)
27refKind: RefKind.None,
src\Workspaces\SharedUtilitiesAndExtensions\Workspace\Core\CodeGeneration\Symbols\CodeGenerationConversionSymbol.cs (1)
31refKind: RefKind.None,
src\Workspaces\SharedUtilitiesAndExtensions\Workspace\Core\CodeGeneration\Symbols\CodeGenerationDestructorSymbol.cs (1)
18refKind: RefKind.None,
src\Workspaces\SharedUtilitiesAndExtensions\Workspace\Core\CodeGeneration\Symbols\CodeGenerationOperatorSymbol.cs (1)
32refKind: RefKind.None,
src\Workspaces\SharedUtilitiesAndExtensions\Workspace\Core\Extensions\SyntaxGeneratorExtensions_CreateEqualsMethod.cs (1)
56refKind: RefKind.None,