[infra] Migrate chrome builder group from mb_config to Starlark

part of multiple CLs:
-  https://crrev.com/i/9078456
=> https://crrev.com/c/7639969

Bug: 448148360
Change-Id: Ic58d4d16338682941b6b6cfafe833a7aa844ac70
Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/7639969
Reviewed-by: Ben Pastene <[email protected]>
Commit-Queue: Will Yeager <[email protected]>
Cr-Commit-Position: refs/heads/main@{#1595788}
NOKEYCHECK=True
GitOrigin-RevId: b1c2f3c0ca64c4bf685aa960aff8e5aa1b803f34
3 files changed
tree: 72357422ba004b60c79c7149dd73008181402177
  1. docs/
  2. lib/
  3. mb_config_expectations/
  4. __init__.py
  5. DIR_METADATA
  6. mb
  7. mb.bat
  8. mb.py
  9. mb_config.pyl
  10. mb_unittest.py
  11. mb_validation_unittest.py
  12. OWNERS
  13. PRESUBMIT.py
  14. README.md
  15. rts_banned_suites.json
README.md

MB - The Meta-Build wrapper

MB is a simple wrapper around the GN build tool.

It was originally written as part of the GYP->GN migration, in order to provide a uniform interface to either GYP or GN, such that users and bots can call one script and not need to worry about whether a given bot was meant to use GN or GYP.

It eventually grew additional functionality and is now still used even though everything is GN-only.

It supports two main functions:

  1. “gen” - the main gn gen invocation that generates the Ninja files needed for the build.

  2. “analyze” - the step that takes a list of modified files and a list of desired targets and reports which targets will need to be rebuilt.

We also use MB as a forcing function to collect all of the different build configurations that we actually support for Chromium builds into one place, in //tools/mb/mb_config.pyl.

For more information, see: