Proprietà riservate e note MSBuildMSBuild reserved and well-known properties

In MSBuildMSBuild è disponibile un set di proprietà predefinite che archiviano informazioni sul file di progetto e i file binari di MSBuildMSBuild.MSBuildMSBuild provides a set of predefined properties that store information about the project file and the MSBuildMSBuild binaries. Queste proprietà vengono valutate come le altre proprietà di MSBuildMSBuild.These properties are evaluated in the same manner as other MSBuildMSBuild properties. Ad esempio, per usare la proprietà MSBuildProjectFile, è necessario digitare $(MSBuildProjectFile).For example, to use the MSBuildProjectFile property, you type $(MSBuildProjectFile).

MSBuild usa i valori indicati nella tabella seguente per predefinire le proprietà riservate e quelle note.MSBuild uses the values in the following table to predefine reserved and well-known properties. L'override può essere eseguito solo per le proprietà note usando proprietà globali, proprietà di ambiente con nomi identici o proprietà dichiarate nel file di progetto.Reserved properties cannot be overridden, but well-known properties can be overridden by using identically named environment properties, global properties, or properties that are declared in the project file.

Proprietà riservate e noteReserved and well-known properties

Nella tabella seguente vengono descritte le proprietà predefinite di MSBuildMSBuild.The following table describes the MSBuildMSBuild predefined properties.

GliProperty Riservata o notaReserved or well-known DescrizioneDescription
MSBuildBinPath RiservataReserved Percorso assoluto della cartella in cui si trovano i file binari di MSBuildMSBuild attualmente in uso, ad esempio C:\Windows\Microsoft.Net\Framework\<NumeroVersione> .The absolute path of the folder where the MSBuildMSBuild binaries that are currently being used are located (for example, C:\Windows\Microsoft.Net\Framework\<versionNumber>). Questa proprietà risulta utile quando è necessario fare riferimento ai file nella directory di MSBuildMSBuild.This property is useful if you have to refer to files in the MSBuildMSBuild directory.

Non includere la barra rovesciata finale in questa proprietà.Do not include the final backslash on this property.
MSBuildExtensionsPath NotaWell-known Introdotta in .NET Framework 4: nessuna differenza tra i valori predefiniti di MSBuildExtensionsPath e MSBuildExtensionsPath32.Introduced in the .NET Framework 4: there is no difference between the default values of MSBuildExtensionsPath and MSBuildExtensionsPath32. È possibile impostare la variabile di ambiente MSBUILDLEGACYEXTENSIONSPATH su un valore non Null per abilitare il comportamento del valore predefinito di MSBuildExtensionsPath nelle versioni precedenti.You can set the environment variable MSBUILDLEGACYEXTENSIONSPATH to a non-null value to enable the behavior of the default value of MSBuildExtensionsPath in earlier versions.

In .NET Framework 3.5 e versioni precedenti il valore predefinito di MSBuildExtensionsPath fa riferimento al percorso della sottocartella MSBuild nella cartella \Programmi\ o \Programmi (x86) , in base al numero di bit del processo corrente.In the .NET Framework 3.5 and earlier, the default value of MSBuildExtensionsPath points to the path of the MSBuild subfolder under the \Program Files\ or \Program Files (x86) folder, depending on the bitness of the current process. Ad esempio, per un processo a 32 bit in un computer a 64 bit, la proprietà fa riferimento alla cartella \Programmi (x86) .For example, for a 32-bit process on a 64-bit machine, this property points to the \Program Files (x86) folder. Per un processo a 64 bit in un computer a 64 bit, questa proprietà fa riferimento alla cartella \Programmi.For a 64-bit process on a 64-bit machine, this property points to the \Program Files folder.

Non includere la barra rovesciata finale in questa proprietà.Do not include the final backslash on this property.

Questo percorso è ideale per contenere i file di destinazione personalizzati.This location is a useful place to put custom target files. È ad esempio possibile installare i file di destinazione in \Programmi\MSBuild\MyFiles\Northwind.targets, quindi importarli nei file di progetto usando il codice XML seguente:For example, your target files could be installed at \Program Files\MSBuild\MyFiles\Northwind.targets and then imported in project files by using this XML code:

<Import Project="$(MSBuildExtensionsPath)\MyFiles\Northwind.targets"/>
MSBuildExtensionsPath32 NotaWell-known Percorso della sottocartella MSBuildMSBuild nella cartella \Programmi o \Programmi (x86) .The path of the MSBuildMSBuild subfolder under the \Program Files or \Program Files (x86) folder. Il percorso fa sempre riferimento alla cartella \Programmi (x86) per un computer a 32 bit e alla cartella \Programmi per un computer a 64 bit.".The path always points to the 32-bit \Program Files (x86) folder on a 32-bit machine and \Program Files on a 64-bit machine.". Vedere anche MSBuildExtensionsPath e MSBuildExtensionsPath64.See also MSBuildExtensionsPath and MSBuildExtensionsPath64.

Non includere la barra rovesciata finale in questa proprietà.Do not include the final backslash on this property.
MSBuildExtensionsPath64 NotaWell-known Percorso della sottocartella MSBuildMSBuild nella cartella \Programmi.The path of the MSBuildMSBuild subfolder under the \Program Files folder. Per un computer a 64 bit, questo percorso fa sempre riferimento alla cartella \Programmi.For a 64-bit machine, this path always points to the \Program Files folder. Per un computer a 32 bit, questo percorso è vuoto.For a 32-bit machine, this path is blank. Vedere anche MSBuildExtensionsPath e MSBuildExtensionsPath32.See also MSBuildExtensionsPath and MSBuildExtensionsPath32.

Non includere la barra rovesciata finale in questa proprietà.Do not include the final backslash on this property.
MSBuildLastTaskResult RiservataReserved true se l'attività precedente è stata completata senza errori (anche se erano presenti avvisi) o false se l'attività precedente ha generato errori.true if the previous task completed without any errors (even if there were warnings), or false if the previous task had errors. In genere, quando si verifica un errore in un'attività, l'errore è l'ultimo elemento che si verifica nel progetto.Typically, when an error occurs in a task, the error is the last thing that happens in that project. Pertanto, il valore di questa proprietà non è mai false, tranne negli scenari seguenti:Therefore, the value of this property is never false, except in these scenarios:

- Quando l'attributo ContinueOnError dell'elemento Task (MSBuild) è impostato su WarnAndContinue (o true) o su ErrorAndContinue.- When the ContinueOnError attribute of the Task element (MSBuild) is set to WarnAndContinue (or true) or ErrorAndContinue.

- Quando Target ha un elemento OnError (MSBuild) come elemento figlio.- When the Target has an OnError element (MSBuild) as a child element.
MSBuildNodeCount RiservataReserved Numero massimo di processi simultanei usati durante la compilazione.The maximum number of concurrent processes that are used when building. Si tratta del valore specificato per -maxcpucount nella riga di comando.This is the value that you specified for -maxcpucount on the command line. Se l'opzione -maxcpucount è stata specificata senza un valore, MSBuildNodeCount specifica il numero di processori nel computer.If you specified -maxcpucount without specifying a value, then MSBuildNodeCount specifies the number of processors in the computer. Per altre informazioni, vedere Riferimenti alla riga di comando e Compilazione di più progetti in parallelo.For more information, see Command-line reference and Build multiple projects in parallel.
MSBuildProgramFiles32 RiservataReserved Percorso della cartella del programma a 32 bit, ad esempio C:\Programmi (x86) .The location of the 32-bit program folder; for example, C:\Program Files (x86).

Non includere la barra rovesciata finale in questa proprietà.Do not include the final backslash on this property.
MSBuildProjectDefaultTargets RiservataReserved L'elenco completo delle destinazioni specificate nell'attributo DefaultTargets dell'elemento Project.The complete list of targets that are specified in the DefaultTargets attribute of the Project element. L'elemento Project seguente conterrebbe, ad esempio, una proprietà MSBuildDefaultTargets con valore A;B;C:For example, the following Project element would have an MSBuildDefaultTargets property value of A;B;C:

<Project DefaultTargets="A;B;C" >
MSBuildProjectDirectory RiservataReserved Percorso assoluto della directory in cui si trova il file di progetto, ad esempio C:\MyCompany\MyProduct.The absolute path of the directory where the project file is located, for example C:\MyCompany\MyProduct.

Non includere la barra rovesciata finale in questa proprietà.Do not include the final backslash on this property.
MSBuildProjectDirectoryNoRoot RiservataReserved Il valore della proprietà MSBuildProjectDirectory, esclusa l'unità radice.The value of the MSBuildProjectDirectory property, excluding the root drive.

Non includere la barra rovesciata finale in questa proprietà.Do not include the final backslash on this property.
MSBuildProjectExtension RiservataReserved Estensione del nome file del file di progetto, incluso il punto, ad esempio proj.The file name extension of the project file, including the period; for example, .proj.
MSBuildProjectFile RiservataReserved Nome file completo del progetto, inclusa l'estensione del nome file, ad esempio MyApp.proj.The complete file name of the project file, including the file name extension; for example, MyApp.proj.
MSBuildProjectFullPath RiservataReserved Percorso assoluto e nome file completo del progetto, inclusa l'estensione del nome file, ad esempio C:\MyCompany\MyProduct\MyApp.proj.The absolute path and complete file name of the project file, including the file name extension; for example, C:\MyCompany\MyProduct\MyApp.proj.
MSBuildProjectName RiservataReserved Nome file del file di progetto senza l'estensione, ad esempio MyApp.The file name of the project file without the file name extension; for example, MyApp.
MSBuildRuntimeType RiservataReserved Il tipo di runtime che è attualmente in esecuzione.The type of the runtime that is currently executing. Introdotto in MSBuild 15.Introduced in MSBuild 15. Il valore può essere non definito (prima di MSBuild 15), Full indicante che MSBuild è in esecuzione sul desktop .NET Framework, Core che indica che MSBuild è in esecuzione in .NET Core (ad esempio, in dotnet build) o Mono che indica che MSBuild è in esecuzione su mono.Value may be undefined (prior to MSBuild 15), Full indicating that MSBuild is running on the desktop .NET Framework, Core indicating that MSBuild is running on .NET Core (for example in dotnet build), or Mono indicating that MSBuild is running on Mono.
MSBuildStartupDirectory RiservataReserved Percorso assoluto della cartella in cui viene chiamato MSBuildMSBuild.The absolute path of the folder where MSBuildMSBuild is called. Tramite questa proprietà, è possibile compilare tutto ciò che si trova sotto un punto specifico in un albero di progetto senza creare file <dirs>.proj in ogni directory.By using this property, you can build everything below a specific point in a project tree without creating <dirs>.proj files in every directory. È invece presente un solo progetto, ad esempio c:\traversal.proj, come illustrato di seguito:Instead, you have just one project—for example, c:\traversal.proj, as shown here:

<Project ...> <ItemGroup> <ProjectFiles Include="$ (MSBuildStartupDirectory) **\*.csproj"/> </ItemGroup> <Target Name="build"> <MSBuild Projects="@(ProjectFiles)"/> </Target> </Project>

Per compilare a un punto qualsiasi dell'albero, digitare:To build at any point in the tree, type:

msbuild c:\traversal.proj

Non includere la barra rovesciata finale in questa proprietà.Do not include the final backslash on this property.
MSBuildThisFile RiservataReserved Il nome file e la parte dell'estensione di MSBuildThisFileFullPath.The file name and file extension portion of MSBuildThisFileFullPath.
MSBuildThisFileDirectory RiservataReserved La parte di directory di MSBuildThisFileFullPath.The directory portion of MSBuildThisFileFullPath.

Includere la barra rovesciata finale nel percorso.Include the final backslash in the path.
MSBuildThisFileDirectoryNoRoot RiservataReserved La parte di directory di MSBuildThisFileFullPath, esclusa l'unità radice.The directory portion of MSBuildThisFileFullPath, excluding the root drive.

Includere la barra rovesciata finale nel percorso.Include the final backslash in the path.
MSBuildThisFileExtension RiservataReserved La parte di estensione del nome file di MSBuildThisFileFullPath.The file name extension portion of MSBuildThisFileFullPath.
MSBuildThisFileFullPath RiservataReserved Percorso assoluto del file di progetto o di destinazioni che contiene la destinazione in esecuzione.The absolute path of the project or targets file that contains the target that is running.

Suggerimento: è possibile specificare un percorso relativo in un file di destinazioni che sia relativo al file di destinazioni e non al file di progetto originale.Tip: You can specify a relative path in a targets file that's relative to the targets file and not relative to the original project file.
MSBuildThisFileName RiservataReserved La parte di nome file di MSBuildThisFileFullPath, senza l'estensione.The file name portion of MSBuildThisFileFullPath, without the file name extension.
MSBuildToolsPath RiservataReserved Percorso di installazione della versione di MSBuildMSBuild associata al valore di MSBuildToolsVersion.The installation path of the MSBuildMSBuild version that's associated with the value of MSBuildToolsVersion.

Non includere la barra rovesciata finale nel percorso.Do not include the final backslash in the path.

Questa proprietà non può essere sottoposta a override.This property cannot be overridden.
MSBuildToolsVersion RiservataReserved Versione del set di strumenti di MSBuildMSBuild da usare per compilare il progetto.The version of the MSBuildMSBuild Toolset that is used to build the project.

Nota: un set di strumenti di MSBuildMSBuild è costituito da attività, destinazioni e strumenti usati per compilare un'applicazione.Note: An MSBuildMSBuild Toolset consists of tasks, targets, and tools that are used to build an application. Gli strumenti includono compilatori come csc.exe e vbc.exe.The tools include compilers such as csc.exe and vbc.exe. Per altre informazioni, vedere Set di strumenti di MSBuild (ToolsVersion) e Configurazioni standard e personalizzate del set di strumenti.For more information, see Toolset (ToolsVersion), and Standard and custom Toolset configurations.
MSBuildVersion RiservataReserved La versione di MSBuildMSBuild usata per compilare il progetto.The version of MSBuildMSBuild used to build the project.

Questa proprietà non può essere sottoposta a override. In caso contrario, viene restituito il messaggio di errore MSB4004 - The 'MSBuildVersion' property is reserved, and can not be modified..This property can't be overridden, otherwise the error message MSB4004 - The 'MSBuildVersion' property is reserved, and can not be modified. is returned.

Nomi in conflitto con gli elementi di MSBuildNames that conflict with MSBuild elements

Oltre a quanto sopra, i nomi corrispondenti a elementi del linguaggio MSBuild non possono essere usati per proprietà, elementi o metadati di elementi definiti dall'utente:In addition to the above, names corresponding to MSBuild language elements cannot be used for user-defined properties, items, or item metadata:

  • VisualStudioProjectVisualStudioProject
  • destinazioneTarget
  • PropertyGroupPropertyGroup
  • OutputOutput
  • ItemGroupItemGroup
  • UsingTaskUsingTask
  • ProjectExtensionsProjectExtensions
  • OnErrorOnError
  • ImportGroupImportGroup
  • ScegliereChoose
  • WhenWhen
  • OtherwiseOtherwise

Vedere ancheSee also