GeneratorSupport GeneratorSupport GeneratorSupport GeneratorSupport Enum

Definizione

Definisce gli identificatori utilizzati per stabilire se un generatore di codice supporta determinati tipi di elementi di codice.Defines identifiers used to determine whether a code generator supports certain types of code elements.

Questa enumerazione ha un attributo FlagsAttribute che consente una combinazione bit per bit dei valori del relativo membro.

public enum class GeneratorSupport
[System.Flags]
[System.Serializable]
public enum GeneratorSupport
type GeneratorSupport = 
Public Enum GeneratorSupport
Ereditarietà
GeneratorSupportGeneratorSupportGeneratorSupportGeneratorSupport
Attributi

Campi

ArraysOfArrays ArraysOfArrays ArraysOfArrays ArraysOfArrays 1

Indica che il generatore supporta le matrici di matrici.Indicates the generator supports arrays of arrays.

AssemblyAttributes AssemblyAttributes AssemblyAttributes AssemblyAttributes 4096

Indica che il generatore supporta gli attributi di assembly.Indicates the generator supports assembly attributes.

ChainedConstructorArguments ChainedConstructorArguments ChainedConstructorArguments ChainedConstructorArguments 32768

Indica che il generatore supporta gli argomenti concatenati del costruttore.Indicates the generator supports chained constructor arguments.

ComplexExpressions ComplexExpressions ComplexExpressions ComplexExpressions 524288

Indica che il generatore supporta le espressioni complesse.Indicates the generator supports complex expressions.

DeclareDelegates DeclareDelegates DeclareDelegates DeclareDelegates 512

Indica che il generatore supporta le dichiarazioni delegate.Indicates the generator supports delegate declarations.

DeclareEnums DeclareEnums DeclareEnums DeclareEnums 256

Indica che il generatore supporta le dichiarazioni di enumerazione.Indicates the generator supports enumeration declarations.

DeclareEvents DeclareEvents DeclareEvents DeclareEvents 2048

Indica che il generatore supporta le dichiarazioni di evento.Indicates the generator supports event declarations.

DeclareIndexerProperties DeclareIndexerProperties DeclareIndexerProperties DeclareIndexerProperties 33554432

Indica che il generatore supporta la dichiarazione di proprietà di indicizzatore.Indicates the generator supports the declaration of indexer properties.

DeclareInterfaces DeclareInterfaces DeclareInterfaces DeclareInterfaces 1024

Indica che il generatore supporta le dichiarazioni di interfaccia.Indicates the generator supports interface declarations.

DeclareValueTypes DeclareValueTypes DeclareValueTypes DeclareValueTypes 128

Indica che il generatore supporta le dichiarazioni di tipi di valore.Indicates the generator supports value type declarations.

EntryPointMethod EntryPointMethod EntryPointMethod EntryPointMethod 2

Indica che il generatore supporta una designazione del metodo del punto di ingresso del programma.Indicates the generator supports a program entry point method designation. Utilizzato nella compilazione di eseguibili.This is used when building executables.

GenericTypeDeclaration GenericTypeDeclaration GenericTypeDeclaration GenericTypeDeclaration 16777216

Indica che il generatore supporta le dichiarazioni di tipi generici.Indicates the generator supports generic type declarations.

GenericTypeReference GenericTypeReference GenericTypeReference GenericTypeReference 8388608

Indica che il generatore supporta riferimenti a tipi generici.Indicates the generator supports generic type references.

GotoStatements GotoStatements GotoStatements GotoStatements 4

Indica che il generatore supporta le istruzioni goto.Indicates the generator supports goto statements.

MultidimensionalArrays MultidimensionalArrays MultidimensionalArrays MultidimensionalArrays 8

Indica che il generatore supporta il riferimento a matrici multidimensionali.Indicates the generator supports referencing multidimensional arrays. Non è attualmente possibile utilizzare CodeDom per creare istanze di matrici multidimensionali.Currently, the CodeDom cannot be used to instantiate multidimensional arrays.

MultipleInterfaceMembers MultipleInterfaceMembers MultipleInterfaceMembers MultipleInterfaceMembers 131072

Indica che il generatore supporta la dichiarazione di membri che implementano più interfacce.Indicates the generator supports the declaration of members that implement multiple interfaces.

NestedTypes NestedTypes NestedTypes NestedTypes 65536

Indica che il generatore supporta la dichiarazione di tipi annidati.Indicates the generator supports the declaration of nested types.

ParameterAttributes ParameterAttributes ParameterAttributes ParameterAttributes 8192

Indica che il generatore supporta gli attributi di parametro.Indicates the generator supports parameter attributes.

PartialTypes PartialTypes PartialTypes PartialTypes 4194304

Indica che il generatore supporta le dichiarazioni di tipi parziali.Indicates the generator supports partial type declarations.

PublicStaticMembers PublicStaticMembers PublicStaticMembers PublicStaticMembers 262144

Indica che il generatore supporta membri statici pubblici.Indicates the generator supports public static members.

ReferenceParameters ReferenceParameters ReferenceParameters ReferenceParameters 16384

Indica che il generatore supporta i parametri reference e out.Indicates the generator supports reference and out parameters.

Resources Resources Resources Resources 2097152

Indica che il generatore supporta la compilazione con risorse .NET Framework,Indicates the generator supports compilation with .NET Framework resources. che possono essere risorse predefinite compilate direttamente in un assembly oppure risorse a cui viene fatto riferimento in un assembly satellite.These can be default resources compiled directly into an assembly, or resources referenced in a satellite assembly.

ReturnTypeAttributes ReturnTypeAttributes ReturnTypeAttributes ReturnTypeAttributes 64

Indica che il generatore supporta le dichiarazioni di attributi di tipi restituiti.Indicates the generator supports return type attribute declarations.

StaticConstructors StaticConstructors StaticConstructors StaticConstructors 16

Indica che il generatore supporta i costruttori statici.Indicates the generator supports static constructors.

TryCatchStatements TryCatchStatements TryCatchStatements TryCatchStatements 32

Indica che il generatore supporta le istruzioni try...catch.Indicates the generator supports try...catch statements.

Win32Resources Win32Resources Win32Resources Win32Resources 1048576

Indica che il generatore supporta la compilazione con risorse Win32.Indicates the generator supports compilation with Win32 resources.

Esempi

Nell'esempio seguente viene illustrato l' CompilerParameters utilizzo di per specificare varie opzioni e impostazioni del compilatore.The following example illustrates using CompilerParameters to specify various compiler settings and options.

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

Commenti

Questi identificatori vengono usati quando si chiama Supports il metodo di un generatore di codice per determinare se il generatore di codice supporta la generazione di determinati tipi di codice.These identifiers are used when calling the Supports method of a code generator to determine whether the code generator supports generating certain types of code.

Si applica a

Vedi anche