-
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 Change: Restore CompileToMethod in S.L.Expressions #20270
Comments
@danmosemsft, @weshaggard, @VSadov, any reason this hasn't come back for 2.0? |
This method depends on types from Reflection.Emit which are not part of .NET Standard so it cannot be added to the standard. However it could be made .NET Core specific if we felt it was useful for those folks. |
In the method's signature? |
Yes in the signature. See https://apisof.net/catalog/System.Linq.Expressions.LambdaExpression.CompileToMethod(MethodBuilder). |
Right but it's available in .net core platform so it'd make sense to remove the ifdef |
@danmosemsft, @VSadov, seems like this should come back for .NET Core 2.0? |
In general @ViktorHofer and I did not chase up missing members where they were specifically excluded from a type as part of defining .NET Standard, based on the assumption that bringing them back even for Core would cause a library in .NET Standard to take a reference outside of .NET Standard. However as I now understand, this was too strict as there's no reason why .NET Core can't have such a reference as it doesn't attempt to offer a standalone implementation for .NET Standard (nor one that could be trimmed to just that). This is a list of many of the members we ignored for this reason. Perhaps others should be reexamined. So I believe this could come back. Whether it should is up to @VSadov @OmarTawfik - of course I think it ideally should. |
Here is a better list -- this is everything (?) it is currently not planned to bring to Core, but exists in Desktop (by some definition). Of course it doesn't describe stuff that isn't implemented, but API is present. |
Nearly everything. There are still a few open issues where I'm awaiting responses if the members should make it in before 2.0 signoff. |
I did some experimenting with this last night. A problem with this idea is that a very large number of the tests make use of a constant value of a type Since the majority of paths are the same with IL compilation and |
Interestingly, storing To recap, interpretation can handle those fine, compiling to IL could not (and cannot on desktop, still) but now can because it does so as a bound constant (an approach unavailable to It had seemed at the time that
|
Any status update on this? |
I'm on a long-term hiatus from contributing, so I won't be experimenting further in the near future. |
Is this something that should perhaps be revisited now that .NET Standard 2.1 will contain Reflection.Emit? |
@danmosemsft Could it be added in .NET Core 3.x? I can submit a PR. |
I actually don't have context. My comments above were from large scale ports to .NEt Core. This component is owned by @cston @333fred @jaredpar (per https://github.com/dotnet/corefx/blob/master/Documentation/project-docs/issue-guide.md) Per https://github.com/dotnet/corefx/issues/33170 they are limiting changes to this library. However bringing back a method that was previously present in desktop may fall under the "regressions" category described in that issue. They will have to make this call. |
Closing as we are not accepting new features, including bringing back old APIs, into the library at this time as it is effectively archived. More information is contained in the library README.md |
@jaredpar could you reconsider it for this particular feature, please? All of the code is already there but disabled behind a |
This missing feature has been the primary reason for my team not adopting .NET Core. Am I to understand then that this will not be part of .Net 5 either? Please reconsider! |
At https://github.com/dotnet/corefx/issues/11408#issue-174928345 @bartdesmet notes:
The entry-point came back conditionally excluded when that issue was closed. I also agree it can be useful, while I've only used it a handful of times myself, it was really useful those few times.
That Xamarin is now using this feature adds another advantage, in that we can't test it, and hence catch regressions that could break Xamarin, without it.
Mostly though I just think it can be useful, and is worth having.
CompileToMethod()
has dependencies on most of what is covered byFEATURE_COMPILE
so replacingFEATURE_COMPILE_TO_METHODBUILDER
withFEATURE_COMPILE
would bring it back in those builds that can feasibly use it (i.e. have support for Emit).The mechanism for testing across both interpreter and compiler could be extended to test across all three possibities of interpreter, compiler andCompileToMethod()
with dynamic methods, but other cases should probably be separate choices.CompileToMethod()
would require a separate set of tests.FEATURE_COMPILE_TO_METHODBUILDER
withFEATURE_COMPILE
TryEmitConstants
to handleTypeBuilder
constants when not emitting toDynamicMethod
(may do this separately anyway if @marek-safar needs it).CompileToMethod()
withDynamicMethod
sThe text was updated successfully, but these errors were encountered: