From 3c0eb21ed103f9467849204c14f481e018601a01 Mon Sep 17 00:00:00 2001 From: Michael Forster Date: Thu, 26 Jan 2023 18:06:51 +0100 Subject: [PATCH] nix: refactor flake to avoid building `jj` for the dev shell We don't actually need `jj` itself in the development shell. But having it in the overlay significantly increases the time it takes to build the shell. --- flake.nix | 98 ++++++++++++++++++++----------------------------------- 1 file changed, 36 insertions(+), 62 deletions(-) diff --git a/flake.nix b/flake.nix index 2dc59b722..a28086deb 100644 --- a/flake.nix +++ b/flake.nix @@ -21,64 +21,7 @@ in { overlays.default = (final: prev: { - jujutsu = final.callPackage - ( - { stdenv - , lib - , fetchFromGitHub - , rustPlatform - , pkg-config - , openssl - , dbus - , sqlite - , file - , gzip - , makeWrapper - , Security - , SystemConfiguration - , libiconv - , installShellFiles - }: - - rustPlatform.buildRustPackage rec { - pname = "jujutsu"; - version = "unstable-${self.shortRev or "dirty"}"; - buildNoDefaultFeatures = true; - buildFeatures = [ "jujutsu-lib/legacy-thrift" ]; - - src = self; - - cargoLock = { - lockFile = "${self}/Cargo.lock"; - }; - nativeBuildInputs = [ - gzip - installShellFiles - makeWrapper - pkg-config - ]; - buildInputs = [ openssl dbus sqlite ] - ++ lib.optionals stdenv.isDarwin [ - Security - SystemConfiguration - libiconv - ]; - postInstall = '' - $out/bin/jj debug mangen > ./jj.1 - installManPage ./jj.1 - - $out/bin/jj debug completion --bash > ./completions.bash - installShellCompletion --bash --name ${pname}.bash ./completions.bash - $out/bin/jj debug completion --fish > ./completions.fish - installShellCompletion --fish --name ${pname}.fish ./completions.fish - $out/bin/jj debug completion --zsh > ./completions.zsh - installShellCompletion --zsh --name _${pname} ./completions.zsh - ''; - } - ) - { - inherit (final.darwin.apple_sdk.frameworks) Security SystemConfiguration; - }; + jujutsu = self.packages.${final.system}.jujutsu; }); } // (foreachSystem (system: @@ -86,21 +29,52 @@ pkgs = import nixpkgs { inherit system; overlays = [ - self.overlays.default rust-overlay.overlays.default ]; }; in { packages.${system} = { - jujutsu = pkgs.jujutsu; + jujutsu = pkgs.rustPlatform.buildRustPackage rec { + pname = "jujutsu"; + version = "unstable-${self.shortRev or "dirty"}"; + buildNoDefaultFeatures = true; + buildFeatures = [ "jujutsu-lib/legacy-thrift" ]; + src = ./.; + cargoLock = { + lockFile = ./Cargo.lock; + }; + nativeBuildInputs = with pkgs; [ + gzip + installShellFiles + makeWrapper + pkg-config + ]; + buildInputs = with pkgs; [ openssl dbus sqlite ] + ++ lib.optionals stdenv.isDarwin [ + darwin.apple_sdk.frameworks.Security + darwin.apple_sdk.frameworks.SystemConfiguration + libiconv + ]; + postInstall = '' + $out/bin/jj debug mangen > ./jj.1 + installManPage ./jj.1 + + $out/bin/jj debug completion --bash > ./completions.bash + installShellCompletion --bash --name ${pname}.bash ./completions.bash + $out/bin/jj debug completion --fish > ./completions.fish + installShellCompletion --fish --name ${pname}.fish ./completions.fish + $out/bin/jj debug completion --zsh > ./completions.zsh + installShellCompletion --zsh --name _${pname} ./completions.zsh + ''; + }; default = self.packages.${system}.jujutsu; }; apps.${system}.default = { type = "app"; - program = "${pkgs.jujutsu}/bin/jj"; + program = "${self.packages.${system}.jujutsu}/bin/jj"; }; - checks.${system}.jujutsu = pkgs.jujutsu.overrideAttrs ({ ... }: { + checks.${system}.jujutsu = self.packages.${system}.jujutsu.overrideAttrs ({ ... }: { cargoBuildType = "debug"; cargoCheckType = "debug"; preCheck = ''