Importing a Type Library as an Assembly

COM type definitions usually reside in a type library. In contrast, CLS-compliant compilers produce type metadata in an assembly. The two sources of type information are quite different. This topic describes techniques for generating metadata from a type library. The resulting assembly is called an interop assembly, and the type information it contains enables .NET Framework applications to use COM types.

There are two ways to make this type information available to your application:

  • Using design-time-only interop assemblies: Beginning with the .NET Framework version 4, you can instruct the compiler to embed type information from the interop assembly into your executable. The compiler embeds only the type information that your application uses. You do not have to deploy the interop assembly with your application. This is the recommended technique.

  • Deploying interop assemblies: You can create a standard reference to the interop assembly. In this case, the interop assembly must be deployed with your application. If you employ this technique, and you are not using a private COM component, always reference the primary interop assembly (PIA) published by the author of the COM component you intend to incorporate in your managed code. For more information about producing and using primary interop assemblies, see Primary Interop Assemblies.

When you use design-time-only interop assemblies, you can embed type information from the primary interop assembly published by the author of the COM component. However, you do not have to deploy the primary interop assembly with your application.

Using design-time-only interop assemblies reduces the size of your application, because most applications do not use all the features of a COM component. The compiler is very efficient when it embeds type information; if your application uses only some of the methods on a COM interface, the compiler does not embed the unused methods. When an application that has embedded type information interacts with another such application, or interacts with an application that uses a primary interop assembly, the common language runtime uses type equivalence rules to determine whether two types with the same name represent the same COM type. You do not have to know these rules to use COM objects. However, if you are interested in the rules, see Type Equivalence and Embedded Interop Types.

Generating Metadata

COM type libraries can be stand-alone files that have a .tlb extension, such as Loanlib.tlb. Some type libraries are embedded in the resource section of a .dll or .exe file. Other sources of type library information are .olb and .ocx files.

After you locate the type library that contains the implementation of your target COM type, you have the following options for generating an interop assembly containing type metadata:

  • Visual Studio

    Visual Studio automatically converts COM types in a type library to metadata in an assembly. For instructions, see How to: Add References to Type Libraries and Walkthrough: Embedding Type Information from Microsoft Office Assemblies (C# and Visual Basic).

  • Type Library Importer (Tlbimp.exe)

    The Type Library Importer provides command-line options to adjust metadata in the resulting interop file, imports types from an existing type library, and generates an interop assembly and a namespace. For instructions, see How to: Generate Interop Assemblies from Type Libraries.

  • System.Runtime.InteropServices.TypeLibConverter class

    This class provides methods to convert coclasses and interfaces in a type library to metadata within an assembly. It produces the same metadata output as Tlbimp.exe. However, unlike Tlbimp.exe, the TypeLibConverter class can convert an in-memory type library to metadata.

  • Custom wrappers

    When a type library is unavailable or incorrect, one option is to create a duplicate definition of the class or interface in managed source code. You then compile the source code with a compiler that targets the runtime to produce metadata in an assembly.

    To define COM types manually, you must have access to the following items:

    • Precise descriptions of the coclasses and interfaces being defined.

    • A compiler, such as the C# compiler, that can generate the appropriate .NET Framework class definitions.

    • Knowledge of the type library-to-assembly conversion rules.

    Writing a custom wrapper is an advanced technique. For additional information about how to generate a custom wrapper, see Customizing Standard Wrappers.

For more information about the COM interop import process, see Type Library to Assembly Conversion Summary.

See Also

Tasks

How to: Add References to Type Libraries

How to: Generate Interop Assemblies from Type Libraries

Walkthrough: Embedding Type Information from Microsoft Office Assemblies (C# and Visual Basic)

Reference

Tlbimp.exe (Type Library Importer)

TypeLibConverter

Concepts

Exposing COM Components to the .NET Framework

Customizing Standard Wrappers

Using COM Types in Managed Code

Compiling an Interop Project

Deploying an Interop Application

Other Resources

Type Library to Assembly Conversion Summary