GeneratorSupport Перечисление

Определение

Определяет идентификаторы, используемые для определения того, поддерживает ли генератор кода определенные типы элементов кода.

Это перечисление поддерживает побитовую комбинацию значений его членов.

public enum class GeneratorSupport
[System.Flags]
[System.Serializable]
public enum GeneratorSupport
[<System.Flags>]
[<System.Serializable>]
type GeneratorSupport = 
Public Enum GeneratorSupport
Наследование
GeneratorSupport
Атрибуты

Поля

Имя Значение Описание
ArraysOfArrays 1

Указывает, что генератор поддерживает массивы массивов.

EntryPointMethod 2

Указывает, что генератор поддерживает назначение метода точки входа программы. Это используется при создании исполняемых файлов.

GotoStatements 4

Указывает, что генератор поддерживает инструкции goto.

MultidimensionalArrays 8

Указывает, что генератор поддерживает ссылки на многомерные массивы. В настоящее время codeDom нельзя использовать для создания экземпляров многомерных массивов.

StaticConstructors 16

Указывает, что генератор поддерживает статические конструкторы.

TryCatchStatements 32

Указывает, что генератор поддерживает try-catch инструкции.

ReturnTypeAttributes 64

Указывает, что генератор поддерживает объявления атрибутов возвращаемого типа.

DeclareValueTypes 128

Указывает, что генератор поддерживает объявления типов значений.

DeclareEnums 256

Указывает, что генератор поддерживает объявления перечисления.

DeclareDelegates 512

Указывает, что генератор поддерживает объявления делегатов.

DeclareInterfaces 1024

Указывает, что генератор поддерживает объявления интерфейса.

DeclareEvents 2048

Указывает, что генератор поддерживает объявления событий.

AssemblyAttributes 4096

Указывает, что генератор поддерживает атрибуты сборки.

ParameterAttributes 8192

Указывает, что генератор поддерживает атрибуты параметров.

ReferenceParameters 16384

Указывает, что генератор поддерживает параметры ссылки и выхода.

ChainedConstructorArguments 32768

Указывает, что генератор поддерживает аргументы конструктора в цепочке.

NestedTypes 65536

Указывает, что генератор поддерживает объявление вложенных типов.

MultipleInterfaceMembers 131072

Указывает, что генератор поддерживает объявление элементов, реализующих несколько интерфейсов.

PublicStaticMembers 262144

Указывает, что генератор поддерживает общедоступные статические элементы.

ComplexExpressions 524288

Указывает, что генератор поддерживает сложные выражения.

Win32Resources 1048576

Указывает, что генератор поддерживает компиляцию с ресурсами Win32.

Resources 2097152

Указывает, что генератор поддерживает компиляцию с .NET ресурсами. Это могут быть ресурсы по умолчанию, скомпилированные непосредственно в сборку или ресурсы, на которые ссылаются вспомогательные сборки.

PartialTypes 4194304

Указывает, что генератор поддерживает объявления частичного типа.

GenericTypeReference 8388608

Указывает, что генератор поддерживает ссылки на универсальный тип.

GenericTypeDeclaration 16777216

Указывает, что генератор поддерживает объявления универсальных типов.

DeclareIndexerProperties 33554432

Указывает, что генератор поддерживает объявление свойств индексатора.

Примеры

В следующем примере показано использование для CompilerParameters указания различных параметров и параметров компилятора.

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 метода генератора кода для определения того, поддерживает ли генератор кода создание определенных типов кода.

Применяется к

См. также раздел