Pakketten valideren op verschillende runtimes
U kunt ervoor kiezen om verschillende implementatieassembly's te hebben voor verschillende runtimes in uw NuGet-pakket. In dat geval moet u ervoor zorgen dat deze assembly's compatibel zijn met elkaar en met de compileertijdassembly's.
Bekijk bijvoorbeeld het volgende scenario. U werkt aan een bibliotheek met respectievelijk enkele interop-aanroepen naar Unix- en Windows-API's. U hebt de volgende code geschreven:
#if Unix
public static void Open(string path, bool securityDescriptor)
{
// Call Unix specific stuff.
}
#else
public static void Open(string path)
{
// Call Windows specific stuff.
}
#endif
De resulterende pakketstructuur ziet er als volgt uit.
lib/net6.0/A.dll
runtimes/unix/lib/net6.0/A.dll
lib\net6.0\A.dll
wordt altijd gebruikt tijdens het compileren, ongeacht het onderliggende besturingssysteem. lib\net6.0\A.dll
wordt ook gebruikt tijdens runtime voor niet-Unix-systemen. Wordt runtimes\unix\lib\net6.0\A.dll
echter tijdens runtime gebruikt voor Unix-systemen.
Wanneer u dit project probeert in te pakken, krijgt u de volgende fout:
D:\demo>dotnet pack
Microsoft (R) Build Engine version 17.0.0-preview-21460-01+8f208e609 for .NET
Copyright (C) Microsoft Corporation. All rights reserved.
Determining projects to restore...
All projects are up-to-date for restore.
You are using a preview version of .NET. See: https://aka.ms/dotnet-core-preview
PackageValidationThrough -> D:\demo\bin\Debug\net6.0\PackageValidationThrough.dll
Successfully created package 'D:\demo\bin\Debug\PackageValidationThrough.1.0.0.nupkg'.
C:\Program Files\dotnet\sdk\6.0.100-rc.1.21463.6\Sdks\Microsoft.NET.Sdk\targets\Microsoft.NET.Compatibility.Common.targets(32,5): error CP0002: Member 'A.B.Open(string)' exists on lib/net6.0/PackageValidationThrough.dll but not on runtimes/unix/lib/net6.0/PackageValidationThrough.dll [D:\demo\PackageValidationThrough.csproj]
C:\Program Files\dotnet\sdk\6.0.100-rc.1.21463.6\Sdks\Microsoft.NET.Sdk\targets\Microsoft.NET.Compatibility.Common.targets(32,5): error CP0002: Member 'A.B.Open(string, bool)' exists on runtimes/unix/lib/net6.0/PackageValidationThrough.dll but not on lib/net6.0/PackageValidationThrough.dll [D:\demo\PackageValidationThrough.csproj]
U realiseert zich uw fout en voegt deze ook toe A.B.Open(string)
aan de Unix-runtime.
#if Unix
public static void Open(string path, bool securityDescriptor)
{
// Call Unix specific stuff.
}
public static void Open(string path)
{
throw new PlatformNotSupportedException();
}
#else
public static void Open(string path)
{
// Call Windows specific stuff.
}
public static void Open(string path, bool securityDescriptor)
{
throw new PlatformNotSupportedException();
}
#endif
U probeert het project opnieuw in te pakken en het lukt.
Strikte modus
U kunt de strikte modus voor deze validator inschakelen door de EnableStrictModeForCompatibleTfms
eigenschap in uw projectbestand in te stellen. Als u strikte modus inschakelt, worden bepaalde regels gewijzigd en worden er andere regels uitgevoerd wanneer u de verschillen krijgt. Dit is handig als u wilt dat beide zijden die u vergelijkt strikt hetzelfde zijn op hun oppervlakte en identiteit. Zie de modus Strikt voor meer informatie.