Skip to content

Commit

Permalink
Support python_env.pip.uv.enable = true
Browse files Browse the repository at this point in the history
  • Loading branch information
yorickvP committed Apr 19, 2024
1 parent 0a029f5 commit 6186b48
Show file tree
Hide file tree
Showing 5 changed files with 140 additions and 2 deletions.
55 changes: 55 additions & 0 deletions flake.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

13 changes: 11 additions & 2 deletions flake.nix
Original file line number Diff line number Diff line change
Expand Up @@ -4,9 +4,11 @@
dream2nix.url = "github:yorickvp/dream2nix";
nixpkgs.follows = "dream2nix/nixpkgs";
flake-parts.url = "github:hercules-ci/flake-parts";
rust-overlay.url = "github:oxalica/rust-overlay";
rust-overlay.inputs.nixpkgs.follows = "nixpkgs";
};

outputs = { self, dream2nix, nixpkgs, flake-parts }@inputs:
outputs = { self, dream2nix, nixpkgs, flake-parts, rust-overlay }@inputs:
flake-parts.lib.mkFlake { inherit inputs; } {
systems = [ "x86_64-linux" ];
# debug = true;
Expand Down Expand Up @@ -51,11 +53,18 @@
config.allowUnfree = true;
inherit system;
overlays = [
(import rust-overlay)
(final: prev: {
pget = prev.callPackage ./pkgs/pget.nix { };
cognix-weights = prev.callPackage ./pkgs/cognix-weights {};
cognix-cli = prev.callPackage ./pkgs/cognix-cli {};
cog = prev.callPackage ./pkgs/cog.nix {};
uv = prev.callPackage ./pkgs/uv.nix {
rustPlatform = prev.makeRustPlatform {
cargo = prev.rust-bin.stable.latest.minimal;
rustc = prev.rust-bin.stable.latest.minimal;
};
};
lib = prev.lib.extend (finall: prevl: {
trivial = prevl.trivial // {
revisionWithDefault = default: nixpkgs.rev or default;
Expand Down Expand Up @@ -86,7 +95,7 @@
path = if pkgs.lib.isDerivation path then path else "/dev/null";
}) config.legacyPackages);
legacyPackages = {
inherit (pkgs) pget cognix-weights cognix-cli cog stream_layered_image;
inherit (pkgs) pget cognix-weights cognix-cli cog stream_layered_image uv;
callCognix = import ./default.nix {
inherit pkgs dream2nix;
};
Expand Down
2 changes: 2 additions & 0 deletions modules/cog.nix
Original file line number Diff line number Diff line change
Expand Up @@ -71,6 +71,7 @@ let
pyEnvWithPip = config.python-env.public.pyEnv.override {
postBuild = "$out/bin/python -m ensurepip";
};
patchTorch = builtins.map (y: if builtins.match "torch==[0-9\.]+$" y == [] then "${y}.*" else y);
in {
imports = [
./cog-interface.nix
Expand Down Expand Up @@ -173,6 +174,7 @@ in {
dream2nix.modules.dream2nix.pip
pipOverridesModule
(proxyLockModule config.lock.content)
./uv-solver.nix
];
paths = { inherit (config.paths) projectRoot package; };
name = "cog-docker-env";
Expand Down
48 changes: 48 additions & 0 deletions modules/uv-solver.nix
Original file line number Diff line number Diff line change
@@ -0,0 +1,48 @@
{ lib, config, packageSets, ... }: let
cfg = config.pip.uv;
pkgs = packageSets.nixpkgs;
# bug: torch==2.1.0 does not resolve to torch==2.1.0+cpu
patchTorch = builtins.map (y: if builtins.match "torch==[0-9\.]+$" y == [] then "${y}.*" else y);
constraintsArgs = lib.optionals (cfg.constraints != []) [
"--constraint"
(builtins.toFile "constraints.txt" (lib.concatMapStrings (x: "${x}\n") cfg.constraints))
];
overridesArgs = lib.optionals (cfg.overrides != []) [
"--override"
(builtins.toFile "overrides.txt" (lib.concatMapStrings (x: "${x}\n") cfg.overrides))
];
extraArgs = constraintsArgs ++ overridesArgs ++ cfg.extraArgs;
in {
# todo: support env
options.pip.uv = with lib; {
enable = mkEnableOption "use uv solver";
overrides = mkOption {
type = types.listOf types.str;
default = [];
};
constraints = mkOption {
type = types.listOf types.str;
default = [];
};
extraArgs = mkOption {
type = types.listOf types.str;
default = [];
};
};
config = lib.mkIf cfg.enable {
deps.fetchPipMetadataScript = pkgs.writeShellScript "fetch-pip-metadata-uv" ''
export UV_DUMP_DREAM2NIX="$out"
${pkgs.uv}/bin/uv pip install \
--dry-run \
--reinstall \
--index-strategy unsafe-highest \
--break-system-packages \
${lib.optionalString (config.pip.pypiSnapshotDate != null) "--exclude-newer ${config.pip.pypiSnapshotDate}"} \
--python ${config.deps.python}/bin/python \
${lib.escapeShellArgs extraArgs} \
${lib.escapeShellArgs (patchTorch config.pip.requirementsList)}
'';
lock.invalidationData.solver = "uv";
lock.invalidationData.extraArgs = extraArgs;
};
}
24 changes: 24 additions & 0 deletions pkgs/uv.nix
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
{ rustPlatform, fetchFromGitHub, lib, cmake, openssl, pkg-config, perl }:
rustPlatform.buildRustPackage {
pname = "uv";
version = "0.1.34.post";
nativeBuildInputs = [ cmake pkg-config perl ];
buildInputs = [ openssl ];
src = fetchFromGitHub {
owner = "yorickvP";
repo = "uv";
rev = "6ef1d706379a3403d917b75d41697e98f9a0619d";
hash = "sha256-U4mowALk3XKSzRkhbZT333v3mVlLBpeatl8mwfeg6uw=";
};
cargoLock = {
lockFile = builtins.fetchurl {
url = "https://raw.githubusercontent.com/astral-sh/uv/6ef1d706379a3403d917b75d41697e98f9a0619d/Cargo.lock";
sha256 = "12v38b50gyi5g7dz269vl4briw5jffw16mlsmiswh0f6q8nb64q4";
};
outputHashes = {
"async_zip-0.0.17" = "sha256-Q5fMDJrQtob54CTII3+SXHeozy5S5s3iLOzntevdGOs=";
"pubgrub-0.2.1" = "sha256-sqC7R2mtqymYFULDW0wSbM/MKCZc8rP7Yy/gaQpjYEI=";
};
};
doCheck = false;
}

0 comments on commit 6186b48

Please sign in to comment.