Build Page, Project Designer (C#)

Note

This article applies to Visual Studio 2015. If you're looking for the latest Visual Studio documentation, see Visual Studio documentation. We recommend upgrading to the latest version of Visual Studio. Download it here

Use the Build page of the Project Designer to specify the project's build configuration properties. This page applies to Visual C# projects only.

To access the Build page, choose a project node (not the Solution node) in Solution Explorer. Then choose Project, Properties on the menu bar. When the Project Designer appears, click the Build tab.

Note

Your computer might show different names or locations for some of the Visual Studio user interface elements in the following instructions. The Visual Studio edition that you have and the settings that you use determine these elements. For more information, see Personalizing the IDE.

Configuration and Platform

The following options enable you to select the configuration and platform to display or modify.

Note

With simplified build configurations, the project system determines whether to build a debug or release version. Therefore, these options are not displayed. For more information, see Debug and Release Project Configurations.

Configuration Specifies which configuration settings to display or modify. The settings can be Active (Debug) (this is the default), Debug, Release, or All Configurations.

Platform Specifies which platform settings to display or modify. The default setting is Active (Any CPU). You can change the active platform using the Configuration Manager. For more information, see How to: Create and Edit Configurations.

General

The following options enable you to configure several C# compiler settings.

Conditional compilation symbols Specifies symbols on which to perform conditional compilation. Separate symbols with a semi-colon (“;”). For more information, see /define (C# Compiler Options).

Define DEBUG constant Defines DEBUG as a symbol in all source code files in your app. Selecting this is equivalent to using the /define:DEBUG command line option.

Define TRACE constant Defines TRACE as a symbol in all source code files in your app. Selecting this is equivalent to using the /define:TRACE command line option.

Target CPU Specifies the processor to be targeted by the output file. Choose x86 for any 32-bit Intel-compatible processor, choose x64 for any 64-bit Intel-compatible processor, choose ARM for ARM processors, or choose Any CPU to specify that any processor is acceptable. Any CPU is the default value for projects, because it allows the application to run on the broadest range of hardware.

For more information, see /platform (C# Compiler Options).

Prefer 32-bit If the Prefer32-bit check box is selected, the application runs as a 32-bit application on both 32-bit and 64-bit versions of Windows. If the check box is cleared, the application runs as a 32-bit application on 32-bit versions of Windows and as a 64-bit application on 64-bit versions of Windows.

If you run an application as a 64-bit application, the pointer size doubles, and compatibility problems can occur with other libraries that are exclusively 32-bit. It is useful to run a 64-bit application only if it needs more than 4 GB of memory or 64-bit instructions provide a significant performance improvement.

This check box is available only if all of the following conditions are true:

  • On the Build Page, the Platform target list is set to Any CPU.

  • On the Application Page, the Output type list specifies that the project is an application.

  • On the Application Page, the Target framework list specifies the .NET Framework 4.5.

    Allow unsafe code Allows code that uses the unsafe keyword to compile. For more information, see /unsafe (C# Compiler Options).

    Optimize code Enable or disable optimizations performed by the compiler to make your output file smaller, faster, and more efficient. For more information, see /optimize (C# Compiler Options).

Errors and Warnings

The following settings are used to configure the error and warning options for the build process.

Warning level Specifies the level to display for compiler warnings. For more information, see /warn (C# Compiler Options).

Suppress warnings Blocks the compiler's ability to generate one or more warnings. Separate multiple warning numbers with a comma or semicolon. For more information, see /nowarn (C# Compiler Options).

Treat Warnings as Errors

The following settings are used to specify which warnings are treated as errors. Select one of the following options to indicate under what conditions to return an error when the build encounters a warning. For more information, see /warnaserror (C# Compiler Options).

None Treats no warnings as errors.

Specific warnings Treats the specified warnings as errors. Separate multiple warning numbers with a comma or semicolon.

All Treats all warnings as errors.

Output

The following settings are used to configure the output options for the build process.

Output path Specifies the location of the output files for this project's configuration. Enter the path of the build output in this box, or choose the Browse button to specify a path. Note that the path is relative; if you enter an absolute path, it will be saved as relative. The default path is bin\Debug or bin\Release\. For more information, see Debug and Release Project Configurations.

With simplified build configurations, the project system determines whether to build a debug or release version. The Build command from the Debug menu (F5) will put the build in the debug location regardless of the Output path you specify. However, the Build command from the Build menu puts it in the location you specify. For more information, see Debug and Release Project Configurations.

XML documentation file Specifies the name of a file into which documentation comments will be processed. For more information, see /doc (C# Compiler Options).

Register for COM interop Indicates that your managed application will expose a COM object (a COM callable wrapper) that allows a COM object to interact with your managed application. The Output type property in the Application page of the Project Designer for this application must be set to Class Library in order for the Register for COM interop property to be available. For an example class that you might include in your Visual C# application and expose as a COM object, see Example COM Class.

Generate serialization assembly Specifies whether the compiler will use the XML Serializer Generator Tool (Sgen.exe) to create XML serialization assemblies. Serialization assemblies can improve the startup performance of XmlSerializer if you have used that class to serialize types in your code. By default, this option is set to Auto, which specifies that serialization assemblies be generated only if you have used XmlSerializer to encode types in your code to XML. Off specifies that serialization assemblies never be generated, regardless of whether your code uses XmlSerializer. On specifies that serialization assemblies always be generated. Serialization assemblies are named TypeName.XmlSerializers.dll. For more information, see XML Serializer Generator Tool (Sgen.exe).

Advanced Click to display the Advanced Build Settings Dialog Box (C#) dialog box.

See Also

Project Properties Reference C# Compiler Options