TypeLibConverter.ConvertTypeLibToAssembly-Methode: (Object, String, Int32, ITypeLibImporterNotifySink, Byte[], StrongNameKeyPair, Boolean)
Veröffentlicht: Oktober 2016
Eine COM-Typbibliothek konvertiert in eine Assembly.
Namespace: System.Runtime.InteropServices
Assembly: mscorlib (in mscorlib.dll)
Syntax
[SecurityPermissionAttribute(SecurityAction.Demand, Flags = SecurityPermissionFlag.UnmanagedCode)]
public AssemblyBuilder ConvertTypeLibToAssembly(
object typeLib,
string asmFileName,
int flags,
ITypeLibImporterNotifySink notifySink,
byte[] publicKey,
StrongNameKeyPair keyPair,
bool unsafeInterfaces
)
public:
[SecurityPermissionAttribute(SecurityAction::Demand, Flags = SecurityPermissionFlag::UnmanagedCode)]
virtual AssemblyBuilder^ ConvertTypeLibToAssembly(
Object^ typeLib,
String^ asmFileName,
int flags,
ITypeLibImporterNotifySink^ notifySink,
array<unsigned char>^ publicKey,
StrongNameKeyPair^ keyPair,
bool unsafeInterfaces
) sealed
[<SecurityPermissionAttribute(SecurityAction.Demand, Flags = SecurityPermissionFlag.UnmanagedCode)>]
abstract ConvertTypeLibToAssembly :
typeLib:Object *
asmFileName:string *
flags:int *
notifySink:ITypeLibImporterNotifySink *
publicKey:byte[] *
keyPair:StrongNameKeyPair *
unsafeInterfaces:bool -> AssemblyBuilder
[<SecurityPermissionAttribute(SecurityAction.Demand, Flags = SecurityPermissionFlag.UnmanagedCode)>]
override ConvertTypeLibToAssembly :
typeLib:Object *
asmFileName:string *
flags:int *
notifySink:ITypeLibImporterNotifySink *
publicKey:byte[] *
keyPair:StrongNameKeyPair *
unsafeInterfaces:bool -> AssemblyBuilder
<SecurityPermissionAttribute(SecurityAction.Demand, Flags := SecurityPermissionFlag.UnmanagedCode)>
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
Type: System.ObjectDas Objekt, das die ITypeLib-Schnittstelle implementiert.
asmFileName
Type: System.StringDer Dateiname der resultierenden Assembly.
flags
Type: System.Int32Ein TypeLibImporterFlags Wert, der alle speziellen Einstellungen.
notifySink
Type: System.Runtime.InteropServices.ITypeLibImporterNotifySinkITypeLibImporterNotifySink vom Aufrufer implementierte Schnittstelle.
publicKey
Type: System.Byte[]Ein byte Array, das den öffentlichen Schlüssel enthält.
keyPair
Type: System.Reflection.StrongNameKeyPairEin StrongNameKeyPair Objekt, das den öffentlichen und privaten kryptografischen Schlüsselpaar enthält.
unsafeInterfaces
Type: System.BooleanWenn true, die Schnittstellen erfordern linkzeittests für UnmanagedCode Berechtigung. Wenn false, die Schnittstellen erfordern, zur Laufzeit überprüft, die einen Stapel benötigen durchlaufen und teurer, aber mehr Schutz zu bieten.
Rückgabewert
Type: System.Reflection.Emit.AssemblyBuilder
Ein AssemblyBuilder -Objekt, das die konvertierte Typbibliothek enthält.
Implementiert
Ausnahmen
Exception | Condition |
---|---|
ArgumentNullException | typeLib ist null. - oder - asmFileName ist null. - oder - notifySink ist null. |
ArgumentException | asmFileName ist eine leere Zeichenfolge. - oder - asmFileName ist länger als MAX_PATH. |
InvalidOperationException | flags ist kein PrimaryInteropAssembly. - oder - publicKey und keyPair sind null. |
ReflectionTypeLoadException | Die erstellten Metadaten enthalten Fehler, die beim Laden von Typen verhindern. |
Hinweise
Wenn Sie nicht, zum Generieren eines starken Namens für die Assembly möchten ist ungültig für publicKey und keyPair werden null, solange flags ist nicht gleich TypeLibImporterFlags.PrimaryInteropAssembly. Andernfalls muss mindestens einer dieser Parameter angegeben werden. Wenn publicKey ist null, den öffentlichen Schlüssel in keyPair in den Metadaten des Manifests festgelegt und eine Signatur anhand des Inhalts der Assembly generiert. Wenn keyPair ist null, publicKey in den Metadaten des Manifests festgelegt und keine Signatur generiert werden. Angabe beider Parameter ist nicht in der Regel hilfreich, und kann dazu führen, dass eine ungültige Signatur.
Weitere Informationen zu ITypeLib, finden Sie unter der entsprechenden Dokumentation in der MSDN Library.
Sicherheit
for permission to call unmanaged code.
Security Action: Demand.
Associated Enumeration: F:System.Security.Permissions.SecurityPermissionFlag.UnmanagedCode
Versionsinformationen
.NET Framework
Verfügbar seit 1.1
Siehe auch
ConvertTypeLibToAssembly Überladen
TypeLibConverter-Klasse
System.Runtime.InteropServices-Namespace
Attribute für das Importieren von Typbibliotheken in Interop-Assemblys
Zurück zum Anfang