IAssemblyPostProcessor IAssemblyPostProcessor IAssemblyPostProcessor IAssemblyPostProcessor Interface

定義

ビルド後のアセンブリを処理するためにクラスが実装するメソッドを定義します。Defines the method a class implements to process an assembly after the assembly has been built.

public interface class IAssemblyPostProcessor : IDisposable
public interface IAssemblyPostProcessor : IDisposable
type IAssemblyPostProcessor = interface
    interface IDisposable
Public Interface IAssemblyPostProcessor
Implements IDisposable
実装

次のコード例の実装を作成する方法を示します、IAssemblyPostProcessorインターフェイス、および Web アプリケーションの Web.config ファイルに登録します。The following code example demonstrates how to create an implementation of the IAssemblyPostProcessor interface, and register it in the Web.config file of a Web application.

コード例の最初の部分は、という名前のクラスを作成します。Samples.Process.postProcessTestを実装する、IAssemblyPostProcessorインターフェイス。The first part of the code example creates a class named Samples.Process.postProcessTest that implements the IAssemblyPostProcessor interface. このクラスは、ファイルの書き込みの単純なアクションを実行時に、PostProcessAssemblyメソッドが呼び出されます。This class performs the simple action of writing a file when the PostProcessAssembly method is called.

using System;
using System.Web.Compilation;
using System.IO;

namespace Samples.Process
{
    public class postProcessTest : IAssemblyPostProcessor
    {
        public static void Main(String[] args)
        {
        }

        public void PostProcessAssembly(string path)
        {
            StreamWriter sw = File.CreateText(@"c:\compile\MyTest.txt");
            sw.WriteLine("Compiled assembly:");
            sw.WriteLine(path);
            sw.Close();
        }

        public void Dispose()
        {

        }
    }
}
Imports Microsoft.VisualBasic
Imports System
Imports System.Web.Compilation
Imports System.IO

Namespace Samples.Process
    Public Class postProcessTest
        Implements IAssemblyPostProcessor

        Sub Main()

        End Sub

        Public Sub PostProcessAssembly(ByVal path As String) _
            Implements IAssemblyPostProcessor.PostProcessAssembly
            Dim sw As StreamWriter
            sw = File.CreateText("c:\compile\MyTest.txt")
            sw.WriteLine("Compiled assembly:")
            sw.WriteLine(path)
            sw.Close()
        End Sub

        Public Sub Dispose() Implements IDisposable.Dispose

        End Sub
    End Class
End Namespace

コマンドを使用して、.dll ファイルにクラスをコンパイルcsc /target:library postProcessTest.csします。Compile the class into a .dll file with the command csc /target:library postProcessTest.cs. ASP.NET アプリケーションの Bin フォルダーに生成された .dll ファイルを追加し、次のコードに示すように、Web.config ファイルに .dll を登録します。Add the resulting .dll file to the Bin folder of an ASP.NET application and register the .dll in the Web.config file, as shown in the following code.

<compilation debug="true" assemblyPostProcessorType="Samples.Process.postProcessTest" />  

Web サイトにアクセスするユーザーと Web アプリケーションが動的にコンパイルされたファイルと、MyTest.txt は C:\compile に書き込まれます。When a user visits the Web site, the Web application is dynamically compiled and the file MyTest.txt will be written to C:\compile.

注釈

このインターフェイスを実装するクラスがコンパイルされた後のアセンブリにアクセスできます。A class implementing this interface can access an assembly after it has been compiled. AssemblyBuilderクラスがアセンブリをコンパイルし、かを確認するかどうか、IAssemblyPostProcessorインターフェイスは、Web 構成ファイルに登録されています。The AssemblyBuilder class compiles assemblies and then checks to see whether an IAssemblyPostProcessor interface has been registered in the Web configuration file. そうである場合、AssemblyBuilder呼び出しをインスタンス化、PostProcessAssemblyのメソッド、IAssemblyPostProcessorコンパイルした後、アセンブリを読み込む前に操作を実行するインターフェイス。If so, the AssemblyBuilder instance calls the PostProcessAssembly method for the IAssemblyPostProcessor interface to perform any action after the compilation and before loading the assembly. たとえば、プロファイラー ツールは、アセンブリのプローブを確立するためには、このインターフェイスを実装する可能性があります。For example, a profiler tool could implement this interface to establish probes in the assembly.

ときに、IAssemblyPostProcessorインターフェイスが登録されて、デバッグ モードで ASP.NET アプリケーションとそのアセンブリをコンパイルするが常にします。When an IAssemblyPostProcessor interface is registered, the ASP.NET application and its assemblies will always be compiled in debug mode.

メソッド

Dispose() Dispose() Dispose() Dispose()

アンマネージ リソースの解放またはリセットに関連付けられているアプリケーション定義のタスクを実行します。Performs application-defined tasks associated with freeing, releasing, or resetting unmanaged resources.

(Inherited from IDisposable)
PostProcessAssembly(String) PostProcessAssembly(String) PostProcessAssembly(String) PostProcessAssembly(String)

アセンブリが読み込まれる前に呼び出されます。これを実装したクラスは、アセンブリを変更できます。Called before the assembly is loaded to allow the implementing class to modify the assembly.

適用対象