Freigeben über


TypeLibConverter.ConvertTypeLibToAssembly Methode

Definition

Konvertiert eine COM-Typbibliothek in eine Assembly.

Überlädt

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

Konvertiert eine COM-Typbibliothek in eine Assembly.

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

Konvertiert eine COM-Typbibliothek in eine Assembly.

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

Konvertiert eine COM-Typbibliothek in eine Assembly.

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

Parameter

typeLib
Object

Das Objekt, das die ITypeLib-Schnittstelle implementiert.

asmFileName
String

Der Dateiname der resultierenden Assembly.

flags
Int32

Ein TypeLibImporterFlags-Wert, der alle speziellen Einstellungen angibt.

notifySink
ITypeLibImporterNotifySink

Die vom Aufrufer implementierte ITypeLibImporterNotifySink-Schnittstelle.

publicKey
Byte[]

Ein byte-Array, das den öffentlichen Schlüssel enthält.

keyPair
StrongNameKeyPair

Ein StrongNameKeyPair-Objekt, das das kryptografische Schlüsselpaar aus öffentlichem und privatem Schlüssel enthält.

unsafeInterfaces
Boolean

Wenn true, erfordert die Schnittstelle Überprüfungen in der Bindungsphase für die UnmanagedCode-Berechtigung. Wenn false, erfordern die Schnittstellen Laufzeitüberprüfungen, bei denen ein Stackwalk durchgeführt werden muss. Diese sind aufwendiger, aber sicherer.

Gibt zurück

Ein AssemblyBuilder-Objekt, das die konvertierte Typbibliothek enthält.

Implementiert

Ausnahmen

typeLib ist null.

- oder -

asmFileName ist null.

- oder -

notifySink ist null.

asmFileName ist eine leere Zeichenfolge.

- oder -

asmFileName übersteigt die vom System definierte Höchstlänge. Weitere Informationen finden Sie unter PathTooLongException.

flags ist nicht PrimaryInteropAssembly.

- oder -

publicKey und keyPair sind null.

Die erstellten Metadaten enthalten Fehler, die das Laden von Typen verhindern.

Hinweise

Wenn Sie keinen starken Namen für Ihre Assembly generieren möchten, ist er gültig für publicKey und keyPair , nullsolange flags nicht gleich TypeLibImporterFlags.PrimaryInteropAssemblyist. Andernfalls muss mindestens einer dieser Parameter angegeben werden. Wenn publicKey dies der Fall ist null, wird der öffentliche Schlüssel in keyPair in den Manifestmetadaten der Zielassembly festgelegt, und eine Signatur wird basierend auf dem Inhalt der Assembly generiert. Wenn keyPair ist null, publicKey wird in den Manifestmetadaten der Zielassembly festgelegt, und es wird keine Signatur generiert. Das Angeben beider Parameter ist im Allgemeinen nicht nützlich und kann zu einer ungültigen Signatur führen.

Weitere Informationen zu ITypeLibfinden Sie in der vorhandenen Dokumentation in der MSDN Library.

Gilt für:

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

Konvertiert eine COM-Typbibliothek in eine Assembly.

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

Parameter

typeLib
Object

Das Objekt, das die ITypeLib-Schnittstelle implementiert.

asmFileName
String

Der Dateiname der resultierenden Assembly.

flags
TypeLibImporterFlags

Ein TypeLibImporterFlags-Wert, der alle speziellen Einstellungen angibt.

notifySink
ITypeLibImporterNotifySink

Die vom Aufrufer implementierte ITypeLibImporterNotifySink-Schnittstelle.

publicKey
Byte[]

Ein byte-Array, das den öffentlichen Schlüssel enthält.

keyPair
StrongNameKeyPair

Ein StrongNameKeyPair-Objekt, das das kryptografische Schlüsselpaar aus öffentlichem und privatem Schlüssel enthält.

asmNamespace
String

Der Namespace für die resultierende Assembly.

asmVersion
Version

Die Version der resultierenden Assembly. Wenn null, wird die Version der Typbibliothek verwendet.

Gibt zurück

Ein AssemblyBuilder-Objekt, das die konvertierte Typbibliothek enthält.

Implementiert

Ausnahmen

typeLib ist null.

- oder -

asmFileName ist null.

- oder -

notifySink ist null.

asmFileName ist eine leere Zeichenfolge.

- oder -

asmFileName übersteigt die vom System definierte Höchstlänge. Weitere Informationen finden Sie unter PathTooLongException.

flags ist nicht PrimaryInteropAssembly.

- oder -

publicKey und keyPair sind null.

Die erstellten Metadaten enthalten Fehler, die das Laden von Typen verhindern.

Beispiele

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

Hinweise

Wenn Sie keinen starken Namen für Ihre Assembly generieren möchten, ist er gültig für publicKey und keyPair , nullsolange flags nicht gleich TypeLibImporterFlags.PrimaryInteropAssemblyist. Andernfalls muss mindestens einer dieser Parameter angegeben werden. Wenn publicKey dies der Fall ist null, wird der öffentliche Schlüssel in keyPair in den Manifestmetadaten der Zielassembly festgelegt, und eine Signatur wird basierend auf dem Inhalt der Assembly generiert. Wenn keyPair ist null, publicKey wird in den Manifestmetadaten der Zielassembly festgelegt, und es wird keine Signatur generiert. Das Angeben beider Parameter ist im Allgemeinen nicht nützlich und kann zu einer ungültigen Signatur führen.

Weitere Informationen zu ITypeLibfinden Sie in der vorhandenen Dokumentation in der MSDN Library.

Gilt für: