-
Notifications
You must be signed in to change notification settings - Fork 26
Conversation
After further discussion and internal conversation, we decided not to target .NET Standard 2.0. Look for a followup that will change this package to target only .NET Core 2.0 and .NET Framework 4.6.1. The decision comes primarily from this package's heavy dependency on System.Reflection.Emit. Without it, there isn't much useful API. Therefore, we'll only target frameworks that support refemit. |
That makes no sense to me. You can target .NET Standard and reference Yes, this means folks can install the package into UWP without a build error which will blow up at runtime. However:
Dropping .NET Standard support entirely makes this package unusable* for the vast majority of libraries. *Yes, folks will be able to consume this from .NET Standard 2.0 thanks to the compat shim, but this package violates what we tell customers to do: if you want to share code between .NET Core and .NET Framework, you should target .NET Standard. |
@terrajobst at the time this was discussed, we were told mixing the 4.3.0 System.* packages with NETStandard.Library 2.0.0 was not okay. There is no System.Reflection.Emit package 4.4.0 and the APIs in this namespace are not in ns2.0. See also this discussion: https://github.com/dotnet/corefx/issues/17746 |
Odd. I tried this other day it worked as expected. |
@terrajobst After my conversation with you on twitter, we did end up moving to .NET Standard 2.0 + Reflection.Emit 4.30 packages, so if there's actually a problem with that combination, I think it needs to be announced very publicly. |
In other words, "if it works, we keep quiet, otherwise I expect Immo to publicly apologize for his bad guidance". Seems fair 😄 |
Well, didn't mean it quite like that of course 😄 but something needs to be done to actually block the combination if it's not meant to be used together. Right now there is zero indication that it could even be a problem. The packages happily install and so far seem to be working correctly. |
Synced with @weshaggard offline. The problem is that we can't build the The real downer is the experience I mentioned earlier: no build errors. We need to fix that. |
Part of dotnet/aspnetcore#2045
Notable changes:
netstandard2.0
,netcoreapp2.0
, andnet461
netstandard2.0
throwsPlatformNotSupportedException
for the following public APIProxyDiagnosticSourceMethodAdapter.Adapt
.PlatformNotSupportedExcpetion
or will not be available at all in the ns2.0 assembly when their public surface depended on System.Reflection.Emit typesBackground: System.Reflection.Emit was (perhaps mistakenly) part of .NET Standard 1.x, but was removed from 2.0. These APIs are only available when targeting .NET Core 2.0 and .NET Framework 4.6.1 directly.