GeneratorSupport 列挙型

定義

コード ジェネレーターが特定の型のコード要素をサポートしているかどうかを判断するために使用する識別子を定義します。

この列挙体は、メンバー値のビットごとの組み合わせをサポートしています。

public enum class GeneratorSupport
[System.Flags]
public enum GeneratorSupport
[System.Flags]
[System.Serializable]
public enum GeneratorSupport
[<System.Flags>]
type GeneratorSupport = 
[<System.Flags>]
[<System.Serializable>]
type GeneratorSupport = 
Public Enum GeneratorSupport
継承
GeneratorSupport
属性

フィールド

ArraysOfArrays 1

コード ジェネレーターが配列の配列をサポートしていることを示します。

AssemblyAttributes 4096

コード ジェネレーターがアセンブリ属性をサポートしていることを示します。

ChainedConstructorArguments 32768

コード ジェネレーターがチェイン コンストラクター引数をサポートしていることを示します。

ComplexExpressions 524288

コード ジェネレーターが複雑な式をサポートしていることを示します。

DeclareDelegates 512

コード ジェネレーターがデリゲートの宣言をサポートしていることを示します。

DeclareEnums 256

コード ジェネレーターが列挙体の宣言をサポートしていることを示します。

DeclareEvents 2048

コード ジェネレーターがイベントの宣言をサポートしていることを示します。

DeclareIndexerProperties 33554432

コード ジェネレーターがインデクサー プロパティの宣言をサポートしていることを示します。

DeclareInterfaces 1024

コード ジェネレーターがインターフェイスの宣言をサポートしていることを示します。

DeclareValueTypes 128

コード ジェネレーターが値型の宣言をサポートしていることを示します。

EntryPointMethod 2

コード ジェネレーターがプログラム エントリ ポイント メソッドの指定をサポートしていることを示します。 この識別子は、実行可能ファイルを作成するときに使用されます。

GenericTypeDeclaration 16777216

コード ジェネレーターがジェネリック型の宣言をサポートしていることを示します。

GenericTypeReference 8388608

コード ジェネレーターがジェネリック型参照をサポートしていることを示します。

GotoStatements 4

コード ジェネレーターが goto ステートメントをサポートしていることを示します。

MultidimensionalArrays 8

コード ジェネレーターが多次元配列の参照をサポートしていることを示します。 現在、CodeDom を使用して多次元配列をインスタンス化することはできません。

MultipleInterfaceMembers 131072

コード ジェネレーターが複数のインターフェイスを実装するメンバーの宣言をサポートしていることを示します。

NestedTypes 65536

コード ジェネレーターが入れ子にされた型の宣言をサポートしていることを示します。

ParameterAttributes 8192

コード ジェネレーターがパラメーター属性をサポートしていることを示します。

PartialTypes 4194304

コード ジェネレーターが部分型の宣言をサポートしていることを示します。

PublicStaticMembers 262144

コード ジェネレーターがパブリック静的メンバーをサポートしていることを示します。

ReferenceParameters 16384

ジェネレーターが参照パラメーターおよび out パラメーターをサポートしていることを示します。

Resources 2097152

ジェネレーターが .NET リソースのコンパイルをサポートしていることを示します。 これらは、アセンブリに直接コンパイルされる既定のリソース、またはサテライト アセンブリで参照されるリソースです。

ReturnTypeAttributes 64

コード ジェネレーターが戻り値の型の属性宣言をサポートしていることを示します。

StaticConstructors 16

コード ジェネレーターが静的コンストラクターをサポートしていることを示します。

TryCatchStatements 32

コード ジェネレーターが try-catch ステートメントをサポートしていることを示します。

Win32Resources 1048576

コード ジェネレーターが Win32 リソースのコンパイルをサポートしていることを示します。

次の例は、 を使用して CompilerParameters さまざまなコンパイラ設定とオプションを指定する方法を示しています。

static bool CompileCode( CodeDomProvider^ provider,
   String^ sourceFile,
   String^ exeFile )
{

   CompilerParameters^ cp = gcnew CompilerParameters;
   if ( !cp)  
   {
      return false;
   }

   // Generate an executable instead of 
   // a class library.
   cp->GenerateExecutable = true;
   
   // Set the assembly file name to generate.
   cp->OutputAssembly = exeFile;
   
   // Generate debug information.
   cp->IncludeDebugInformation = true;
   
   // Add an assembly reference.
   cp->ReferencedAssemblies->Add( "System.dll" );
   
   // Save the assembly as a physical file.
   cp->GenerateInMemory = false;
   
   // Set the level at which the compiler 
   // should start displaying warnings.
   cp->WarningLevel = 3;
   
   // Set whether to treat all warnings as errors.
   cp->TreatWarningsAsErrors = false;
   
   // Set compiler argument to optimize output.
   cp->CompilerOptions = "/optimize";
   
   // Set a temporary files collection.
   // The TempFileCollection stores the temporary files
   // generated during a build in the current directory,
   // and does not delete them after compilation.
   cp->TempFiles = gcnew TempFileCollection( ".",true );

   if ( provider->Supports( GeneratorSupport::EntryPointMethod ) )
   {
      // Specify the class that contains 
      // the main method of the executable.
      cp->MainClass = "Samples.Class1";
   }

   if ( Directory::Exists( "Resources" ) )
   {
      if ( provider->Supports( GeneratorSupport::Resources ) )
      {
         // Set the embedded resource file of the assembly.
         // This is useful for culture-neutral resources,
         // or default (fallback) resources.
         cp->EmbeddedResources->Add( "Resources\\Default.resources" );

         // Set the linked resource reference files of the assembly.
         // These resources are included in separate assembly files,
         // typically localized for a specific language and culture.
         cp->LinkedResources->Add( "Resources\\nb-no.resources" );
      }
   }

   // Invoke compilation.
   CompilerResults^ cr = provider->CompileAssemblyFromFile( cp, sourceFile );

   if ( cr->Errors->Count > 0 )
   {
      // Display compilation errors.
      Console::WriteLine( "Errors building {0} into {1}",
         sourceFile, cr->PathToAssembly );
      for each ( CompilerError^ ce in cr->Errors )
      {
         Console::WriteLine( "  {0}", ce->ToString() );
         Console::WriteLine();
      }
   }
   else
   {
      Console::WriteLine( "Source {0} built into {1} successfully.",
         sourceFile, cr->PathToAssembly );
   }

   // Return the results of compilation.
   if ( cr->Errors->Count > 0 )
   {
      return false;
   }
   else
   {
      return true;
   }
}
public static bool CompileCode(CodeDomProvider provider,
    String sourceFile,
    String exeFile)
{

    CompilerParameters cp = new CompilerParameters();

    // Generate an executable instead of
    // a class library.
    cp.GenerateExecutable = true;

    // Set the assembly file name to generate.
    cp.OutputAssembly = exeFile;

    // Generate debug information.
    cp.IncludeDebugInformation = true;

    // Add an assembly reference.
    cp.ReferencedAssemblies.Add( "System.dll" );

    // Save the assembly as a physical file.
    cp.GenerateInMemory = false;

    // Set the level at which the compiler
    // should start displaying warnings.
    cp.WarningLevel = 3;

    // Set whether to treat all warnings as errors.
    cp.TreatWarningsAsErrors = false;

    // Set compiler argument to optimize output.
    cp.CompilerOptions = "/optimize";

    // Set a temporary files collection.
    // The TempFileCollection stores the temporary files
    // generated during a build in the current directory,
    // and does not delete them after compilation.
    cp.TempFiles = new TempFileCollection(".", true);

    if (provider.Supports(GeneratorSupport.EntryPointMethod))
    {
        // Specify the class that contains
        // the main method of the executable.
        cp.MainClass = "Samples.Class1";
    }

    if (Directory.Exists("Resources"))
    {
        if (provider.Supports(GeneratorSupport.Resources))
        {
            // Set the embedded resource file of the assembly.
            // This is useful for culture-neutral resources,
            // or default (fallback) resources.
            cp.EmbeddedResources.Add("Resources\\Default.resources");

            // Set the linked resource reference files of the assembly.
            // These resources are included in separate assembly files,
            // typically localized for a specific language and culture.
            cp.LinkedResources.Add("Resources\\nb-no.resources");
        }
    }

    // Invoke compilation.
    CompilerResults cr = provider.CompileAssemblyFromFile(cp, sourceFile);

    if(cr.Errors.Count > 0)
    {
        // Display compilation errors.
        Console.WriteLine("Errors building {0} into {1}",
            sourceFile, cr.PathToAssembly);
        foreach(CompilerError ce in cr.Errors)
        {
            Console.WriteLine("  {0}", ce.ToString());
            Console.WriteLine();
        }
    }
    else
    {
        Console.WriteLine("Source {0} built into {1} successfully.",
            sourceFile, cr.PathToAssembly);
        Console.WriteLine("{0} temporary files created during the compilation.",
            cp.TempFiles.Count.ToString());
    }

    // Return the results of compilation.
    if (cr.Errors.Count > 0)
    {
        return false;
    }
    else
    {
        return true;
    }
}
Public Shared Function CompileCode(ByVal provider As CodeDomProvider, _
ByVal sourceFile As String, ByVal exeFile As String) As Boolean

    Dim cp As New CompilerParameters()

    ' Generate an executable instead of 
    ' a class library.
    cp.GenerateExecutable = True

    ' Set the assembly file name to generate.
    cp.OutputAssembly = exeFile

    ' Generate debug information.
    cp.IncludeDebugInformation = True

    ' Add an assembly reference.
    cp.ReferencedAssemblies.Add("System.dll")

    ' Save the assembly as a physical file.
    cp.GenerateInMemory = False

    ' Set the level at which the compiler 
    ' should start displaying warnings.
    cp.WarningLevel = 3

    ' Set whether to treat all warnings as errors.
    cp.TreatWarningsAsErrors = False

    ' Set compiler argument to optimize output.
    cp.CompilerOptions = "/optimize"

    ' Set a temporary files collection.
    ' The TempFileCollection stores the temporary files
    ' generated during a build in the current directory,
    ' and does not delete them after compilation.
    cp.TempFiles = New TempFileCollection(".", True)

    If provider.Supports(GeneratorSupport.EntryPointMethod) Then
        ' Specify the class that contains
        ' the main method of the executable.
        cp.MainClass = "Samples.Class1"
    End If


    If Directory.Exists("Resources") Then
        If provider.Supports(GeneratorSupport.Resources) Then
            ' Set the embedded resource file of the assembly.
            ' This is useful for culture-neutral resources,
            ' or default (fallback) resources.
            cp.EmbeddedResources.Add("Resources\Default.resources")

            ' Set the linked resource reference files of the assembly.
            ' These resources are included in separate assembly files,
            ' typically localized for a specific language and culture.
            cp.LinkedResources.Add("Resources\nb-no.resources")
        End If
    End If

    ' Invoke compilation.
    Dim cr As CompilerResults = _
        provider.CompileAssemblyFromFile(cp, sourceFile)

    If cr.Errors.Count > 0 Then
        ' Display compilation errors.
        Console.WriteLine("Errors building {0} into {1}", _
            sourceFile, cr.PathToAssembly)
        Dim ce As CompilerError
        For Each ce In cr.Errors
            Console.WriteLine("  {0}", ce.ToString())
            Console.WriteLine()
        Next ce
    Else
        Console.WriteLine("Source {0} built into {1} successfully.", _
            sourceFile, cr.PathToAssembly)
        Console.WriteLine("{0} temporary files created during the compilation.", _
                cp.TempFiles.Count.ToString())
    End If

    ' Return the results of compilation.
    If cr.Errors.Count > 0 Then
        Return False
    Else
        Return True
    End If
End Function 'CompileCode

注釈

これらの識別子は、コード ジェネレーターの メソッドを Supports 呼び出して、コード ジェネレーターが特定の種類のコードの生成をサポートしているかどうかを判断するときに使用されます。

適用対象

こちらもご覧ください