commit | ddd6caff9edac56dad727a79eb5b0faf4dbd6cb9 | [log] [tgz] |
---|---|---|
author | Lorenz Brun <lorenz@nexantic.com> | Thu Mar 04 17:16:04 2021 +0100 |
committer | Lorenz Brun <lorenz@nexantic.com> | Thu Mar 04 17:16:04 2021 +0100 |
tree | 120710eb4a9acf0c3ad1086d9f6f6f3c850a0d70 | |
parent | bcae658f9530e95cde2ac931beacae71c9fb240e [diff] |
Build mkfs.xfs using rules_cc This drops the old big genrule for mkfs.xfs and replaces it with a nice rules_cc build system with the help of bazel_cc_fix generated patches and our musl-based toolchain. While we're at it I bumped the versions of all related dependencies to their latest stable release. This also means pulling in ini.h which is a dependency of the new xfstools version. Instructions to regenerate the patches are included in the spec files. Toolchain selection is done by the existing transition in our rootfs rule so we automatically get a musl-built static binary when building for the rootfs. Test Plan: Tested with E2E tests, should fail fairly catastrophically if something were wrong. X-Origin-Diff: phab/D708 GitOrigin-RevId: 648a05cdd08cfa84a8a9f4c057c52446e7005631
This is the main repository containing Monogon's public source code, including Metropolis.
We assume a Fedora host system provisioned using rW, and IntelliJ as the IDE.
For better reproducibility, all builds are executed in containers.
Spinning up: scripts/create_container.sh
Spinning down: scripts/destroy_container.sh
Running commands: scripts/run_in_container.sh <...>
Using bazel using a wrapper script: scripts/bin/bazel <...>
(add to your local $PATH for convenience)
This repository is compatible with the IntelliJ Bazel plugin. All commands run inside the container, and necessary paths are mapped into the container.
The following steps are necessary:
Install Google's Bazel plugin in IntelliJ.
Add the absolute path to your ~/.cache/bazel-nxt
folder to your idea64.vmoptions
(Help → Edit Custom VM Options) and restart IntelliJ:
-Dbazel.bep.path=/home/leopold/.cache/bazel-nxt
Set "Bazel Binary Location" in Other Settings → Bazel Settings to the absolute path of scripts/bin/bazel
. This is a wrapper that will execute Bazel inside the container.
Use File → Import Bazel project... to create a new project from .bazelproject
.
After running the first sync, everything should now resolve in the IDE, including generated code.
It's strongly recommend to use our project presets for file watchers and other IDE features. Run this command and re-open the project in order to install them:
bazel run intellij/localconfig $(pwd)
Launch the node:
bazel run //:launch
Run a kubectl command:
bazel run //metropolis/cli/dbg -- kubectl describe