What is the CLSCompliant
attribute?
You mark classes with the CLSCompliant
attribute when you want to make sure it can be used by any other .NET language.
These are the basic rules:
Unsigned types should not be part of the public interface of the class. What this means is public fields should not have unsigned types like
uint
orulong
, public methods should not return unsigned types, parameters passed to public function should not have unsigned types. However unsigned types can be part of private members.Unsafe types like pointers should not be used with
public
members. However they can be used withprivate
members.Class names and member names should not differ only based on their case. For example we cannot have two methods named
MyMethod
andMYMETHOD
.Only properties and methods may be overloaded, operators should not be overloaded.
The other answers are correct. Let me clarify some things--CLS stands for the Common Language Specification. It's the minimal set of rules and required language features that a .NET language must implement and understand. This set is a subset of the common type system, which defines how types are defined in .NET.
Being CLS compliant means that you can write code that can be consumed by any language that can be compiled and run on the CLR. But CLS compliance is not required, giving you the flexibility in cases where CLS compliance would be hard or impossible to do.
If you intend your code to be consumed by other developers, your API (your public classes and methods) should be CLS compliant. You should declare this by adding the CLSCompliantAttribute to your assemblies. If you are not writing for others, CLS compliance is not necessary, although FxCop (Framework Cop) would disagree with me.
When your assembly is marked with the CLSCompliantAttribute, the compiler will (should!) check your code to see if, when compiled, it will violate any of the CLS rules (some of which ocdecio mentioned) and report violations to you for fixing.
out
parameters - so I think Microsoft needs to revisit the CLS's requirements and perhaps loosen them. –
Crush It tells other consumers of your code that it is CLS compliant, and also makes the C# compiler check that it's CLS compliant for you.
The referenced article contains a lot more detail about what CLS compliance entails.
As it fits here: To mark a whole project CLS compliant add this line to AssemblyInfo.cs
(can be found under Properties in Solution Explorer)
[assembly:CLSCompliant(true)]
or equivalently in VB.NET (AssemblyInfo.vb
is hidden under My Project)
<Assembly: CLSCompliant(True)>
Thanks to Making Your Code CLS Compliant.
CLS compliant is a subset of the full language spectrum allowed by the CLR. It restricts it to subsets that are likely available by the majority of languages that target the CLR. This increases, but does not guarantee, that your library can be used by all languages targeting the CLR.
© 2022 - 2024 — McMap. All rights reserved.