-
Notifications
You must be signed in to change notification settings - Fork 4.8k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[API Proposal]: Add managed API surface area for ByRefLike Generic constraints #68002
Comments
Tagging subscribers to this area: @dotnet/area-system-reflection-metadata Issue DetailsBackground and motivationThe design for ByRefLike Generic constraints requires some new API surface area. Specifically the need to represent the new metadata values and a new feature flag to indicate support for the compiler. API ProposalMetadata enum values: namespace System.Reflection
{
[Flags]
public enum GenericParameterAttributes
{
+ [Obsolete("No longer represents all special constraints")]
SpecialConstraintMask = 0x001C,
+ AcceptByRefLike = 0x0020,
}
} Feature flag: namespace System.Runtime.CompilerServices
{
public static partial class RuntimeFeature
{
+ /// <summary>
+ /// Represents a runtime feature where byref-like types can be used in Generic parameters.
+ /// </summary>
+ public const string GenericsAcceptByRefLike = nameof(GenericsAcceptByRefLike);
}
} API UsageUsage is similar to the official documentation for any of the existing Alternative DesignsThe following would represent a binary breaking change. namespace System.Reflection
{
[Flags]
public enum GenericParameterAttributes
{
- SpecialConstraintMask = 0x001C,
+ SpecialConstraintMask = 0x003C,
+ AcceptByRefLike = 0x0020,
}
} RisksUpdating the enumeration value is troublesome since it contains a value that is a mask—an established anti-pattern. The "safest" way to handle this is the initial proposal but that does introduce confusion about new scenarios. It might be prudent to create a new API for accessing the specific constraints from the variance values.
|
Todo for v7: review above and have a plan forward for V8. |
@AaronRobinsonMSFT I prefer the original proposal is fine with obsoleting Is this ready for review? Is there any newer information that would affect this proposal? |
I prefer obsoleting as well.
It is ready for review, but since we are deferring till .NET 8 and we still have language design discussion I'm not in any hurry to move this forward as it may change. I could see fallout from the language design influencing this in subtle ways so think we can hold off. |
@AaronRobinsonMSFT should this be moved to v9? |
Yep. Done. |
namespace System.Reflection
{
[Flags]
public enum GenericParameterAttributes
{
SpecialConstraintMask = 0x001C,
+ AllowByRefLike = 0x0020,
}
}
namespace System.Runtime.CompilerServices
{
public static partial class RuntimeFeature
{
+ /// <summary>
+ /// Represents a runtime feature where byref-like types can be used in Generic parameters.
+ /// </summary>
+ public const string ByRefLikeGenerics = nameof(ByRefLikeGenerics);
}
} |
Background and motivation
The design for ByRefLike Generic constraints requires some new API surface area. Specifically the need to represent the new metadata values and a new feature flag to indicate support for the compiler.
API Proposal
Metadata enum values:
Feature flag.
API Usage
Usage is similar to the official documentation for any of the existing
GenericParameterAttributes
enumeration values.Alternative Designs
The following would represent a binary breaking change.
Risks
Updating the enumeration value is troublesome since it contains a value that is a mask—an established anti-pattern. The "safest" way to handle this is the initial proposal but that does introduce confusion about new scenarios. It might be prudent to create a new API for accessing the specific constraints from the variance values.
The text was updated successfully, but these errors were encountered: