Click here to Skip to main content
65,938 articles
CodeProject is changing. Read more.
Articles
(untagged)

Writing CLS-Compliant Structures in Visual Basic 2008

0.00/5 (No votes)
9 Mar 2008 2  
Techniques for writing your own Structures which adhere to the Microsoft CLS, using Visual Basic 2008.

Introduction

Most developers already know what the Common Language Specifications (CLS) are: a set of rules that every developer should adhere to, to make sure their managed assemblies can work even when referenced by applications written with programming languages different from the one used by the developer herself.

In this article, we’re going to focus on writing CLS-Compliant structures in Visual Basic 2008. As an extension, this code will work also in Visual Basic 2005 and .NET 2.0.

Using the code

When you implement your own object types using Visual Basic (typically, writing Structures), you must override some members which are inherited by Structures. You are obliged to do this if you’re writing a CLS-compliant assembly.

Particularly, CLS-compliant structures must override the equality and difference operators, and the Equals and GetHashCode methods.

The last mentioned operation can also be accomplished by implementing the IEqualityComparer interface, which provides definitions for both methods.

The following code shows an example of how to override the operators and the Equals method:

Public Structure MyStructure
   'If our assembly is CLS-Compliant, we have to override some members
   Public Shared Operator =(ByVal obj1 As MyStructure, _
          ByVal obj2 As MyStructure) As Boolean
       Return obj1.Equals(obj2)
   End Operator
   Public Shared Operator <>(ByVal obj1 As MyStructure, _
          ByVal obj2 As MyStructure) As Boolean
       Return Not obj1.Equals(obj2)
   End Operator
   Public Overrides Function Equals(ByVal obj As Object) As Boolean
       Return Object.Equals(Me, obj)
   End Function
  'Add other code here
  ............
End Structure

To compare two objects, we can call the shared method Equals, which is provided by the Object class.

Points of interest

This is just an example, but I think it’s really important to take care of such situations when writing CLS-compliant class libraries. Anyway, remember that if you want to be sure of your assembly being CLS-compliant, you can analyze it with the free Microsoft FxCop analysis tool.

License

This article has no explicit license attached to it but may contain usage terms in the article text or the download files themselves. If in doubt please contact the author via the discussion board below.

A list of licenses authors might use can be found here