commit | 77cb6c5ec3acadf02ad5005dd751cfbf0ec1602f | [log] [tgz] |
---|---|---|
author | Serge Bazanski <serge@nexantic.com> | Sat Dec 19 00:09:22 2020 +0100 |
committer | Serge Bazanski <serge@nexantic.com> | Sat Dec 19 00:09:22 2020 +0100 |
tree | 7ddfcdf78c489a5d6fad7a20bd3580d803407450 | |
parent | 26d41999e0c71813648c16ad84bba810c3b9d593 [diff] |
core -> metropolis Smalltown is now called Metropolis! This is the first commit in a series of cleanup commits that prepare us for an open source release. This one just some Bazel packages around to follow a stricter directory layout. All of Metropolis now lives in `//metropolis`. All of Metropolis Node code now lives in `//metropolis/node`. All of the main /init now lives in `//m/n/core`. All of the Kubernetes functionality/glue now lives in `//m/n/kubernetes`. Next steps: - hunt down all references to Smalltown and replace them appropriately - narrow down visibility rules - document new code organization - move `//build/toolchain` to `//monogon/build/toolchain` - do another cleanup pass between `//golibs` and `//monogon/node/{core,common}`. - remove `//delta` and `//anubis` Fixes T799. Test Plan: Just a very large refactor. CI should help us out here. Bug: T799 X-Origin-Diff: phab/D667 GitOrigin-RevId: 6029b8d4edc42325d50042596b639e8b122d0ded
This is the monorepo storing all of nexantic's internal projects and libraries.
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)
Launch the node:
bazel run //:launch
Run a kubectl command:
bazel run //metropolis/cli/dbg -- kubectl describe
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)