-
Notifications
You must be signed in to change notification settings - Fork 173
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鈥檒l occasionally send you account related emails.
Already on GitHub? Sign in to your account
Switch to .NET 6 #549
Comments
.NET Standard 2.0 is still pivotal to the ecosystem for support for .NET Framework, UWP, Xamarin Forms, and Unity developers. Moving to .NET 6 for building the project makes sense still of course and allows you to make use of C# 10 features of course, but that doesn't mean the underlying library needs to be moved up as well. It's going to be a while before developers and the applications they write can adopt the latest .NET still. .NET Standard still helps to ensure the widest audience can use your library. See this blog here, which outlines this well.. Many newer runtime features are available still for .NET Standard 2.0 by changing the language version and polyfills. This article here has some info by @Sergio0694. We're doing this in the Community Toolkit's as well.
Source generators work wherever you need them as well, they were designed with .NET Standard 2.0 in mind still. |
Hello @michael-hawker, thanks a lot for sharing your thoughts as well as some precious info. You make quite a compelling argument in favor of .NET Standard 2.0. I've also looked into Community Toolkit and it seems to provide quite a few goodies EmbedIO can use, so thanks for that too. So, the new plan could be to triple-target .NET Standard 2.0, .NET Standard 2.1, and .NET 6. Would this fit existing runtimes optimally, or is there something I overlooked? |
@Sergio0694 has a bit more experience with how the multi-targeting works from the .NET Community Toolkit side, he may be able to call out any more specifics or things to watch out for. Though my understanding is basically that as long as the consumer of the package is running on the newer runtime they get all the optimized benefits that runtime provides automatically. The main bits you have to worry about as the author is just setting up your csproj files and some conditionals to properly exclude the polyfill bits that bring the newer features to the .NET Standard 2.0 target. Though there's a lot of examples on how that all works in the .NET Community Toolkit. |
I announced a possible switch of EmbedIO to .NET 6 in #546:
Although which SWAN version to use is no more a concern, there are some features introduced with recent versions of .NET (Core) and the C# compiler that are missing from .NET Standard 2.0 and can do a sizable difference in EmbedIO's reliability, performance, and code quality. Just from the top of my mind:
nameof
when validating arguments);ConfiguredObject
).There are even more features that can be beneficial in the near future: think for example
WebSocketBase
using a source generator for routing, instead of building and compiling LINQ expression at run time.Comments and criticisms are welcome, as usual.
The text was updated successfully, but these errors were encountered: