GeneratorSupport Enum

Definition

Definierar identifierare som används för att avgöra om en kodgenerator stöder vissa typer av kodelement.

Den här uppräkningen stöder en bitvis kombination av dess medlemsvärden.

public enum class GeneratorSupport
[System.Flags]
[System.Serializable]
public enum GeneratorSupport
[<System.Flags>]
[<System.Serializable>]
type GeneratorSupport = 
Public Enum GeneratorSupport
Arv
GeneratorSupport
Attribut

Fält

Name Värde Description
ArraysOfArrays 1

Anger att generatorn stöder matriser med matriser.

EntryPointMethod 2

Anger att generatorn stöder en programinmatningspunktsmetodbeteckning. Detta används när du skapar körbara filer.

GotoStatements 4

Anger att generatorn stöder goto-instruktioner.

MultidimensionalArrays 8

Anger att generatorn stöder hänvisning till flerdimensionella matriser. CodeDom kan för närvarande inte användas för att instansiera flerdimensionella matriser.

StaticConstructors 16

Anger att generatorn stöder statiska konstruktorer.

TryCatchStatements 32

Anger att generatorn stöder try-catch instruktioner.

ReturnTypeAttributes 64

Anger att generatorn stöder returtypattributdeklarationer.

DeclareValueTypes 128

Anger att generatorn stöder värdetypsdeklarationer.

DeclareEnums 256

Anger att generatorn stöder uppräkningsdeklarationer.

DeclareDelegates 512

Anger att generatorn stöder ombudsdeklarationer.

DeclareInterfaces 1024

Anger att generatorn stöder gränssnittsdeklarationer.

DeclareEvents 2048

Anger att generatorn stöder händelsedeklarationer.

AssemblyAttributes 4096

Anger att generatorn stöder sammansättningsattribut.

ParameterAttributes 8192

Anger att generatorn stöder parameterattribut.

ReferenceParameters 16384

Anger att generatorn stöder referens- och utparametrar.

ChainedConstructorArguments 32768

Anger att generatorn stöder länkade konstruktorargument.

NestedTypes 65536

Anger att generatorn stöder deklarationen av kapslade typer.

MultipleInterfaceMembers 131072

Anger att generatorn stöder deklarationen av medlemmar som implementerar flera gränssnitt.

PublicStaticMembers 262144

Anger att generatorn stöder offentliga statiska medlemmar.

ComplexExpressions 524288

Anger att generatorn stöder komplexa uttryck.

Win32Resources 1048576

Anger att generatorn stöder kompilering med Win32-resurser.

Resources 2097152

Anger att generatorn stöder kompilering med .NET resurser. Dessa kan vara standardresurser som kompileras direkt till en sammansättning eller resurser som refereras i en satellitsammansättning.

PartialTypes 4194304

Anger att generatorn stöder partiella typdeklarationer.

GenericTypeReference 8388608

Anger att generatorn stöder generiska typreferenser.

GenericTypeDeclaration 16777216

Anger att generatorn stöder allmänna typdeklarationer.

DeclareIndexerProperties 33554432

Anger att generatorn stöder deklarationen av indexerarens egenskaper.

Exempel

I följande exempel visas hur du använder CompilerParameters för att ange olika kompilatorinställningar och alternativ.

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

Kommentarer

Dessa identifierare används när du anropar Supports metoden för en kodgenerator för att avgöra om kodgeneratorn stöder generering av vissa typer av kod.

Gäller för

Se även