What is the 'CLSCompliant' attribute in .NET?
Asked Answered
H

5

200

What is the CLSCompliant attribute?

Hulse answered 20/2, 2009 at 17:15 Comment(0)
A
213

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:

  1. 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 or ulong, 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.

  2. Unsafe types like pointers should not be used with public members. However they can be used with private members.

  3. Class names and member names should not differ only based on their case. For example we cannot have two methods named MyMethod and MYMETHOD.

  4. Only properties and methods may be overloaded, operators should not be overloaded.

Atheism answered 20/2, 2009 at 17:18 Comment(4)
Would you do that as a default for every project?Antistrophe
Not necessarily, mostly for those that may have exposure to other .net languages.Internuncial
Another restriction is CS3006: Overloaded method 'Foo.Bar(ref Baz)' differing only in ref or out, or in array rank, is not CLS-compliantDrumhead
One more: public identifiers should not start with an underscore character.Width
G
52

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.

Graph answered 20/2, 2009 at 18:18 Comment(2)
Unfortunately the grand-vision of the CLR having many different frontend languages (like VB.NET - which dying a slow death - and others now gone, like MC++, Delphi.NET, Oxygene, J#, JScript.NET, and so on) limits the benefits of completing CLSCompliance given that the other remaining languages that support the CLR have no problem supporting non-CLSCompliant features like optional parameters and out parameters - so I think Microsoft needs to revisit the CLS's requirements and perhaps loosen them.Crush
Oxygene and other Elements languages still target the CLR.Orozco
P
51

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.

Plasmo answered 20/2, 2009 at 17:20 Comment(2)
So if I add the attribute and then build my project with no complaints, that means my project is CLS compliant and all is good?Bozen
@Svish, yes that is the case. The compiler will let you know if you violate any rules.Drumhead
C
15

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.

Carboxylase answered 21/9, 2015 at 16:9 Comment(0)
S
14

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.

Saturate answered 20/2, 2009 at 17:20 Comment(0)

© 2022 - 2024 — McMap. All rights reserved.