Binder\Binder.ValueChecks.cs (92)
695BindDefaultArguments(indexerAccess.Syntax, parameters, extensionReceiver: null, argumentsBuilder, refKindsBuilderOpt, namesBuilder, ref argsToParams, out defaultArguments, indexerAccess.Expanded, enableCallerInfo: true, diagnostics: diagnostics);
749Debug.Assert(expr.Syntax.Kind() != SyntaxKind.Argument || valueKind == BindValueKind.RefOrOut);
861diagnostics.Add(expr.Syntax, useSiteInfo);
896expr.Syntax,
904if (!hasResolutionErrors && CheckValueKind(expr.Syntax, expr, valueKind, checkingReceiver: false, diagnostics: diagnostics) ||
1120return CheckMethodReturnValueKind(call.Method, call.Syntax, node, valueKind, checkingReceiver, diagnostics);
1124expr.Syntax,
1138return CheckMethodReturnValueKind(sliceAccess.Method, sliceAccess.Syntax, node, valueKind, checkingReceiver, diagnostics);
1163return CheckMethodReturnValueKind(getItemOrSliceHelper, elementAccess.Syntax, node, valueKind, checkingReceiver, diagnostics);
1183(CheckValueKind(conditional.Consequence.Syntax, conditional.Consequence, valueKind, checkingReceiver: false, diagnostics: diagnostics) &
1184CheckValueKind(conditional.Alternative.Syntax, conditional.Alternative, valueKind, checkingReceiver: false, diagnostics: diagnostics)))
1263Error(diagnostics, ErrorCode.ERR_BadSKknown, expr.Syntax, ((BoundNamespaceExpression)expr).NamespaceSymbol, MessageID.IDS_SK_NAMESPACE.Localize(), MessageID.IDS_SK_VARIABLE.Localize());
1269if (!IsInPossibleBadNegCastContext(expr.Syntax))
1271Error(diagnostics, ErrorCode.ERR_BadSKunknown, expr.Syntax, expr.Type, MessageID.IDS_SK_TYPE.Localize());
1328diagnostics.Add(ErrorCode.WRN_AssignmentToLockOrDispose, local.Syntax.Location, localSymbol);
1378Error(diagnostics, inUnsafeRegion ? ErrorCode.WRN_RefReturnLocal2 : ErrorCode.ERR_RefReturnLocal2, local.Syntax, localSymbol);
1389Error(diagnostics, inUnsafeRegion ? ErrorCode.WRN_RefReturnNonreturnableLocal2 : ErrorCode.ERR_RefReturnNonreturnableLocal2, local.Syntax, localSymbol);
1462diagnostics.Add(ErrorCode.WRN_AssignmentToLockOrDispose, parameter.Syntax.Location, parameterSymbol.Name);
1588(checkingReceiver: true, isRefScoped: true, inUnsafeRegion: false, _) => (ErrorCode.ERR_RefReturnScopedParameter2, parameter.Syntax),
1589(checkingReceiver: true, isRefScoped: true, inUnsafeRegion: true, _) => (ErrorCode.WRN_RefReturnScopedParameter2, parameter.Syntax),
1590(checkingReceiver: true, isRefScoped: false, inUnsafeRegion: false, { IsReturnOnly: true }) => (ErrorCode.ERR_RefReturnOnlyParameter2, parameter.Syntax),
1591(checkingReceiver: true, isRefScoped: false, inUnsafeRegion: true, { IsReturnOnly: true }) => (ErrorCode.WRN_RefReturnOnlyParameter2, parameter.Syntax),
1592(checkingReceiver: true, isRefScoped: false, inUnsafeRegion: false, _) => (ErrorCode.ERR_RefReturnParameter2, parameter.Syntax),
1593(checkingReceiver: true, isRefScoped: false, inUnsafeRegion: true, _) => (ErrorCode.WRN_RefReturnParameter2, parameter.Syntax),
2005Error(diagnostics, ErrorCode.ERR_ReturnNotLValue, expr.Syntax, propertySymbol);
2525CheckRefEscape(argument.Syntax, argument, escapeTo, false, diagnostics) :
2526CheckValEscape(argument.Syntax, argument, escapeTo, false, diagnostics);
2551return CheckValEscape(receiver.Syntax, receiver, escapeTo, false, diagnostics);
2590CheckRefEscape(argument.Syntax, argument, escapeTo, false, diagnostics) :
2591CheckValEscape(argument.Syntax, argument, escapeTo, false, diagnostics);
2627? CheckRefEscape(argument.Syntax, argument, escapeTo, checkingReceiver: false, diagnostics)
2628: CheckValEscape(argument.Syntax, argument, escapeTo, checkingReceiver: false, diagnostics);
2670receiver = new BoundCapturedReceiverPlaceholder(receiver.Syntax, receiver, receiver.Type).MakeCompilerGenerated();
3240if (!hasMixingError && !CheckValEscape(argument.Syntax, argument, escapeTo, false, diagnostics))
3294? CheckRefEscape(fromArg.Syntax, fromArg, toArgEscape, checkingReceiver: false, diagnostics)
3295: CheckValEscape(fromArg.Syntax, fromArg, toArgEscape, checkingReceiver: false, diagnostics);
3689CheckRefEscape(expr.Syntax, expr, escapeTo, checkingReceiver: false, diagnostics: diagnostics);
3693CheckValEscape(expr.Syntax, expr, escapeTo, checkingReceiver: false, diagnostics: diagnostics);
4070return CheckRefEscape(conditional.Consequence.Syntax, conditional.Consequence, escapeTo, checkingReceiver: false, diagnostics: diagnostics) &&
4071CheckRefEscape(conditional.Alternative.Syntax, conditional.Alternative, escapeTo, checkingReceiver: false, diagnostics: diagnostics);
4107call.Syntax,
4126indexerAccess.Syntax,
4150indexerAccess.Syntax,
4174call.Syntax,
4203elementAccess.Syntax,
4221functionPointerInvocation.Syntax,
4239propertyAccess.Syntax,
5067Error(diagnostics, inUnsafeRegion ? ErrorCode.WRN_EscapeVariable : ErrorCode.ERR_EscapeVariable, node, expr.Syntax);
5084return CheckValEscape(underlyingReceiver.Syntax, underlyingReceiver, escapeTo, checkingReceiver, diagnostics);
5099CheckValEscape(conditional.Consequence.Syntax, conditional.Consequence, escapeTo, checkingReceiver: false, diagnostics: diagnostics) &&
5100CheckValEscape(conditional.Alternative.Syntax, conditional.Alternative, escapeTo, checkingReceiver: false, diagnostics: diagnostics);
5107var consValid = CheckValEscape(conditional.Consequence.Syntax, conditional.Consequence, escapeTo, checkingReceiver: false, diagnostics: diagnostics);
5116return CheckValEscape(conditional.Alternative.Syntax, conditional.Alternative, escapeTo, checkingReceiver: false, diagnostics: diagnostics);
5121return CheckValEscape(coalescingOp.LeftOperand.Syntax, coalescingOp.LeftOperand, escapeTo, checkingReceiver, diagnostics) &&
5122CheckValEscape(coalescingOp.RightOperand.Syntax, coalescingOp.RightOperand, escapeTo, checkingReceiver, diagnostics);
5148call.Syntax,
5161ptrInvocation.Syntax,
5174indexerAccess.Syntax,
5193indexerAccess.Syntax,
5213call.Syntax,
5233elementAccess.Syntax,
5246propertyAccess.Syntax,
5259objectCreation.Syntax,
5271initializerExpr.Syntax,
5291initializerExpr.Syntax,
5307escape = escape && CheckValEscape(initializerExpr.Syntax, initializerExpr, escapeTo, checkingReceiver: false, diagnostics: diagnostics);
5317unary.Syntax,
5358conversion.Syntax,
5372conversion.Syntax,
5406increment.Syntax,
5425compound.Syntax,
5434return CheckValEscape(compound.Left.Syntax, compound.Left, escapeTo, checkingReceiver: false, diagnostics: diagnostics);
5438return CheckValEscape(compound.Left.Syntax, compound.Left, escapeTo, checkingReceiver: false, diagnostics: diagnostics) &&
5439CheckValEscape(compound.Right.Syntax, compound.Right, escapeTo, checkingReceiver: false, diagnostics: diagnostics);
5452binary.Syntax,
5460return CheckValEscape(binary.Left.Syntax, binary.Left, escapeTo, checkingReceiver: false, diagnostics: diagnostics) &&
5461CheckValEscape(binary.Right.Syntax, binary.Right, escapeTo, checkingReceiver: false, diagnostics: diagnostics);
5466if (range.LeftOperandOpt is { } left && !CheckValEscape(left.Syntax, left, escapeTo, checkingReceiver: false, diagnostics: diagnostics))
5471return !(range.RightOperandOpt is { } right && !CheckValEscape(right.Syntax, right, escapeTo, checkingReceiver: false, diagnostics: diagnostics));
5477uo.Syntax,
5486return CheckValEscape(clauseValue.Syntax, clauseValue, escapeTo, checkingReceiver: false, diagnostics: diagnostics);
5490return CheckValEscape(variableValue.Syntax, variableValue, escapeTo, checkingReceiver: false, diagnostics: diagnostics);
5502return CheckValEscape(accessedExpression.Syntax, accessedExpression, escapeTo, checkingReceiver, diagnostics);
5506return CheckValEscape(operandExpression.Syntax, operandExpression, escapeTo, checkingReceiver, diagnostics);
5521if (!CheckValEscape(result.Syntax, result, escapeTo, checkingReceiver: false, diagnostics: diagnostics))
5767if (!CheckValEscape(element.Syntax, element, escapeTo, checkingReceiver: false, diagnostics: diagnostics))
5785colElement.Syntax,
5794else if (!CheckValEscape(expr.Syntax, expr, escapeTo, checkingReceiver: false, diagnostics))
5809Error(diagnostics, _inUnsafeRegion ? ErrorCode.WRN_EscapeVariable : ErrorCode.ERR_EscapeVariable, initExpr.Syntax, expr.Syntax);
5835bool result = CheckValEscape(expression.Syntax, data.Construction, escapeTo, checkingReceiver: false, diagnostics);
5921call.Syntax,
Binder\Binder_Attributes.cs (9)
290Debug.Assert(boundAttribute.Syntax.Kind() == SyntaxKind.Attribute);
298return new SourceAttributeData(Compilation, (AttributeSyntax)boundAttribute.Syntax, attributeType, attributeConstructor, hasErrors);
302ValidateTypeForAttributeParameters(attributeConstructor.Parameters, ((AttributeSyntax)boundAttribute.Syntax).Name, diagnostics, ref hasErrors);
323(AttributeSyntax)boundAttribute.Syntax,
333diagnostics.Add(boundAttribute.Syntax, useSiteInfo);
337(AttributeSyntax)boundAttribute.Syntax,
893Binder.Error(diagnostics, ErrorCode.ERR_BadAttributeArgument, node.Syntax);
964Binder.Error(diagnostics, ErrorCode.ERR_AttrArgWithTypeVars, node.Syntax, typeOfArgument.ToDisplayString(SymbolDisplayFormat.CSharpErrorMessageFormat));
1048Binder.Error(diagnostics, ErrorCode.ERR_BadAttributeArgument, node.Syntax);
Binder\Binder_Await.cs (7)
32var placeholder = new BoundAwaitableValuePlaceholder(expression.Syntax, expression.Type);
124var syntax = expression.Syntax;
321&& (!isRuntimeAsyncEnabled || getRuntimeAwaitAwaiter(awaiterType, out runtimeAsyncAwaitCall, out runtimeAsyncAwaitCallPlaceholder, expression.Syntax, diagnostics));
350var asyncHelpersType = GetSpecialType(InternalSpecialType.System_Runtime_CompilerServices_AsyncHelpers, diagnostics, expression.Syntax);
372placeholder = new BoundAwaitableValuePlaceholder(expression.Syntax, expression.Type);
382expression.Syntax,
406reportObsoleteDiagnostics(this, diagnostics, runtimeAwaitCall.Method, expression.Syntax);
Binder\Binder_Conversions.cs (56)
28diagnostics.Add(source.Syntax, useSiteInfo);
29return CreateConversion(source.Syntax, source, conversion, isCast: false, conversionGroupOpt: null, InConversionGroupFlags.Unspecified, destination: destination, diagnostics: diagnostics);
38return CreateConversion(source.Syntax, source, conversion, isCast: false, conversionGroupOpt: null, InConversionGroupFlags.Unspecified, destination: destination, diagnostics: diagnostics);
79var placeholder2 = new BoundValuePlaceholder(source.Syntax, source.Type);
280source = new BoundDefaultExpression(source.Syntax, targetType: null, constantValue, type: destination)
292diagnostics.Add(ErrorCode.WRN_ConvertingLock, source.Syntax);
342new BoundValuePlaceholder(source.Syntax, source.Type.GetNullableUnderlyingType()),
373new BoundValuePlaceholder(source.Syntax, source.Type.GetNullableUnderlyingType()),
402new BoundValuePlaceholder(source.Syntax, sourceTypes[i].Type),
732var stringFactory = GetWellKnownType(WellKnownType.System_Runtime_CompilerServices_FormattableStringFactory, diagnostics, unconvertedSource.Syntax);
737unconvertedSource.Syntax,
765BoundExpression expr = bindObjectCreationExpression(node.Syntax, node.InitializerOpt, node.Binder, destination.StrippedType(), arguments, diagnostics);
773Debug.Assert(expr is not BoundBadExpression { ChildBoundNodes: var children } || !children.Any((child, node) => child.Syntax == node.Syntax, node));
837_ = GetSpecialTypeMember(SpecialMember.System_Nullable_T__ctor, diagnostics, syntax: node.Syntax);
861_node.Syntax,
896_diagnostics.Add(ErrorCode.ERR_CollectionRefLikeElementType, _node.Syntax);
915var syntax = _node.Syntax;
965var syntax = _node.Syntax;
987var collectionCreation = bindCollectionConstructorConstruction(in this, _node.WithElement?.Syntax ?? _node.Syntax, constructor);
1010(SpreadElementSyntax)spreadElement.Syntax,
1016element.Syntax,
1105element.Syntax,
1126var expressionSyntax = element.Expression.Syntax;
1153var syntax = _node.Syntax;
1170_node.WithElement.Syntax.GetFirstToken().GetLocation(),
1185_diagnostics.Add(ErrorCode.ERR_CollectionArgumentsMustBeEmpty, _node.WithElement.Syntax.GetFirstToken().GetLocation());
1202var withSyntax = withElement.Syntax;
1284var collectionBuilderMethods = @this._binder.GetCollectionBuilderMethods(@this._node.Syntax, namedType, @this._diagnostics, forParams: false);
1309var syntax = @this._node.WithElement?.Syntax ?? @this._node.Syntax;
2245? new BoundBadExpression(node.WithElement!.Syntax, LookupResultKind.Empty, symbols: [], naturalWithArguments, CreateErrorType())
2258node.Syntax,
2287if (!TryGetCollectionIterationType(node.Syntax, targetType, out elementTypeWithAnnotations))
2294node.Syntax,
2313node.WithElement, node.WithElement?.Syntax ?? node.Syntax, targetType, constructor: out _, isExpanded: out _, diagnostics))
2319!HasCollectionExpressionApplicableAddMethod(node.Syntax, targetType, addMethods: out _, diagnostics))
2333Error(diagnostics, ErrorCode.ERR_NoImplicitConv, spreadElement.Expression.Syntax, spreadElement.Expression.Display, elementType);
2341GenerateImplicitConversionError(diagnostics, this.Compilation, spreadElement.Expression.Syntax, elementConversion, enumeratorInfo.ElementType, elementType);
2351GenerateImplicitConversionError(diagnostics, element.Syntax, elementConversion, (BoundExpression)element, elementType);
2361Error(diagnostics, ErrorCode.ERR_CollectionExpressionTargetTypeNotConstructible, node.Syntax, targetType);
2386? CreateConversion(source.Consequence.Syntax, source.Consequence, underlyingConversions[0], isCast: false, conversionGroupOpt: null, InConversionGroupFlags.Unspecified, destination, diagnostics)
2390? CreateConversion(source.Alternative.Syntax, source.Alternative, underlyingConversions[1], isCast: false, conversionGroupOpt: null, InConversionGroupFlags.Unspecified, destination, diagnostics)
2399source.Syntax.Location,
2406return new BoundConditionalOperator(source.Syntax, isRef: false, condition, trueExpr, falseExpr, constantValue, source.Type, wasTargetTyped: targetTyped, destination, hasErrors)
2426? CreateConversion(oldValue.Syntax, oldValue, underlyingConversions[i], isCast: false, conversionGroupOpt: null, InConversionGroupFlags.Unspecified, destination, diagnostics)
2429new BoundSwitchExpressionArm(oldCase.Syntax, oldCase.Locals, oldCase.Pattern, oldCase.WhenClause, newValue, oldCase.Label, oldCase.HasErrors);
2436source.Syntax, source.Type, targetTyped, source.Expression, newSwitchArms, source.ReachabilityDecisionDag,
2505syntax: source.Syntax,
2954var tupleSyntax = (TupleExpressionSyntax)sourceTuple.Syntax;
2983convertedArguments.Add(CreateConversion(argument.Syntax, argument, elementConversion, isCast: isCast, elementConversionGroup, InConversionGroupFlags.Unspecified, destType.Type, diagnostics));
2987sourceTuple.Syntax,
3000sourceTuple.Syntax,
3584return this.MethodGroupConversionHasErrors(boundMethodGroup.Syntax, conversion, boundMethodGroup.ReceiverOpt, conversion.IsExtensionMethod, isAddressOf: false, delegateType, diagnostics);
Binder\Binder_Deconstruct.cs (14)
132new BoundConversion(boundRHS.Syntax, boundRHS, Conversion.Deconstruction, @checked: false, explicitCastInCode: false,
145boundRHS.Syntax,
162boundRHS.Syntax,
229Error(diagnostics, ErrorCode.ERR_DeconstructRequiresExpression, boundRHS.Syntax);
326diagnostics.Add(single.Syntax, useSiteInfo);
331GenerateImplicitConversionError(diagnostics, Compilation, single.Syntax, nestedConversion, tupleOrDeconstructedTypes[i], single.Type);
410variables[i] = new DeconstructionVariable(errorLocal, errorLocal.Syntax);
416Error(diagnostics, ErrorCode.ERR_TypeInferenceFailedForImplicitlyTypedDeconstructionVariable, pending.Syntax, "_");
417variables[i] = new DeconstructionVariable(pending.FailInference(this, diagnostics), pending.Syntax);
498Error(diagnostics, ErrorCode.ERR_DeconstructRequiresExpression, element.Syntax);
516Error(diagnostics, ErrorCode.ERR_DeconstructRequiresExpression, element.Syntax);
521locationsBuilder.Add(element.Syntax.Location);
604return InferTupleElementName(expression.Syntax);
623var receiverSyntax = (CSharpSyntaxNode)receiver.Syntax;
Binder\Binder_Expressions.cs (88)
241expr.Syntax,
322var exprSyntax = (SwitchExpressionSyntax)expr.Syntax;
360diagnostics.Add(op.NoCommonTypeError, op.Syntax.Location, trueArg, falseArg);
375sourceTuple.Syntax,
390diagnostics.Add(ErrorCode.ERR_DefaultLiteralNoTargetType, defaultExpr.Syntax.GetLocation());
394defaultExpr.Syntax,
413diagnostics.Add(ErrorCode.ERR_ImplicitObjectCreationNoTargetType, expr.Syntax.GetLocation(), expr.Display);
433diagnostics.Add(ErrorCode.ERR_CollectionExpressionNoTargetType, expr.Syntax.GetLocation());
450var syntax = expr.Syntax;
2849GenerateAnonymousFunctionConversionError(diagnostics, operand.Syntax, (UnboundLambda)operand, targetType);
2939GenerateImplicitConversionError(diagnostics, operand.Syntax, conversion, operand, targetType);
2986GenerateExplicitConversionErrors(diagnostics, argument.Syntax, elementConversion, argument, targetElementType);
3582coercedArgument = CreateConversion(argument.Syntax, argument, kind, isCast: false, conversionGroupOpt: null, InConversionGroupFlags.Unspecified, parameterTypeWithAnnotations.Type, diagnostics);
3603coercedArgument = CreateConversion(argument.Syntax, argument, kind, isCast: false, conversionGroupOpt: null, InConversionGroupFlags.Unspecified, parameterTypeWithAnnotations.Type, diagnostics);
3727ReportUnsafeIfNotAllowed(argument.Syntax, diagnostics);
3763unconvertedString.Syntax,
3778diagnostics.Add(ErrorCode.ERR_InterpolatedStringHandlerArgumentAttributeMalformed, unconvertedString.Syntax.Location, correspondingParameter, handlerType);
3780unconvertedString.Syntax,
3796unconvertedString.Syntax,
3888unconvertedString.Syntax.Location,
3907arguments[argumentIndex].Syntax.Location,
3928placeholderSyntax = receiver.Syntax;
3931placeholderSyntax = unconvertedString.Syntax;
3935placeholderSyntax = arguments[argumentIndex].Syntax;
3963interpolatedString.Syntax,
3990var available = CheckFeatureAvailability(argument.Syntax, MessageID.IDS_FeatureRefReadonlyParameters, diagnostics);
4008argument.Syntax,
4014if (!this.CheckValueKind(argument.Syntax, argument, BindValueKind.RefersToLocation, checkingReceiver: false, BindingDiagnosticBag.Discarded))
4020argument.Syntax,
4026if (this.CheckValueKind(argument.Syntax, argument, BindValueKind.Assignable, checkingReceiver: false, BindingDiagnosticBag.Discarded))
4031argument.Syntax,
4039argument.Syntax,
4534Error(diagnostics, ErrorCode.ERR_ConstantExpected, size.Syntax);
4771Error(diagnostics, ErrorCode.ERR_ConstantExpected, sizeOpt.Syntax);
5241return (parameter, boundParameter.Syntax);
5277Debug.Assert(result is not BoundBadExpression { ChildBoundNodes: var children } || !children.Any((child, node) => child.Syntax == node, node));
5420lengthOrCount = new BoundLiteral(expression.Syntax, ConstantValue.Create(length), @this.GetSpecialType(SpecialType.System_Int32, diagnostics, expression.Syntax)) { WasCompilerGenerated = true };
5461diagnostics.Add(ErrorCode.ERR_CollectionArgumentsDynamicBinding, arg.Syntax);
5463arg.Syntax, LookupResultKind.Empty, symbols: [],
5526var argSyntax = analyzedArguments.Arguments[0].Syntax;
5528var end = analyzedArguments.Arguments[analyzedArguments.Arguments.Count - 1].Syntax.Span.End;
5569GenerateImplicitConversionError(diagnostics, unboundLambda.Syntax, conversion, unboundLambda, type);
5582CheckParameterModifierMismatchMethodConversion(unboundLambda.Syntax, boundLambda.Symbol, type, invokedAsExtensionMethod: false, diagnostics);
5609diagnostics.Add(ErrorCode.ERR_MethodNameExpected, argument.Syntax.Location);
5633Conversion conv = Conversions.MethodGroupConversion(argument.Syntax, methodGroup, type, ref useSiteInfo);
5638argument.Syntax, default, WellKnownMemberNames.DelegateInvokeName, ImmutableArray.Create(sourceDelegate.DelegateInvokeMethod),
5654if (!this.MethodGroupConversionHasErrors(argument.Syntax, conv, argument, conv.IsExtensionMethod, isAddressOf: false, type, diagnostics))
5670diagnostics.Add(ErrorCode.ERR_MethodNameExpected, argument.Syntax.Location);
5746var result = MakeBadExpressionForObjectCreation(node.Syntax, CreateErrorType(), arguments, node.InitializerOpt, typeSyntax: node.Syntax, diagnostics);
5917typeSyntax: boundLeft.Syntax,
6138diagnostics.Add(ErrorCode.ERR_InterpolatedStringsReferencingInstanceCannotBeInObjectInitializers, argument.Syntax.Location);
6149MessageID.IDS_FeatureImplicitIndexerInitializer.CheckFeatureAvailability(diagnostics, implicitIndexer.Syntax);
6184if (!CheckValueKind(boundMember.Syntax, boundMember, valueKind, checkingReceiver: false, diagnostics: diagnostics))
6282var memberInitializerSyntax = boundMemberInitializer.Syntax;
6371diagnostics.Add(ErrorCode.ERR_RequiredMembersMustBeAssignedValue, initializerExpression.Syntax.Location, requiredMember);
6524var boundElementInitializer = BindInitializerExpressionOrValue(elementInitializer, initializerType, BindValueKind.RValue, implicitReceiver.Syntax, diagnostics);
7010CheckRequiredMembersInObjectInitializer(creation.Constructor, creation.InitializerExpressionOpt?.Initializers ?? default, creation.Syntax, diagnostics);
8128CheckFeatureAvailability(boundLeft.Syntax, MessageID.IDS_FeatureStaticAbstractMembersInInterfaces, diagnostics);
8133Error(diagnostics, ErrorCode.ERR_LookupInTypeVariable, boundLeft.Syntax, leftType);
8196diagnostics.Add(expr.Syntax, useSiteInfo);
9094propertyResult.ReportDiagnostics(binder, expression.Location, expression, diagnostics, memberName, left, left.Syntax, actualReceiverArguments, symbols,
9758if (expr.Syntax.Parent is ConditionalAccessExpressionSyntax conditional &&
9759conditional.Expression == expr.Syntax)
9761location = expr.Syntax.SyntaxTree.GetLocation(TextSpan.FromBounds(expr.Syntax.SpanStart, conditional.OperatorToken.Span.End));
9765location = expr.Syntax.GetLocation();
9780checkInlineArrayBounds(convertedIndex.Syntax, constIndex, length, excludeEnd: true, diagnostics);
9861location = hatExpression.Syntax;
9867location = operand.Syntax;
9875location = index.Syntax;
9981Error(diagnostics, ErrorCode.WRN_NegativeArrayIndex, index.Syntax);
9995var receiverPlaceholder = new BoundImplicitIndexerReceiverPlaceholder(expr.Syntax, isEquivalentToThisReference: expr.IsEquivalentToThisReference, expr.Type) { WasCompilerGenerated = true };
9996var argumentPlaceholders = ImmutableArray.Create(new BoundImplicitIndexerValuePlaceholder(convertedArguments[0].Syntax, int32) { WasCompilerGenerated = true });
10027var node = index.Syntax;
10135BoundExpression result = CreateConversion(expr.Syntax, expr, conversion, isCast: false, conversionGroupOpt: null, InConversionGroupFlags.Unspecified, destination: targetType, diagnostics); // UNDONE: was cast?
10176Error(diagnostics, ErrorCode.ERR_VoidError, expr.Syntax);
10194Error(diagnostics, ErrorCode.ERR_BadArgExtraRef, analyzedArguments.Argument(i).Syntax, i + 1, refKind.ToArgumentDisplayString());
10274var syntax = propertyGroup.Syntax;
10540var receiverPlaceholder = new BoundImplicitIndexerReceiverPlaceholder(receiver.Syntax, isEquivalentToThisReference: receiver.IsEquivalentToThisReference, receiver.Type) { WasCompilerGenerated = true };
10878node, node.Syntax, node.Name, analyzedArguments, ref useSiteInfo,
11081return GetMethodGroupOrLambdaDelegateType(node.Syntax, method, hasParams: useParams);
11614if (access.Syntax is AssignmentExpressionSyntax assignment)
11720diagnostics.Add(new CSDiagnostic(diagnosticInfo, access.Syntax.Location));
11721receiver = BadExpression(receiver.Syntax, receiver);
11763if (receiver?.Syntax != GetConditionalReceiverSyntax(conditionalAccessNode))
11778receiver = new BoundConditionalReceiver(receiver.Syntax, 0, receiverType ?? CreateErrorType(), hasErrors: receiver.HasErrors) { WasCompilerGenerated = true };
Binder\Binder_InterpolatedString.cs (19)
112diagnostics.Add(ErrorCode.WRN_AlignmentMagnitude, alignment.Syntax.Location, alignmentConstant.Int32Value, magnitudeLimit);
268unconvertedInterpolatedString.Syntax,
339SyntaxNode syntax = unconvertedSource.Syntax;
495binaryOperator.Syntax,
504convertedBinaryOperator = UpdateBinaryOperatorWithInterpolatedContents(binaryOperator, appendCalls, data, binaryOperator.Syntax, diagnostics);
532expression.Syntax,
542original.Syntax,
583unconvertedInterpolatedString.Syntax,
593unconvertedInterpolatedString.Syntax,
620binaryOperator.Syntax,
628var result = UpdateBinaryOperatorWithInterpolatedContents(binaryOperator, appendCalls, data, binaryOperator.Syntax, diagnostics);
689CheckFeatureAvailability(value.Syntax, MessageID.IDS_FeatureImprovedInterpolatedStrings, diagnostics);
699CheckFeatureAvailability(value.Syntax, MessageID.IDS_FeatureImprovedInterpolatedStrings, diagnostics);
853var objectType = GetSpecialType(SpecialType.System_Object, diagnostics, unconvertedInterpolatedString.Syntax);
939parameterNamesAndLocationsBuilder.Add(("alignment", insert.Alignment.Syntax.Location));
945parameterNamesAndLocationsBuilder.Add(("format", insert.Format.Syntax.Location));
975var call = MakeInvocationExpression(part.Syntax, implicitBuilderReceiver, methodName, arguments, diagnostics, names: parameterNamesAndLocations, searchExtensionsIfNecessary: false);
989diagnostics.Add(ErrorCode.ERR_InterpolatedStringHandlerMethodReturnMalformed, part.Syntax.Location, method);
999diagnostics.Add(ErrorCode.ERR_InterpolatedStringHandlerMethodReturnInconsistent, part.Syntax.Location, method, expected);
Binder\Binder_Invocation.cs (25)
298Error(diagnostics, ErrorCode.ERR_CantUseVoidInArglist, argument.Syntax);
313Error(diagnostics, ErrorCode.ERR_CantUseInOrOutInArglist, argument.Syntax);
526Error(diagnostics, ErrorCode.ERR_NamedArgumentSpecificationBeforeFixedArgumentInDynamicInvocation, arguments.Arguments[i].Syntax);
566Error(diagnostics, ErrorCode.ERR_CannotDynamicInvokeOnExpression, receiver.Syntax, receiver.Type);
576Error(diagnostics, ErrorCode.ERR_InDynamicMethodArg, arguments[argIndex].Syntax);
597Error(diagnostics, ErrorCode.ERR_BadDynamicMethodArgLambda, arg.Syntax);
603Error(diagnostics, ErrorCode.ERR_BadDynamicMethodArgMemgrp, arg.Syntax);
611Error(diagnostics, ErrorCode.ERR_BadDynamicMethodArg, arg.Syntax, "__arglist");
620Error(diagnostics, ErrorCode.ERR_BadDynamicMethodArg, arg.Syntax, arg.Type);
772methodGroup.Syntax,
910argumentSyntax = arg.Syntax;
1093Error(diagnostics, ErrorCode.ERR_NoImplicitConv, call.ReceiverOpt.Syntax, distinguisher.First, distinguisher.Second);
1099Error(diagnostics, ErrorCode.ERR_NoImplicitConv, call.ReceiverOpt.Syntax, distinguisher.First, distinguisher.Second);
1113Error(diagnostics, ErrorCode.ERR_BadDynamicMethodArg, dynInvoke.Expression.Syntax, dynInvoke.Expression.Type);
1285CheckFeatureAvailability(receiverArgument.Syntax, MessageID.IDS_FeatureRefExtensionMethods, diagnostics);
1291CheckFeatureAvailability(receiverArgument.Syntax, MessageID.IDS_FeatureRefExtensionMethods, diagnostics);
1408var result = !CheckValueKind(receiver.Syntax, receiver, valueKind, checkingReceiver: true, BindingDiagnosticBag.Discarded);
1713defaultValue = new BoundLiteral(syntax, ConstantValue.Create(argument.Syntax.ToString()), Compilation.GetSpecialType(SpecialType.System_String)) { WasCompilerGenerated = true };
1764defaultValue.Syntax,
1919Error(diagnostics, ErrorCode.WRN_ImplicitCopyInReadOnlyMember, receiver.Syntax, method, ThisParameterSymbol.SymbolName);
1965var identifier = (IdentifierNameSyntax)typeOrValue.Syntax;
2412diagnostics.Add(ErrorCode.ERR_NameofExtensionMember, boundArgument.Syntax);
2443diagnostics.Add(methodGroup.Syntax, useSiteInfo);
2447diagnostics.Add(ErrorCode.ERR_NameofExtensionMethod, methodGroup.Syntax.Location);
2559boundExpression.Syntax,
Binder\Binder_Operators.cs (36)
75var placeholder = new BoundValuePlaceholder(right.Syntax, left.HasDynamicType() ? left.Type : right.Type).MakeCompilerGenerated();
318var leftPlaceholder = new BoundValuePlaceholder(left.Syntax, leftType).MakeCompilerGenerated();
508leftPlaceholder = new BoundValuePlaceholder(left.Syntax, leftType).MakeCompilerGenerated();
1280left = BindSimpleBinaryOperator((BinaryExpressionSyntax)current.Syntax, diagnostics, left ?? current.Left, right, leaveUnconvertedIfInterpolatedString: false);
1321GenerateImplicitConversionError(diagnostics, right.Syntax, conversion, right, left.Type);
1546var operandPlaceholder = new BoundValuePlaceholder(resultLeft.Syntax, resultLeft.Type).MakeCompilerGenerated();
1549resultLeft.Syntax,
1621CreateConversion(left.Syntax, new BoundValuePlaceholder(left.Syntax, left.Type).MakeCompilerGenerated(), implicitConversion, isCast: false, conversionGroupOpt: null, InConversionGroupFlags.Unspecified, booleanType, diagnostics);
1628diagnostics.Add(left.Syntax, useSiteInfo);
1634diagnostics.Add(left.Syntax, useSiteInfo);
1651var operandPlaceholder = new BoundValuePlaceholder(left.Syntax, namedType).MakeCompilerGenerated();
1652UnaryOperatorAnalysisResult result = operatorOverloadResolution(left.Syntax, operandPlaceholder, isNegative ? UnaryOperatorKind.False : UnaryOperatorKind.True, diagnostics);
1660CreateConversion(left.Syntax, operandPlaceholder, result.Conversion, isCast: false, conversionGroupOpt: null, InConversionGroupFlags.Unspecified, parameterType, diagnostics);
2829Error(diagnostics, ErrorCode.ERR_ConstantStringTooLong, right.Syntax);
3410var operandPlaceholder = new BoundValuePlaceholder(operand.Syntax, operandType).MakeCompilerGenerated();
3596operandPlaceholder = new BoundValuePlaceholder(operand.Syntax, operandType).MakeCompilerGenerated();
4047Error(diagnostics, ErrorCode.ERR_IllegalSuppression, expr.Syntax);
4053Error(diagnostics, ErrorCode.ERR_DuplicateNullSuppression, expr.Syntax);
4198bool receiverIsLValue = CheckValueKind(receiver.Syntax, receiver, BindValueKind.AddressOf, checkingReceiver: false, diagnostics: BindingDiagnosticBag.Discarded);
4317Error(diagnostics, ErrorCode.ERR_IllegalSuppression, expr.Syntax);
4392var resultOperand = CreateConversion(operand.Syntax, operand, best.Conversion, isCast: false, conversionGroupOpt: null, InConversionGroupFlags.Unspecified, signature.OperandType, diagnostics);
4688if (node.Operand != operand.Syntax || operand.Syntax.Kind() != SyntaxKind.NumericLiteralExpression)
4693var literal = (LiteralExpressionSyntax)operand.Syntax;
5387operandPlaceholder = new BoundValuePlaceholder(operand.Syntax, operand.Type).MakeCompilerGenerated();
5397operand = new BoundDefaultExpression(operand.Syntax, targetType: null, constantValueOpt: ConstantValue.Null,
5434operandPlaceholder = new BoundValuePlaceholder(operand.Syntax, operand.Type).MakeCompilerGenerated();
5652var leftPlaceholder = new BoundValuePlaceholder(leftOperand.Syntax, optLeftType).MakeCompilerGenerated();
5674var leftPlaceholder = new BoundValuePlaceholder(leftOperand.Syntax, optLeftType0).MakeCompilerGenerated();
5693var leftPlaceholder = new BoundValuePlaceholder(leftOperand.Syntax, optLeftType).MakeCompilerGenerated();
5743var leftPlaceholder = new BoundValuePlaceholder(leftOperand.Syntax, optLeftType0).MakeCompilerGenerated();
5757var leftPlaceholder = new BoundValuePlaceholder(leftOperand.Syntax, optLeftType).MakeCompilerGenerated();
5953diagnostics.Add(ErrorCode.ERR_RefConditionalDifferentTypes, falseExpr.Syntax.Location, trueType);
5987CheckValEscape(falseExpr.Syntax, falseExpr, whenTrueEscape, checkingReceiver: false, diagnostics: diagnostics);
5989CheckValEscape(trueExpr.Syntax, trueExpr, whenFalseEscape, checkingReceiver: false, diagnostics: diagnostics);
Binder\Binder_Patterns.cs (7)
35expression = BadExpression(expression.Syntax, expression);
60this.Compilation, pattern.Syntax, expression, innerPattern, whenTrueLabel: whenTrueLabel, whenFalseLabel: whenFalseLabel, diagnostics);
133DecisionDagBuilder.CheckRedundantPatternsForIsPattern(this.Compilation, pattern.Syntax, expression, pattern, diagnostics);
625diagnostics.Add(ErrorCode.ERR_ValueCantBeNull, expression.Syntax.Location, inputType);
635diagnostics.Add(ErrorCode.ERR_PatternWrongType, expression.Syntax.Location, inputType, expression.Display);
647expression.Syntax.Location, inputType, expression.Display, new CSharpRequiredLanguageVersion(requiredVersion));
685diagnostics.Add(ErrorCode.ERR_PatternSpanCharCannotBeStringNull, convertedExpression.Syntax.Location, inputType);
Binder\Binder_Query.cs (8)
741yExpression = new BoundBadExpression(yExpression.Syntax, LookupResultKind.Empty, ImmutableArray<Symbol?>.Empty, ImmutableArray.Create(yExpression), CreateErrorType());
747yExpression = new BoundBadExpression(yExpression.Syntax, LookupResultKind.Empty, ImmutableArray<Symbol?>.Empty, ImmutableArray.Create(yExpression), yExpression.Type);
808field2Value = new BoundBadExpression(field2Value.Syntax, LookupResultKind.Empty, ImmutableArray<Symbol?>.Empty, ImmutableArray.Create(field2Value), field2Value.Type, true);
823new AnonymousTypeField(fieldName, fieldValue.Syntax.Location, TypeWithAnnotations.Create(TypeOrError(fieldValue)), RefKind.None, ScopedKind.None);
956diagnostics.Add(ErrorCode.ERR_BadSKunknown, ultimateReceiver.Syntax.Location, ((BoundNamespaceExpression)ultimateReceiver).NamespaceSymbol, MessageID.IDS_SK_NAMESPACE.Localize());
964receiver = new BoundBadExpression(receiver.Syntax, LookupResultKind.NotAValue, ImmutableArray<Symbol?>.Empty, ImmutableArray.Create(receiver), CreateErrorType());
971Error(diagnostics, ErrorCode.ERR_BadSKunknown, ultimateReceiver.Syntax, ultimateReceiver.Type, MessageID.IDS_SK_TYVAR.Localize());
986receiver = new BoundBadExpression(receiver.Syntax, LookupResultKind.NotAValue, ImmutableArray<Symbol?>.Empty, ImmutableArray.Create(receiver), CreateErrorType());
Binder\Binder_Statements.cs (30)
156Debug.Assert(result.Syntax is StatementSyntax, "BoundStatement should be associated with a statement syntax.");
158Debug.Assert(System.Linq.Enumerable.Contains(result.Syntax.AncestorsAndSelf(), node), @"Bound statement (or one of its parents)
684Error(diagnostics, ErrorCode.WRN_UnobservedAwaitableExpression, expression.Syntax);
1238SyntaxNode initializerSyntax = initializerOpt.Syntax;
1305CheckFeatureAvailability(initializerOpt.Syntax, MessageID.IDS_FeatureExtensibleFixedStatement, diagnostics);
1334var result = PerformPatternMethodLookup(initializer, methodName, initializer.Syntax, additionalDiagnostics, out var patternMethodSymbol, out bool isExpanded);
1347additionalDiagnostics.Add(ErrorCode.WRN_PatternBadSignature, initializer.Syntax.Location, initializer.Type, "fixed", patternMethodSymbol);
1368SyntaxNode initializerSyntax = initializer.Syntax;
1473diagnostics.Add(ErrorCode.ERR_VoidAssignment, op1.Syntax.Location);
1582Error(diagnostics, errorCode, node, getName(op1), op2.Syntax);
1604Error(diagnostics, errorCode, node, getName(op1), op2.Syntax);
1719var syntax = expr.Syntax;
1768SyntaxNode syntax = expr.Syntax;
1989diagnostics.Add(expression.Syntax, useSiteInfo);
1995Error(diagnostics, ErrorCode.ERR_RefAssignmentMustHaveIdentityConversion, expression.Syntax, targetType);
2018expression.Syntax,
2024GenerateImplicitConversionError(diagnostics, expression.Syntax, conversion, expression, targetType);
2032return CreateConversion(expression.Syntax, expression, conversion, isCast: false, conversionGroupOpt: null, InConversionGroupFlags.Unspecified, targetType, diagnostics);
2454Error(diagnostics, ErrorCode.ERR_InvalidAddrOp, ((BoundAddressOfOperator)operand).Operand.Syntax);
2473GenerateImplicitConversionError(diagnostics, expr.Syntax, conversion, expr, targetType);
2573GenerateImplicitConversionError(diagnostics, argument.Syntax, elementConversion, argument, targetElementType);
2719diagnostics.Add(expr.Syntax, useSiteInfo);
2734Error(diagnostics, ErrorCode.WRN_IncorrectBooleanAssg, assignment.Syntax);
2740syntax: expr.Syntax,
3215Error(diagnostics, ErrorCode.ERR_RefReturnMustHaveIdentityConversion, argument.Syntax, returnType);
3232Error(diagnostics, ErrorCode.ERR_BadAsyncReturnExpression, argument.Syntax, returnType, argument.Type);
3236GenerateImplicitConversionError(diagnostics, argument.Syntax, conversion, argument, returnType);
3239ReportCantConvertLambdaReturn(argument.Syntax, diagnostics);
3246return CreateConversion(argument.Syntax, argument, conversion, isCast: false, conversionGroupOpt: null, InConversionGroupFlags.Unspecified, returnType, diagnostics);
3501var syntax = expressionSyntax ?? expression.Syntax;
Binder\Binder_Symbols.cs (4)
1502diagnostics.Add(receiver.Syntax, useSiteInfo);
1509Error(diagnostics, ErrorCode.ERR_AmbiguousPrimaryConstructorParameterAsColorColorReceiver, receiver.Syntax, parameter.Name, parameter.Type, parameter);
1519receiver = new BoundBadExpression(receiver.Syntax, LookupResultKind.Ambiguous, ImmutableArray<Symbol>.Empty, ImmutableArray.Create(receiver), receiver.Type, hasErrors: true).MakeCompilerGenerated();
1529receiver = new BoundBadExpression(receiver.Syntax, LookupResultKind.Empty, ImmutableArray<Symbol>.Empty, childBoundNodes: [AdjustBadExpressionChild(receiver)], receiver.Type, hasErrors: true).MakeCompilerGenerated();
Binder\Binder_TupleOperators.cs (5)
65tuple.Syntax, tuple, wasTargetTyped: false, builder.ToImmutableAndFree(), tuple.ArgumentNamesOpt, tuple.InferredNamesOpt, tuple.Type, tuple.HasErrors);
325Location location = ((BoundTupleExpression)(useRight ? right : left)).Arguments[i].Syntax.Parent.Location;
340return new BoundDefaultExpression(expr.Syntax, targetType);
392.SelectAsArray((t, s) => (BoundExpression)new BoundTupleOperandPlaceholder(s, t.Type), expr.Syntax);
414ImmutableArray<Location> elementLocations = elements.SelectAsArray(e => e.Syntax.Location);
Binder\DecisionDagBuilder.cs (33)
136builder.Add(MakeTestsForPattern(index: 1, pattern.Syntax, rootIdentifier, pattern, whenClause: null, whenTrueLabel));
153if (label.Syntax.Kind() != SyntaxKind.DefaultSwitchLabel)
155builder.Add(MakeTestsForPattern(++i, label.Syntax, rootIdentifier, label.Pattern, label.WhenClause, label.Label));
175builder.Add(MakeTestsForPattern(++i, arm.Syntax, rootIdentifier, arm.Pattern, arm.WhenClause, arm.Label));
370var syntax = pattern.Syntax;
447input = MakeConvertToType(input, declaration.Syntax, type!, isExplicitTest: false, tests);
471output = MakeConvertToType(input: input, syntax: typePattern.Syntax, type: type, isExplicitTest: typePattern.IsExplicitNotNullTest, tests: tests);
535return new Tests.One(new BoundDagExplicitNullTest(constant.Syntax, input));
540return new Tests.One(new BoundDagValueTest(constant.Syntax, constant.ConstantValue, input));
546output = input = constant.Value.Type is { } type ? MakeConvertToType(input, constant.Syntax, type, isExplicitTest: false, tests) : input;
555tests.Add(new Tests.One(new BoundDagValueTest(constant.Syntax, constant.ConstantValue, input)));
570output = input = MakeConvertToType(input, recursive.Syntax, inputType, isExplicitTest: recursive.IsExplicitNotNullTest, tests);
578var evaluation = new BoundDagDeconstructEvaluation(recursive.Syntax, method, OriginalInput(input, method));
606SyntaxNode syntax = pattern.Syntax;
619tests.Add(new Tests.One(new BoundDagTypeTest(recursive.Syntax, ErrorType(), input, hasErrors: true)));
633tests.Add(new Tests.One(new BoundDagTypeTest(recursive.Syntax, ErrorType(), input, hasErrors: true)));
659input = MakeConvertToType(input, member.Syntax, member.Receiver.Type.StrippedType(), isExplicitTest: false, tests);
667var eval = new BoundDagPropertyEvaluation(member.Syntax, property, isLengthOrCount, OriginalInput(input, property));
674var eval = new BoundDagFieldEvaluation(member.Syntax, field, OriginalInput(input, field));
740var evaluation = new BoundDagTypeEvaluation(bin.Syntax, bin.NarrowedType, input);
766output = MakeConvertToType(input, rel.Syntax, type, isExplicitTest: false, tests);
775tests.Add(new Tests.One(new BoundDagRelationalTest(rel.Syntax, rel.Relation, rel.ConstantValue, output, rel.HasErrors)));
811var boundDecisionDag = new BoundDecisionDag(rootDecisionDagNode.Syntax, rootDecisionDagNode, _suitableForLowering);
1000state.SelectedTest = new BoundDagNonNullTest(t.Syntax, isExplicitTest: true, t.Input, t.HasErrors);
1259state.Dag = uniqifyDagNode(new BoundEvaluationDecisionDagNode(e.Syntax, e, next));
1268state.Dag = uniqifyDagNode(new BoundTestDecisionDagNode(d.Syntax, d, whenTrue, whenFalse));
1994builder.Append($" WHEN[{cd.WhenClause.Syntax}]");
2443assignments.Add(new Tests.One(new BoundDagAssignmentEvaluation(useValueFrom.Syntax, b.TempContainingValue, useValueFrom)));
2539SyntaxNode syntax = test.Syntax;
2575if (e.Syntax.IsKind(SyntaxKind.ListPattern))
2598new One(new BoundDagValueTest(t.Syntax, safeAdd(t.Value, offset), lengthTemp));
2602new One(new BoundDagRelationalTest(t.Syntax, t.OperatorKind, safeAdd(t.Value, offset), lengthTemp));
2873condition = new Tests.One(new BoundDagValueTest(s2.Syntax, ConstantValue.Create(lengthValue), s1LengthTemp));
Binder\DecisionDagBuilder_CheckOrReachability.cs (35)
129existingCases.Add(builder.MakeTestsForPattern(++index, switchArm.Syntax, rootIdentifier, switchArm.Pattern, whenClause: switchArm.WhenClause, label: switchArm.Label));
176if (label.Syntax.Kind() != SyntaxKind.DefaultSwitchLabel)
183existingCases.Add(builder.MakeTestsForPattern(++index, label.Syntax, rootIdentifier, label.Pattern, label.WhenClause, label.Label));
193if (label.Syntax.Kind() != SyntaxKind.DefaultSwitchLabel)
362var negated = new BoundNegatedPattern(pattern.Syntax, negated: pattern, pattern.InputType, narrowedType: pattern.InputType);
379diagnostics.Add(ErrorCode.HDN_RedundantPatternStackGuard, pattern.Syntax);
398SyntaxNode? diagSyntax = pattern.Syntax;
480var wrappedPattern = new BoundBinaryPattern(newPattern.Syntax, disjunction: false, current.Left, newPattern, current.InputType, newPattern.NarrowedType);
860PushBinaryOperation(current.Syntax, endOfLeft, disjunction);
931var result = new BoundNegatedPattern(node.Syntax, node, node.InputType, narrowedType: node.InputType);
986new BoundTypeExpression(recursivePattern.Syntax, aliasOpt: null, recursivePattern.InputType.StrippedType()),
1027BoundPattern typePattern = new BoundTypePattern(pattern.Syntax,
1028new BoundTypeExpression(pattern.Syntax, aliasOpt: null, pattern.InputType),
1031var result = new BoundBinaryPattern(pattern.Syntax, disjunction: false, left: typePattern, right: pattern, inputType, pattern.NarrowedType);
1043var result = new BoundDeclarationPattern(node.Syntax, node.DeclaredType, node.IsVar, node.Variable, node.VariableAccess, node.InputType, node.NarrowedType)
1083initialCheck = new BoundTypePattern(node.Syntax, node.DeclaredType, node.IsExplicitNotNullTest, node.InputType, node.NarrowedType, node.HasErrors);
1088var nullCheck = new BoundConstantPattern(node.Syntax,
1089new BoundLiteral(node.Syntax, constantValueOpt: ConstantValue.Null, type: node.InputType, hasErrors: false),
1091initialCheck = new BoundNegatedPattern(node.Syntax, nullCheck, node.InputType, narrowedType: node.InputType);
1096initialCheck = new BoundRecursivePattern(node.Syntax, declaredType: null, deconstructMethod: null, deconstruction: default,
1106var discards = deconstruction.SelectAsArray(d => d.WithPattern(MakeDiscardPattern(d.Syntax, d.Pattern.InputType)));
1120newPattern.Syntax, declaredType: node.DeclaredType, deconstructMethod: node.DeconstructMethod,
1135VisitPatternAndCombine(node.Syntax, deconstruction[i].Pattern, startOfLeft);
1155newPattern.Syntax, declaredType: node.DeclaredType, deconstructMethod: null, deconstruction: default,
1171VisitPatternAndCombine(node.Syntax, property.Pattern, startOfLeft);
1219var discards = subpatterns.SelectAsArray(d => d.WithPattern(MakeDiscardPattern(d.Syntax, d.Pattern.InputType)));
1225var lengthTest = new BoundITuplePattern(ituplePattern.Syntax, ituplePattern.GetLengthMethod, ituplePattern.GetItemMethod, discards,
1242BoundPattern newITuple = new BoundITuplePattern(newPattern.Syntax, ituplePattern.GetLengthMethod,
1256VisitPatternAndCombine(ituplePattern.Syntax, subpatterns[i].Pattern, startOfLeft);
1306newPattern.Syntax, newSubpatterns, hasSlice, listPattern.LengthAccess, listPattern.IndexerAccess,
1331BoundPattern newSlice = new BoundSlicePattern(newPattern.Syntax, newPattern, slice.IndexerAccess,
1337newPattern.Syntax, newSubpatterns, hasSlice: true, listPattern.LengthAccess, listPattern.IndexerAccess,
1361VisitPatternAndCombine(listPattern.Syntax, slicePattern.Pattern, startOfLeft);
1367VisitPatternAndCombine(listPattern.Syntax, listPattern.Subpatterns[i], startOfLeft);
1388return MakeDiscardPattern(pattern.Syntax, pattern.InputType);
Binder\DecisionDagBuilder_ListPatterns.cs (5)
22var syntax = list.Syntax;
25output = input = MakeConvertToType(input, list.Syntax, list.NarrowedType, isExplicitTest: false, tests);
29tests.Add(new Tests.One(new BoundDagTypeTest(list.Syntax, ErrorType(), input, hasErrors: true)));
64var sliceEvaluation = new BoundDagSliceEvaluation(slicePattern.Syntax, slicePattern.InputType, lengthTemp, startIndex: startIndex, endIndex: index,
79var indexEvaluation = new BoundDagIndexerEvaluation(subpattern.Syntax, subpattern.InputType, lengthTemp, index++,
Binder\ForEachLoopBinder.cs (28)
244messageId.CheckFeatureAvailability(diagnostics, Compilation, collectionExpr.Syntax.Location);
248Error(diagnostics, ErrorCode.ERR_RefLvalueExpected, collectionExpr.Syntax);
254Error(diagnostics, ErrorCode.ERR_RefLvalueExpected, collectionExpr.Syntax);
364collectionExpr.Syntax,
371hasErrors |= !CheckValueKind(collectionExpr.Syntax, collectionExpr, requiredCurrentKind, checkingReceiver: false, diagnostics);
486Error(diagnostics, ErrorCode.ERR_RefAssignmentMustHaveIdentityConversion, collectionExpr.Syntax, iterationVariableType.Type);
649collectionExpr.Syntax,
665collectionExpr.Syntax,
708inferredType = TypeWithAnnotations.Create(GetSpecialType(SpecialType.System_Char, diagnostics, collectionExpr.Syntax));
726SyntaxNode exprSyntax = collectionExpr.Syntax;
841if (CheckValueKind(collectionExpr.Syntax, collectionExpr, BindValueKind.RefersToLocation | BindValueKind.Assignable, checkingReceiver: false, BindingDiagnosticBag.Discarded))
849if (!CheckValueKind(collectionExpr.Syntax, collectionExpr, BindValueKind.RefersToLocation, checkingReceiver: false, BindingDiagnosticBag.Discarded))
855NamedTypeSymbol spanType = GetWellKnownType(wellKnownSpan, diagnostics, collectionExpr.Syntax);
867diagnostics.Add(ErrorCode.ERR_InlineArrayForEachNotSupported, collectionExpr.Syntax.GetLocation(), collectionExpr.Type);
873BoundExpression span = new BoundValuePlaceholder(collectionExpr.Syntax, spanType).MakeCompilerGenerated();
895CheckFeatureAvailability(collectionExpr.Syntax, MessageID.IDS_FeatureInlineArrays, diagnostics);
901_ = GetWellKnownTypeMember(WellKnownMember.System_Runtime_CompilerServices_Unsafe__AsRef_T, diagnostics, syntax: collectionExpr.Syntax);
904_ = GetWellKnownTypeMember(WellKnownMember.System_Runtime_CompilerServices_Unsafe__Add_T, diagnostics, syntax: collectionExpr.Syntax);
905_ = GetWellKnownTypeMember(WellKnownMember.System_Runtime_CompilerServices_Unsafe__As_T, diagnostics, syntax: collectionExpr.Syntax);
907CheckInlineArrayTypeIsSupported(collectionExpr.Syntax, collectionExpr.Type, elementField.Type, diagnostics);
915diagnostics.Add(ErrorCode.ERR_InlineArrayForEachNotSupported, collectionExpr.Syntax.GetLocation(), collectionExpr.Type);
945diagnostics.Add(ErrorCode.ERR_NullNotValid, collectionExpr.Syntax.Location);
1134collectionExpr.Syntax,
1239CheckFeatureAvailability(expr.Syntax, MessageID.IDS_FeatureDisposalPattern, diagnostics);
1258Error(diagnostics, ErrorCode.ERR_BadAllowByRefLikeEnumerator, expr.Syntax, enumeratorType);
1560collectionExpr.Syntax,
1574collectionExpr.Syntax,
1586collectionExpr.Syntax,
Binder\RefSafetyAnalysis.cs (12)
346RoslynDebug.Assert(added, $"Expression {expr} `{expr.Syntax}` visited more than once.");
359RoslynDebug.Assert(_visited.Contains(expr), $"Expected {expr} `{expr.Syntax}` to be visited.");
604ValidateAssignment(node.Syntax, node.Left, node.Right, node.IsRef, _diagnostics);
618node.Syntax,
629ValidateAssignment(node.Syntax, node.Left, node, isRef: false, _diagnostics);
737ValidateRefConditionalOperator(node.Syntax, node.Consequence, node.Alternative, _diagnostics);
862node.Syntax,
980node.Syntax,
1024Error(_diagnostics, ErrorCode.ERR_CallArgMixing, argument.Syntax, node.Constructor, parameter.Name);
1050node.Syntax,
1067node.Syntax,
1116VisitDeconstructionArguments(variables, right.Syntax, right.Conversion, right.Operand);
Binder\Semantics\Conversions\Conversions.cs (10)
164var syntax = node.Syntax;
194node.WithElement, node.WithElement?.Syntax ?? syntax, targetType, out constructor, out isExpanded, BindingDiagnosticBag.Discarded))
242new BoundValuePlaceholder(element.Syntax, enumeratorInfo.ElementType),
258GetDelegateOrFunctionPointerArguments(source.Syntax, analyzedArguments, delegateInvokeMethodOpt.Parameters, binder.Compilation);
306diagnostics.Add(expr.Syntax, useSiteInfo);
356expr.Syntax.Location,
367expr.Syntax.Location,
379binder: binder, location: expr.Syntax.Location, nodeOpt: expr.Syntax, diagnostics: overloadDiagnostics,
381receiver: resolution.MethodGroup.Receiver, invokedExpression: expr.Syntax, arguments: resolution.AnalyzedArguments,
BoundTree\BoundDagEvaluation.cs (7)
135return new BoundDagTemp(Syntax, Type, this);
154return new BoundDagTemp(Syntax, Field.Type, this);
168return new BoundDagTemp(Syntax, Property.Type, this);
191return new BoundDagTemp(Syntax, Property.Type, this);
222return new BoundDagTemp(Syntax, IndexerType, this);
259return new BoundDagTemp(Syntax, SliceType, this);
320builder.Add(new BoundDagTemp(Syntax, parameter.Type, this, i));
BoundTree\UnboundLambda.cs (17)
33SyntaxNode IBoundLambdaOrFunction.Syntax { get { return Syntax; } }
75public MessageID MessageID { get { return Syntax.Kind() == SyntaxKind.AnonymousMethodExpression ? MessageID.IDS_AnonMethod : MessageID.IDS_Lambda; } }
83SyntaxNode IBoundLambdaOrFunction.Syntax { get { return Syntax; } }
447var lambda = new UnboundLambda(Syntax, data, FunctionType, WithDependencies, nullableState, getterNullResilienceData, HasErrors);
460var lambda = new UnboundLambda(Syntax, data, FunctionType, WithDependencies, _nullableState, _getterNullResilienceData, HasErrors);
613Binder.RecordLambdaBinding(UnboundLambda.Syntax);
632this.Binder.GenerateAnonymousFunctionConversionError(diagnostics, _unboundLambda.Syntax, _unboundLambda, targetType);
759var lambdaBodyBinder = new ExecutableCodeBinder(_unboundLambda.Syntax, lambdaSymbol, GetWithParametersBinder(lambdaSymbol, Binder));
807_unboundLambda.Syntax,
855lambdaBodyBinder = new ExecutableCodeBinder(_unboundLambda.Syntax, lambdaSymbol, GetWithParametersBinder(lambdaSymbol, Binder), inExpressionTree ? BinderFlags.InExpressionTree : BinderFlags.None);
918var result = new BoundLambda(_unboundLambda.Syntax, _unboundLambda, block, diagnostics.ToReadOnlyAndFree(), lambdaBodyBinder, delegateType, inferredReturnType: default)
1022_unboundLambda.Syntax,
1057var lambdaBodyBinder = new ExecutableCodeBinder(_unboundLambda.Syntax, lambdaSymbol, GetWithParametersBinder(lambdaSymbol, Binder));
1280_unboundLambda.Syntax,
1553public override MessageID MessageID { get { return this.UnboundLambda.Syntax.Kind() == SyntaxKind.AnonymousMethodExpression ? MessageID.IDS_AnonMethod : MessageID.IDS_Lambda; } }
1559return UnboundLambda.Syntax.AnonymousFunctionBody();
1566var syntax = UnboundLambda.Syntax;
CodeGen\EmitAddress.cs (12)
136var temp = this.AllocateTemp(type, expression.Syntax);
140EmitSymbolToken(type, expression.Syntax);
244EmitInitObj(receiverType, true, expression.Syntax);
245EmitBox(receiverType, expression.Syntax);
318EmitSymbolToken(refValue.Type, refValue.Syntax);
331var value = this.AllocateTemp(expression.Type, expression.Syntax);
407EmitSymbolToken(elementType, arrayAccess.Syntax);
412arrayAccess.Syntax);
447EmitStaticFieldAddress(field, fieldAccess.Syntax);
524EmitBox(receiver.Type, receiver.Syntax);
559EmitSymbolToken(field, fieldAccess.Syntax);
582EmitSymbolToken(fixedElementField, fieldAccess.Syntax);
CodeGen\EmitArrayInitializer.cs (25)
58_builder.EmitArrayBlockInitializer(data, inits.Syntax);
93EmitVectorElementStore(arrayType, init.Syntax);
208EmitArrayElementStore(arrayType, init.Syntax);
462var rosPointerCtor = (MethodSymbol?)Binder.GetWellKnownTypeMember(_module.Compilation, WellKnownMember.System_ReadOnlySpan_T__ctor_Pointer, _diagnostics, syntax: wrappedExpression.Syntax, isOptional: true);
555var field = _builder.module.GetFieldForData(data, alignment: 1, wrappedExpression.Syntax, _diagnostics.DiagnosticBag);
557_builder.EmitToken(field, wrappedExpression.Syntax);
573EmitSymbolToken(rosPointerCtor.AsMember(spanType), wrappedExpression.Syntax, optArgList: null);
608MethodSymbol? createSpan = (MethodSymbol?)Binder.GetWellKnownTypeMember(_module.Compilation, WellKnownMember.System_Runtime_CompilerServices_RuntimeHelpers__CreateSpanRuntimeFieldHandle, _diagnostics, syntax: wrappedExpression.Syntax, isOptional: true);
616var field = _builder.module.GetFieldForData(data, alignment: (ushort)specialElementType.SizeInBytes(), wrappedExpression.Syntax, _diagnostics.DiagnosticBag);
618_builder.EmitToken(field, wrappedExpression.Syntax);
620EmitSymbolToken(createSpan.Construct(elementType), wrappedExpression.Syntax, optArgList: null);
632if (!tryGetReadOnlySpanArrayCtor(wrappedExpression.Syntax, out var rosArrayCtor))
649var cachingField = _builder.module.GetArrayCachingFieldForData(data, _module.Translate(arrayType), wrappedExpression.Syntax, _diagnostics.DiagnosticBag);
655_builder.EmitToken(cachingField, wrappedExpression.Syntax);
665EmitSymbolToken(arrayType.ElementType, wrappedExpression.Syntax);
666_builder.EmitArrayBlockInitializer(data, wrappedExpression.Syntax);
669_builder.EmitToken(cachingField, wrappedExpression.Syntax);
675EmitSymbolToken(rosArrayCtor.AsMember(spanType), wrappedExpression.Syntax, optArgList: null);
696if (!tryGetReadOnlySpanArrayCtor(arrayCreation.Syntax, out var rosArrayCtor))
708arrayCreation.Syntax, _diagnostics.DiagnosticBag);
715_builder.EmitToken(cachingField, arrayCreation.Syntax);
725_builder.EmitToken(cachingField, arrayCreation.Syntax);
743EmitSymbolToken(rosArrayCtor.AsMember(spanType), arrayCreation.Syntax, optArgList: null);
761EmitSymbolToken(spanType, wrappedExpression.Syntax);
771EmitDefaultValue(spanType, used, wrappedExpression.Syntax);
CodeGen\EmitConversion.cs (12)
86EmitSymbolToken(expression.ConversionMethod, expression.Syntax, optArgList: null);
262EmitBox(conversion.Operand.Type, conversion.Operand.Syntax);
273EmitSymbolToken(conversion.Type, conversion.Syntax);
281EmitStaticCast(conversion.Type, conversion.Syntax);
294EmitBox(conversion.Operand.Type, conversion.Operand.Syntax);
305EmitSymbolToken(conversion.Type, conversion.Syntax);
310EmitSymbolToken(conversion.Type, conversion.Syntax);
367EmitSymbolToken(receiver.Type, receiver.Syntax);
375EmitBox(receiver.Type, receiver.Syntax);
398EmitSymbolToken(method, node.Syntax, null);
403var ctor = DelegateConstructor(node.Syntax, delegateType);
404if ((object)ctor != null) EmitSymbolToken(ctor, node.Syntax, null);
CodeGen\EmitExpression.cs (109)
56EmitConstantExpression(expression.Type, constantValue, used, expression.Syntax);
183EmitLoadIndirect(thisType, expression.Syntax);
184EmitBox(thisType, expression.Syntax);
247EmitThrowIfModuleCancellationRequested(expression.Syntax);
252EmitModuleCancellationTokenLoad(expression.Syntax);
374EmitDefaultValue(node.Type, used, node.Syntax);
387EmitInitObj(receiverType, true, expression.Syntax);
388EmitBox(receiverType, expression.Syntax);
471EmitDefaultValue(receiverType, true, receiver.Syntax);
472EmitBox(receiverType, receiver.Syntax);
474EmitLoadIndirect(receiverType, receiver.Syntax);
476cloneTemp = AllocateTemp(receiverType, receiver.Syntax);
480EmitBox(receiverType, receiver.Syntax);
491EmitLoadIndirect(receiverType, receiver.Syntax);
492EmitBox(receiverType, receiver.Syntax);
524EmitSymbolToken(hasValueOpt, expression.Syntax, null);
545EmitDefaultValue(expression.Type, used, expression.Syntax);
658EmitLoadIndirect(expression.Type, expression.Syntax);
667EmitLoadIndirect(expression.Type, expression.Syntax);
680EmitSymbolToken(expression.Operand.Type, expression.Operand.Syntax);
695EmitSymbolToken(getTypeMethod, expression.Syntax, null);
782EmitLoadIndirect(expression.Type, expression.Syntax);
803EmitLoadIndirect(expression.Type, expression.Syntax);
825EmitLoadIndirect(thisType, thisRef.Syntax);
845var syntax = node.Syntax;
891DefineLocal(local, sequence.Syntax);
925var seqLocal = DefineLocal(local, sequence.Syntax);
1105EmitSymbolToken(elementType, arrayAccess.Syntax);
1112_builder.EmitArrayElementLoad(_module.Translate((ArrayTypeSymbol)arrayAccess.Expression.Type), arrayAccess.Expression.Syntax);
1157EmitLoadIndirect(field.Type, fieldAccess.Syntax);
1176EmitSymbolToken(field, fieldAccess.Syntax);
1203EmitSymbolToken(field, fieldAccess.Syntax);
1249EmitSymbolToken(receiver.Type, receiver.Syntax);
1263EmitSymbolToken(field, fieldAccess.Syntax);
1425EmitLoadIndirect(local.LocalSymbol.Type, local.Syntax);
1438EmitLoadIndirect(parameterType, parameter.Syntax);
1661EmitSymbolToken(method.ContainingType, call.Syntax);
1691EmitSymbolToken(receiver.Type, receiver.Syntax);
1696EmitSymbolToken(method, call.Syntax,
1699EmitCallCleanup(call.Syntax, useKind, method);
1797EmitBox(parentCallReceiverType, nested.Syntax);
1816tempOpt = this.AllocateTemp(parentCallReceiverType, nested.Syntax);
1953EmitBox(receiverType, receiver.Syntax);
2035EmitSymbolToken(receiver.Type, receiver.Syntax);
2040EmitSymbolToken(actualMethodTargetedByTheCall, call.Syntax,
2043EmitCallCleanup(call.Syntax, useKind, method);
2078EmitDefaultValue(receiverType, true, receiver.Syntax);
2079EmitBox(receiverType, receiver.Syntax);
2086EmitLoadIndirect(receiverType, receiver.Syntax);
2087tempOpt = AllocateTemp(receiverType, receiver.Syntax);
2408EmitSymbolToken(arrayType.ElementType, expression.Syntax);
2412_builder.EmitArrayCreation(_module.Translate(arrayType), expression.Syntax);
2453EmitInitObj(expression.Type, used, expression.Syntax);
2488EmitSymbolToken(constructor, expression.Syntax,
2710EmitSymbolToken(target.Type, target.Syntax);
2751EmitSymbolToken(constructor, objCreation.Syntax,
3090assignmentOperator.Left.Syntax,
3118EmitIndirectStore(local.LocalSymbol.Type, local.Syntax);
3137EmitArrayElementStore(arrayType, expression.Syntax);
3150EmitIndirectStore(expression.Type, expression.Syntax);
3155EmitIndirectStore(expression.Type, expression.Syntax);
3161EmitIndirectStore(expression.Type, expression.Syntax);
3173EmitIndirectStore(expression.Type, expression.Syntax);
3178EmitIndirectStore(expression.Type, expression.Syntax);
3195EmitIndirectStore(nested.Type, expression.Syntax);
3222EmitLoadIndirect(assignment.Type, assignment.Syntax);
3231EmitSymbolToken(thisRef.Type, thisRef.Syntax);
3325EmitIndirectStore(field.Type, fieldAccess.Syntax);
3330EmitSymbolToken(field, fieldAccess.Syntax);
3340EmitIndirectStore(parameter.ParameterSymbol.Type, parameter.Syntax);
3428EmitBox(operand.Type, operand.Syntax);
3431EmitSymbolToken(isOp.TargetType.Type, isOp.Syntax);
3457EmitBox(operandType, operand.Syntax);
3460EmitSymbolToken(targetType, asOp.Syntax);
3465EmitSymbolToken(targetType, asOp.Syntax);
3511EmitDefaultValue(expression.Type, used, expression.Syntax);
3551EmitSymbolToken(getTypeMethod, boundTypeOf.Syntax, null);
3558EmitSymbolToken(type, boundTypeOfOperator.SourceType.Syntax);
3566EmitSymbolToken(type, boundSizeOfOperator.SourceType.Syntax);
3584EmitSymbolToken(symbol, node.Syntax, null, encodeAsRawDefinitionToken: true);
3597EmitHoistedVariableId(node.HoistedField, node.Syntax);
3611EmitHoistedVariableId(node.HoistedField, node.Syntax);
3646_module.GetModuleVersionId(_module.Translate(node.Type, node.Syntax, _diagnostics.DiagnosticBag), node.Syntax, _diagnostics.DiagnosticBag),
3647node.Syntax);
3700_builder.EmitToken(_module.GetInstrumentationPayloadRoot(node.AnalysisKind, _module.Translate(node.Type, node.Syntax, _diagnostics.DiagnosticBag), node.Syntax, _diagnostics.DiagnosticBag), node.Syntax);
3713EmitSymbolToken(node.Method, node.Syntax, null);
3726EmitSymbolToken(node.Method.ContainingType, node.Syntax);
3730EmitSymbolToken(getMethod, node.Syntax, null);
3734EmitSymbolToken(node.Type, node.Syntax);
3741EmitSymbolToken(node.Field, node.Syntax);
3753EmitSymbolToken(node.Field.ContainingType, node.Syntax);
3757EmitSymbolToken(getField, node.Syntax, null);
3761EmitSymbolToken(node.Type, node.Syntax);
3828EmitStaticCast(expr.Type, expr.Syntax);
3833EmitStaticCast(expr.Type, expr.Syntax);
3852EmitStaticCast(expr.Type, expr.Syntax);
3857EmitStaticCast(expr.Type, expr.Syntax);
3889EmitStaticCast(expr.Type, expr.Syntax);
3894EmitStaticCast(expr.Type, expr.Syntax);
3902EmitBox(expr.Type, expr.LeftOperand.Syntax);
3919EmitStaticCast(expr.Type, expr.Syntax);
4063temp = AllocateTemp(ptrInvocation.InvokedExpression.Type, ptrInvocation.Syntax);
4085EmitSignatureToken(ptrInvocation.FunctionPointer, ptrInvocation.Syntax);
4086EmitCallCleanup(ptrInvocation.Syntax, useKind, method);
4157EmitSymbolToken(load.ConstrainedToTypeOpt, load.Syntax);
4161EmitSymbolToken(load.TargetMethod, load.Syntax, optArgList: null);
CodeGen\EmitStatement.cs (22)
182this.EmitBox(exprType, thrown.Syntax);
593EmitBox(operand.Type, operand.Syntax);
596EmitSymbolToken(isOp.TargetType.Type, isOp.TargetType.Syntax);
613EmitBox(conditionType, condition.Syntax);
686DefineLocal(local, block.Syntax);
711_diagnostics.Add(ErrorCode.ERR_ModuleEmitFailure, block.Syntax.Location, ((Cci.INamedEntity)_module).Name, "Exception handling is not allowed in exception filters");
763DefineLocal(local, !declaringReferences.IsEmpty ? (CSharpSyntaxNode)declaringReferences[0].GetSyntax() : block.Syntax);
868(boundReturnStatement.Syntax.IsKind(SyntaxKind.Block) || _method?.IsImplicitConstructor == true) &&
925_module.Translate(expressionOpt.Type, boundReturnStatement.Syntax, _diagnostics.DiagnosticBag);
940_diagnostics.Add(ErrorCode.ERR_ModuleEmitFailure, statement.Syntax.Location, ((Cci.INamedEntity)_module).Name, "Exception handling is not allowed in exception filters");
1071_module.Translate(catchBlock.ExceptionTypeOpt, catchBlock.Syntax, _diagnostics.DiagnosticBag) :
1072_module.GetSpecialType(SpecialType.System_Object, catchBlock.Syntax, _diagnostics.DiagnosticBag);
1086var syntax = catchBlock.Syntax as CatchClauseSyntax;
1119var exceptionType = _module.Translate(catchBlock.ExceptionTypeOpt, catchBlock.Syntax, _diagnostics.DiagnosticBag);
1122_builder.EmitToken(exceptionType, catchBlock.Syntax);
1140var localSyntax = !declaringReferences.IsEmpty ? (CSharpSyntaxNode)declaringReferences[0].GetSyntax() : catchBlock.Syntax;
1154EmitSymbolToken(exceptionSourceOpt.Type, exceptionSourceOpt.Syntax);
1192var temp = AllocateTemp(exceptionSource.Type, exceptionSource.Syntax);
1328temp = AllocateTemp(expression.Type, expression.Syntax);
1342this.EmitStringSwitchJumpTable(switchCaseLabels, fallThroughLabel, key, expression.Syntax, expression.Type);
1346this.EmitLengthBasedStringSwitchJumpTable(lengthBasedSwitchStringJumpTableOpt, fallThroughLabel, key, expression.Syntax, expression.Type);
1351_builder.EmitIntegerSwitchJumpTable(switchCaseLabels, fallThroughLabel, key, expression.Type.EnumUnderlyingTypeOrSelf().PrimitiveTypeCode, expression.Syntax);
Compilation\MemberSemanticModel.cs (14)
1497alreadyInTree = _guardedBoundNodeMap.ContainsKey(bound.Syntax);
1505Debug.Assert(syntax != _root || _guardedBoundNodeMap.ContainsKey(bound.Syntax));
1529alreadyInTree = _guardedBoundNodeMap.ContainsKey(bound.Syntax);
1541Debug.Assert(syntax != _root || _guardedBoundNodeMap.ContainsKey(bound.Syntax));
1850return GetEnclosingBinderInternalWithinRoot(AdjustStartingNodeAccordingToNewRoot(startingNode, unbound.Syntax),
1851position, unbound.BindForErrorRecovery().Binder, unbound.Syntax);
1854return GetEnclosingBinderInternalWithinRoot(AdjustStartingNodeAccordingToNewRoot(startingNode, lambda.Body.Syntax),
1855position, lambda.Binder, lambda.Body.Syntax);
1863return GetEnclosingBinderInternalWithinRoot(AdjustStartingNodeAccordingToNewRoot(startingNode, queryClause.Syntax),
1864position, queryClause.Binder, queryClause.Syntax);
1879var span = expr.Syntax.FullSpan;
1898if (value.Syntax.FullSpan.Contains(position))
1903if (expr.Syntax.FullSpan.Contains(position))
1992_guardedBoundNodeMap.ContainsKey(bind(bindableRoot, out _).Syntax));
Compiler\MethodCompiler.cs (9)
1019body = BoundBlock.SynthesizedNoLocals(initializerStatements.Syntax, initializerStatements.Statements);
1052new BoundBlock(analyzedInitializers.Syntax, ImmutableArray<LocalSymbol>.Empty, analyzedInitializers.Statements), // The block is necessary to establish the right local scope for the analysis
1175var syntax = body.Syntax;
1624return new BoundBadStatement(body.Syntax, ImmutableArray.Create<BoundNode>(body), hasErrors: true);
2010body = new BoundBlock(constructor.Syntax, constructor.Locals, ImmutableArray.Create<BoundStatement>(constructor.Initializer));
2014body = new BoundBlock(constructor.Syntax, constructor.Locals, ImmutableArray.Create<BoundStatement>(constructor.Initializer, body));
2363if (!LambdaUtilities.TryGetLambdaBodies(node.Syntax, out var body1, out var body2))
2498var constructorInitializer = new BoundExpressionStatement(initializerInvocation.Syntax, initializerInvocation) { WasCompilerGenerated = method.IsImplicitlyDeclared };
2513compilationState.ReportCtorInitializerCycles(method, ctorCall.Method, ctorCall.Syntax, diagnostics);
FlowAnalysis\DefiniteAssignment.cs (22)
394LeaveParameters(methodParameters, returnBranch.Branch.Syntax, null);
395if ((object)methodThisParameter != null) LeaveParameter(methodThisParameter, returnBranch.Branch.Syntax, null);
396if ((object)extensionParameter != null) LeaveParameter(extensionParameter, returnBranch.Branch.Syntax, null);
1472CheckAssigned(fieldAccess, node.Syntax);
1576LeaveParameter(param, node.Syntax, paramExpr.Syntax.Location);
2324CheckAssigned(localSymbol, node.Syntax);
2331Diagnostics.Add(ErrorCode.ERR_FixedLocalInLambda, new SourceLocation(node.Syntax), localSymbol);
2399LeaveParameters(node.Symbol.Parameters, node.Syntax, null);
2408LeaveParameters(node.Symbol.Parameters, pending.Branch.Syntax, null);
2427CheckAssigned(MethodThisParameter, node.Syntax);
2435CheckAssigned(node.ParameterSymbol, node.Syntax);
2506if (_unassignedVariableAddressOfSyntaxes?.Contains(node.Syntax as PrefixUnaryExpressionSyntax) == false)
2513_unsafeAddressTakenVariables.Add(variable, node.Syntax.Location);
2530CheckAssigned(arg, arg.Syntax);
2631CheckAssigned(MethodThisParameter, node.Syntax);
2660if (node.FieldSymbol.IsFixedSizeBuffer && node.Syntax != null && !SyntaxFacts.IsFixedStatementExpression(node.Syntax))
2668_unsafeAddressTakenVariables.Add(receiver, node.Syntax.Location);
2675CheckAssigned(node, node.FieldSymbol, node.Syntax);
2696ReportUnassignedIfNotCapturedInLocalFunction(backingField, node.Syntax, unassignedSlot);
2715CheckAssigned(node, associatedField, node.Syntax);
FlowAnalysis\NullableWalker.cs (83)
648enforceMemberNotNull(syntaxOpt: pendingReturn.Branch.Syntax, pendingReturn.State);
652EnforceParameterNotNullOnExit(returnStatement.Syntax, pendingReturn.State);
1088_ => syntaxOpt ?? (SyntaxNodeOrToken)methodMainNode.Syntax.GetLastToken()
1103enforceMemberNotNullWhen(returnStatement.Syntax, sense: value, pendingReturn.State);
1116enforceMemberNotNullWhenIfAffected(returnStatement.Syntax, sense: true, members: method.ContainingType.GetMembers(memberName), state: pendingReturn.StateWhenTrue, otherState: pendingReturn.StateWhenFalse);
1121enforceMemberNotNullWhenIfAffected(returnStatement.Syntax, sense: false, members: method.ContainingType.GetMembers(memberName), state: pendingReturn.StateWhenFalse, otherState: pendingReturn.StateWhenTrue);
1161Diagnostics.Add(ErrorCode.WRN_MemberNotNullWhen, syntaxOpt?.GetLocation() ?? methodMainNode.Syntax.GetLastToken().GetLocation(), member.Name, sense ? "true" : "false");
1268EnforceParameterNotNullWhenOnExit(returnStatement.Syntax, parameters, sense: value, stateWhen: pendingReturn.State);
1282ReportParameterIfBadConditionalState(returnStatement.Syntax, parameter, sense: true, stateWhen: pendingReturn.StateWhenTrue);
1283ReportParameterIfBadConditionalState(returnStatement.Syntax, parameter, sense: false, stateWhen: pendingReturn.StateWhenFalse);
1290EnforceParameterNotNullWhenOnExit(returnStatement.Syntax, parameters, sense: value, stateWhen: pendingReturn.State);
1329location = syntaxOpt?.GetLocation() ?? methodMainNode.Syntax.GetLastToken().GetLocation();
1415var location = syntaxOpt?.GetLocation() ?? methodMainNode.Syntax.GetLastToken().GetLocation();
1438ReportDiagnostic(ErrorCode.WRN_ShouldNotReturn, syntaxOpt?.GetLocation() ?? methodMainNode.Syntax.GetLastToken().GetLocation());
1492compilation.GetBinderFactory(node.SyntaxTree).GetBinder(node.Syntax);
1931var key = (object?)symbol ?? methodMainNode.Syntax;
1974RoslynDebug.Assert(AreCloseEnough(originalSymbol, updatedSymbol), $"Attempting to set {node.Syntax} from {originalSymbol.ToDisplayString()} to {updatedSymbol.ToDisplayString()}");
2441location ??= value.Syntax.GetLocation();
3040CheckDisallowedNullAssignment(resultType, parameterAnnotations, equalsValue.Value.Syntax);
3067EnforceDoesNotReturn(node.Syntax);
3097CheckDisallowedNullAssignment(returnState, ToInwardAnnotations(returnAnnotations), node.Syntax, boundValueOpt: expr);
3109EnforceDoesNotReturn(node.Syntax);
3126EnforceNotNullIfNotNull(node.Syntax, this.State, parameters, method.ReturnNotNullIfParameterNotNull, ResultType.State, outputParam: null);
3144ReportNullabilityMismatchInAssignment(expr.Syntax, lvalueResultType, destinationType);
3482enforceMemberNotNull(syntax: pendingReturn.Branch?.Syntax, pendingReturn.State);
3487EnforceParameterNotNullOnExit(returnStatement.Syntax, pendingReturn.State);
4177var foundIterationType = _binder.TryGetCollectionIterationType((ExpressionSyntax)node.Syntax, collectionType, out targetElementType);
4184_binder.TryGetCollectionIterationType(node.Syntax, collectionType, out targetElementType);
4503receiver: new BoundExpressionWithNullability(objectInitializer.Syntax, objectInitializer, NullableAnnotation.NotAnnotated, containingType));
4619[new BoundExpressionWithNullability(objectInitializer.Syntax, objectInitializer, nullableAnnotation: NullableAnnotation.NotAnnotated, containingType)],
4664ReportDiagnostic(ErrorCode.WRN_NullReferenceInitializer, initializer.Syntax, symbol);
5530MethodSymbol reinferredMethod = ReInferBinaryOperator(binary.Syntax, method, leftOperand, rightOperand, leftUnderlyingType, rightUnderlyingType);
5619[new BoundExpressionWithNullability(leftOperand.Syntax, leftOperand, leftUnderlyingType.ToTypeWithAnnotations(compilation).NullableAnnotation, leftUnderlyingType.Type),
5620new BoundExpressionWithNullability(rightOperand.Syntax, rightOperand, rightUnderlyingType.ToTypeWithAnnotations(compilation).NullableAnnotation, rightUnderlyingType.Type)],
5688if (CheckDisallowedNullAssignment(resultType, parameterAnnotations, expr.Syntax, operand))
6588ReportNullabilityMismatchInAssignment(node.Syntax, source, destination);
6649new BoundExpressionWithNullability(expr.Syntax, expr, type.NullableAnnotation, type.Type);
7371var syntax = node.Syntax;
7511var syntaxForConstraintCheck = node.Syntax switch
7515_ => node.Syntax
8080ReportNullabilityMismatchInArgument(argumentNoConversion.Syntax, argumentResultType, parameter, parameterType.Type, forOutput: false);
8100if (CheckDisallowedNullAssignment(stateAfterConversion, parameterAnnotations, argumentNoConversion.Syntax))
8122CheckDisallowedNullAssignment(resultType, parameterAnnotations, argumentNoConversion.Syntax);
8222var parameterValue = new BoundParameter(argument.Syntax, parameter);
8262var parameterValue = new BoundParameter(argument.Syntax, parameter);
8265CheckDisallowedNullAssignment(parameterWithState, leftAnnotations, argument.Syntax);
8278ReportNullabilityMismatchInArgument(argument.Syntax, lValueType.Type, parameter, parameterType.Type, forOutput: true);
8744collection.Syntax, withElement: null, elements: elementsBuilder.ToImmutableAndFree())
8761return new BoundExpressionWithNullability(argument.Syntax, argument, NullableAnnotation.Oblivious, type: null);
8764return new BoundExpressionWithNullability(argument.Syntax, argument, argumentType.NullableAnnotation, argumentType.Type);
8888ReportNullabilityMismatchInAssignment(sourceExpression.Syntax, GetTypeAsDiagnosticArgument(sourceType), destinationType);
9244var locations = tupleOpt.TupleElements.SelectAsArray((element, location) => element.TryGetFirstLocation() ?? location, node.Syntax.Location);
9248tupleOpt.CheckConstraints(new ConstraintsHelper.CheckConstraintsArgs(compilation, _conversions, includeNullability: true, node.Syntax.Location, diagnostics: null),
9249typeSyntax: node.Syntax, locations, nullabilityDiagnosticsOpt: diagnostics);
9417diagnosticLocation: (conversionOpt ?? convertedNode).Syntax.GetLocation());
9490if (lambda.Syntax is LambdaExpressionSyntax lambdaSyntax)
9930diagnosticLocation ??= (conversionOpt ?? conversionOperand).Syntax.GetLocation();
10207Location operandLocation = conversionOperand.Syntax.GetLocation();
10220if (!isLiftedConversion && CheckDisallowedNullAssignment(operandType, parameterAnnotations, conversionOperand.Syntax))
10295conversionOpt.Syntax.SpanStart != convertedNode.Syntax.SpanStart)
10494ReportNullabilityMismatchWithTargetDelegate(group.Syntax.Location, delegateType, delegateInvokeMethod, method, node.IsExtensionMethod);
10566ReportNullabilityMismatchWithTargetDelegate(arg.Syntax.Location, delegateType, delegateInvokeMethod, argInvokeMethod, invokedAsExtensionMethod: false);
10624var syntax = group.Syntax;
10630if (method.GetMemberArityIncludingExtension() != 0 && HasImplicitTypeArguments(group.Syntax))
10806CheckDisallowedNullAssignment(rightState, leftAnnotations, right.Syntax);
11019placeholderArgs.Add(new BoundExpressionWithNullability(variables[i].Expression.Syntax, variables[i].Expression, NullableAnnotation.Oblivious, conversion.DeconstructionInfo.OutputPlaceholders[i].Type));
11029CheckMethodConstraints(invocation.Syntax, deconstructMethod);
11144CheckDisallowedNullAssignment(valueType, leftAnnotations, right.Syntax);
11245return fields.SelectAsArray((f, e) => (BoundExpression)new BoundFieldAccess(e.Syntax, e, f, constantValueOpt: null), expr);
11334incrementOperator = ReInferUnaryOperator(node.Syntax, incrementOperator, node.Operand, GetNullableUnderlyingTypeIfNecessary(isLifted, operandType));
11556CheckDisallowedNullAssignment(resultTypeWithState, leftArgumentAnnotations, node.Syntax);
11594argument.Syntax, argumentType, parameterType,
12048ReportDiagnostic(ErrorCode.WRN_NullReferenceReceiver, expr.Syntax.GetLocation());
12102var variableLocation = node.Syntax switch
12106_ => throw ExceptionUtilities.UnexpectedValue(node.Syntax)
12137var foreachSyntax = (ForEachStatementSyntax)node.Syntax;
12299method = ReInferUnaryOperator(node.Syntax, method, operand, operandType);
12353[new BoundExpressionWithNullability(operand.Syntax, operand, operandType.ToTypeWithAnnotations(compilation).NullableAnnotation, operandType.Type)],
12515MethodSymbol reInferredMethod = ReInferBinaryOperator(binary.Syntax, logicalOperator, leftOperand, rightOperand, leftUnderlyingType, rightUnderlyingType);
12531var updatedTrueFalseOperator = ReInferUnaryOperator(leftOperand.Syntax, trueFalseOperator, binary.Left, leftType);
12946if (!ReportPossibleNullReceiverIfNeeded(resultTypeSymbol, resultType.State, checkNullableValueType, receiverOpt.Syntax, out reportedDiagnostic))
13123ReportDiagnostic(ErrorCode.WRN_ThrowPossibleNull, expr.Syntax);
FlowAnalysis\NullableWalker_Patterns.cs (5)
300var labelStateMap = LearnFromDecisionDag(node.Syntax, node.ReachabilityDecisionDag, node.Expression, expressionState, stateWhenNotNullOpt: null);
831? ReInferAndVisitExtensionPropertyAccess(e, e.Property, new BoundExpressionWithNullability(e.Syntax, expression, NullableAnnotation.NotAnnotated, inputType)).Member
992var labelStateMap = LearnFromDecisionDag(node.Syntax, node.ReachabilityDecisionDag, node.Expression, expressionState, stateWhenNotNullOpt: null);
1007((SwitchExpressionSyntax)node.Syntax).SwitchKeyword.GetLocation(),
1160var labelStateMap = LearnFromDecisionDag(node.Syntax, node.ReachabilityDecisionDag, node.Expression, expressionState, hasStateWhenNotNull ? conditionalStateWhenNotNull : null);
Generated\BoundNodes.xml.Generated.cs (232)
312var result = new BoundFieldEqualsValue(this.Syntax, field, locals, value, this.HasErrors);
342var result = new BoundPropertyEqualsValue(this.Syntax, property, locals, value, this.HasErrors);
372var result = new BoundParameterEqualsValue(this.Syntax, parameter, locals, value, this.HasErrors);
400var result = new BoundGlobalStatementInitializer(this.Syntax, statement, this.HasErrors);
473var result = new BoundValuePlaceholder(this.Syntax, type, this.HasErrors);
501var result = new BoundCapturedReceiverPlaceholder(this.Syntax, receiver, type, this.HasErrors);
542var result = new BoundDeconstructValuePlaceholder(this.Syntax, variableSymbol, isDiscardExpression, type, this.HasErrors);
577var result = new BoundTupleOperandPlaceholder(this.Syntax, type, this.HasErrors);
606var result = new BoundAwaitableValuePlaceholder(this.Syntax, type, this.HasErrors);
641var result = new BoundDisposableValuePlaceholder(this.Syntax, type, this.HasErrors);
679var result = new BoundObjectOrCollectionValuePlaceholder(this.Syntax, isNewInstance, type, this.HasErrors);
714var result = new BoundImplicitIndexerValuePlaceholder(this.Syntax, type, this.HasErrors);
752var result = new BoundImplicitIndexerReceiverPlaceholder(this.Syntax, isEquivalentToThisReference, type, this.HasErrors);
787var result = new BoundListPatternReceiverPlaceholder(this.Syntax, type, this.HasErrors);
822var result = new BoundListPatternIndexPlaceholder(this.Syntax, type, this.HasErrors);
857var result = new BoundSlicePatternReceiverPlaceholder(this.Syntax, type, this.HasErrors);
892var result = new BoundSlicePatternRangePlaceholder(this.Syntax, type, this.HasErrors);
920var result = new BoundCollectionBuilderElementsPlaceholder(this.Syntax, type, this.HasErrors);
951var result = new BoundDup(this.Syntax, refKind, type, this.HasErrors);
979var result = new BoundPassByCopy(this.Syntax, expression, type, this.HasErrors);
1016var result = new BoundBadExpression(this.Syntax, resultKind, symbols, childBoundNodes, type, this.HasErrors);
1044var result = new BoundBadStatement(this.Syntax, childBoundNodes, this.HasErrors);
1072var result = new BoundExtractedFinallyBlock(this.Syntax, finallyBlock, this.HasErrors);
1107var result = new BoundTypeExpression(this.Syntax, aliasOpt, boundContainingTypeOpt, boundDimensionsOpt, typeWithAnnotations, type, this.HasErrors);
1156var result = new BoundTypeOrValueExpression(this.Syntax, binder, valueSymbol, type, this.HasErrors);
1197var result = new BoundNamespaceExpression(this.Syntax, namespaceSymbol, aliasOpt, this.HasErrors);
1239var result = new BoundUnaryOperator(this.Syntax, operatorKind, operand, constantValueOpt, methodOpt, constrainedToTypeOpt, resultKind, originalUserDefinedOperatorsOpt, type, this.HasErrors);
1287var result = new BoundIncrementOperator(this.Syntax, operatorKind, operand, methodOpt, constrainedToTypeOpt, operandPlaceholder, operandConversion, resultPlaceholder, resultConversion, resultKind, originalUserDefinedOperatorsOpt, type, this.HasErrors);
1319var result = new BoundAddressOfOperator(this.Syntax, operand, isManaged, type, this.HasErrors);
1348var result = new BoundUnconvertedAddressOfOperator(this.Syntax, operand, this.HasErrors);
1391var result = new BoundFunctionPointerLoad(this.Syntax, targetMethod, constrainedToTypeOpt, type, this.HasErrors);
1423var result = new BoundPointerIndirectionOperator(this.Syntax, operand, refersToLocation, type, this.HasErrors);
1460var result = new BoundPointerElementAccess(this.Syntax, expression, index, @checked, refersToLocation, type, this.HasErrors);
1497var result = new BoundFunctionPointerInvocation(this.Syntax, invokedExpression, arguments, argumentRefKindsOpt, resultKind, type, this.HasErrors);
1529var result = new BoundRefTypeOperator(this.Syntax, operand, getTypeFromHandle, type, this.HasErrors);
1559var result = new BoundMakeRefOperator(this.Syntax, operand, type, this.HasErrors);
1591var result = new BoundRefValueOperator(this.Syntax, nullableAnnotation, operand, type, this.HasErrors);
1623var result = new BoundFromEndIndexExpression(this.Syntax, operand, methodOpt, type, this.HasErrors);
1656var result = new BoundRangeExpression(this.Syntax, leftOperandOpt, rightOperandOpt, methodOpt, type, this.HasErrors);
1713var result = new BoundBinaryOperator(this.Syntax, operatorKind, data, resultKind, left, right, type, this.HasErrors);
1751var result = new BoundTupleBinaryOperator(this.Syntax, left, right, operatorKind, operators, type, this.HasErrors);
1804var result = new BoundUserDefinedConditionalLogicalOperator(this.Syntax, operatorKind, logicalOperator, trueOperator, falseOperator, trueFalseOperandPlaceholder, trueFalseOperandConversion, constrainedToTypeOpt, resultKind, originalUserDefinedOperatorsOpt, left, right, type, this.HasErrors);
1851var result = new BoundCompoundAssignmentOperator(this.Syntax, @operator, left, right, leftPlaceholder, leftConversion, finalPlaceholder, finalConversion, resultKind, originalUserDefinedOperatorsOpt, type, this.HasErrors);
1885var result = new BoundAssignmentOperator(this.Syntax, left, right, isRef, type, this.HasErrors);
1920var result = new BoundDeconstructionAssignmentOperator(this.Syntax, left, right, isUsed, type, this.HasErrors);
1961var result = new BoundNullCoalescingOperator(this.Syntax, leftOperand, rightOperand, leftPlaceholder, leftConversion, operatorResultKind, @checked, type, this.HasErrors);
1992var result = new BoundNullCoalescingAssignmentOperator(this.Syntax, leftOperand, rightOperand, type, this.HasErrors);
2031var result = new BoundUnconvertedConditionalOperator(this.Syntax, condition, consequence, alternative, constantValueOpt, noCommonTypeError, this.HasErrors);
2075var result = new BoundConditionalOperator(this.Syntax, isRef, condition, consequence, alternative, constantValueOpt, naturalTypeOpt, wasTargetTyped, type, this.HasErrors);
2108var result = new BoundArrayAccess(this.Syntax, expression, indices, type, this.HasErrors);
2137var result = new BoundRefArrayAccess(this.Syntax, arrayAccess, this.HasErrors);
2167var result = new BoundArrayLength(this.Syntax, expression, type, this.HasErrors);
2208var result = new BoundAwaitableInfo(this.Syntax, awaitableInstancePlaceholder, isDynamic, getAwaiter, isCompleted, getResult, runtimeAsyncAwaitCall, runtimeAsyncAwaitCallPlaceholder, this.HasErrors);
2243var result = new BoundAwaitExpression(this.Syntax, expression, awaitableInfo, debugInfo, type, this.HasErrors);
2296var result = new BoundTypeOfOperator(this.Syntax, sourceType, getTypeFromHandle, type, this.HasErrors);
2328var result = new BoundBlockInstrumentation(this.Syntax, locals, prologue, epilogue, this.HasErrors);
2372var result = new BoundMethodDefIndex(this.Syntax, method, type, this.HasErrors);
2415var result = new BoundLocalId(this.Syntax, local, hoistedField, type, this.HasErrors);
2458var result = new BoundParameterId(this.Syntax, parameter, hoistedField, type, this.HasErrors);
2493var result = new BoundStateMachineInstanceId(this.Syntax, type, this.HasErrors);
2528var result = new BoundMaximumMethodDefIndex(this.Syntax, type, this.HasErrors);
2566var result = new BoundInstrumentationPayloadRoot(this.Syntax, analysisKind, type, this.HasErrors);
2601var result = new BoundThrowIfModuleCancellationRequested(this.Syntax, type, this.HasErrors);
2636var result = new ModuleCancellationTokenExpression(this.Syntax, type, this.HasErrors);
2671var result = new BoundModuleVersionId(this.Syntax, type, this.HasErrors);
2706var result = new BoundModuleVersionIdString(this.Syntax, type, this.HasErrors);
2746var result = new BoundSourceDocumentIndex(this.Syntax, document, type, this.HasErrors);
2789var result = new BoundMethodInfo(this.Syntax, method, getMethodFromHandle, type, this.HasErrors);
2832var result = new BoundFieldInfo(this.Syntax, field, getFieldFromHandle, type, this.HasErrors);
2886var result = new BoundDefaultExpression(this.Syntax, targetType, constantValueOpt, type, this.HasErrors);
2921var result = new BoundIsOperator(this.Syntax, operand, targetType, conversionKind, type, this.HasErrors);
2958var result = new BoundAsOperator(this.Syntax, operand, targetType, operandPlaceholder, operandConversion, type, this.HasErrors);
2990var result = new BoundSizeOfOperator(this.Syntax, sourceType, constantValueOpt, type, this.HasErrors);
3038var result = new BoundConversion(this.Syntax, operand, conversion, isBaseConversion, @checked, explicitCastInCode, constantValueOpt, conversionGroupOpt, inConversionGroupFlags, type, this.HasErrors);
3071var result = new BoundReadOnlySpanFromArray(this.Syntax, operand, conversionMethod, type, this.HasErrors);
3106var result = new BoundArgList(this.Syntax, type, this.HasErrors);
3137var result = new BoundArgListOperator(this.Syntax, arguments, argumentRefKindsOpt, type, this.HasErrors);
3176var result = new BoundFixedLocalCollectionInitializer(this.Syntax, elementPointerType, elementPointerPlaceholder, elementPointerConversion, expression, getPinnableOpt, type, this.HasErrors);
3215var result = new BoundSequencePoint(this.Syntax, statementOpt, this.HasErrors);
3242var result = new BoundSequencePointWithSpan(this.Syntax, statementOpt, span, this.HasErrors);
3279var result = new BoundSavePreviousSequencePoint(this.Syntax, identifier, this.HasErrors);
3316var result = new BoundRestorePreviousSequencePoint(this.Syntax, identifier, this.HasErrors);
3347var result = new BoundStepThroughSequencePoint(this.Syntax, span, this.HasErrors);
3383var result = new BoundBlock(this.Syntax, locals, localFunctions, hasUnsafeModifier, instrumentation, statements, this.HasErrors);
3412var result = new BoundScope(this.Syntax, locals, statements, this.HasErrors);
3443var result = new BoundStateMachineScope(this.Syntax, fields, statement, this.HasErrors);
3479var result = new BoundLocalDeclaration(this.Syntax, localSymbol, declaredTypeOpt, initializerOpt, argumentsOpt, inferredType, this.HasErrors);
3519var result = new BoundMultipleLocalDeclarations(this.Syntax, localDeclarations, this.HasErrors);
3549var result = new BoundUsingLocalDeclarations(this.Syntax, patternDisposeInfoOpt, awaitOpt, localDeclarations, this.HasErrors);
3581var result = new BoundLocalFunctionStatement(this.Syntax, symbol, blockBody, expressionBody, this.HasErrors);
3612var result = new BoundNoOpStatement(this.Syntax, flavor, this.HasErrors);
3645var result = new BoundReturnStatement(this.Syntax, refKind, expressionOpt, @checked, this.HasErrors);
3673var result = new BoundYieldReturnStatement(this.Syntax, expression, this.HasErrors);
3715var result = new BoundThrowStatement(this.Syntax, expressionOpt, this.HasErrors);
3743var result = new BoundExpressionStatement(this.Syntax, expression, this.HasErrors);
3780var result = new BoundBreakStatement(this.Syntax, label, this.HasErrors);
3817var result = new BoundContinueStatement(this.Syntax, label, this.HasErrors);
3862var result = new BoundSwitchStatement(this.Syntax, expression, innerLocals, innerLocalFunctions, switchSections, reachabilityDecisionDag, defaultLabel, breakLabel, this.HasErrors);
3898var result = new BoundSwitchDispatch(this.Syntax, expression, cases, defaultLabel, lengthBasedStringSwitchDataOpt, this.HasErrors);
3931var result = new BoundIfStatement(this.Syntax, condition, consequence, alternativeOpt, this.HasErrors);
4011var result = new BoundDoStatement(this.Syntax, locals, condition, body, breakLabel, continueLabel, this.HasErrors);
4041var result = new BoundWhileStatement(this.Syntax, locals, condition, body, breakLabel, continueLabel, this.HasErrors);
4083var result = new BoundForStatement(this.Syntax, outerLocals, initializer, innerLocals, condition, increment, body, breakLabel, continueLabel, this.HasErrors);
4132var result = new BoundForEachStatement(this.Syntax, enumeratorInfoOpt, elementPlaceholder, elementConversion, iterationVariableType, iterationVariables, iterationErrorExpressionOpt, expression, deconstructionOpt, body, breakLabel, continueLabel, this.HasErrors);
4163var result = new BoundForEachDeconstructStep(this.Syntax, deconstructionAssignment, targetPlaceholder, this.HasErrors);
4202var result = new BoundUsingStatement(this.Syntax, locals, declarationsOpt, expressionOpt, body, awaitOpt, patternDisposeInfoOpt, this.HasErrors);
4236var result = new BoundFixedStatement(this.Syntax, locals, declarations, body, this.HasErrors);
4267var result = new BoundLockStatement(this.Syntax, argument, body, this.HasErrors);
4304var result = new BoundTryStatement(this.Syntax, tryBlock, catchBlocks, finallyBlockOpt, finallyLabelOpt, preferFaultHandler, this.HasErrors);
4345var result = new BoundCatchBlock(this.Syntax, locals, exceptionSourceOpt, exceptionTypeOpt, exceptionFilterPrologueOpt, exceptionFilterOpt, body, isSynthesizedAsyncCatchAll, this.HasErrors);
4376var result = new BoundLiteral(this.Syntax, constantValueOpt, type, this.HasErrors);
4416var result = new BoundUtf8String(this.Syntax, value, type, this.HasErrors);
4451var result = new BoundThisReference(this.Syntax, type, this.HasErrors);
4486var result = new BoundPreviousSubmissionReference(this.Syntax, type, this.HasErrors);
4521var result = new BoundHostObjectMemberReference(this.Syntax, type, this.HasErrors);
4550var result = new BoundBaseReference(this.Syntax, type, this.HasErrors);
4599var result = new BoundLocal(this.Syntax, localSymbol, declarationKind, constantValueOpt, isNullableUnknown, type, this.HasErrors);
4644var result = new BoundPseudoVariable(this.Syntax, localSymbol, emitExpressions, type, this.HasErrors);
4677var result = new BoundRangeVariable(this.Syntax, rangeVariableSymbol, value, type, this.HasErrors);
4717var result = new BoundParameter(this.Syntax, parameterSymbol, type, this.HasErrors);
4754var result = new BoundLabelStatement(this.Syntax, label, this.HasErrors);
4786var result = new BoundGotoStatement(this.Syntax, label, caseExpressionOpt, labelExpressionOpt, this.HasErrors);
4817var result = new BoundLabeledStatement(this.Syntax, label, body, this.HasErrors);
4854var result = new BoundLabel(this.Syntax, label, type, this.HasErrors);
4891var result = new BoundStatementList(this.Syntax, statements, this.HasErrors);
4924var result = new BoundConditionalGoto(this.Syntax, condition, jumpIfTrue, label, this.HasErrors);
4987var result = new BoundSwitchExpressionArm(this.Syntax, locals, pattern, whenClause, value, label, this.HasErrors);
5015var result = new BoundUnconvertedSwitchExpression(this.Syntax, expression, switchArms, reachabilityDecisionDag, defaultLabel, reportedNotExhaustive, type, this.HasErrors);
5049var result = new BoundConvertedSwitchExpression(this.Syntax, naturalTypeOpt, wasTargetTyped, expression, switchArms, reachabilityDecisionDag, defaultLabel, reportedNotExhaustive, type, this.HasErrors);
5079var result = new BoundDecisionDag(this.Syntax, rootNode, suitableForLowering, this.HasErrors);
5124var result = new BoundEvaluationDecisionDagNode(this.Syntax, evaluation, next, this.HasErrors);
5158var result = new BoundTestDecisionDagNode(this.Syntax, test, whenTrue, whenFalse, this.HasErrors);
5193var result = new BoundWhenDecisionDagNode(this.Syntax, bindings, whenExpression, whenTrue, whenFalse, this.HasErrors);
5230var result = new BoundLeafDecisionDagNode(this.Syntax, label, this.HasErrors);
5276var result = new BoundDagTemp(this.Syntax, type, source, index, this.HasErrors);
5305var result = new BoundDagTypeTest(this.Syntax, type, input, this.HasErrors);
5333var result = new BoundDagNonNullTest(this.Syntax, isExplicitTest, input, this.HasErrors);
5359var result = new BoundDagExplicitNullTest(this.Syntax, input, this.HasErrors);
5388var result = new BoundDagValueTest(this.Syntax, value, input, this.HasErrors);
5419var result = new BoundDagRelationalTest(this.Syntax, operatorKind, value, input, this.HasErrors);
5460var result = new BoundDagDeconstructEvaluation(this.Syntax, deconstructMethod, input, this.HasErrors);
5489var result = new BoundDagTypeEvaluation(this.Syntax, type, input, this.HasErrors);
5518var result = new BoundDagFieldEvaluation(this.Syntax, field, input, this.HasErrors);
5549var result = new BoundDagPropertyEvaluation(this.Syntax, property, isLengthOrCount, input, this.HasErrors);
5580var result = new BoundDagIndexEvaluation(this.Syntax, property, index, input, this.HasErrors);
5627var result = new BoundDagIndexerEvaluation(this.Syntax, indexerType, lengthTemp, index, indexerAccess, receiverPlaceholder, argumentPlaceholder, input, this.HasErrors);
5676var result = new BoundDagSliceEvaluation(this.Syntax, sliceType, lengthTemp, startIndex, endIndex, indexerAccess, receiverPlaceholder, argumentPlaceholder, input, this.HasErrors);
5705var result = new BoundDagAssignmentEvaluation(this.Syntax, target, input, this.HasErrors);
5737var result = new BoundSwitchSection(this.Syntax, locals, switchLabels, statements, this.HasErrors);
5770var result = new BoundSwitchLabel(this.Syntax, label, pattern, whenClause, this.HasErrors);
5812var result = new BoundSequencePointExpression(this.Syntax, expression, type, this.HasErrors);
5848var result = new BoundSequence(this.Syntax, locals, sideEffects, value, type, this.HasErrors);
5884var result = new BoundSpillSequence(this.Syntax, locals, sideEffects, value, type, this.HasErrors);
5923var result = new BoundDynamicMemberAccess(this.Syntax, receiver, typeArgumentsOpt, name, invoked, indexed, type, this.HasErrors);
5976var result = new BoundDynamicInvocation(this.Syntax, argumentNamesOpt, argumentRefKindsOpt, applicableMethods, expression, arguments, type, this.HasErrors);
6009var result = new BoundConditionalAccess(this.Syntax, receiver, accessExpression, type, this.HasErrors);
6050var result = new BoundLoweredConditionalAccess(this.Syntax, receiver, hasValueMethodOpt, whenNotNull, whenNullOpt, id, forceCopyOfNullableValueType, type, this.HasErrors);
6088var result = new BoundConditionalReceiver(this.Syntax, id, type, this.HasErrors);
6121var result = new BoundComplexConditionalReceiver(this.Syntax, valueTypeReceiver, referenceTypeReceiver, type, this.HasErrors);
6162var result = new BoundMethodGroup(this.Syntax, typeArgumentsOpt, name, methods, lookupSymbolOpt, lookupError, flags, functionType, receiverOpt, resultKind, this.HasErrors);
6190var result = new BoundPropertyGroup(this.Syntax, properties, receiverOpt, resultKind, this.HasErrors);
6249var result = new BoundCall(this.Syntax, receiverOpt, initialBindingReceiverIsSubjectToCloning, method, arguments, argumentNamesOpt, argumentRefKindsOpt, isDelegateCall, expanded, invokedAsExtensionMethod, argsToParamsOpt, defaultArguments, resultKind, originalMethodsOpt, type, this.HasErrors);
6288var result = new BoundEventAssignmentOperator(this.Syntax, @event, isAddition, isDynamic, receiverOpt, argument, type, this.HasErrors);
6333var result = new BoundAttribute(this.Syntax, constructor, constructorArguments, constructorArgumentNamesOpt, constructorArgumentsToParamsOpt, constructorExpanded, constructorDefaultArguments, namedArguments, resultKind, type, this.HasErrors);
6371var result = new BoundUnconvertedObjectCreationExpression(this.Syntax, arguments, argumentNamesOpt, argumentRefKindsOpt, initializerOpt, binder, this.HasErrors);
6443var result = new BoundObjectCreationExpression(this.Syntax, constructor, constructorsGroup, arguments, argumentNamesOpt, argumentRefKindsOpt, expanded, argsToParamsOpt, defaultArguments, constantValueOpt, initializerExpressionOpt, wasTargetTyped, type, this.HasErrors);
6490var result = new BoundUnconvertedCollectionExpression(this.Syntax, withElement, elements, this.HasErrors);
6522var result = new BoundUnconvertedWithElement(this.Syntax, arguments, argumentNamesOpt, argumentRefKindsOpt, this.HasErrors);
6571var result = new BoundCollectionExpression(this.Syntax, collectionTypeKind, placeholder, collectionCreation, collectionBuilderMethod, collectionBuilderElementsPlaceholder, wasTargetTyped, hasWithElement, unconvertedCollectionExpression, elements, type, this.HasErrors);
6599var result = new BoundCollectionExpressionSpreadExpressionPlaceholder(this.Syntax, type, this.HasErrors);
6639var result = new BoundCollectionExpressionSpreadElement(this.Syntax, expression, expressionPlaceholder, conversion, enumeratorInfoOpt, lengthOrCount, elementPlaceholder, iteratorBody, this.HasErrors);
6684var result = new BoundTupleLiteral(this.Syntax, arguments, argumentNamesOpt, inferredNamesOpt, type, this.HasErrors);
6714var result = new BoundConvertedTupleLiteral(this.Syntax, sourceTuple, wasTargetTyped, arguments, argumentNamesOpt, inferredNamesOpt, type, this.HasErrors);
6757var result = new BoundDynamicObjectCreationExpression(this.Syntax, name, arguments, argumentNamesOpt, argumentRefKindsOpt, initializerExpressionOpt, applicableMethods, wasTargetTyped, type, this.HasErrors);
6789var result = new BoundNoPiaObjectCreationExpression(this.Syntax, guidString, initializerExpressionOpt, wasTargetTyped, type, this.HasErrors);
6836var result = new BoundObjectInitializerExpression(this.Syntax, placeholder, initializers, type, this.HasErrors);
6885var result = new BoundObjectInitializerMember(this.Syntax, memberSymbol, arguments, argumentNamesOpt, argumentRefKindsOpt, expanded, argsToParamsOpt, defaultArguments, resultKind, accessorKind, receiverType, type, this.HasErrors);
6930var result = new BoundDynamicObjectInitializerMember(this.Syntax, memberName, receiverType, type, this.HasErrors);
6958var result = new BoundCollectionInitializerExpression(this.Syntax, placeholder, initializers, type, this.HasErrors);
7003var result = new BoundCollectionElementInitializer(this.Syntax, addMethod, arguments, implicitReceiverOpt, expanded, argsToParamsOpt, defaultArguments, invokedAsExtensionMethod, resultKind, type, this.HasErrors);
7035var result = new BoundDynamicCollectionElementInitializer(this.Syntax, applicableMethods, expression, arguments, type, this.HasErrors);
7070var result = new BoundImplicitReceiver(this.Syntax, type, this.HasErrors);
7106var result = new BoundAnonymousObjectCreationExpression(this.Syntax, constructor, arguments, declarations, type, this.HasErrors);
7146var result = new BoundAnonymousPropertyDeclaration(this.Syntax, property, type, this.HasErrors);
7176var result = new BoundNewT(this.Syntax, initializerExpressionOpt, wasTargetTyped, type, this.HasErrors);
7212var result = new BoundDelegateCreationExpression(this.Syntax, argument, methodOpt, isExtensionMethod, wasTargetTyped, type, this.HasErrors);
7244var result = new BoundArrayCreation(this.Syntax, bounds, initializerOpt, type, this.HasErrors);
7275var result = new BoundArrayInitialization(this.Syntax, isInferred, initializers, this.HasErrors);
7321var result = new BoundStackAllocArrayCreation(this.Syntax, elementType, count, initializerOpt, type, this.HasErrors);
7350var result = new BoundConvertedStackAllocExpression(this.Syntax, elementType, count, initializerOpt, type, this.HasErrors);
7390var result = new BoundFieldAccess(this.Syntax, receiverOpt, fieldSymbol, constantValueOpt, resultKind, isByValue, isDeclaration, type, this.HasErrors);
7430var result = new BoundHoistedFieldAccess(this.Syntax, fieldSymbol, type, this.HasErrors);
7468var result = new BoundPropertyAccess(this.Syntax, receiverOpt, initialBindingReceiverIsSubjectToCloning, propertySymbol, autoPropertyAccessorKind, resultKind, type, this.HasErrors);
7504var result = new BoundEventAccess(this.Syntax, receiverOpt, eventSymbol, isUsableAsField, resultKind, type, this.HasErrors);
7555var result = new BoundIndexerAccess(this.Syntax, receiverOpt, initialBindingReceiverIsSubjectToCloning, indexer, arguments, argumentNamesOpt, argumentRefKindsOpt, expanded, accessorKind, argsToParamsOpt, defaultArguments, originalIndexersOpt, type, this.HasErrors);
7604var result = new BoundImplicitIndexerAccess(this.Syntax, receiver, argument, lengthOrCountAccess, receiverPlaceholder, indexerOrSliceAccess, argumentPlaceholders, type, this.HasErrors);
7645var result = new BoundInlineArrayAccess(this.Syntax, expression, argument, isValue, getItemOrSliceHelper, type, this.HasErrors);
7685var result = new BoundDynamicIndexerAccess(this.Syntax, receiver, arguments, argumentNamesOpt, argumentRefKindsOpt, applicableIndexers, type, this.HasErrors);
7725var result = new BoundLambda(this.Syntax, unboundLambda, symbol, body, diagnostics, binder, type, this.HasErrors);
7769var result = new UnboundLambda(this.Syntax, data, functionType, withDependencies, this.HasErrors);
7810var result = new BoundQueryClause(this.Syntax, value, definedSymbol, operation, cast, binder, unoptimizedForm, type, this.HasErrors);
7836var result = new BoundTypeOrInstanceInitializers(this.Syntax, statements, this.HasErrors);
7873var result = new BoundNameOfOperator(this.Syntax, argument, constantValueOpt, type, this.HasErrors);
7915var result = new BoundUnconvertedInterpolatedString(this.Syntax, parts, constantValueOpt, type, this.HasErrors);
7943var result = new BoundInterpolatedString(this.Syntax, interpolationData, parts, constantValueOpt, type, this.HasErrors);
7971var result = new BoundInterpolatedStringHandlerPlaceholder(this.Syntax, type, this.HasErrors);
8009var result = new BoundInterpolatedStringArgumentPlaceholder(this.Syntax, argumentIndex, type, this.HasErrors);
8044var result = new BoundStringInsert(this.Syntax, value, alignment, format, isInterpolatedStringHandlerAppendCall, this.HasErrors);
8086var result = new BoundIsPatternExpression(this.Syntax, expression, pattern, isNegated, reachabilityDecisionDag, whenTrueLabel, whenFalseLabel, type, this.HasErrors);
8151var result = new BoundConstantPattern(this.Syntax, value, constantValue, inputType, narrowedType, this.HasErrors);
8191var result = new BoundDiscardPattern(this.Syntax, inputType, narrowedType, this.HasErrors);
8244var result = new BoundDeclarationPattern(this.Syntax, declaredType, isVar, variable, variableAccess, inputType, narrowedType, this.HasErrors);
8285var result = new BoundRecursivePattern(this.Syntax, declaredType, deconstructMethod, deconstruction, properties, isExplicitNotNullTest, variable, variableAccess, inputType, narrowedType, this.HasErrors);
8329var result = new BoundListPattern(this.Syntax, subpatterns, hasSlice, lengthAccess, indexerAccess, receiverPlaceholder, argumentPlaceholder, variable, variableAccess, inputType, narrowedType, this.HasErrors);
8368var result = new BoundSlicePattern(this.Syntax, pattern, indexerAccess, receiverPlaceholder, argumentPlaceholder, inputType, narrowedType, this.HasErrors);
8408var result = new BoundITuplePattern(this.Syntax, getLengthMethod, getItemMethod, subpatterns, inputType, narrowedType, this.HasErrors);
8450var result = new BoundPositionalSubpattern(this.Syntax, symbol, pattern, this.HasErrors);
8480var result = new BoundPropertySubpattern(this.Syntax, member, isLengthOrCount, pattern, this.HasErrors);
8512var result = new BoundPropertySubpatternMember(this.Syntax, receiver, symbol, type, this.HasErrors);
8548var result = new BoundTypePattern(this.Syntax, declaredType, isExplicitNotNullTest, inputType, narrowedType, this.HasErrors);
8587var result = new BoundBinaryPattern(this.Syntax, disjunction, left, right, inputType, narrowedType, this.HasErrors);
8621var result = new BoundNegatedPattern(this.Syntax, negated, inputType, narrowedType, this.HasErrors);
8660var result = new BoundRelationalPattern(this.Syntax, relation, value, constantValue, inputType, narrowedType, this.HasErrors);
8695var result = new BoundDiscardExpression(this.Syntax, nullableAnnotation, isInferred, type, this.HasErrors);
8723var result = new BoundThrowExpression(this.Syntax, expression, type, this.HasErrors);
8766var result = new OutVariablePendingInference(this.Syntax, variableSymbol, receiverOpt, this.HasErrors);
8792var result = new DeconstructionVariablePendingInference(this.Syntax, variableSymbol, receiverOpt, this.HasErrors);
8827var result = new OutDeconstructVarPendingInference(this.Syntax, variableSymbol, isDiscardExpression, this.HasErrors);
8863var result = new BoundNonConstructorMethodBody(this.Syntax, blockBody, expressionBody, this.HasErrors);
8893var result = new BoundConstructorMethodBody(this.Syntax, locals, initializer, blockBody, expressionBody, this.HasErrors);
8924var result = new BoundExpressionWithNullability(this.Syntax, expression, nullableAnnotation, type, this.HasErrors);
8959var result = new BoundWithExpression(this.Syntax, receiver, cloneMethod, initializerExpression, type, this.HasErrors);
Lowering\AsyncRewriter\RuntimeAsyncRewriter.cs (6)
29var factory = new SyntheticBoundNodeFactory(method, node.Syntax, compilationState, diagnostics);
95_factory.Syntax = node.Syntax;
121node.Syntax.Location,
279if (TryReplaceWithProxy(node.LocalSymbol, node.Syntax, out BoundNode? replacement))
290if (TryReplaceWithProxy(node.ParameterSymbol, node.Syntax, out BoundNode? replacement))
307if (TryReplaceWithProxy(thisParameter, node.Syntax, out BoundNode? replacement))
Lowering\ClosureConversion\ClosureConversion.cs (24)
306body = new BoundBlock(body.Syntax, _addedLocals.ToImmutableAndFree(), _addedStatements.ToImmutableAndFree()) { WasCompilerGenerated = true };
372var syntax = scopeBoundNode.Syntax;
650result.Add(new BoundExpressionStatement(node.Syntax, (BoundExpression)(BoundNode)node));
673SyntaxNode syntax = node.Syntax;
829return new BoundParameter(node.Syntax, replacementParameter, node.HasErrors);
849FramePointer(node.Syntax, (NamedTypeSymbol)node.Type));
856: FramePointer(node.Syntax, _topLevelMethod.ContainingType); // technically, not the correct static type
1085node.Syntax,
1127syntax: node.Syntax,
1211return new BoundStatementList(node.Syntax, statements);
1250rewrittenExceptionSource.Syntax,
1263prologueBuilder.Add(new BoundExpressionStatement(p.Syntax, p) { WasCompilerGenerated = true });
1270rewrittenFilterPrologue = new BoundStatementList(rewrittenFilter.Syntax, prologueBuilder.ToImmutableAndFree());
1323return new BoundBlock(node.Syntax, newLocals.ToImmutableAndFree(), newStatements.ToImmutableAndFree(), node.HasErrors);
1347node.Syntax,
1355node.Syntax,
1374node.Syntax,
1405syntax: conversion.Syntax,
1440return new BoundNoOpStatement(node.Syntax, NoOpStatementFlavor.Default);
1655RemapLambdaOrLocalFunction(node.Syntax, node.Symbol, default(ImmutableArray<TypeWithAnnotations>), closureKind, ref referencedMethod, out receiver, out constructedFrame);
1666node.Syntax,
1684InLoopOrLambda(node.Syntax, lambdaScope.Syntax);
1689var F = new SyntheticBoundNodeFactory(_currentMethod, node.Syntax, CompilationState, Diagnostics);
Lowering\ClosureConversion\ExpressionLambdaRewriter.cs (8)
117var r = new ExpressionLambdaRewriter(compilationState, typeMap, node.Syntax, recursionDepth, diagnostics);
121diagnostics.Add(ErrorCode.ERR_MissingPredefinedMember, node.Syntax.Location, r.ExpressionType, "Lambda");
174_bound.Syntax = node.Syntax;
358return new BoundBadExpression(node.Syntax, default(LookupResultKind), ImmutableArray<Symbol>.Empty, ImmutableArray.Create<BoundExpression>(node), ExpressionType);
389return new BoundBadExpression(node.Syntax, 0, ImmutableArray<Symbol>.Empty, ImmutableArray.Create<BoundExpression>(node), ExpressionType);
1141return new BoundBadExpression(node.Syntax, default(LookupResultKind), ImmutableArray<Symbol>.Empty, ImmutableArray.Create<BoundExpression>(node), node.Type);
1148return new BoundBadExpression(node.Syntax, default(LookupResultKind), ImmutableArray<Symbol>.Empty, ImmutableArray.Create<BoundExpression>(node), node.Type);
1180return new BoundBadExpression(node.Syntax, default(LookupResultKind), ImmutableArray<Symbol>.Empty, ImmutableArray.Create<BoundExpression>(node), node.Type);
Lowering\DiagnosticsPass_ExpressionTrees.cs (6)
61_diagnostics.Add(code, node.Syntax.Location, args);
278Binder.ReportDiagnosticsIfObsolete(_diagnostics, node.EventSymbol.AssociatedField, node.Syntax, hasBaseReceiver, _containingSymbol, _containingSymbol.ContainingType, BinderFlags.None);
292Binder.ReportDiagnosticsIfObsolete(_diagnostics, node.Event, ((AssignmentExpressionSyntax)node.Syntax).Left, hasBaseReceiver, _containingSymbol, _containingSymbol.ContainingType, BinderFlags.None);
635switch (node.Syntax.Kind())
639var lambdaSyntax = (ParenthesizedLambdaExpressionSyntax)node.Syntax;
657var lambdaSyntax = (SimpleLambdaExpressionSyntax)node.Syntax;
Lowering\Instrumentation\DebugInfoInjector.cs (45)
61switch (original.Syntax)
106throw ExceptionUtilities.UnexpectedValue(original.Syntax.Kind());
109else if (original.Syntax is ParameterSyntax parameterSyntax)
121SyntaxNode syntax = original.Syntax;
172if (original.WasCompilerGenerated && original.Syntax.Kind() == SyntaxKind.Block)
175return new BoundSequencePointWithSpan(original.Syntax, rewritten, ((BlockSyntax)original.Syntax).CloseBraceToken.Span);
193if (original.Syntax is BlockSyntax blockSyntax && !original.WasCompilerGenerated)
195prologue = new BoundSequencePointWithSpan(original.Syntax, previousPrologue, blockSyntax.OpenBraceToken.Span);
199SyntaxNode? parent = original.Syntax.Parent;
202epilogue = new BoundSequencePointWithSpan(original.Syntax, previousEpilogue, blockSyntax.CloseBraceToken.Span);
215original.Syntax is RecordDeclarationSyntax { ParameterList.Parameters.Count: > 0 })
231return AddConditionSequencePoint(base.InstrumentDoStatementCondition(original, rewrittenCondition, factory), original.Syntax, factory);
238return AddConditionSequencePoint(base.InstrumentWhileStatementCondition(original, rewrittenCondition, factory), original.Syntax, factory);
243var doSyntax = (DoStatementSyntax)original.Syntax;
253WhileStatementSyntax whileSyntax = (WhileStatementSyntax)original.Syntax;
271var forEachSyntax = (CommonForEachStatementSyntax)original.Syntax;
278var forEachSyntax = (ForEachVariableStatementSyntax)original.Syntax;
292var forEachSyntax = (CommonForEachStatementSyntax)original.Syntax;
314switch (original.Syntax.Kind())
318var forEachSyntax = (ForEachStatementSyntax)original.Syntax;
324var forEachSyntax = (ForEachVariableStatementSyntax)original.Syntax;
329throw ExceptionUtilities.UnexpectedValue(original.Syntax.Kind());
331return new BoundSequencePointWithSpan(original.Syntax,
339return BoundSequencePoint.Create(original.Condition?.Syntax,
345var syntax = (CommonForEachStatementSyntax)original.Syntax;
355return AddConditionSequencePoint(base.InstrumentForStatementCondition(original, rewrittenCondition, factory), original.Syntax, factory);
360var syntax = (IfStatementSyntax)original.Syntax;
374return AddConditionSequencePoint(base.InstrumentIfStatementCondition(original, rewrittenCondition, factory), original.Syntax, factory);
379var labeledSyntax = (LabeledStatementSyntax)original.Syntax;
388return AddSequencePoint(original.Syntax.Kind() == SyntaxKind.VariableDeclarator ?
389(VariableDeclaratorSyntax)original.Syntax :
390((LocalDeclarationStatementSyntax)original.Syntax).Declaration.Variables.First(),
396LockStatementSyntax lockSyntax = (LockStatementSyntax)original.Syntax;
406if (original.WasCompilerGenerated && original.ExpressionOpt == null && original.Syntax.Kind() == SyntaxKind.Block)
409return new BoundSequencePointWithSpan(original.Syntax, rewritten, ((BlockSyntax)original.Syntax).CloseBraceToken.Span);
412if (original.Syntax is ParameterSyntax parameterSyntax)
420return new BoundSequencePoint(original.Syntax, rewritten);
425SwitchStatementSyntax switchSyntax = (SwitchStatementSyntax)original.Syntax;
439WhenClauseSyntax? whenClause = original.Syntax.FirstAncestorOrSelf<WhenClauseSyntax>();
450return AddSequencePoint((UsingStatementSyntax)original.Syntax,
480var filterClause = ((CatchClauseSyntax)original.Syntax).Filter;
490return AddConditionSequencePoint(base.InstrumentSwitchStatementExpression(original, rewrittenExpression, factory), original.Syntax, factory);
495return new BoundSequencePointExpression(original.Syntax, base.InstrumentSwitchExpressionArmExpression(original, rewrittenExpression, factory), rewrittenExpression.Type);
Lowering\Instrumentation\LocalStateTracingInstrumenter.cs (6)
181var scope = new Scope(factory.SynthesizedLocal(contextType, methodBody.Syntax, kind: SynthesizedLocalKind.LocalStoreTracker));
280_scope.Open(_factory.SynthesizedLocal(_contextType, original.Syntax, kind: SynthesizedLocalKind.LocalStoreTracker));
398var logger = GetLocalOrParameterStoreLogger(targetType, targetSymbol, refAssignmentSourceIsLocal, original.Syntax);
469var toStringMethod = GetSpecialMethodSymbol(SpecialMember.System_Object__ToString, value.Syntax);
532var logger = GetLocalOrParameterStoreLogger(targetType, targetSymbol, refAssignmentSourceIsLocal: null, original.Syntax);
610var logger = GetLocalOrParameterStoreLogger(targetType, targetSymbol, refAssignmentSourceIsLocal: null, invocation.Syntax);
Lowering\IteratorRewriter\IteratorRewriter.cs (4)
142Binder.TryGetSpecialTypeMember(F.Compilation, member, body.Syntax, bag, out symbol);
148Binder.GetSpecialType(F.Compilation, type, body.Syntax, bag);
162Binder.Error(bag, ErrorCode.ERR_PropertyLacksGet, body.Syntax, symbol);
166bag.ReportUseSite(getter, body.Syntax.Location);
Lowering\LocalRewriter\LocalRewriter.cs (17)
107var factory = new SyntheticBoundNodeFactory(method, statement.Syntax, compilationState, diagnostics, instrumentationState);
177return new BoundBadStatement(statement.Syntax, ImmutableArray.Create<BoundNode>(statement), hasErrors: true);
253var nameofIdentiferSyntax = (IdentifierNameSyntax)((InvocationExpressionSyntax)nameofOperator.Syntax).Expression;
266var result = MakeLiteral(node.Syntax, constantValue, type);
304visited.Syntax,
322var result = new BoundFieldAccess(node.Syntax, new BoundThisReference(node.Syntax, primaryCtor.ContainingType), field, ConstantValue.NotAvailable, LookupResultKind.Viable, node.Type);
347location = node.Syntax.Location;
587return BadExpression(node.Syntax, node.Type, ImmutableArray.Create(node));
671tryGetResult = TryGetSpecialTypeMethod(node.Syntax, SpecialMember.System_Type__GetTypeFromHandle, out getTypeFromHandle);
675tryGetResult = TryGetWellKnownTypeMember(node.Syntax, WellKnownMember.System_Type__GetTypeFromHandle, out getTypeFromHandle);
680return new BoundTypeOfOperator(node.Syntax, sourceType, null, type, hasErrors: true);
697if (!TryGetWellKnownTypeMember(node.Syntax, WellKnownMember.System_Type__GetTypeFromHandle, out getTypeFromHandle))
699return new BoundRefTypeOperator(node.Syntax, operand, null, type, hasErrors: true);
739statement.Syntax,
823return new BoundStatementList(node.Syntax, rewrittenStatements, node.HasErrors);
872var syntax = initializer.Syntax;
Lowering\LocalRewriter\LocalRewriter.DecisionDagRewriter.cs (12)
474_factory.Syntax = test.Syntax;
568return new ValueDispatchNode.LeafDispatchNode(node.Syntax, label);
573return new ValueDispatchNode.LeafDispatchNode(node.Syntax, label);
583return ValueDispatchNode.RelationalDispatch.CreateBalanced(testNode.Syntax, relational.Value, relational.OperatorKind, whenTrue: whenTrue, whenFalse: whenFalse);
604return PushEqualityTestsIntoTree(value.Syntax, otherwise, cases.ToImmutableAndFree(), fac);
609return new ValueDispatchNode.LeafDispatchNode(node.Syntax, label);
1071ArrayBuilder<BoundStatement> sectionBuilder = BuilderForSection(whenNode.Syntax);
1094var whenClauseSyntax = whenNodes[0].Syntax;
1097Debug.Assert(whenNodes.All(n => n.Syntax == whenClauseSyntax));
1163ArrayBuilder<BoundStatement> sectionBuilder = BuilderForSection(whenClause.Syntax);
1171addConditionalGoto(whenClause.WhenExpression, whenClause.Syntax, trueLabel, sectionBuilder);
1208_factory.Syntax = node.Syntax;
Lowering\LocalRewriter\LocalRewriter.PatternLocalRewriter.cs (14)
145BoundExpression access = _localRewriter.MakeFieldAccess(f.Syntax, input, field, null, LookupResultKind.Viable, field.Type);
216_localRewriter._diagnostics.Add(t.Syntax, useSiteInfo);
222_localRewriter.TryGetNullableMethod(t.Syntax, inputType, SpecialMember.System_Nullable_T_GetValueOrDefault, out MethodSymbol getValueOrDefault))
230evaluated = _localRewriter.MakeConversionNode(t.Syntax, input, conversion, type, @checked: false);
337return new BoundRangeExpression(e.Syntax, makeUnloweredIndexArgument(e.StartIndex), end,
347_factory.Syntax = test.Syntax;
353return MakeNullCheck(d.Syntax, input, input.Type.IsNullableType() ? BinaryOperatorKind.NullableNullNotEqual : BinaryOperatorKind.NotEqual);
360return MakeNullCheck(d.Syntax, input, input.Type.IsNullableType() ? BinaryOperatorKind.NullableNullEqual : BinaryOperatorKind.Equal);
364return MakeValueTest(d.Syntax, input, d.Value);
369return MakeRelationalTest(d.Syntax, input, d.OperatorKind, d.Value);
508_localRewriter._diagnostics.Add(test.Syntax, useSiteInfo);
569loweredInput.Syntax.Kind() == SyntaxKind.TupleExpression &&
634var originalInput = BoundDagTemp.ForOriginalInput(loweredInput.Syntax, loweredInput.Type);
641var fieldFetchEvaluation = new BoundDagFieldEvaluation(expr.Syntax, field, originalInput);
Lowering\LocalRewriter\LocalRewriter_AssignmentOperator.cs (4)
49return VisitWindowsRuntimeEventFieldAssignmentOperator(node.Syntax, eventAccess, loweredRight);
84return MakeStaticAssignmentOperator(node.Syntax, loweredLeft, loweredRight, node.IsRef, used, AssignmentKind.SimpleAssignment);
130return RewriteWindowsRuntimeEventAssignmentOperator(eventAccess.Syntax,
160EmbedIfNeedTo(loweredReceiver, indexerAccess.ApplicableIndexers, indexerAccess.Syntax);
Lowering\LocalRewriter\LocalRewriter_BinaryOperator.cs (8)
71var syntax = node.Syntax;
120return LowerPartsToString(data, parts, node.Syntax, node.Type);
159loweredLeft = MakeBinaryOperator(original, original.Syntax, original.OperatorKind, loweredLeft, loweredRight, original.Type, original.LeftTruthOperatorMethod ?? original.BinaryOperatorMethod, original.ConstrainedToType,
209Debug.Assert(oldNode == null || (oldNode.Syntax == syntax));
752_diagnostics.Add(loweredLeft.Syntax, useSiteInfo);
776_diagnostics.Add(loweredLeft.Syntax, useSiteInfo);
2154SyntaxNode rightSyntax = loweredRight.Syntax;
2233_factory.Syntax = loweredRight.Syntax;
Lowering\LocalRewriter\LocalRewriter_Call.cs (8)
51loweredReceiver = new BoundTypeExpression(node.Syntax, null, firstContainer);
58loweredReceiver = new BoundTypeExpression(node.Syntax, null, _factory.CurrentType);
67EmbedIfNeedTo(loweredReceiver, methodGroup.Methods, node.Syntax);
422var rewrittenCall = MakeCall(node, node.Syntax, rewrittenReceiver, method, rewrittenArguments, argRefKindsOpt, node.ResultKind, temps.ToImmutableAndFree());
1023new BoundComplexConditionalReceiver(receiverTemp.Syntax,
1195optimized = CreateArrayEmptyCallIfAvailable(possibleParamsArray.Syntax, ((ArrayTypeSymbol)possibleParamsArray.Type!).ElementType);
1659value.Syntax,
1726argument.Syntax,
Lowering\LocalRewriter\LocalRewriter_CollectionExpression.cs (15)
37_factory.Syntax = node.Syntax;
156new BoundExpressionStatement(iteratorBody.Syntax, iteratorBody));
178if (!TryGetWellKnownTypeMember(node.Syntax, WellKnownMember.System_Linq_Enumerable__ToList, out MethodSymbol? toListGeneric, isOptional: true))
349node.Syntax,
447var syntax = iteratorBody.Syntax;
464node.Syntax,
490var syntax = node.Syntax;
827var syntax = node.Syntax;
906var expressionSyntax = rewrittenValue.Syntax;
1146sideEffects.Add(new BoundAssignmentOperator(rewrittenSpreadOperand.Syntax, indexTemp, _factory.Binary(BinaryOperatorKind.Addition, indexTemp.Type, indexTemp, spreadLength), isRef: false, indexTemp.Type));
1277var expressionSyntax = rewrittenValue.Syntax;
1364node.Syntax,
1424var statements = builder.SelectAsArray(expr => (BoundStatement)new BoundExpressionStatement(expr.Syntax, expr));
1429new BoundBlock(iteratorBody.Syntax, locals: ImmutableArray<LocalSymbol>.Empty, statements);
1508var iterationVariable = _factory.SynthesizedLocal(enumeratorInfo.ElementType, node.Syntax);
Lowering\LocalRewriter\LocalRewriter_CompoundAssignmentOperator.cs (12)
42SyntaxNode syntax = node.Syntax;
79return MakeInstanceCompoundAssignmentOperatorResult(node.Syntax, node.Left, node.Right, node.Operator.Method, node.Operator.Kind.IsChecked(), AssignmentKind.CompoundAssignment);
158rewrittenAssignment = new BoundSequence(node.Syntax, eventTemps.ToImmutableAndFree(), sequence.ToImmutableAndFree(), condition, condition.Type!);
169node.Syntax,
181SyntaxNode syntax = node.Syntax;
208operand = VisitCompoundAssignmentStringConcatenation(opLHS, right, node.Operator.Kind, node.Syntax);
365return new BoundDynamicMemberAccess(memberAccess.Syntax, receiverTemp, memberAccess.TypeArgumentsOpt, memberAccess.Name, memberAccess.Invoked, memberAccess.Indexed, memberAccess.Type);
442SyntaxNode syntax = indexerAccess.Syntax;
669indexerAccess.Syntax,
775return MakeFieldAccess(fieldAccess.Syntax, receiverOpt, fieldAccess.FieldSymbol, fieldAccess.ConstantValueOpt, fieldAccess.ResultKind, fieldAccess.Type, fieldAccess);
866return MakeEventAccess(eventAccess.Syntax, receiverOpt, eventAccess.EventSymbol, eventAccess.ConstantValueOpt, eventAccess.ResultKind, eventAccess.Type);
899rewrittenReceiver.Syntax,
Lowering\LocalRewriter\LocalRewriter_ConditionalOperator.cs (1)
33node.Syntax,
Lowering\LocalRewriter\LocalRewriter_Conversion.cs (23)
34InterpolationHandlerResult interpolationResult = RewriteToInterpolatedStringHandlerPattern(data, parts, node.Operand.Syntax);
53return ConvertToNullable(node.Syntax, node.Type, objectCreation);
63return ConvertToNullable(node.Syntax, node.Type, rewrittenCollection);
79var result = MakeConversionNode(node, node.Syntax, rewrittenOperand, node.Conversion, node.Checked, node.ExplicitCastInCode, node.ConstantValueOpt, rewrittenType);
100_factory.Syntax = node.Syntax;
106BadExpression(node.Syntax, byteArray, ImmutableArray<BoundExpression>.Empty) :
107MakeUnderlyingArrayForUtf8Span(node.Syntax, byteArray, bytes, out length);
109if (!TryGetWellKnownTypeMember<MethodSymbol>(node.Syntax, WellKnownMember.System_ReadOnlySpan_T__ctor_Array_Start_Length, out MethodSymbol? ctor))
111result = BadExpression(node.Syntax, node.Type, ImmutableArray<BoundExpression>.Empty);
115result = new BoundObjectCreationExpression(node.Syntax, ctor.AsMember((NamedTypeSymbol)node.Type), utf8Bytes, _factory.Literal(0), _factory.Literal(length));
133node.Syntax.Location,
306Debug.Assert(oldNodeOpt == null || oldNodeOpt.Syntax == syntax);
555return new BoundFunctionPointerLoad(oldNodeOpt.Syntax, symbolOpt,
569_factory.Syntax = (mg.ReceiverOpt ?? mg).Syntax;
577EnsureParamCollectionAttributeExists(rewrittenOperand.Syntax, rewrittenType);
815return MakeConversionNode(rewrittenOperand.Syntax, rewrittenOperand, conversion, rewrittenType, @checked);
829diagnostics.Add(rewrittenOperand.Syntax, useSiteInfo);
840rewrittenOperand.Syntax.Location,
1030syntax: expression.Syntax,
1333seq.Syntax,
1337conditional.Syntax,
1401MethodSymbol ctor = UnsafeGetNullableMethod(call.Syntax, resultType, SpecialMember.System_Nullable_T__ctor);
1402return new BoundObjectCreationExpression(call.Syntax, ctor, call);
Lowering\LocalRewriter\LocalRewriter_DeconstructionAssignmentOperator.cs (8)
254effects.assignments.Add(MakeAssignmentOperator(resultPart.Syntax, leftTarget, resultPart,
266compilation: _compilation, shouldCheckConstraints: false, includeNullability: false, errorPositions: default, syntax: (CSharpSyntaxNode)right.Syntax, diagnostics: _diagnostics);
269right.Syntax, sourceTuple: null, wasTargetTyped: false, arguments: builder!.ToImmutableAndFree(), argumentNamesOpt: default, inferredNamesOpt: default, tupleType);
364var fieldAccess = MakeTupleFieldAccessAndReportUseSiteDiagnostics(tuple, expression.Syntax, fields[i]);
392var localBound = new BoundLocal(target.Syntax, localSymbol, constantValueOpt: null, type: outputPlaceholder.Type)
452assignmentTargets.Add(new Binder.DeconstructionVariable(variable, variable.Syntax));
458assignmentTargets.Add(new Binder.DeconstructionVariable(GetAssignmentTargetsAndSideEffects(tuple, temps, effects), tuple.Syntax));
465assignmentTargets.Add(new Binder.DeconstructionVariable(temp, variable.Syntax));
Lowering\LocalRewriter\LocalRewriter_Event.cs (7)
37_diagnostics.Add(errorInfo, node.Syntax.Location);
51return RewriteWindowsRuntimeEventAssignmentOperator(node.Syntax, node.Event, kind, rewrittenReceiverOpt, rewrittenArgument);
59return MakeCall(node.Syntax, rewrittenReceiverOpt, method, rewrittenArguments);
216return MakeEventAccess(node.Syntax, rewrittenReceiver, node.EventSymbol, node.ConstantValueOpt, node.ResultKind, node.Type);
299_factory.Syntax = node.Syntax;
337module.EmbeddedTypesManagerOpt.EmbedEventIfNeedTo(node.Event.GetCciAdapter(), node.Syntax, _diagnostics.DiagnosticBag, isUsedForComAwareEventBinding: true);
345return new BoundBadExpression(node.Syntax, LookupResultKind.NotCreatable, ImmutableArray.Create<Symbol?>(node.Event),
Lowering\LocalRewriter\LocalRewriter_FixedStatement.cs (9)
83SyntaxNode? node = boundFixed.Syntax.Parent;
255VariableDeclaratorSyntax? declarator = fixedInitializer.Syntax.FirstAncestorOrSelf<VariableDeclaratorSyntax>();
311var initializerSyntax = initializerExpr.Syntax;
316VariableDeclaratorSyntax? declarator = fixedInitializer.Syntax.FirstAncestorOrSelf<VariableDeclaratorSyntax>();
448VariableDeclaratorSyntax? declarator = fixedInitializer.Syntax.FirstAncestorOrSelf<VariableDeclaratorSyntax>();
478if (TryGetWellKnownTypeMember(fixedInitializer.Syntax, WellKnownMember.System_Runtime_CompilerServices_RuntimeHelpers__get_OffsetToStringData, out offsetMethod))
484helperCall = new BoundBadExpression(fixedInitializer.Syntax, LookupResultKind.NotInvocable, ImmutableArray<Symbol?>.Empty, ImmutableArray<BoundExpression>.Empty, ErrorTypeSymbol.UnknownResultType);
539if (TryGetSpecialTypeMethod(fixedInitializer.Syntax, SpecialMember.System_Array__get_Length, out lengthMethod))
545lengthCall = new BoundBadExpression(fixedInitializer.Syntax, LookupResultKind.NotInvocable, ImmutableArray<Symbol?>.Empty, ImmutableArray.Create<BoundExpression>(factory.Local(pinnedTemp)), ErrorTypeSymbol.UnknownResultType);
Lowering\LocalRewriter\LocalRewriter_IfStatement.cs (6)
56builder.Add(new BoundConditionalGoto(rewrittenCondition.Syntax, rewrittenCondition, false, afterif));
78builder.Add(new BoundConditionalGoto(rewrittenCondition.Syntax, rewrittenCondition, false, alt));
81var syntax = (IfStatementSyntax)node.Syntax;
102var syntax = (IfStatementSyntax)node.Syntax;
116return new BoundStatementList(node.Syntax, builder.ToImmutableAndFree(), node.HasErrors);
137builder.Add(new BoundConditionalGoto(rewrittenCondition.Syntax, rewrittenCondition, false, afterif));
Lowering\LocalRewriter\LocalRewriter_Index.cs (10)
18BoundExpression fromEnd = MakeLiteral(node.Syntax, ConstantValue.Create(true), booleanType);
24operand = new BoundDefaultExpression(operand.Syntax, operand.Type!.GetNullableUnderlyingType());
31return new BoundObjectCreationExpression(node.Syntax, node.MethodOpt, operand, fromEnd);
39BoundExpression condition = MakeOptimizedHasValue(operand.Syntax, operand);
42BoundExpression boundOperandGetValueOrDefault = MakeOptimizedGetValueOrDefault(operand.Syntax, operand);
43BoundExpression indexCreation = new BoundObjectCreationExpression(node.Syntax, node.MethodOpt, boundOperandGetValueOrDefault, fromEnd);
46BoundExpression consequence = ConvertToNullable(node.Syntax, node.Type, indexCreation);
49BoundExpression alternative = new BoundDefaultExpression(node.Syntax, node.Type);
53syntax: node.Syntax,
62syntax: node.Syntax,
Lowering\LocalRewriter\LocalRewriter_IndexerAccess.cs (8)
58EmbedIfNeedTo(loweredReceiver, node.ApplicableIndexers, node.Syntax);
88node.Syntax,
367createSpan = _factory.ModuleBuilderOpt.EnsureInlineArrayAsReadOnlySpanExists(node.Syntax, spanType, intType, _diagnostics.DiagnosticBag);
371createSpan = _factory.ModuleBuilderOpt.EnsureInlineArrayAsSpanExists(node.Syntax, spanType, intType, _diagnostics.DiagnosticBag);
393elementRef = _factory.ModuleBuilderOpt.EnsureInlineArrayFirstElementRefExists(node.Syntax, _diagnostics.DiagnosticBag);
398elementRef = _factory.ModuleBuilderOpt.EnsureInlineArrayFirstElementRefReadOnlyExists(node.Syntax, _diagnostics.DiagnosticBag);
412elementRef = _factory.ModuleBuilderOpt.EnsureInlineArrayElementRefExists(node.Syntax, intType, _diagnostics.DiagnosticBag);
417elementRef = _factory.ModuleBuilderOpt.EnsureInlineArrayElementRefReadOnlyExists(node.Syntax, intType, _diagnostics.DiagnosticBag);
Lowering\LocalRewriter\LocalRewriter_LockStatement.cs (9)
24LockStatementSyntax lockSyntax = (LockStatementSyntax)node.Syntax;
38rewrittenArgument.Syntax,
45if (LockBinder.TryFindLockTypeInfo(argumentType, _diagnostics, rewrittenArgument.Syntax) is not { } lockTypeInfo)
56rewrittenArgument.Syntax,
67var expressionStatement = new BoundExpressionStatement(rewrittenArgument.Syntax, tempAssignment);
70rewrittenArgument.Syntax,
71rewrittenArgument.Syntax,
91rewrittenArgument.Syntax,
145MakeLiteral(rewrittenArgument.Syntax, ConstantValue.False, boolType),
Lowering\LocalRewriter\LocalRewriter_NullCoalescingAssignmentOperator.cs (8)
17SyntaxNode syntax = node.Syntax;
58var leftPlaceholder = new BoundValuePlaceholder(lhsRead.Syntax, lhsRead.Type);
84if (!TryGetNullableMethod(leftOperand.Syntax,
92if (!TryGetNullableMethod(leftOperand.Syntax,
116var tmp = _factory.StoreToTemp(BoundCall.Synthesized(leftOperand.Syntax, lhsRead, initialBindingReceiverIsSubjectToCloning: ThreeState.Unknown, getValueOrDefault),
123var tmpAssignment = MakeAssignmentOperator(node.Syntax, tmp, loweredRight, used: true, isChecked: false, AssignmentKind.SimpleAssignment);
131node.Syntax,
139var lhsReadHasValue = BoundCall.Synthesized(leftOperand.Syntax, lhsRead, initialBindingReceiverIsSubjectToCloning: ThreeState.Unknown, hasValue);
Lowering\LocalRewriter\LocalRewriter_NullCoalescingOperator.cs (7)
19return MakeNullCoalescingOperator(node.Syntax, rewrittenLeft, rewrittenRight, node.LeftPlaceholder, node.LeftConversion, node.OperatorResultKind, rewrittenResultType);
140TryGetNullableMethod(rewrittenLeft.Syntax, rewrittenLeft.Type, SpecialMember.System_Nullable_T_GetValueOrDefault, out MethodSymbol? getValueOrDefault, isOptional: true))
142return BoundCall.Synthesized(rewrittenLeft.Syntax, rewrittenLeft, initialBindingReceiverIsSubjectToCloning: ThreeState.Unknown, getValueOrDefault);
147TryGetNullableMethod(rewrittenLeft.Syntax, rewrittenLeft.Type, SpecialMember.System_Nullable_T_GetValueOrDefaultDefaultValue, out MethodSymbol? getValueOrDefaultDefaultValue, isOptional: true))
149return BoundCall.Synthesized(rewrittenLeft.Syntax, rewrittenLeft, initialBindingReceiverIsSubjectToCloning: ThreeState.Unknown, getValueOrDefaultDefaultValue, rewrittenRight);
257MethodSymbol getValueOrDefault = UnsafeGetNullableMethod(rewrittenLeft.Syntax, rewrittenLeftType, SpecialMember.System_Nullable_T_GetValueOrDefault);
258rewrittenLeft = BoundCall.Synthesized(rewrittenLeft.Syntax, rewrittenLeft, initialBindingReceiverIsSubjectToCloning: ThreeState.Unknown, getValueOrDefault);
Lowering\LocalRewriter\LocalRewriter_ObjectCreationExpression.cs (14)
21var constructorInvocation = _dynamicFactory.MakeDynamicConstructorInvocation(node.Syntax, node.Type, loweredArguments, node.ArgumentNamesOpt, node.ArgumentRefKindsOpt).ToExpression();
28return MakeExpressionWithInitializer(node.Syntax, constructorInvocation, node.InitializerExpressionOpt, node.Type);
99rewrittenObjectCreation = new BoundDefaultExpression(rewrittenObjectCreation.Syntax, rewrittenObjectCreation.Type!);
105node.Syntax,
128return MakeExpressionWithInitializer(node.Syntax, rewrittenObjectCreation, node.InitializerExpressionOpt, node.Type);
173return new BoundSequence(withExpr.Syntax, temps.ToImmutableAndFree(), sideEffects.ToImmutableAndFree(), value, type);
199withExpr.Syntax,
319var rewrittenNewT = MakeNewT(node.Syntax, (TypeParameterSymbol)node.Type);
325return MakeExpressionWithInitializer(node.Syntax, rewrittenNewT, node.InitializerExpressionOpt, rewrittenNewT.Type!);
382_factory.Syntax = node.Syntax;
394newGuid = new BoundBadExpression(node.Syntax, LookupResultKind.NotCreatable, ImmutableArray<Symbol?>.Empty, ImmutableArray<BoundExpression>.Empty, ErrorTypeSymbol.UnknownResultType);
412callGetTypeFromCLSID = new BoundBadExpression(node.Syntax, LookupResultKind.OverloadResolutionFailure, ImmutableArray<Symbol?>.Empty, ImmutableArray<BoundExpression>.Empty, ErrorTypeSymbol.UnknownResultType);
428rewrittenObjectCreation = new BoundBadExpression(node.Syntax, LookupResultKind.OverloadResolutionFailure, ImmutableArray<Symbol?>.Empty, ImmutableArray<BoundExpression>.Empty, node.Type);
438return MakeExpressionWithInitializer(node.Syntax, rewrittenObjectCreation, node.InitializerExpressionOpt, node.Type);
Lowering\LocalRewriter\LocalRewriter_ObjectOrCollectionInitializerExpression.cs (10)
163EmbedIfNeedTo(rewrittenReceiver, initializer.ApplicableMethods, initializer.Syntax);
190var syntax = initializer.Syntax;
401result.Add(MakeStaticAssignmentOperator(assignment.Syntax, rewrittenAccess, rewrittenRight, isRef: assignment.IsRef, used: false, AssignmentKind.SimpleAssignment));
473result.Add(MakeStaticAssignmentOperator(assignment.Syntax, rewrittenAccess, rewrittenRight, false, used: false, AssignmentKind.SimpleAssignment));
506result.Add(MakeStaticAssignmentOperator(assignment.Syntax, rewrittenAccess, rewrittenRight, false, used: false, AssignmentKind.SimpleAssignment));
540result.Add(MakeStaticAssignmentOperator(assignment.Syntax, rewrittenAccess, rewrittenRight, isRef: false, used: false, AssignmentKind.SimpleAssignment));
712return MakeFieldAccess(rewrittenLeft.Syntax, rewrittenReceiver, fieldSymbol, null, rewrittenLeft.ResultKind, fieldSymbol.Type);
720rewrittenLeft.Syntax,
735rewrittenLeft.Syntax,
745return MakeEventAccess(rewrittenLeft.Syntax, rewrittenReceiver, eventSymbol, null, rewrittenLeft.ResultKind, eventSymbol.Type);
Lowering\LocalRewriter\LocalRewriter_Range.cs (11)
46return ConvertToNullable(node.Syntax, node.Type, rangeCreation);
60operand = new BoundDefaultExpression(operand.Syntax, operand.Type.GetNullableUnderlyingType());
95if (!TryGetNullableMethod(node.Syntax, node.Type, SpecialMember.System_Nullable_T__ctor, out MethodSymbol nullableCtor))
97return BadExpression(node.Syntax, node.Type, node);
101BoundExpression consequence = new BoundObjectCreationExpression(node.Syntax, nullableCtor, rangeExpr);
104BoundExpression alternative = new BoundDefaultExpression(node.Syntax, node.Type);
110syntax: node.Syntax,
119syntax: node.Syntax,
135BoundExpression operandHasValue = MakeOptimizedHasValue(tempOperand.Syntax, tempOperand);
144condition = MakeBinaryOperator(node.Syntax, BinaryOperatorKind.BoolAnd, condition, operandHasValue, boolType, method: null, constrainedToTypeOpt: null);
147return MakeOptimizedGetValueOrDefault(tempOperand.Syntax, tempOperand);
Lowering\LocalRewriter\LocalRewriter_StackAlloc.cs (6)
48return new BoundConvertedStackAllocExpression(stackAllocNode.Syntax, elementType, stackSize, initializerOpt, type);
58stackAllocNode.Syntax, elementType, stackSize, initializerOpt, _compilation.CreatePointerTypeSymbol(elementType));
61if (TryGetWellKnownTypeMember(stackAllocNode.Syntax, WellKnownMember.System_Span_T__ctor_Pointer, out MethodSymbol? spanConstructor))
68syntax: stackAllocNode.Syntax,
81var tempAccess = _factory.StoreToTemp(constructorCall, out BoundAssignmentOperator tempAssignment, syntaxOpt: stackAllocNode.Syntax);
85syntax: stackAllocNode.Syntax,
Lowering\LocalRewriter\LocalRewriter_StringConcat.cs (7)
60return CreateStringConcat(originalOperator.Syntax, arguments);
531arg.Syntax,
544arg.Syntax,
554args[i] = BoundCall.Synthesized(arg.Syntax, receiverOpt: null, initialBindingReceiverIsSubjectToCloning: ThreeState.Unknown, stringImplicitConversionToReadOnlySpan, arg);
607var method = UnsafeGetSpecialTypeMethod(current.Syntax, member);
610currentResult = new BoundBinaryOperator(current.Syntax, current.OperatorKind, constantValueOpt: null, method, constrainedToTypeOpt: null, default(LookupResultKind), currentResult, right, current.Type);
623var syntax = expr.Syntax;
Lowering\LocalRewriter\LocalRewriter_StringInterpolation.cs (3)
149return LowerPartsToString(data, node.Parts, node.Syntax, node.Type);
196var placeholder = new BoundValuePlaceholder(result.Syntax, result.Type);
197result = new BoundNullCoalescingOperator(result.Syntax, result, _factory.StringLiteral(""), leftPlaceholder: placeholder, leftConversion: placeholder, BoundNullCoalescingOperatorResultKind.LeftType, @checked: false, result.Type) { WasCompilerGenerated = true };
Lowering\LocalRewriter\LocalRewriter_SwitchExpression.cs (12)
30: base(node.Syntax, localRewriter, node.SwitchArms.SelectAsArray(arm => arm.Syntax),
48_factory.Syntax = node.Syntax;
73var syntax = (SwitchExpressionSyntax)node.Syntax;
79result.Add(new BoundStepThroughSequencePoint(node.Syntax, span: spanForSwitchBody));
89LocalSymbol resultTemp = _factory.SynthesizedLocal(node.Type, node.Syntax, kind: SynthesizedLocalKind.LoweringTemp);
93_factory.Syntax = arm.Syntax;
95sectionBuilder.AddRange(switchSections[arm.Syntax]);
116result.Add(new BoundScope(arm.Syntax, arm.Locals, statements));
120_factory.Syntax = node.Syntax;
125result.Add(new BoundRestorePreviousSequencePoint(node.Syntax, restorePointForSwitchBody));
149result.Add(new BoundRestorePreviousSequencePoint(node.Syntax, restorePointForEnclosingStatement));
Lowering\LocalRewriter\LocalRewriter_TupleBinaryOperator.cs (23)
71syntax: expr.Syntax,
85tuple.Syntax, sourceTuple: null, wasTargetTyped: true, newArguments, ImmutableArray<string?>.Empty,
107var syntax = boundConversion.Syntax;
165tuple.Syntax, sourceTuple: null, wasTargetTyped: false, newArguments, ImmutableArray<string?>.Empty,
209return new BoundLiteral(expr.Syntax, ConstantValue.Null, expr.Type);
217syntax: expr.Syntax, operand: deferredOperand,
264return new BoundLiteral(left.Syntax, ConstantValue.Create(nullnull.Kind == BinaryOperatorKind.Equal), boolType);
347_factory.Conditional(leftHasValue, innerSequence, MakeBooleanConstant(right.Syntax, boolValue), boolType),
348MakeBooleanConstant(right.Syntax, !boolValue),
364hasValue = MakeBooleanConstant(expr.Syntax, true);
374hasValue = MakeBooleanConstant(expr.Syntax, false);
376value = new BoundDefaultExpression(expr.Syntax, expr.Type.StrippedType());
383hasValue = MakeBooleanConstant(expr.Syntax, true);
416return _factory.MakeNullableHasValue(expr.Syntax, expr);
460syntax: operand.Syntax,
472BoundExpression valueOrDefaultCall = MakeOptimizedGetValueOrDefault(expr.Syntax, expr);
480expr.Syntax, expr, conversion, enclosing.Checked, enclosing.ExplicitCastInCode,
535return MakeTupleFieldAccessAndReportUseSiteDiagnostics(tuple, tuple.Syntax, tuple.Type.TupleElements[i]);
563return _factory.Not(MakeUnaryOperator(UnaryOperatorKind.DynamicFalse, left.Syntax, method: null, constrainedToTypeOpt: null, dynamicResult, boolType));
567return MakeUnaryOperator(UnaryOperatorKind.DynamicTrue, left.Syntax, method: null, constrainedToTypeOpt: null, dynamicResult, boolType);
574return new BoundLiteral(left.Syntax, ConstantValue.Create(operatorKind == BinaryOperatorKind.Equal), boolType);
589result = MakeUnaryOperator(boolOperator.Kind, binary.Syntax, boolOperator.Method, boolOperator.ConstrainedToTypeOpt, convertedBinary, boolType);
615oldNodeOpt: conv, syntax: conv.Syntax, rewrittenOperand: LowerConversions(conv.Operand),
Lowering\LocalRewriter\LocalRewriter_UnaryOperator.cs (16)
60return MakeUnaryOperator(node, node.OperatorKind, node.Syntax, node.MethodOpt, node.ConstrainedToTypeOpt, loweredOperand, node.Type);
162return MakeConversionNode(newNode.Syntax, newNode, Conversion.ExplicitEnumeration, type, @checked: false);
410SyntaxNode syntax = node.Syntax;
453return MakeInstanceCompoundAssignmentOperatorResult(node.Syntax, node.Operand, rightOpt: null, node.MethodOpt, node.OperatorKind.IsChecked(), AssignmentKind.IncrementDecrement);
581SyntaxNode syntax = node.Syntax;
797SyntaxNode syntax = node.Syntax;
834BoundExpression condition = _factory.MakeNullableHasValue(node.Syntax, boundTemp);
907syntax: node.Syntax,
914MethodSymbol ctor = UnsafeGetNullableMethod(node.Syntax, binaryOperandType, SpecialMember.System_Nullable_T__ctor);
915boundOne = new BoundObjectCreationExpression(node.Syntax, ctor, boundOne);
933return MakeBinaryOperator(node.Syntax, binaryOperatorKind, binaryOperand, boundOne, binaryOperand.Type, method: null, constrainedToTypeOpt: null);
948binOp = MakeDecimalIncDecOperator(node.Syntax, binaryOperatorKind, binaryOperand);
952binOp = MakeLiftedDecimalIncDecOperator(node.Syntax, binaryOperatorKind, binaryOperand);
956binOp = MakeBinaryOperator(node.Syntax, binaryOperatorKind, binaryOperand, boundOne, binaryOperandType, method: null, constrainedToTypeOpt: null);
1025return MakePropertyGetAccess(transformedExpression.Syntax, propertyAccess.ReceiverOpt, propertyAccess.PropertySymbol, propertyAccess);
1033return MakePropertyGetAccess(transformedExpression.Syntax, indexerAccess.ReceiverOpt, indexerAccess.Indexer, indexerAccess.Arguments, indexerAccess.ArgumentRefKindsOpt);
Lowering\MethodToClassRewriter.cs (6)
113rewrittenMethodSymbol = GetMethodWrapperForBaseNonVirtualCall(rewrittenMethodSymbol, node.Syntax);
200if (TryReplaceWithProxy(node.ParameterSymbol, node.Syntax, out BoundNode? replacement))
216if (TryReplaceWithProxy(node.LocalSymbol, node.Syntax, out BoundNode? replacement))
302SyntheticBoundNodeFactory factory = new SyntheticBoundNodeFactory(this.CurrentMethod, rewrittenLeft.Syntax, this.CompilationState, this.Diagnostics);
310node.Syntax,
346method = GetMethodWrapperForBaseNonVirtualCall(method, originalArgument.Syntax);
Lowering\SpillSequenceSpiller.cs (27)
84var result = new BoundSpillSequenceBuilder(this.Syntax, value);
162AddStatement(new BoundExpressionStatement(expression.Syntax, expression) { WasCompilerGenerated = true });
236var spiller = new SpillSequenceSpiller(method, body.Syntax, compilationState, tempSubstitution, receiverSubstitution, diagnostics);
296var result = new BoundBlock(statement.Syntax, builder.GetLocals(), builder.GetStatements()) { WasCompilerGenerated = true };
309if (builder.Syntax != null)
310_F.Syntax = builder.Syntax;
627builder = new BoundSpillSequenceBuilder(lastSpill < newList.Length ? (newList[lastSpill] as BoundSpillSequenceBuilder)?.Syntax : null);
730exceptionFilterPrologueOpt = new BoundStatementList(node.Syntax, builder.GetStatements());
762var builder = new BoundSpillSequenceBuilder(node.Syntax);
765_F.Syntax = node.Syntax;
800builder = new BoundSpillSequenceBuilder(indicesBuilder.Syntax);
828var boundsBuilder = new BoundSpillSequenceBuilder(builder.Syntax);
881var leftBuilder = new BoundSpillSequenceBuilder(builder.Syntax);
1004var leftBuilder = new BoundSpillSequenceBuilder(builder.Syntax);
1042var receiverBuilder = new BoundSpillSequenceBuilder(builder.Syntax);
1067_F.Syntax = node.Syntax;
1071receiverBuilder.AddStatement(_F.ExpressionStatement(new BoundComplexConditionalReceiver(node.Syntax, cache, _F.Sequence(new[] { _F.AssignmentExpression(cache, receiver) }, cache), receiverType) { WasCompilerGenerated = true }));
1107var invokedExpressionBuilder = new BoundSpillSequenceBuilder(builder.Syntax);
1133if (conditionBuilder == null) conditionBuilder = new BoundSpillSequenceBuilder((consequenceBuilder ?? alternativeBuilder).Syntax);
1134if (consequenceBuilder == null) consequenceBuilder = new BoundSpillSequenceBuilder(alternativeBuilder.Syntax);
1135if (alternativeBuilder == null) alternativeBuilder = new BoundSpillSequenceBuilder(consequenceBuilder.Syntax);
1259var leftBuilder = new BoundSpillSequenceBuilder(builder.Syntax);
1294if (receiverBuilder == null) receiverBuilder = new BoundSpillSequenceBuilder((whenNotNullBuilder ?? whenNullBuilder).Syntax);
1295if (whenNotNullBuilder == null) whenNotNullBuilder = new BoundSpillSequenceBuilder(whenNullBuilder.Syntax);
1296if (whenNullBuilder == null) whenNullBuilder = new BoundSpillSequenceBuilder(whenNotNullBuilder.Syntax);
1444var expressionBuilder = new BoundSpillSequenceBuilder(builder.Syntax);
1477builder = new BoundSpillSequenceBuilder(valueBuilder.Syntax);
Lowering\StateMachineRewriter\IteratorAndAsyncCaptureWalker.cs (10)
75walker.CaptureVariable(method.ThisParameter, node.Syntax);
239CaptureRefInitializer(variableInitializer, local.SynthesizedKind != SynthesizedLocalKind.UserDefined ? variableInitializer.Syntax : syntax);
310CaptureVariable(node.ParameterSymbol, node.Syntax);
319CaptureVariable(thisSymbol, node.Syntax);
327CaptureVariable(topLevelMethod.ThisParameter, node.Syntax);
333CaptureVariable(topLevelMethod.ThisParameter, node.Syntax);
421Capture(_topLevelMethod.ThisParameter, node.Syntax);
427Capture(_topLevelMethod.ThisParameter, node.Syntax);
433Capture(node.LocalSymbol, node.Syntax);
439Capture(node.ParameterSymbol, node.Syntax);
Lowering\SyntheticBoundNodeFactory.cs (5)
519innerInstrumentation.Syntax,
1248return new BoundThrowExpression(thrown.Syntax, thrown, type) { WasCompilerGenerated = true };
1637return new BoundUnaryOperator(expression.Syntax, UnaryOperatorKind.BoolLogicalNegation, expression, null, null, constrainedToTypeOpt: null, LookupResultKind.Viable, expression.Type);
1689var syntax = argument.Syntax;
1737return new BoundLocal(node.Syntax, temp, constantValueOpt: null, type: node.Type) { WasCompilerGenerated = true };
Operations\CSharpOperationFactory.cs (169)
324return new NoneOperation(children, _semanticModel, boundNode.Syntax, type: type, constantValue, isImplicit: isImplicit);
327_semanticModel, boundNode.Syntax,
364boundNode.Syntax,
376boundNode.Syntax,
418builder.Add((IVariableDeclaratorOperation)CreateVariableDeclaratorInternal(decl, decl.Syntax));
429SyntaxNode syntax = boundDeconstructValuePlaceholder.Syntax;
441SyntaxNode syntax = boundDeconstructionAssignmentOperator.Syntax;
450SyntaxNode syntax = boundCall.Syntax;
482SyntaxNode syntax = boundFunctionPointerInvocation.Syntax;
501boundUnconvertedAddressOf.Syntax,
511var invalidOperation = OperationFactory.CreateInvalidOperation(_semanticModel, boundAttribute.Syntax, GetIOperationChildren(boundAttribute), isImplicit: true);
512return new AttributeOperation(invalidOperation, _semanticModel, boundAttribute.Syntax, isAttributeImplicit);
519initializer = new ObjectOrCollectionInitializerOperation(namedArguments, _semanticModel, boundAttribute.Syntax, boundAttribute.GetPublicTypeSymbol(), isImplicit: true);
523var objectCreationOperation = new ObjectCreationOperation(boundAttribute.Constructor.GetPublicSymbol(), initializer, DeriveArguments(boundAttribute), _semanticModel, boundAttribute.Syntax, boundAttribute.GetPublicTypeSymbol(), boundAttribute.ConstantValueOpt, isImplicit: true);
524return new AttributeOperation(objectCreationOperation, _semanticModel, boundAttribute.Syntax, isAttributeImplicit);
563SyntaxNode syntax = boundLocal.Syntax;
583SyntaxNode syntax = boundFieldAccess.Syntax;
611CreateImplicitReceiver(boundObjectInitializerMember.Syntax, boundObjectInitializerMember.ReceiverType);
624SyntaxNode syntax = boundPropertyAccess.Syntax;
634SyntaxNode syntax = boundIndexerAccess.Syntax;
654SyntaxNode syntax = boundEventAccess.Syntax;
665SyntaxNode syntax = boundEventAssignmentOperator.Syntax;
675SyntaxNode syntax = boundParameter.Syntax;
683SyntaxNode syntax = boundLiteral.Syntax;
692SyntaxNode syntax = boundNode.Syntax;
700SyntaxNode syntax = boundAnonymousObjectCreationExpression.Syntax;
713SyntaxNode syntax = boundObjectCreationExpression.Syntax;
756SyntaxNode syntax = boundWithExpression.Syntax;
768SyntaxNode syntax = boundDynamicObjectCreationExpression.Syntax;
780implicitReceiver.Syntax, type: null, isImplicit: true);
784methodGroup.Syntax, methodGroup.GetPublicTypeSymbol(), methodGroup.WasCompilerGenerated);
797SyntaxNode syntax = boundDynamicInvocation.Syntax;
811return CreateImplicitReceiver(boundObjectInitializerMember.Syntax, boundObjectInitializerMember.ReceiverType);
840SyntaxNode syntax = boundDynamicIndexerAccess.Syntax;
849SyntaxNode syntax = boundObjectInitializerExpression.Syntax;
858SyntaxNode syntax = boundCollectionInitializerExpression.Syntax;
867SyntaxNode syntax = boundObjectInitializerMember.Syntax;
922CreateImplicitReceiver(boundObjectInitializerMember.Syntax, boundObjectInitializerMember.ReceiverType);
927IOperation instanceReceiver = CreateImplicitReceiver(boundDynamicObjectInitializerMember.Syntax, boundDynamicObjectInitializerMember.ReceiverType);
931SyntaxNode syntax = boundDynamicObjectInitializerMember.Syntax;
943SyntaxNode syntax = boundCollectionElementInitializer.Syntax;
961boundDynamicMemberAccess.Syntax, boundDynamicMemberAccess.GetPublicTypeSymbol(), boundDynamicMemberAccess.WasCompilerGenerated);
993SyntaxNode syntax = boundCollectionElementInitializer.Syntax;
1013SyntaxNode syntax = boundLambda.Syntax;
1025SyntaxNode syntax = boundLocalFunctionStatement.Syntax;
1045SyntaxNode syntax = boundConversion.Syntax;
1073SyntaxNode syntax = boundConversion.Syntax;
1095if (boundOperand.Syntax == boundConversion.Syntax)
1116if (nestedConversion.Syntax == nestedOperand.Syntax && nestedConversion.ExplicitCastInCode &&
1157SyntaxNode syntax = boundAsOperator.Syntax;
1169SyntaxNode syntax = boundDelegateCreationExpression.Syntax;
1180SyntaxNode bindingSyntax = boundMethodGroup.Syntax;
1191SyntaxNode syntax = boundIsOperator.Syntax;
1202SyntaxNode syntax = boundSizeOfOperator.Syntax;
1213SyntaxNode syntax = boundTypeOfOperator.Syntax;
1223SyntaxNode syntax = boundArrayCreation.Syntax;
1226(boundArrayCreation.InitializerOpt?.Syntax == syntax && !boundArrayCreation.InitializerOpt.WasCompilerGenerated);
1233SyntaxNode syntax = boundArrayInitialization.Syntax;
1245expr.Syntax,
1321SyntaxNode syntax = element.Syntax;
1336SyntaxNode syntax = boundDefaultLiteral.Syntax;
1344SyntaxNode syntax = boundDefaultExpression.Syntax;
1354SyntaxNode syntax = boundBaseReference.Syntax;
1363SyntaxNode syntax = boundThisReference.Syntax;
1387SyntaxNode syntax = boundAssignmentOperator.Syntax;
1399SyntaxNode syntax = boundAssignmentOperator.Syntax;
1416SyntaxNode syntax = boundCompoundAssignmentOperator.Syntax;
1443SyntaxNode syntax = boundIncrementOperator.Syntax;
1453SyntaxNode syntax = boundBadExpression.Syntax;
1458bool isImplicit = boundBadExpression.WasCompilerGenerated || boundBadExpression.ChildBoundNodes.Any(static (e, boundBadExpression) => e?.Syntax == boundBadExpression.Syntax, boundBadExpression);
1466SyntaxNode syntax = boundNewT.Syntax;
1475SyntaxNode syntax = creation.Syntax;
1486SyntaxNode syntax = boundUnaryOperator.Syntax;
1540SyntaxNode syntax = boundBinaryOperator.Syntax;
1563SyntaxNode syntax = boundBinaryOperator.Syntax;
1607SyntaxNode syntax = boundTupleBinaryOperator.Syntax;
1619SyntaxNode syntax = boundConditionalOperator.Syntax;
1630SyntaxNode syntax = boundNullCoalescingOperator.Syntax;
1649SyntaxNode syntax = boundNode.Syntax;
1659SyntaxNode syntax = boundAwaitExpression.Syntax;
1669SyntaxNode syntax = boundArrayAccess.Syntax;
1680SyntaxNode syntax = boundIndexerAccess.Syntax;
1702SyntaxNode syntax = boundInlineArrayAccess.Syntax;
1712SyntaxNode syntax = boundNameOfOperator.Syntax;
1722SyntaxNode syntax = boundThrowExpression.Syntax;
1731SyntaxNode syntax = boundAddressOfOperator.Syntax;
1740SyntaxNode syntax = boundImplicitReceiver.Syntax;
1750SyntaxNode syntax = boundConditionalAccess.Syntax;
1759SyntaxNode syntax = boundConditionalReceiver.Syntax;
1769SyntaxNode syntax = boundFieldEqualsValue.Syntax;
1778SyntaxNode syntax = boundPropertyEqualsValue.Syntax;
1787SyntaxNode syntax = boundParameterEqualsValue.Syntax;
1796SyntaxNode syntax = boundBlock.Syntax;
1805SyntaxNode syntax = boundContinueStatement.Syntax;
1814SyntaxNode syntax = boundBreakStatement.Syntax;
1822SyntaxNode syntax = boundYieldBreakStatement.Syntax;
1831SyntaxNode syntax = boundGotoStatement.Syntax;
1838SyntaxNode syntax = boundNoOpStatement.Syntax;
1872SyntaxNode syntax = boundIfStatement.Syntax;
1894SyntaxNode syntax = boundWhileStatement.Syntax;
1908SyntaxNode syntax = boundDoStatement.Syntax;
1923SyntaxNode syntax = boundForStatement.Syntax;
2009var declaratorSyntax = boundForEachStatement.IterationVariableType.Syntax;
2030SyntaxNode syntax = boundForEachStatement.Syntax;
2041SyntaxNode syntax = boundTryStatement.Syntax;
2055SyntaxNode syntax = boundCatchBlock.Syntax;
2065SyntaxNode syntax = boundFixedStatement.Syntax;
2083SyntaxNode syntax = boundUsingStatement.Syntax;
2091SyntaxNode syntax = boundThrowStatement.Syntax;
2100SyntaxNode syntax = boundReturnStatement.Syntax;
2108SyntaxNode syntax = boundYieldReturnStatement.Syntax;
2118legacyMode ? null : new SynthesizedLocal((_semanticModel.GetEnclosingSymbol(boundLockStatement.Syntax.SpanStart) as IMethodSymbol).GetSymbol(),
2121syntaxOpt: boundLockStatement.Argument.Syntax).GetPublicSymbol();
2124SyntaxNode syntax = boundLockStatement.Syntax;
2132SyntaxNode syntax = boundBadStatement.Syntax;
2135bool isImplicit = boundBadStatement.WasCompilerGenerated || boundBadStatement.ChildBoundNodes.Any(static (e, boundBadStatement) => e?.Syntax == boundBadStatement.Syntax, boundBadStatement);
2142var node = boundLocalDeclaration.Syntax;
2196SyntaxNode declarationGroupSyntax = boundMultipleLocalDeclarations.Syntax;
2233SyntaxNode syntax = boundLabelStatement.Syntax;
2242SyntaxNode syntax = boundLabeledStatement.Syntax;
2252bool isImplicit = boundExpressionStatement.WasCompilerGenerated || boundExpressionStatement.Syntax == boundExpressionStatement.Expression.Syntax;
2253SyntaxNode syntax = boundExpressionStatement.Syntax;
2260Debug.Assert(boundExpressionStatement.Syntax == sequence.Value.Syntax);
2269SyntaxNode syntax = boundTupleExpression.Syntax;
2305SyntaxNode syntax = boundInterpolatedString.Syntax;
2402builder.Add(new InterpolatedStringTextOperation(valueOperation, _semanticModel, part.Syntax, isImplicit));
2410Debug.Assert(valueOperation.Syntax != part.Syntax);
2412builder.Add(new InterpolationOperation(valueOperation, alignmentOperation, formatOperation, _semanticModel, part.Syntax, isImplicit));
2445SyntaxNode syntax = boundStringInsert.Syntax;
2453SyntaxNode syntax = boundNode.Syntax;
2472conversion.Syntax,
2483return new InterpolatedStringAdditionOperation(left, right, _semanticModel, current.Syntax, current.WasCompilerGenerated);
2505return new InterpolatedStringAppendOperation(@this.Create(part), operationKind, @this._semanticModel, part.Syntax, isImplicit: true);
2511interpolatedString.Syntax,
2524SyntaxNode syntax = placeholder.Syntax;
2551placeholder.Syntax,
2559SyntaxNode syntax = boundConstantPattern.Syntax;
2570SyntaxNode syntax = boundRelationalPattern.Syntax;
2589SyntaxNode syntax = boundDeclarationPattern.Syntax;
2612boundRecursivePattern.Syntax,
2631boundITuplePattern.Syntax,
2642syntax: boundTypePattern.Syntax,
2655boundNode.Syntax,
2669boundNode.Syntax,
2680boundNegatedPattern.Syntax,
2720boundBinaryPattern.Syntax,
2731SyntaxNode syntax = boundSwitchStatement.Syntax;
2742return new SwitchCaseOperation(clauses, body, locals, condition: null, _semanticModel, boundSwitchSection.Syntax, isImplicit: boundSwitchSection.WasCompilerGenerated);
2766boundSwitchExpression.Syntax,
2782boundSwitchExpressionArm.Syntax,
2788SyntaxNode syntax = boundSwitchLabel.Syntax;
2792if (boundSwitchLabel.Syntax.Kind() == SyntaxKind.DefaultSwitchLabel)
2816SyntaxNode syntax = boundIsPatternExpression.Syntax;
2824if (boundQueryClause.Syntax.Kind() != SyntaxKind.QueryExpression)
2831SyntaxNode syntax = boundQueryClause.Syntax;
2848boundNode.Syntax,
2863boundIndex.Syntax,
2878boundRange.Syntax,
2889boundNode.Syntax,
2897SyntaxNode subpatternSyntax = subpattern.Syntax;
2910var nameSyntax = member.Syntax;
2917nameSyntax = member.Syntax;
2975SyntaxNode syntax = placeholder.Syntax;