The ‘Validate platform compatibility’ rule is an important static analysis rule in C# that ensures your code is compatible with the platforms it is intended to run on. This rule checks for platform compatibility attributes like SupportedOSPlatform and UnsupportedOSPlatform in your code, which indicate the specific platforms or versions of platforms on which the annotated code elements are supported or unsupported, respectively.
Ignoring this rule can lead to runtime errors if your code attempts to call APIs that are not supported on the host operating system. For example, a method marked with [UnsupportedOSPlatform("windows")] will throw an exception if called on a Windows machine.
To comply with this rule, always mark your platform-specific APIs with the appropriate attributes and ensure that your code does not call any APIs that are not supported on the current platform. Use the RuntimeInformation.IsOSPlatform method to check the platform at runtime before calling any platform-specific APIs. Additionally, consider providing alternative implementations for different platforms to improve the portability of your code.
// An API supported only on Linux.[SupportedOSPlatform("linux")]publicvoidLinuxOnlyApi(){}// API is supported on Windows, iOS from version 14.0, and MacCatalyst from version 14.0.[SupportedOSPlatform("windows")][SupportedOSPlatform("ios14.0")]// MacCatalyst is a superset of iOS, therefore it's also supported.publicvoidSupportedOnWindowsIos14AndMacCatalyst14(){}publicvoidCaller(){LinuxOnlyApi();// This call site is reachable on all platforms. 'LinuxOnlyApi()' is only supported on: 'linux'SupportedOnWindowsIos14AndMacCatalyst14();// This call site is reachable on all platforms. 'SupportedOnWindowsIos14AndMacCatalyst14()'// is only supported on: 'windows', 'ios' 14.0 and later, 'MacCatalyst' 14.0 and later.}
Seamless integrations. Try Datadog Code Security
Datadog Code Security
Try this rule and analyze your code with Datadog Code Security
How to use this rule
1
2
rulesets:- csharp-best-practices # Rules to enforce C# best practices.
Create a static-analysis.datadog.yml with the content above at the root of your repository
Use our free IDE Plugins or add Code Security scans to your CI pipelines