Crate bootstrap

Source
Expand description

Implementation of bootstrap, the Rust build system.

This module, and its descendants, are the implementation of the Rust build system. Most of this build system is backed by Cargo but the outer layer here serves as the ability to orchestrate calling Cargo, sequencing Cargo builds, building artifacts like LLVM, etc. The goals of bootstrap are:

  • To be an easily understandable, easily extensible, and maintainable build system.
  • Leverage standard tools in the Rust ecosystem to build the compiler, aka crates.io and Cargo.
  • A standard interface to build across all platforms, including MSVC

Β§Further information

More documentation can be found in each respective module below, and you can also check out the src/bootstrap/README.md file for more information.

Modules§

  • core πŸ”’
  • utils πŸ”’
    This module contains integral components of the build and configuration process, providing support for a wide range of tasks and operations such as caching, tarballs, release channels, job management, etc.

Macros§

  • forward πŸ”’
  • A helper macro to unwrap a result except also print out details like:

Structs§

  • Global configuration for the build system.
  • A structure representing a Rust compiler.
  • Global configuration for the entire build and/or bootstrap.
  • Crate πŸ”’
  • Deserialized version of all flags for this compile.

Enums§

Constants§

  • Keeps track of major changes made to the bootstrap configuration.
  • EXTRA_CHECK_CFGS πŸ”’
    Extra --check-cfg to add when building the compiler or tools (Mode restriction, config name, config values (if any))
  • LLD_FILE_NAMES πŸ”’
    LLD file names for all flavors.
  • LLVM_TOOLS πŸ”’

Functions§