Note
Access to this page requires authorization. You can try signing in or changing directories.
Access to this page requires authorization. You can try changing directories.
When you build projects, it's often necessary to set build options using information that isn't in the project file or the files that comprise your project. This information is typically stored in environment variables.
Note
MSBuild treats environment variables as trusted inputs. They can cause MSBuild to load build logic such as tasks, .targets, or .props files from custom locations or alter how the build executes.
Reference environment variables
All environment variables that are valid MSBuild property names are available to the MSBuild project file as properties. Valid property names are described in MSBuild properties. For example, environment variables that begin with a number aren't available in MSBuild.
Note
If the project file contains an explicit definition of a property that has the same name as an environment variable, the property in the project file overrides the value of the environment variable.
To use an environment variable in an MSBuild project
- Reference the environment variable the same way you would a variable declared in your project file. For example, the following code references the BIN_PATH environment variable: - <FinalOutput>$(BIN_PATH)\MyAssembly.dll</FinalOutput>- You can use a - Conditionattribute to provide a default value for a property if the environment variable wasn't set.
To provide a default value for a property
- Use a - Conditionattribute on a property to set the value only if the property has no value. For example, the following code sets the- ToolsPathproperty to c:\tools only if the- ToolsPathenvironment variable isn't set:- <ToolsPath Condition="'$(TOOLSPATH)' == ''">c:\tools</ToolsPath>- Note - Property names are not case-sensitive so both - $(ToolsPath)and- $(TOOLSPATH)reference the same property or environment variable.
Example
The following project file uses environment variables to specify the location of directories.
<Project DefaultTargets="FakeBuild">
    <PropertyGroup>
        <FinalOutput>$(BIN_PATH)\myassembly.dll</FinalOutput>
        <ToolsPath Condition=" '$(ToolsPath)' == '' ">
            C:\Tools
        </ToolsPath>
    </PropertyGroup>
    <Target Name="FakeBuild">
        <Message Text="Building $(FinalOutput) using the tools at $(ToolsPath)..."/>
    </Target>
</Project>