TypeLibConverter.ConvertTypeLibToAssembly Método
Definição
Importante
Algumas informações dizem respeito a um produto pré-lançado que pode ser substancialmente modificado antes de ser lançado. A Microsoft não faz garantias, de forma expressa ou implícita, em relação à informação aqui apresentada.
Converte uma biblioteca de tipos COM numa assembleia.
Sobrecargas
| Name | Description |
|---|---|
| ConvertTypeLibToAssembly(Object, String, Int32, ITypeLibImporterNotifySink, Byte[], StrongNameKeyPair, Boolean) |
Converte uma biblioteca de tipos COM numa assembleia. |
| ConvertTypeLibToAssembly(Object, String, TypeLibImporterFlags, ITypeLibImporterNotifySink, Byte[], StrongNameKeyPair, String, Version) |
Converte uma biblioteca de tipos COM numa assembleia. |
ConvertTypeLibToAssembly(Object, String, Int32, ITypeLibImporterNotifySink, Byte[], StrongNameKeyPair, Boolean)
Converte uma biblioteca de tipos COM numa assembleia.
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
Parâmetros
- typeLib
- Object
O objeto que implementa a ITypeLib interface.
- asmFileName
- String
O nome do ficheiro do conjunto resultante.
- flags
- Int32
Um valor que TypeLibImporterFlags indica quaisquer configurações especiais.
- notifySink
- ITypeLibImporterNotifySink
ITypeLibImporterNotifySink Interface implementada pelo interlocutor.
- publicKey
- Byte[]
Um byte array contendo a chave pública.
- keyPair
- StrongNameKeyPair
Um StrongNameKeyPair objeto que contém o par de chaves criptográficas pública e privada.
- unsafeInterfaces
- Boolean
Se true, as interfaces requerem verificações de tempo de ligação para obter UnmanagedCode permissões. Se false, as interfaces requerem verificações em tempo de execução que exigem uma caminhada pela pilha e são mais caras, mas ajudam a proporcionar maior proteção.
Devoluções
Um AssemblyBuilder objeto que contém a biblioteca de tipos convertida.
Implementações
Exceções
asmFileName é uma corda vazia.
-ou-
asmFileName é maior do que o comprimento máximo definido pelo sistema. Para obter mais informações, veja PathTooLongException.
Os metadados produzidos apresentam erros que impedem o carregamento de qualquer tipo.
Observações
Se não quiser gerar um nome forte para a sua assembleia, é válida para publicKey e para ser keyPair, desde que null não seja igual flagsa .TypeLibImporterFlags.PrimaryInteropAssembly Caso contrário, pelo menos um destes parâmetros deve ser especificado. Se publicKey for null, a chave pública será keyPair definida nos metadados manifestos da assembleia alvo e será gerada uma assinatura com base no conteúdo da assembleia. Se keyPair for null, publicKey será definido nos metadados manifestos da assembleia alvo e não será gerada assinatura. Especificar ambos os parâmetros geralmente não é útil e pode resultar numa assinatura inválida.
Para mais informações sobre ITypeLib, por favor consulte a documentação existente na biblioteca MSDN.
Aplica-se a
ConvertTypeLibToAssembly(Object, String, TypeLibImporterFlags, ITypeLibImporterNotifySink, Byte[], StrongNameKeyPair, String, Version)
Converte uma biblioteca de tipos COM numa assembleia.
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
Parâmetros
- typeLib
- Object
O objeto que implementa a ITypeLib interface.
- asmFileName
- String
O nome do ficheiro do conjunto resultante.
- flags
- TypeLibImporterFlags
Um valor que TypeLibImporterFlags indica quaisquer configurações especiais.
- notifySink
- ITypeLibImporterNotifySink
ITypeLibImporterNotifySink Interface implementada pelo interlocutor.
- publicKey
- Byte[]
Um byte array contendo a chave pública.
- keyPair
- StrongNameKeyPair
Um StrongNameKeyPair objeto que contém o par de chaves criptográficas pública e privada.
- asmNamespace
- String
O espaço de nomes para a assembleia resultante.
- asmVersion
- Version
A versão do conjunto resultante. Se null, a versão da biblioteca de tipos é utilizada.
Devoluções
Um AssemblyBuilder objeto que contém a biblioteca de tipos convertida.
Implementações
Exceções
asmFileName é uma corda vazia.
-ou-
asmFileName é maior do que o comprimento máximo definido pelo sistema. Para obter mais informações, veja PathTooLongException.
Os metadados produzidos apresentam erros que impedem o carregamento de qualquer tipo.
Exemplos
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
Observações
Se não quiser gerar um nome forte para a sua assembleia, é válida para publicKey e para ser keyPair, desde que null não seja igual flagsa .TypeLibImporterFlags.PrimaryInteropAssembly Caso contrário, pelo menos um destes parâmetros deve ser especificado. Se publicKey for null, a chave pública será keyPair definida nos metadados manifestos da assembleia alvo e será gerada uma assinatura com base no conteúdo da assembleia. Se keyPair for null, publicKey será definido nos metadados manifestos da assembleia alvo e não será gerada assinatura. Especificar ambos os parâmetros geralmente não é útil e pode resultar numa assinatura inválida.
Para mais informações sobre ITypeLib, por favor consulte a documentação existente na biblioteca MSDN.