Type Forwarding in the Common Language Runtime
Type forwarding allows you to move a type to another assembly without having to recompile applications that use the original assembly.
For example, suppose an application uses the
Example class in an assembly named
Utility.dll. The developers of
Utility.dll might decide to refactor the assembly, and in the process they might move the
Example class to another assembly. If the old version of
Utility.dll is replaced by the new version of
Utility.dll and its companion assembly, the application that uses the
Example class fails because it cannot locate the
Example class in the new version of
The developers of
Utility.dll can avoid this by forwarding requests for the
Example class, using the TypeForwardedToAttribute attribute. If the attribute has been applied to the new version of
Utility.dll, requests for the
Example class are forwarded to the assembly that now contains the class. The existing application continues to function normally, without recompilation.
In the .NET Framework version 2.0, you cannot forward types from assemblies written in Visual Basic. However, an application written in Visual Basic can consume forwarded types. That is, if the application uses an assembly coded in C# or C++, and a type from that assembly is forwarded to another assembly, the Visual Basic application can use the forwarded type.
There are four steps to forwarding a type:
Move the source code for the type from the original assembly to the destination assembly.
In the assembly where the type used to be located, add a TypeForwardedToAttribute for the type that was moved. The following code shows the attribute for a type named
Examplethat was moved.
Compile the assembly that now contains the type.
Recompile the assembly where the type used to be located, with a reference to the assembly that now contains the type. For example, if you are compiling a C# file from the command line, use the /reference (C# Compiler Options) option to specify the assembly that contains the type. In C++, use the #using directive in the source file to specify the assembly that contains the type.
We'd love to hear your thoughts. Choose the type you'd like to provide:
Our feedback system is built on GitHub Issues. Read more on our blog.