TypeLibConverter.ConvertTypeLibToAssembly メソッド

定義

COM タイプ ライブラリをアセンブリに変換します。

オーバーロード

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

COM タイプ ライブラリをアセンブリに変換します。

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

COM タイプ ライブラリをアセンブリに変換します。

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

COM タイプ ライブラリをアセンブリに変換します。

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

パラメーター

typeLib
Object

ITypeLib インターフェイスを実装するオブジェクト。

asmFileName
String

結果として得られるアセンブリのファイル名。

flags
Int32

任意の特別な設定を示す TypeLibImporterFlags 値。

notifySink
ITypeLibImporterNotifySink

呼び出し元によって実装されている ITypeLibImporterNotifySink インターフェイス。

publicKey
Byte[]

公開キーを保持している byte 配列。

keyPair
StrongNameKeyPair

公開暗号キーと秘密暗号キーのペアを保持している StrongNameKeyPair オブジェクト。

unsafeInterfaces
Boolean

true の場合は、インターフェイスでは UnmanagedCode アクセス許可についてリンク時チェックが要求されます。 false の場合は、インターフェイスではランタイム チェックが要求されます。この場合は、スタック ウォークが必要となるため負荷もかかりますが、保護は強化されます。

戻り値

AssemblyBuilder

変換後のタイプ ライブラリを保持している AssemblyBuilder オブジェクト。

実装

例外

typeLibnullです。

または asmFileNamenullです。

または notifySinknullです。

asmFileName が空の文字列です。

  • または - asmFileName がシステム定義の最大長を超えています。 詳細については、「PathTooLongException」を参照してください。

flagsPrimaryInteropAssembly ではありません。

  • または - publicKeykeyPairnull です。

生成されたメタデータには、型の読み込みを妨げているエラーがあります。

注釈

アセンブリの厳密な名前を生成しない場合は、有効でありpublicKey keyPair null、等TypeLibImporterFlags.PrimaryInteropAssemblyしくない限りflags有効です。 それ以外の場合は、これらのパラメーターの少なくとも 1 つを指定する必要があります。 そのnull場合publicKey、公開キーがkeyPairターゲット アセンブリのマニフェスト メタデータに設定され、アセンブリの内容に基づいて署名が生成されます。 の場合 keyPairnullpublicKey ターゲット アセンブリのマニフェスト メタデータに設定され、署名は生成されません。 両方のパラメーターを指定することは一般的に役に立ちません。無効な署名が発生する可能性があります。

詳細については ITypeLib、MSDN ライブラリの既存のドキュメントを参照してください。

適用対象

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

COM タイプ ライブラリをアセンブリに変換します。

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

パラメーター

typeLib
Object

ITypeLib インターフェイスを実装するオブジェクト。

asmFileName
String

結果として得られるアセンブリのファイル名。

flags
TypeLibImporterFlags

任意の特別な設定を示す TypeLibImporterFlags 値。

notifySink
ITypeLibImporterNotifySink

呼び出し元によって実装されている ITypeLibImporterNotifySink インターフェイス。

publicKey
Byte[]

公開キーを保持している byte 配列。

keyPair
StrongNameKeyPair

公開暗号キーと秘密暗号キーのペアを保持している StrongNameKeyPair オブジェクト。

asmNamespace
String

結果として得られるアセンブリの名前空間。

asmVersion
Version

結果として得られるアセンブリのバージョン。 null の場合は、タイプ ライブラリのバージョンが使用されます。

戻り値

AssemblyBuilder

変換後のタイプ ライブラリを保持している AssemblyBuilder オブジェクト。

実装

例外

typeLibnullです。

または asmFileNamenullです。

または notifySinknullです。

asmFileName が空の文字列です。

  • または - asmFileName がシステム定義の最大長を超えています。 詳細については、「PathTooLongException」を参照してください。

flagsPrimaryInteropAssembly ではありません。

  • または - publicKeykeyPairnull です。

生成されたメタデータには、型の読み込みを妨げているエラーがあります。

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

注釈

アセンブリの厳密な名前を生成しない場合は、有効でありpublicKey keyPair null、等TypeLibImporterFlags.PrimaryInteropAssemblyしくない限りflags有効です。 それ以外の場合は、これらのパラメーターの少なくとも 1 つを指定する必要があります。 そのnull場合publicKey、公開キーがkeyPairターゲット アセンブリのマニフェスト メタデータに設定され、アセンブリの内容に基づいて署名が生成されます。 の場合 keyPairnullpublicKey ターゲット アセンブリのマニフェスト メタデータに設定され、署名は生成されません。 両方のパラメーターを指定することは一般的に役に立ちません。無効な署名が発生する可能性があります。

詳細については ITypeLib、MSDN ライブラリの既存のドキュメントを参照してください。

適用対象