-
Notifications
You must be signed in to change notification settings - Fork 135
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
Update Framework support for 4.7.1 #138
Comments
Hence, .Net Standard cannot actually cover any legacy cases. Can't we switch to C# 7.2 without dropping direct support for older frameworks? |
Or would we want to leverage new APIs only available in 4.7.1? |
So far, the features I'd like to make use of are: so yes I would love to move to 4.7.1 but I understand your concern. Currently 4.5.2 is the oldest framework version still under mainstream ms support (until October this year) so I would request that we at least move to that, although 4.6 would be much preferable due to the collection changes. And yes we should go to c#7.2 regardless if only for the improved struct support (which as far as I can tell does not require framework changes) |
@JohanLarsson are you aware of any users targeting .Net Framework < 4.6? What about < 4.7.1? |
We use older versions in some projects but they are legacy so not a problem, if they are updated we will bump version for them. Unity is stuck on some really old version net35 IIRC, I'm not aware of any Unity users but then I'm not aware of any users. #if net35
namespace System.Runtime.CompilerServices
{
[AttributeUsage(AttributeTargets.Constructor | AttributeTargets.Method, Inherited = false)]
public sealed class MethodImplAttribute : Attribute
{
public MethodImplAttribute(MethodImplOptions methodImplOptions)
{
}
}
}
namespace System.Reflection
{
public enum MethodImplAttributes
{
AggressiveInlining = 256,
}
}
#endif Stubs to keep the compiler happy, not sure if this will work. @AQuentin2033 Where do we need tuples and |
I wanted to use ReadOnlyCollection internally for Polygon, polyline2D/3D Regarding Unity - legacy unity builds against .net3.5 by default (although since 2017.1 you can choose .net4.6 and from 2018.1 the beta seems to let you choose .netstandard2.0). According to the current (and previous) nuget package for Spatial .net 4.0 is the minimum, so that would imply there cannot be any legacy unity users... I suppose we could use shims and conditional compilation and backport code to support multiple framework versions. Its a lot of work though and harder to maintain and test and if there is no users requiring/requesting it then the value is pretty low. Users would also have the option of simply staying on their current version if they wish, nothing says they have to upgrade if they are happy with the current code. |
FYI: I've dropped support for older platforms and upgraded the target frameworks to .NET Framework 4.6.1 and .NET Standard 2.0. |
With the support for netstandard2.0 and netstandard1.3 for legacy cases I would like to raise the native framework version to 4.7.1 and switch to using c# 7.2 for the core library, the unittests and benchmarking project.
As users of lower versions of the framework can link in the .netstandard versions I cannot see this being an issue for anyone but if it is please chime in.
The text was updated successfully, but these errors were encountered: