TypeLibConverter.ConvertTypeLibToAssembly Metodo

Definizione

Converte una libreria dei tipi COM in un assembly.

Overload

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

Converte una libreria dei tipi COM in un 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

Parametri

typeLib
Object

Oggetto che implementa l'interfaccia ITypeLib .

asmFileName
String

Nome file dell'assembly risultante.

flags
Int32

Valore TypeLibImporterFlags che indica eventuali impostazioni speciali.

notifySink
ITypeLibImporterNotifySink

ITypeLibImporterNotifySink interfaccia implementata dal chiamante.

publicKey
Byte[]

Matrice byte contenente la chiave pubblica.

keyPair
StrongNameKeyPair

Oggetto StrongNameKeyPair contenente la coppia di chiavi di crittografia pubblica e privata.

unsafeInterfaces
Boolean

Se true, le interfacce richiedono controlli relativi all'ora di collegamento per UnmanagedCode l'autorizzazione. Se false, le interfacce richiedono controlli di runtime che richiedono una procedura dettagliata dello stack e sono più costosi, ma contribuiscono a garantire una maggiore protezione.

Valori restituiti

Oggetto AssemblyBuilder contenente la libreria dei tipi convertita.

Implementazioni

Eccezioni

typeLib è null.

oppure

asmFileName è null.

oppure

notifySink è null.

asmFileName è una stringa vuota.

oppure

asmFileName è maggiore della lunghezza massima definita dal sistema. Per altre informazioni, vedere PathTooLongException.

flags non PrimaryInteropAssemblyè .

oppure

publicKey e keyPair sono null.

I metadati generati hanno errori che impediscono il caricamento di qualsiasi tipo.

Commenti

Se non si vuole generare un nome sicuro per l'assembly, è valido per publicKey e deve essere keyPair, purché null non sia uguale flagsTypeLibImporterFlags.PrimaryInteropAssembly a . In caso contrario, è necessario specificare almeno uno di questi parametri. Se publicKey è null, la chiave pubblica in keyPair verrà impostata nei metadati del manifesto dell'assembly di destinazione e verrà generata una firma in base al contenuto dell'assembly. Se keyPair è null, publicKey verrà impostato nei metadati del manifesto dell'assembly di destinazione e non verrà generata alcuna firma. La specifica di entrambi i parametri non è in genere utile e può comportare una firma non valida.

Per altre informazioni su ITypeLib, vedere la relativa documentazione esistente in MSDN Library.

Si applica a

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

Converte una libreria dei tipi COM in un 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

Parametri

typeLib
Object

Oggetto che implementa l'interfaccia ITypeLib .

asmFileName
String

Nome file dell'assembly risultante.

flags
TypeLibImporterFlags

Valore TypeLibImporterFlags che indica eventuali impostazioni speciali.

notifySink
ITypeLibImporterNotifySink

ITypeLibImporterNotifySink interfaccia implementata dal chiamante.

publicKey
Byte[]

Matrice byte contenente la chiave pubblica.

keyPair
StrongNameKeyPair

Oggetto StrongNameKeyPair contenente la coppia di chiavi di crittografia pubblica e privata.

asmNamespace
String

Spazio dei nomi per l'assembly risultante.

asmVersion
Version

Versione dell'assembly risultante. Se null, viene utilizzata la versione della libreria dei tipi.

Valori restituiti

Oggetto AssemblyBuilder contenente la libreria dei tipi convertita.

Implementazioni

Eccezioni

typeLib è null.

oppure

asmFileName è null.

oppure

notifySink è null.

asmFileName è una stringa vuota.

oppure

asmFileName è maggiore della lunghezza massima definita dal sistema. Per altre informazioni, vedere PathTooLongException.

flags non PrimaryInteropAssemblyè .

oppure

publicKey e keyPair sono null.

I metadati generati hanno errori che impediscono il caricamento di qualsiasi tipo.

Esempio

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

Commenti

Se non si vuole generare un nome sicuro per l'assembly, è valido per publicKey e deve essere keyPair, purché null non sia uguale flagsTypeLibImporterFlags.PrimaryInteropAssembly a . In caso contrario, è necessario specificare uno di questi parametri. Se publicKey è null, la chiave pubblica in keyPair verrà impostata nei metadati del manifesto dell'assembly di destinazione e verrà generata una firma in base al contenuto dell'assembly. Se keyPair è null, publicKey verrà impostato nei metadati del manifesto dell'assembly di destinazione e non verrà generata alcuna firma. La specifica di entrambi i parametri non è in genere utile e può comportare una firma non valida.

Per altre informazioni su ITypeLib, vedere la relativa documentazione esistente in MSDN Library.

Si applica a