Перейти к файлу
Xamarin Public Jenkins (auto-signing) 8463cdd285 Finalize changelog 2021-06-17 15:54:19 +00:00
.github Imported Upstream version 16.9+xamarinxplat.2021.03.07.08.05 2021-04-15 15:43:31 +00:00
branding Imported Upstream version 15.4+xamarinxplat.2017.11.27.11.23 2017-11-29 14:41:49 +00:00
debian Finalize changelog 2021-06-17 15:54:19 +00:00
documentation Imported Upstream version 16.10.1+xamarinxplat.2021.05.26.14.00 2021-06-17 15:32:31 +00:00
eng Imported Upstream version 16.10.1+xamarinxplat.2021.05.26.14.00 2021-06-17 15:32:31 +00:00
mono Imported Upstream version 16.10.1+xamarinxplat.2021.05.26.14.00 2021-06-17 15:32:31 +00:00
ref Imported Upstream version 16.10.1+xamarinxplat.2021.05.26.14.00 2021-06-17 15:32:31 +00:00
scripts Imported Upstream version 16.10.1+xamarinxplat.2021.05.26.14.00 2021-06-17 15:32:31 +00:00
src Imported Upstream version 16.10.1+xamarinxplat.2021.05.26.14.00 2021-06-17 15:32:31 +00:00
.editorconfig Imported Upstream version 16.9+xamarinxplat.2021.03.07.08.05 2021-04-15 15:43:31 +00:00
.gitattributes Imported Upstream version 16.9+xamarinxplat.2021.03.07.08.05 2021-04-15 15:43:31 +00:00
.gitignore Imported Upstream version 16.9+xamarinxplat.2021.03.07.08.05 2021-04-15 15:43:31 +00:00
.vsconfig Imported Upstream version 16.4+xamarinxplat.2019.09.09.15.03 2019-09-30 17:31:26 +00:00
.vsts-dotnet-ci.yml Imported Upstream version 16.10.1+xamarinxplat.2021.05.26.14.00 2021-06-17 15:32:31 +00:00
.vsts-dotnet.yml Imported Upstream version 16.10.1+xamarinxplat.2021.05.26.14.00 2021-06-17 15:32:31 +00:00
Directory.Build.props Imported Upstream version 16.10.1+xamarinxplat.2021.05.26.14.00 2021-06-17 15:32:31 +00:00
Directory.Build.rsp Imported Upstream version 15.8+xamarinxplat.2018.07.31.22.43 2018-09-05 14:38:41 +00:00
Directory.Build.targets Imported Upstream version 16.9+xamarinxplat.2021.03.07.08.05 2021-04-15 15:43:31 +00:00
LICENSE Imported Upstream version 16.1+xamarinxplat.2019.06.05.11.19 2019-07-17 14:01:51 +00:00
MSBuild.Dev.slnf Imported Upstream version 16.9+xamarinxplat.2021.03.07.08.05 2021-04-15 15:43:31 +00:00
MSBuild.SourceBuild.slnf Imported Upstream version 16.10.1+xamarinxplat.2021.05.26.14.00 2021-06-17 15:32:31 +00:00
MSBuild.sln Imported Upstream version 16.10.1+xamarinxplat.2021.05.26.14.00 2021-06-17 15:32:31 +00:00
Makefile Imported Upstream version 16.4+xamarinxplat.2019.09.09.15.03 2019-09-30 17:31:26 +00:00
NuGet.config Imported Upstream version 16.10.1+xamarinxplat.2021.05.26.14.00 2021-06-17 15:32:31 +00:00
PublishToBlob.proj Imported Upstream version 15.8+xamarinxplat.2018.07.31.22.43 2018-09-05 14:38:41 +00:00
README.md Imported Upstream version 16.10.1+xamarinxplat.2021.05.26.14.00 2021-06-17 15:32:31 +00:00
THIRDPARTYNOTICES.txt Imported Upstream version 15.8+xamarinxplat.2018.07.31.22.43 2018-09-05 14:38:41 +00:00
build.cmd Imported Upstream version 16.5+xamarinxplat.2020.01.10.05.36 2020-01-15 18:40:53 +00:00
build.sh Imported Upstream version 16.0+xamarinxplat.2019.03.13.11.00 2019-04-18 18:31:41 +00:00
create-zip Imported Upstream version 15.4+xamarinxplat.2017.11.27.11.23 2017-11-29 14:41:49 +00:00
gen_build_info.sh Imported Upstream version 15.4+xamarinxplat.2017.11.27.11.23 2017-11-29 14:41:49 +00:00
global.json Imported Upstream version 16.10.1+xamarinxplat.2021.05.26.14.00 2021-06-17 15:32:31 +00:00
install-mono-prefix.sh Imported Upstream version 16.4+xamarinxplat.2019.09.09.15.03 2019-09-30 17:31:26 +00:00
msbuild-deploy.in Imported Upstream version 15.4+xamarinxplat.2017.11.27.11.23 2017-11-29 14:41:49 +00:00
msbuild-mono-deploy.in Imported Upstream version 16.4+xamarinxplat.2019.09.09.15.03 2019-09-30 17:31:26 +00:00
nuget-fixup-2.patch Imported Upstream version 15.4+xamarinxplat.2017.11.27.11.23 2017-11-29 14:41:49 +00:00
nuget-fixup.patch Imported Upstream version 15.4+xamarinxplat.2017.11.27.11.23 2017-11-29 14:41:49 +00:00

README.md

Microsoft.Build (MSBuild)

The Microsoft Build Engine is a platform for building applications. This engine, also known as MSBuild, provides an XML schema for a project file that controls how the build platform processes and builds software. Visual Studio uses MSBuild, but MSBuild can run without Visual Studio. By invoking msbuild.exe on your project or solution file, you can orchestrate and build products in environments where Visual Studio isn't installed.

For more information on MSBuild, see the MSBuild documentation on docs.microsoft.com.

Build Status

The current development branch is main. Changes in main will go into a future update of MSBuild, which will release with Visual Studio 16.10 and a corresponding version of the .NET Core SDK.

Build Status

We have forked for MSBuild 16.9 in the branch vs16.9. Changes to that branch need special approval.

Build Status

MSBuild 16.7 builds from the branch vs16.7. Only high-priority bugfixes will be considered for servicing 16.7.

Build Status

MSBuild 16.4 builds from the branch vs16.4. Only high-priority bugfixes will be considered for servicing 16.4.

Build Status

MSBuild 15.9 builds from the branch vs15.9. Only very-high-priority bugfixes will be considered for servicing 15.9.

Building

Building MSBuild with Visual Studio 2019 on Windows

For the full supported experience, you will need to have Visual Studio 2019 or higher.

To get started on Visual Studio 2019:

  1. Install Visual Studio 2019. Select the following Workloads:
  • .NET desktop development
  • .NET Core cross-platform development
  1. Open a Developer Command Prompt for VS 2019 prompt.
  2. Clone the source code: git clone https://github.com/dotnet/msbuild
  1. Run .\build.cmd from the root of the repo to build the code. This also restores packages needed to open the projects in Visual Studio.
  2. Open MSBuild.sln or MSBuild.Dev.slnf in Visual Studio 2019.

Note: To create a usable MSBuild with your changes, run .\build.cmd /p:CreateBootstrap=true. To build release, add -c Release: .\build.cmd -c Release /p:CreateBootstrap=true.

This newly-built MSBuild will be located at artifacts\bin\bootstrap\net472\MSBuild\Current\Bin\MSBuild.exe. It may not work for all scenarios, including C++ builds.

Building MSBuild in Unix (Mac & Linux)

MSBuild can be run on Unix systems that support .NET Core. Set-up instructions can be viewed on the wiki: Building Testing and Debugging on .Net Core MSBuild

Localization

You can turn on localized builds via the /p:LocalizedBuild=true command line argument. For more information on localized builds and how to make contributions to MSBuild's translations, see our localization documentation

Getting Started

Before you contribute, please read through the contributing and developer guides to get an idea of what kinds of pull requests we accept.

Looking for something to work on? This list of up for grabs issues is a great place to start.

You are also encouraged to start a discussion by filing an issue or creating a gist.

MSBuild Components

  • MSBuild. Microsoft.Build.CommandLine is the entrypoint for the Microsoft Build Engine (MSBuild.exe).

  • Microsoft.Build. The Microsoft.Build namespaces contain types that provide programmatic access to, and control of, the MSBuild engine.

  • Microsoft.Build.Framework. The Microsoft.Build.Framework namespace contains the types that define how tasks and loggers interact with the MSBuild engine. For additional information on this component, see our Microsoft.Build.Framework wiki page.

  • Microsoft.Build.Tasks. The Microsoft.Build.Tasks namespace contains the implementation of all tasks shipping with MSBuild.

  • Microsoft.Build.Utilities. The Microsoft.Build.Utilities namespace provides helper classes that you can use to create your own MSBuild loggers and tasks.

License

MSBuild is licensed under the MIT license.