Partager via


TypeLibConverter.ConvertTypeLibToAssembly Méthode

Définition

Convertit une bibliothèque de types COM en assembly.

Surcharges

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

Convertit une bibliothèque de types COM en assembly.

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

Convertit une bibliothèque de types COM en assembly.

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

Convertit une bibliothèque de types COM en 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

Paramètres

typeLib
Object

Objet qui implémente l'interface ITypeLib.

asmFileName
String

Nom de fichier de l’assembly résultant.

flags
Int32

Valeur de TypeLibImporterFlags indiquant d’éventuels paramètres spéciaux.

notifySink
ITypeLibImporterNotifySink

Interface ITypeLibImporterNotifySink implémentée par l’appelant.

publicKey
Byte[]

Tableau byte contenant la clé publique.

keyPair
StrongNameKeyPair

Objet StrongNameKeyPair contenant la paire de clés de chiffrement publique et privée.

unsafeInterfaces
Boolean

Si la valeur est true, les interfaces nécessitent des vérifications lors de l’édition des liens pour l’autorisation UnmanagedCode. Si la valeur est false, les interfaces nécessitent des vérifications lors de l’exécution qui obligent à un parcours de la pile et sont moins économiques, mais qui offrent une meilleure protection.

Retours

Objet AssemblyBuilder contenant la bibliothèque de types convertie.

Implémente

Exceptions

typeLib a la valeur null.

-ou-

asmFileName a la valeur null.

-ou-

notifySink a la valeur null.

asmFileName est une chaîne vide.

- ou -

asmFileName dépasse la longueur maximale définie par le système. Pour plus d'informations, consultez PathTooLongException.

flags n’est pas un PrimaryInteropAssembly.

- ou -

publicKey et keyPair sont null.

Les métadonnées produites comportent des erreurs qui empêchent tout chargement de type.

Remarques

Si vous ne souhaitez pas générer de nom fort pour votre assembly, il est valide pour publicKey et keyPair pour être null, tant que flags n’est pas égal TypeLibImporterFlags.PrimaryInteropAssemblyà . Sinon, au moins un de ces paramètres doit être spécifié. Si publicKey a la valeur null, la clé publique dans keyPair est définie dans les métadonnées du manifeste de l’assembly cible et une signature est générée en fonction du contenu de l’assembly. Si keyPair est null, publicKey est défini dans les métadonnées du manifeste de l’assembly cible et aucune signature n’est générée. La spécification des deux paramètres n’est généralement pas utile et peut entraîner une signature non valide.

Pour plus d’informations sur ITypeLib, consultez sa documentation existante dans la bibliothèque MSDN.

S’applique à

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

Convertit une bibliothèque de types COM en 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

Paramètres

typeLib
Object

Objet qui implémente l'interface ITypeLib.

asmFileName
String

Nom de fichier de l’assembly résultant.

flags
TypeLibImporterFlags

Valeur de TypeLibImporterFlags indiquant d’éventuels paramètres spéciaux.

notifySink
ITypeLibImporterNotifySink

Interface ITypeLibImporterNotifySink implémentée par l’appelant.

publicKey
Byte[]

Tableau byte contenant la clé publique.

keyPair
StrongNameKeyPair

Objet StrongNameKeyPair contenant la paire de clés de chiffrement publique et privée.

asmNamespace
String

Espace de noms pour l’assembly résultant.

asmVersion
Version

Version de l’assembly résultant. Si la valeur est null, la version de la bibliothèque de types est utilisée.

Retours

Objet AssemblyBuilder contenant la bibliothèque de types convertie.

Implémente

Exceptions

typeLib a la valeur null.

-ou-

asmFileName a la valeur null.

-ou-

notifySink a la valeur null.

asmFileName est une chaîne vide.

- ou -

asmFileName dépasse la longueur maximale définie par le système. Pour plus d'informations, consultez PathTooLongException.

flags n’est pas un PrimaryInteropAssembly.

- ou -

publicKey et keyPair sont null.

Les métadonnées produites comportent des erreurs qui empêchent tout chargement de type.

Exemples

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

Remarques

Si vous ne souhaitez pas générer de nom fort pour votre assembly, il est valide pour publicKey et keyPair pour être null, tant que flags n’est pas égal TypeLibImporterFlags.PrimaryInteropAssemblyà . Sinon, au moins l’un de ces paramètres doit être spécifié. Si publicKey a la valeur null, la clé publique dans keyPair est définie dans les métadonnées du manifeste de l’assembly cible et une signature est générée en fonction du contenu de l’assembly. Si keyPair est null, publicKey est défini dans les métadonnées du manifeste de l’assembly cible et aucune signature n’est générée. La spécification des deux paramètres n’est généralement pas utile et peut entraîner une signature non valide.

Pour plus d’informations sur ITypeLib, consultez sa documentation existante dans la bibliothèque MSDN.

S’applique à