Skip to content

Latest commit

 

History

History
42 lines (30 loc) · 2.11 KB

README.md

File metadata and controls

42 lines (30 loc) · 2.11 KB

Building

To build just CoreCLR, use the -subset flag to the build.sh (or build.cmd) script at the repo root:

For Linux:

./build.sh -subset clr

For Windows:

build.cmd -subset clr

By default, build generates a 'debug' build type, that includes asserts and is easier for some people to debug. If you want to make performance measurements, or just want tests to execute more quickly, you can also build the 'release' version (which does not have these checks) by adding the flag -configuration release (or -c release), for example:

./build.sh -subset clr -configuration release

CoreCLR also supports a 'checked' build type which has asserts enabled like 'debug', but is built with the native compiler optimizer enabled, so it runs much faster. This is the usual mode used for running tests in the CI system. You can build that using, for example:

./build.sh -subset clr -configuration checked

This will produce outputs as follows:

  • Product binaries will be dropped in artifacts\bin\coreclr\<OS>.<arch>.<flavor> folder.
  • A NuGet package, Microsoft.Dotnet.CoreCLR, will be created under artifacts\bin\coreclr\<OS>.<arch>.<flavor>\.nuget folder.
  • Test binaries will be dropped under artifacts\tests\coreclr\<OS>.<arch>.<flavor> folder. However, the root build script will not build the tests.

The build places logs in artifacts\log and these are useful when the build fails.

The build places all of its intermediate output in the artifacts\obj\coreclr directory, so if you remove that directory you can force a full rebuild.

To build CoreCLR, the root build script invokes the src\coreclr\build.cmd (or build.sh) script. To build the CoreCLR tests, you must use this script. Use build -? to learn about the options to this script.

See Running Tests for instructions on running the tests.

See also Build CoreCLR on Linux, Build CoreCLR on OS X, Build CoreCLR on FreeBSD, Cross Compilation for ARM on Windows, Cross Compilation for Android on Linux.