TypeLibConverter.ConvertTypeLibToAssembly Metode
Definisi
Penting
Beberapa informasi terkait produk prarilis yang dapat diubah secara signifikan sebelum dirilis. Microsoft tidak memberikan jaminan, tersirat maupun tersurat, sehubungan dengan informasi yang diberikan di sini.
Mengonversi pustaka tipe COM menjadi rakitan.
Overload
ConvertTypeLibToAssembly(Object, String, Int32, ITypeLibImporterNotifySink, Byte[], StrongNameKeyPair, Boolean) |
Mengonversi pustaka tipe COM menjadi rakitan. |
ConvertTypeLibToAssembly(Object, String, TypeLibImporterFlags, ITypeLibImporterNotifySink, Byte[], StrongNameKeyPair, String, Version) |
Mengonversi pustaka tipe COM menjadi rakitan. |
ConvertTypeLibToAssembly(Object, String, Int32, ITypeLibImporterNotifySink, Byte[], StrongNameKeyPair, Boolean)
Mengonversi pustaka tipe COM menjadi rakitan.
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
Objek yang mengimplementasikan ITypeLib
antarmuka.
- asmFileName
- String
Nama file dari rakitan yang dihasilkan.
- flags
- Int32
Nilai TypeLibImporterFlags yang menunjukkan pengaturan khusus apa pun.
- notifySink
- ITypeLibImporterNotifySink
ITypeLibImporterNotifySink antarmuka yang diimplementasikan oleh pemanggil.
- publicKey
- Byte[]
Array byte
yang berisi kunci publik.
- keyPair
- StrongNameKeyPair
Objek StrongNameKeyPair yang berisi pasangan kunci kriptografi publik dan privat.
- unsafeInterfaces
- Boolean
Jika true
, antarmuka memerlukan pemeriksaan waktu tautan untuk UnmanagedCode izin. Jika false
, antarmuka memerlukan pemeriksaan run time yang memerlukan stack walk dan lebih mahal, tetapi membantu memberikan perlindungan yang lebih besar.
Mengembalikan
Objek AssemblyBuilder yang berisi pustaka tipe yang dikonversi.
Penerapan
Pengecualian
typeLib
adalah null
.
-atau-
asmFileName
adalah null
.
-atau-
notifySink
adalah null
.
asmFileName
adalah string kosong.
-atau-
asmFileName
lebih panjang dari panjang maksimum yang ditentukan sistem. Untuk informasi selengkapnya, lihat PathTooLongException.
Metadata yang dihasilkan memiliki kesalahan yang mencegah jenis apa pun dimuat.
Keterangan
Jika Anda tidak ingin menghasilkan nama yang kuat untuk assembly Anda, nama tersebut valid untuk publicKey
dan keyPair
menjadi null
, selama flags
tidak sama dengan TypeLibImporterFlags.PrimaryInteropAssembly. Jika tidak, setidaknya salah satu parameter ini harus ditentukan. Jika publicKey
adalah null
, kunci publik di keyPair
akan ditetapkan dalam metadata manifes perakitan target dan tanda tangan akan dihasilkan berdasarkan konten perakitan. Jika keyPair
adalah null
, publicKey
akan diatur dalam metadata manifes perakitan target dan tidak ada tanda tangan yang akan dihasilkan. Menentukan kedua parameter umumnya tidak berguna, dan dapat mengakibatkan tanda tangan yang tidak valid.
Untuk informasi selengkapnya tentang ITypeLib
, silakan lihat dokumentasi yang ada di pustaka MSDN.
Berlaku untuk
ConvertTypeLibToAssembly(Object, String, TypeLibImporterFlags, ITypeLibImporterNotifySink, Byte[], StrongNameKeyPair, String, Version)
Mengonversi pustaka tipe COM menjadi rakitan.
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
Objek yang mengimplementasikan ITypeLib
antarmuka.
- asmFileName
- String
Nama file dari rakitan yang dihasilkan.
- flags
- TypeLibImporterFlags
Nilai TypeLibImporterFlags yang menunjukkan pengaturan khusus apa pun.
- notifySink
- ITypeLibImporterNotifySink
ITypeLibImporterNotifySink antarmuka yang diimplementasikan oleh pemanggil.
- publicKey
- Byte[]
Array byte
yang berisi kunci publik.
- keyPair
- StrongNameKeyPair
Objek StrongNameKeyPair yang berisi pasangan kunci kriptografi publik dan privat.
- asmNamespace
- String
Namespace layanan untuk assembly yang dihasilkan.
- asmVersion
- Version
Versi rakitan yang dihasilkan. Jika null
, versi pustaka jenis digunakan.
Mengembalikan
Objek AssemblyBuilder yang berisi pustaka tipe yang dikonversi.
Penerapan
Pengecualian
typeLib
adalah null
.
-atau-
asmFileName
adalah null
.
-atau-
notifySink
adalah null
.
asmFileName
adalah string kosong.
-atau-
asmFileName
lebih panjang dari panjang maksimum yang ditentukan sistem. Untuk informasi selengkapnya, lihat PathTooLongException.
Metadata yang dihasilkan memiliki kesalahan yang mencegah jenis apa pun dimuat.
Contoh
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
Keterangan
Jika Anda tidak ingin menghasilkan nama yang kuat untuk assembly Anda, nama tersebut valid untuk publicKey
dan keyPair
menjadi null
, selama flags
tidak sama dengan TypeLibImporterFlags.PrimaryInteropAssembly. Jika tidak, setidaknya salah satu parameter ini harus ditentukan. Jika publicKey
adalah null
, kunci publik di keyPair
akan ditetapkan dalam metadata manifes perakitan target dan tanda tangan akan dihasilkan berdasarkan konten perakitan. Jika keyPair
adalah null
, publicKey
akan diatur dalam metadata manifes perakitan target dan tidak ada tanda tangan yang akan dihasilkan. Menentukan kedua parameter umumnya tidak berguna, dan dapat mengakibatkan tanda tangan yang tidak valid.
Untuk informasi selengkapnya tentang ITypeLib
, silakan lihat dokumentasi yang ada di pustaka MSDN.