diff --git a/releases/UWP/net-native2.0/README.md b/releases/UWP/net-native2.0/README.md index f1a869f..cc50d22 100644 --- a/releases/UWP/net-native2.0/README.md +++ b/releases/UWP/net-native2.0/README.md @@ -9,7 +9,7 @@ When using Visual Studio these packages require Visual Studio version 15.4 or la #### .NET Standard 2.0 Support -- The Windows Fall Creators Update brings support for .NET Standard 2.0 to UWP development. In order to leverage the new APIs with .NET Standard 2.0, you need to set the minimum version target of your application to the Windows Fall Creators Update SDK preview. You will then have the ability to reference .NET Standard 2.0 NuGet packages, class libraries, and APIs directly from your UWP application. +- The Windows Fall Creators Update brings support for .NET Standard 2.0 to UWP development. In order to leverage the new APIs with .NET Standard 2.0, you need to set the minimum version target of your application to the Windows Fall Creators Update SDK preview. You will then have the ability to reference .NET Standard 2.0 NuGet packages, class libraries, and APIs directly from your UWP application. - More information is available on .NET Standard 2.0 support [here](https://docs.microsoft.com/en-us/dotnet/standard/net-standard). #### Improvements to Program Optimization, Throughput and Debuggability. @@ -44,21 +44,21 @@ When using Visual Studio these packages require Visual Studio version 15.4 or la - **.NET Standard 2.0 and other .NET Library NuGet Packages** - While the vast majority of .NET Standard 2.0 APIs will work normally on the .NET Native platform, there are a small number of exceptions where the .NET Native platform could not fully support the expected behavior, typically because it would require JIT compilation or it is restricted by the app sandbox (AppContainer). An example is reading and writing process information with the Process class. As well, there are also some limitations in certain API that is not part of .NET Standard 2.0. See [https://github.com/dotnet/corefx/wiki/UWP-Compat](https://github.com/dotnet/corefx/wiki/UWP-Compat) for more details. - - Although NuGet will now allow you to reference packages that expect the desktop .NET Framework, it cannot determine whether those libraries use an API that is not available on .NET Native. To warn you of this, NuGet and Visual Studio will display a warning like, "NU1701: Package ‘PackageNameHere 1.0.0’ was restored using ‘.NETFramework,Version=v4.6.1’ instead of the project target framework ‘.NETStandard,Version=v2.0’. This package may not be fully compatible with your project.". When you receive this warning, you will want to make sure through testing or by reference to the library author that the package will indeed work in your .NET Native project. Over time, we expect many of these packages to re-package to avoid the warning. + - Although NuGet will now allow you to reference packages that expect the desktop .NET Framework, it cannot determine whether those libraries use an API that is not available on .NET Native. To warn you of this, NuGet and Visual Studio will display a warning like, "NU1701: Package ‘PackageNameHere 1.0.0’ was restored using ‘.NETFramework,Version=v4.6.1’ instead of the project target framework ‘.NETStandard,Version=v2.0’. This package may not be fully compatible with your project.". When you receive this warning, you will want to make sure through testing or by reference to the library author that the package will indeed work in your .NET Native project. Over time, we expect many of these packages to re-package to avoid the warning. - System.Diagnostics.Debugger.Log and System.Diagnostics.Debugger.IsLogging do not report the message to the debugger on Release (.NET Native) builds. Debug (CoreCLR) builds function as expected. [405171] - System.Net.HttpWebRequest behavior change regarding POST'ing empty content with entity body related request headers (i.e. 'Content-Type', et. al.) from prior .NET Native releases. See [https://github.com/dotnet/corefx/wiki/ApiCompat](https://github.com/dotnet/corefx/wiki/ApiCompat) for more details. - Exception thrown from C# dynamic binder when calling interface methods on WinRT objects. [476163] - - Exception: Microsoft.CSharp.RuntimeBinder.RuntimeBinderException:The call is ambiguous between the following methods or properties: 'System.Collections.Generic.IDictionary.Add(string, object)' and 'System.Collections.Generic.IDictionary.Add(string, object)' + - Exception: Microsoft.CSharp.RuntimeBinder.RuntimeBinderException:The call is ambiguous between the following methods or properties: ```System.Collections.Generic.IDictionary.Add(string, object)``` and ```System.Collections.Generic.IDictionary.Add(string, object)``` - Workaround: The recommended fix would be to cast the dynamic object to the desired interface type and just make a call statically. - - Example: dynamicObject.Add("key", value); - - Fix: ((IDictionary)dynamicObject).Add("key", value); + - Example: ```dynamicObject.Add("key", value);``` + - Fix: ```((IDictionary)dynamicObject).Add("key", value);``` - **Build Warnings and other Compilation Changes** - - App developers encountering an OutOfMemoryException during Release compilation can specify true in their project properties. This will run part of the toolchain on a single thread reducing the amount of memory used, and it may prevent the exception. + - App developers encountering an OutOfMemoryException during Release compilation can specify ```true``` in their project properties. This will run part of the toolchain on a single thread reducing the amount of memory used, and it may prevent the exception. - App sizes and build times have increased by approximately 20% due to support for additional .NET Standard 2.0 APIs - MCG0004:InternalAssert Assert Failed: unexpectedly found non-native type during [UNKNOWN] Caused by an interop-eligible struct(outer) containing a second struct(inner) as a field with explicit layout and one or more static fields. The workaround is to declare all the static fields of the inner struct before the instance fields. [484367] - Clicking "Enable static analysis for .NET Native" option in UWP project properties fails with the error: Could not find file 'x86\ilc\lib\Facades' - - Workaround: Uncheck the "Enable static analysis for .NET Native" option in project properties under the Build pane + - Workaround: Uncheck the ```"Enable static analysis for .NET Native"``` option in project properties under the Build pane ## Resources