Guest Sergio Pedri Posted August 27, 2024 Posted August 27, 2024 We’re happy to announce the official launch of the 8.3 release of the .NET Community Toolkit! This new version includes .NET 8 and NativeAOT support for all libraries, performance improvements, several bug fixes and enhancements, and more! [ATTACH type=full" alt=".NET Community Toolkit 8.3.0]5919[/ATTACH] As always, we deeply appreciate all the feedback received both by teams here at Microsoft using the Toolkit, as well as other developers in the community. All the issues, bug reports, comments and feedback continue to be extremely useful for us to plan and prioritize feature work across the entire .NET Community Toolkit. Thank you to everyone contributing to this project and helping make the .NET Community Toolkit better! [ATTACH type=full" alt="🎉]5920[/ATTACH] [HEADING=1]What’s in the .NET Community Toolkit? [ATTACH type=full" alt="👀]5921[/ATTACH][/HEADING] The .NET Community Toolkit includes the following libraries: [iCODE]CommunityToolkit.Common[/iCODE] [iCODE]CommunityToolkit.Mvvm[/iCODE] (aka “Microsoft MVVM Toolkit”) [iCODE]CommunityToolkit.Diagnostics[/iCODE] [iCODE]CommunityToolkit.HighPerformance[/iCODE] These components are also widely used in several inbox apps that ship with Windows, such as the Microsoft Store and the Photos app! [ATTACH type=full" alt="🚀]5922[/ATTACH] For more details on the history of the .NET Community Toolkit, here is a link to our previous 8.0.0 announcement post. Here is a breakdown of the main changes that are included in this new 8.3 release of the .NET Community Toolkit. [HEADING=1].NET 8 and NativeAOT support [ATTACH type=full" alt="🚀]5923[/ATTACH][/HEADING] The main change in this new release of the .NET Community Toolkit is support for .NET 8 and NativeAOT! As part of this, all APIs across all packages have been annotated to fully support trimming and AOT compatibility, to ensure using any part of the .NET Community Toolkit goes smoothly even in those scenarios. Here you can see an example of a new trim annotation, that correctly shows up in the IDE to warn about potentially unsafe code (even from code generated by [iCODE][ObservableProperty][/iCODE]!): [ATTACH type=full" alt="Trim warning for validatable properties]5924[/ATTACH] Additionally, this new release of the MVVM Toolkit adds support for the [iCODE]net8.0-windows10.0.17763.0[/iCODE] target as well, to be fully trim and AOT compatible with WinAppSDK (WinUI 3) as well! Adding this new target framework is necessary to ensure that all types that might be marshalled to WinRT will have all needed interop code generated for them, via CsWinRT. This is all fully transparent for consumers of the package: just reference the MVVM Toolkit from any project, publish with NativeAOT, and it will work as expected! [HEADING=1]Removing overhead for unused MVVM Toolkit features (ie. making it “more pay-for-play”) [ATTACH type=full" alt="🎈]5925[/ATTACH][/HEADING] This release also includes more performance improvements for the MVVM Toolkit. This time, the focus was on making the support for [iCODE]INotifyPropertyChanging[/iCODE] fully pay-for-play: meaning that when this interface is not needed, there will be no additional overhead because of it. For instance, frameworks such as UWP and WinUI 3 don’t need viewmodels to implement this property. In those scenarios, you can set this in your .csproj file: <PropertyGroup> <MvvmToolkitEnableINotifyPropertyChangingSupport>false</MvvmToolkitEnableINotifyPropertyChangingSupport> </PropertyGroup> When this property is set to [iCODE]false[/iCODE] (it defaults to [iCODE]true[/iCODE] for backwards compatibility), all code associated with [iCODE]INotifyPropertyChanging[/iCODE] in [iCODE]ObservableObject[/iCODE] will be trimmed out (the event will never be raised, and event args will never be allocated). Additionally, the MVVM Toolkit source generator will also detect and respect the value of this property, and it will optimize the code to avoid generating all the code that was meant to implement that functionality! [HEADING=1]Other changes and improvements [ATTACH type=full" alt="✅]5926[/ATTACH][/HEADING] Fix generation for OnPropertyChanging for [iCODE][NotifyPropertyChangedFor][/iCODE] (#722): when using [iCODE][NotifyPropertyChangedFor][/iCODE], the generated [iCODE]OnPropertyChanging[/iCODE] methods were not being invoked for dependent properties. This has now been fixed. Include [iCODE]sizeof(T)[/iCODE] in offset calculation for [iCODE]Memory2D<T>[/iCODE] from [iCODE]MemoryManager[/iCODE] (#841): creating a [iCODE]Memory2D<T>[/iCODE] instance wrapping a [iCODE]MemoryManager[/iCODE] incorrectly tracked the data offset. This is no longer the case, thank you @Lillenne! Avoid auto-generating [iCODE]ObservableValidator.HasError[/iCODE] (#844): the [iCODE]ObservableValidator.HasError[/iCODE] property will no longer automatically show up in table views in frameworks that dynamically generate columns from declared properties. Thank you @arivoir! Fix [iCODE]IBufferWriterExtensions.Write[/iCODE] for unmanaged types (#799): fixed an incorrect length calculation in the [iCODE]Write[/iCODE] extension for unmanaged types. Thank you @pziezio! You can see the full changelog for this release from the GitHub release page. [HEADING=1]Get started today! [ATTACH type=full" alt="🎉]5927[/ATTACH][/HEADING] You can find all source code in our GitHub repo, some handwritten docs on MS learn, and complete API references in the .NET API browser website. If you would like to contribute, feel free to open issues or to reach out to let us know about your experience! To follow the conversation on Twitter, use the #CommunityToolkit hashtag. All your feedback greatly helped shape the direction of these libraries, so make sure to share them! Happy coding! [ATTACH type=full" alt="💻]5928[/ATTACH] The post .NET Community Toolkit 8.3 is here! NativeAOT, .NET 8 enhancements, and more! appeared first on .NET Blog. Continue reading... Quote
Recommended Posts
Join the conversation
You can post now and register later. If you have an account, sign in now to post with your account.