Section 22.3. Exporting .NET Components


22.3. Exporting .NET Components

You can export your .NET class for use with existing COM components. The Regasm tool will register the metadata from your component in the System Registry.

Invoke Regasm with the name of the DLL, which must be installed in the GAC (see Chapter 17). For example:

Regasm myAssembly.dll

This will export your component's metadata to the Registry. For example, you can create a new C# DLL project in which you recreate your four-function calculator, as shown in Example 22-8.

Example 22-8. The four-function calculator in a DLL
using System; using System.Reflection; [assembly: AssemblyKeyFile("test.key")] namespace Programming_CSharp {     public class Calculator     {         public Calculator( )         {                      }         public Double Add (Double left, Double right)         {             return left + right;         }         public Double Subtract (Double left, Double right)         {             return left - right;         }         public Double Multiply (Double left, Double right)         {             return left * right;         }         public Double Divide (Double left, Double right)         {             return left / right;         }     } }

Save this to a file named Calculator.cs in a project named ProgrammingCSharpDLL. To create a strong name, click Project ProgrammingCSharpDLL Properties. Choose the Signing tab and sign the assembly, as shown in Figure 22-17.

Figure 22-17. Creating a key within Visual Studio


This will open the Create Key dialog, as shown in Figure 22-18.

Figure 22-18. Creating a strong name key


Add your program to the GAC, and register it:

gacutil /i ProgrammingCSharpDLL.dll Regasm ProgrammingCSharpDLL.dll

You can now invoke the four-function calculator as a COM object using standard VBScript. For example, you can create a tiny Windows-script host file, as shown in Example 22-9.

Example 22-9. Invoking the calculator COM object with a Windows-scripting host file
dim calc dim msg  dim result  set calc = CreateObject("Programming_CSharp.Calculator")  result = calc.Multiply(7,3)  msg = "7 * 3 =" & result & "." Call MsgBox(msg)

When this is run, a dialog box pops up to verify that the object was created and invoked, as shown in Figure 22-19.

Figure 22-19. Late binding via COM


22.3.1. Creating a Type Library

If you wish to use early binding with your .NET DLL, you'll typically create a type library. You can do so with the TlbExp (Type Library Export) utility, by writing:

TlbExp ProgrammingCSharpDLL.dll /out:Calc.tlb

The result is a type library that you can browse and view in the OLE/COM object viewer, as shown in Figure 22-20.

Figure 22-20. Viewing the type library contents


With this type library in hand, you can import the calculator class into any COM environment.



Programming C#(c) Building. NET Applications with C#
Programming C#: Building .NET Applications with C#
ISBN: 0596006993
EAN: 2147483647
Year: 2003
Pages: 180
Authors: Jesse Liberty

flylib.com © 2008-2017.
If you may any questions please contact us: flylib@qtcs.net