Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add NixOS support #1287

Merged
merged 1 commit into from
Oct 25, 2024
Merged

Add NixOS support #1287

merged 1 commit into from
Oct 25, 2024

Conversation

jaroeichler
Copy link
Contributor

@jaroeichler jaroeichler commented Aug 28, 2024

Description

Use nix-ld to run Bazel.

Fixes #1229

Type of change

Please delete options that aren't relevant.

  • New feature (non-breaking change which adds functionality)
  • This change requires a documentation update

How Has This Been Tested?

Used a pretty minimal system configuration and Bazel test ... passes 51 of 52 tests, integration_tests/running_actions_manager_test fails.

Checklist

  • Updated documentation if needed
  • Tests added/amended
  • bazel test //... passes locally
  • PR is contained in a single commit, using git amend see some docs

This change is Reviewable

@CLAassistant
Copy link

CLAassistant commented Aug 28, 2024

CLA assistant check
All committers have signed the CLA.

@jaroeichler
Copy link
Contributor Author

services.envfs.enable is only needed for some scripts that need /bin/bash. Is there a better way?

@SpamDoodler can you please check if this works on your system? I've made a few changes to what we've tried a few days ago. In particular, it works without NIX_CC_USE_RESPONSE_FILE=0 on a pretty minimal system configuration.

Copy link
Member

@aaronmondal aaronmondal left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Reviewed 5 of 5 files at r1, all commit messages.
Reviewable status: 0 of 2 LGTMs obtained, and all files reviewed, and pending CI: Remote / large-ubuntu-22.04, and 3 discussions need to be resolved


flake.nix line 80 at r1 (raw file):

          "/run/current-system/sw/bin"
          "${binutils.bintools}/bin"
          "${coreutils}/bin"

nit: For kicks, consider using uutils-coreutils-noprefix as pure rust implementation of the coreutils 💃


flake.nix line 83 at r1 (raw file):

          "${customClang}/bin"
          "${git}/bin"
          "${python3Full}/bin"

Interesting. This looks like it exposes several nonhermeticities in the devShell. Most of this should probably be in the main devShell as well.

Regarding the python dependency, why do we need the Full variant? What's the closure size difference here?


flake.nix line 490 at r1 (raw file):

                ln -fs ${nixosBazelrc} nixos.bazelrc
                export CC=customClang
              fi

This should be a flake module similar to the config.pre-commit.installationScript and config.local-remote-execution.installationScript. This way users can use it as a generic "NixOS Bazel compatibility" module and are not bound to our choice of clang/binutils/python and may import it in arbitrary Bazel+Nix projects.

See:

Also note that the symlink here is too naive and should be done similar to what we have in

Copy link
Contributor Author

@jaroeichler jaroeichler left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Reviewable status: 0 of 2 LGTMs obtained, and 4 of 7 files reviewed, and pending CI: Bazel Dev / ubuntu-22.04, Cargo Dev / macos-13, Cargo Dev / ubuntu-22.04, Installation / macos-13, Installation / macos-14, Installation / ubuntu-22.04, Publish image, Publish nativelink-worker-init, Publish nativelink-worker-lre-cc, docker-compose-compiles-nativelink (22.04), macos-13, ubuntu-20.04 / stable, ubuntu-22.04 / stable, windows-2022 / stable, and 3 discussions need to be resolved


flake.nix line 80 at r1 (raw file):

Previously, aaronmondal (Aaron Siddhartha Mondal) wrote…

nit: For kicks, consider using uutils-coreutils-noprefix as pure rust implementation of the coreutils 💃

Let's go with that.


flake.nix line 83 at r1 (raw file):

Previously, aaronmondal (Aaron Siddhartha Mondal) wrote…

Interesting. This looks like it exposes several nonhermeticities in the devShell. Most of this should probably be in the main devShell as well.

Regarding the python dependency, why do we need the Full variant? What's the closure size difference here?

There's around 20M closure size difference. The only reason I went for that is that it's used somewhere else in the flake for some image. I've replaced it with python3


flake.nix line 490 at r1 (raw file):

Previously, aaronmondal (Aaron Siddhartha Mondal) wrote…

This should be a flake module similar to the config.pre-commit.installationScript and config.local-remote-execution.installationScript. This way users can use it as a generic "NixOS Bazel compatibility" module and are not bound to our choice of clang/binutils/python and may import it in arbitrary Bazel+Nix projects.

See:

Also note that the symlink here is too naive and should be done similar to what we have in

I've pretty much copied your setup. An empty default of paths in nixos.settings.path is somehow intentional since I don't want to pass customClang to the module and just replacing it with pkgs.clang leads to iostream not found. Side note, lib.mdDoc is deprecated.

Copy link
Member

@aaronmondal aaronmondal left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nice work!

:lgtm:

Reviewed 3 of 3 files at r2, all commit messages.
Reviewable status: 1 of 2 LGTMs obtained, and all files reviewed

Copy link
Member

@aaronmondal aaronmondal left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

+@adam-singer

Reviewable status: 1 of 2 LGTMs obtained, and all files reviewed (waiting on @adam-singer)

Copy link
Member

@allada allada left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

-@adam-singer
:lgtm:

Reviewed 4 of 5 files at r1, 3 of 3 files at r2, all commit messages.
Reviewable status: :shipit: complete! 2 of 2 LGTMs obtained, and all files reviewed

Copy link
Member

@allada allada left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can we rebase and land this?

Reviewable status: :shipit: complete! 2 of 2 LGTMs obtained, and all files reviewed

@jaroeichler
Copy link
Contributor Author

Sure, adjusted the nixos flake module path to the darwin flake module path

Copy link
Member

@allada allada left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

:lgtm:

Reviewed 7 of 7 files at r3, all commit messages.
Reviewable status: 2 of 2 LGTMs obtained, and all files reviewed, and pending CI: Web Platform Deployment / macos-14

Copy link
Member

@aaronmondal aaronmondal left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@jaroeichler I believe there is some sort of rebase conflict going on here. The darwin logic in the flake no longer needs to be conditional and is already on main. For some reason darwin-related changes show up in this diff.

Reviewed 1 of 7 files at r3, all commit messages.
Reviewable status: 2 of 2 LGTMs obtained, and all files reviewed, and pending CI: Web Platform Deployment / macos-14

@jaroeichler
Copy link
Contributor Author

@aaronmondal Thanks, didn't notice it when reviewing the diff. Should be fine now.

Copy link
Member

@aaronmondal aaronmondal left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks ❤️

:lgtm:

Reviewed 4 of 7 files at r3, 2 of 2 files at r4, all commit messages.
Reviewable status: 2 of 2 LGTMs obtained, and all files reviewed, and pending CI: Bazel Dev / macos-13, Bazel Dev / macos-14, Bazel Dev / ubuntu-24.04, Cargo Dev / macos-13, Cargo Dev / ubuntu-22.04, Coverage, Installation / macos-13, Installation / macos-14, Installation / ubuntu-22.04, Local / ubuntu-22.04, NativeLink.com Cloud / Remote Cache / macos-14, NativeLink.com Cloud / Remote Cache / ubuntu-24.04, Publish image, Publish nativelink-worker-init, Publish nativelink-worker-lre-cc, Remote / large-ubuntu-22.04, Web Platform Deployment / macos-14, Web Platform Deployment / ubuntu-24.04, asan / ubuntu-22.04, docker-compose-compiles-nativelink (22.04), integration-tests (22.04), macos-13, ubuntu-20.04 / stable, ubuntu-22.04, ubuntu-22.04 / stable, windows-2022 / stable

@aaronmondal aaronmondal merged commit b2386fd into TraceMachina:main Oct 25, 2024
35 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Document development on NixOS
5 participants