This page is not yet available in Spanish. We are working on its translation. If you have any questions or feedback about our current translation project, feel free to reach out to us!
Metadata
ID:csharp-best-practices/platform-compatibility
Language: C#
Severity: Warning
Category: Best Practices
Description
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.}
Integraciones sin problemas. Prueba Datadog Code Security
Datadog Code Security
Prueba esta regla y analiza tu código con Datadog Code Security
Cómo usar esta regla
1
2
rulesets:- csharp-best-practices # Rules to enforce C# best practices.
Crea un static-analysis.datadog.yml con el contenido anterior en la raíz de tu repositorio
Utiliza nuestros complementos del IDE gratuitos o añade análisis de Code Security a tus pipelines de CI.