Поделиться через


TypeLibConverter.ConvertTypeLibToAssembly Метод

Определение

Преобразует библиотеку COM-типов в сборку.

Перегрузки

ConvertTypeLibToAssembly(Object, String, Int32, ITypeLibImporterNotifySink, Byte[], StrongNameKeyPair, Boolean)

Преобразует библиотеку COM-типов в сборку.

ConvertTypeLibToAssembly(Object, String, TypeLibImporterFlags, ITypeLibImporterNotifySink, Byte[], StrongNameKeyPair, String, Version)

Преобразует библиотеку COM-типов в сборку.

ConvertTypeLibToAssembly(Object, String, Int32, ITypeLibImporterNotifySink, Byte[], StrongNameKeyPair, Boolean)

Преобразует библиотеку COM-типов в сборку.

public:
 virtual System::Reflection::Emit::AssemblyBuilder ^ ConvertTypeLibToAssembly(System::Object ^ typeLib, System::String ^ asmFileName, int flags, System::Runtime::InteropServices::ITypeLibImporterNotifySink ^ notifySink, cli::array <System::Byte> ^ publicKey, System::Reflection::StrongNameKeyPair ^ keyPair, bool unsafeInterfaces);
public System.Reflection.Emit.AssemblyBuilder ConvertTypeLibToAssembly (object typeLib, string asmFileName, int flags, System.Runtime.InteropServices.ITypeLibImporterNotifySink notifySink, byte[] publicKey, System.Reflection.StrongNameKeyPair keyPair, bool unsafeInterfaces);
abstract member ConvertTypeLibToAssembly : obj * string * int * System.Runtime.InteropServices.ITypeLibImporterNotifySink * byte[] * System.Reflection.StrongNameKeyPair * bool -> System.Reflection.Emit.AssemblyBuilder
override this.ConvertTypeLibToAssembly : obj * string * int * System.Runtime.InteropServices.ITypeLibImporterNotifySink * byte[] * System.Reflection.StrongNameKeyPair * bool -> System.Reflection.Emit.AssemblyBuilder
Public Function ConvertTypeLibToAssembly (typeLib As Object, asmFileName As String, flags As Integer, notifySink As ITypeLibImporterNotifySink, publicKey As Byte(), keyPair As StrongNameKeyPair, unsafeInterfaces As Boolean) As AssemblyBuilder

Параметры

typeLib
Object

Объект, реализующий интерфейс ITypeLib.

asmFileName
String

Имя файла итоговой сборки.

flags
Int32

Значение TypeLibImporterFlags, указывающее любые специальные параметры.

notifySink
ITypeLibImporterNotifySink

Интерфейс ITypeLibImporterNotifySink, реализованный вызывающим объектом.

publicKey
Byte[]

Массив byte, содержащий открытый ключ.

keyPair
StrongNameKeyPair

Объект StrongNameKeyPair, содержащий пару криптографических ключей — открытый и закрытый.

unsafeInterfaces
Boolean

Если значение равно true, для интерфейса необходимы проверки времени компоновки для разрешения UnmanagedCode. Если значение равно false, для интерфейсов необходимы проверки во время выполнения, для которых требуется проверка стека. Они более ресурсоемки, но обеспечивают более высокую безопасность.

Возвращаемое значение

Объект AssemblyBuilder, содержащий преобразованную библиотеку типов.

Реализации

Исключения

typeLib имеет значение null.

-или-

asmFileName имеет значение null.

-или-

notifySink имеет значение null.

Параметр asmFileName равен пустой строке.

-или-

asmFileName длиннее заданной системой максимальной длины. Для получения дополнительной информации см. PathTooLongException.

flags не является PrimaryInteropAssembly.

-или-

Значения параметров publicKey и keyPair равны null.

Созданные метаданные содержат ошибки, препятствующие загрузке типов.

Комментарии

Если вы не хотите создавать строгое имя для сборки, оно допустимо для publicKey и , если nullflags не равно TypeLibImporterFlags.PrimaryInteropAssemblykeyPair . В противном случае необходимо указать хотя бы один из этих параметров. Если publicKey имеет значение null, открытый ключ в keyPair будет задан в метаданных манифеста целевой сборки, а на основе содержимого сборки будет создана сигнатура. Если keyPair имеет значение null, publicKey будет задано в метаданных манифеста целевой сборки, и сигнатура не будет создана. Указание обоих параметров обычно не является полезным и может привести к недопустимой сигнатуре.

Дополнительные сведения о ITypeLibсм. в существующей документации в библиотеке MSDN.

Применяется к

ConvertTypeLibToAssembly(Object, String, TypeLibImporterFlags, ITypeLibImporterNotifySink, Byte[], StrongNameKeyPair, String, Version)

Преобразует библиотеку COM-типов в сборку.

public:
 virtual System::Reflection::Emit::AssemblyBuilder ^ ConvertTypeLibToAssembly(System::Object ^ typeLib, System::String ^ asmFileName, System::Runtime::InteropServices::TypeLibImporterFlags flags, System::Runtime::InteropServices::ITypeLibImporterNotifySink ^ notifySink, cli::array <System::Byte> ^ publicKey, System::Reflection::StrongNameKeyPair ^ keyPair, System::String ^ asmNamespace, Version ^ asmVersion);
public System.Reflection.Emit.AssemblyBuilder ConvertTypeLibToAssembly (object typeLib, string asmFileName, System.Runtime.InteropServices.TypeLibImporterFlags flags, System.Runtime.InteropServices.ITypeLibImporterNotifySink notifySink, byte[] publicKey, System.Reflection.StrongNameKeyPair keyPair, string asmNamespace, Version asmVersion);
abstract member ConvertTypeLibToAssembly : obj * string * System.Runtime.InteropServices.TypeLibImporterFlags * System.Runtime.InteropServices.ITypeLibImporterNotifySink * byte[] * System.Reflection.StrongNameKeyPair * string * Version -> System.Reflection.Emit.AssemblyBuilder
override this.ConvertTypeLibToAssembly : obj * string * System.Runtime.InteropServices.TypeLibImporterFlags * System.Runtime.InteropServices.ITypeLibImporterNotifySink * byte[] * System.Reflection.StrongNameKeyPair * string * Version -> System.Reflection.Emit.AssemblyBuilder
Public Function ConvertTypeLibToAssembly (typeLib As Object, asmFileName As String, flags As TypeLibImporterFlags, notifySink As ITypeLibImporterNotifySink, publicKey As Byte(), keyPair As StrongNameKeyPair, asmNamespace As String, asmVersion As Version) As AssemblyBuilder

Параметры

typeLib
Object

Объект, реализующий интерфейс ITypeLib.

asmFileName
String

Имя файла итоговой сборки.

flags
TypeLibImporterFlags

Значение TypeLibImporterFlags, указывающее любые специальные параметры.

notifySink
ITypeLibImporterNotifySink

Интерфейс ITypeLibImporterNotifySink, реализованный вызывающим объектом.

publicKey
Byte[]

Массив byte, содержащий открытый ключ.

keyPair
StrongNameKeyPair

Объект StrongNameKeyPair, содержащий пару криптографических ключей — открытый и закрытый.

asmNamespace
String

Пространство имен для итоговой сборки.

asmVersion
Version

Версия итоговой сборки. Если значение равно null, используется версия библиотеки типов.

Возвращаемое значение

Объект AssemblyBuilder, содержащий преобразованную библиотеку типов.

Реализации

Исключения

typeLib имеет значение null.

-или-

asmFileName имеет значение null.

-или-

notifySink имеет значение null.

Параметр asmFileName равен пустой строке.

-или-

asmFileName длиннее заданной системой максимальной длины. Для получения дополнительной информации см. PathTooLongException.

flags не является PrimaryInteropAssembly.

-или-

Значения параметров publicKey и keyPair равны null.

Созданные метаданные содержат ошибки, препятствующие загрузке типов.

Примеры

using namespace System;
using namespace System::Reflection;
using namespace System::Reflection::Emit;
using namespace System::Runtime::InteropServices;

enum class RegKind
{
   RegKind_Default, RegKind_Register, RegKind_None
};

ref class ConversionEventHandler: public ITypeLibImporterNotifySink
{
public:
   virtual void ReportEvent( ImporterEventKind eventKind, int eventCode, String^ eventMsg )
   {
      
      // handle warning event here...
   }

   virtual Assembly^ ResolveRef( Object^ typeLib )
   {
      
      // resolve reference here and return a correct assembly...
      return nullptr;
   }

};


[DllImport("oleaut32.dll",CharSet=CharSet::Unicode,PreserveSig=false)]
extern void LoadTypeLibEx( String^ strTypeLibName, RegKind regkind,
         [MarshalAs(UnmanagedType::Interface)] interior_ptr<Object^> typeLib );

int main()
{
   Object^ typeLib = gcnew Object;
   LoadTypeLibEx( "SHDocVw.dll", RegKind::RegKind_None,  &typeLib );
   if ( typeLib == nullptr )
   {
      Console::WriteLine( "LoadTypeLibEx failed." );
      return 0;
   }

   TypeLibConverter^ converter = gcnew TypeLibConverter;
   ConversionEventHandler^ eventHandler = gcnew ConversionEventHandler;
   AssemblyBuilder^ asmb = converter->ConvertTypeLibToAssembly( typeLib, "ExplorerLib.dll", (System::Runtime::InteropServices::TypeLibImporterFlags)0, eventHandler, nullptr, nullptr, nullptr, nullptr );
   asmb->Save( "ExplorerLib.dll" );
}
using System;
using System.Reflection;
using System.Reflection.Emit;
using System.Runtime.InteropServices;

public class App
{
    private enum RegKind
    {
        RegKind_Default = 0,
        RegKind_Register = 1,
        RegKind_None = 2
    }
    
    [ DllImport( "oleaut32.dll", CharSet = CharSet.Unicode, PreserveSig = false )]
    private static extern void LoadTypeLibEx( String strTypeLibName, RegKind regKind, 
        [ MarshalAs( UnmanagedType.Interface )] out Object typeLib );
    
    public static void Main()
    {
        Object typeLib;
        LoadTypeLibEx( "SHDocVw.dll", RegKind.RegKind_None, out typeLib ); 
        
        if( typeLib == null )
        {
            Console.WriteLine( "LoadTypeLibEx failed." );
            return;
        }
            
        TypeLibConverter converter = new TypeLibConverter();
        ConversionEventHandler eventHandler = new ConversionEventHandler();
        AssemblyBuilder asm = converter.ConvertTypeLibToAssembly( typeLib, "ExplorerLib.dll", 0, eventHandler, null, null, null, null );	
        asm.Save( "ExplorerLib.dll" );
    }
}

public class ConversionEventHandler : ITypeLibImporterNotifySink
{
    public void ReportEvent( ImporterEventKind eventKind, int eventCode, string eventMsg )
    {
        // handle warning event here...
    }
    
    public Assembly ResolveRef( object typeLib )
    {
        // resolve reference here and return a correct assembly...
        return null; 
    }	
}
Imports System.Reflection
Imports System.Reflection.Emit
Imports System.Runtime.InteropServices

Public Class App
    Private Enum RegKind
        RegKind_Default = 0
        RegKind_Register = 1
        RegKind_None = 2
    End Enum 'RegKind

    <DllImport("oleaut32.dll", CharSet:=CharSet.Unicode, PreserveSig:=False)> _
    Private Shared Sub LoadTypeLibEx(ByVal strTypeLibName As [String], ByVal regKind As RegKind, <MarshalAs(UnmanagedType.Interface)> ByRef typeLib As [Object])
    End Sub

    Public Shared Sub Main()
        Dim typeLib As [Object]
        LoadTypeLibEx("SHDocVw.dll", RegKind.RegKind_None, typeLib)

        If typeLib Is Nothing Then
            Console.WriteLine("LoadTypeLibEx failed.")
            Return
        End If

        Dim converter As New TypeLibConverter()
        Dim eventHandler As New ConversionEventHandler()
        Dim asm As AssemblyBuilder = converter.ConvertTypeLibToAssembly(typeLib, "ExplorerLib.dll", 0, eventHandler, Nothing, Nothing, Nothing, Nothing)
        asm.Save("ExplorerLib.dll")
    End Sub
End Class
 _

Public Class ConversionEventHandler
    Implements ITypeLibImporterNotifySink

    Public Sub ReportEvent(ByVal eventKind As ImporterEventKind, ByVal eventCode As Integer, ByVal eventMsg As String) Implements ITypeLibImporterNotifySink.ReportEvent
        ' handle warning event here...
    End Sub

    Public Function ResolveRef(ByVal typeLib As Object) As [Assembly] Implements ITypeLibImporterNotifySink.ResolveRef
        ' resolve reference here and return a correct assembly...
        Return Nothing
    End Function 'ResolveRef
End Class

Комментарии

Если вы не хотите создавать строгое имя для сборки, оно допустимо для publicKey и , если nullflags не равно TypeLibImporterFlags.PrimaryInteropAssemblykeyPair . В противном случае необходимо указать один из этих параметров. Если publicKey имеет значение null, открытый ключ в keyPair будет задан в метаданных манифеста целевой сборки, а на основе содержимого сборки будет создана сигнатура. Если keyPair имеет значение null, publicKey будет задано в метаданных манифеста целевой сборки, и сигнатура не будет создана. Указание обоих параметров обычно не является полезным и может привести к недопустимой сигнатуре.

Дополнительные сведения о ITypeLibсм. в существующей документации в библиотеке MSDN.

Применяется к