X-Git-Url: http://git.scottworley.com/auto-upgrade-with-pinch/blobdiff_plain/c1430067aa042d9dd6e3b1e103d336094135eb97..98604ba76ee41d5835d3f0d4ef76e7250d9f59c2:/overlays/pinch.nix diff --git a/overlays/pinch.nix b/overlays/pinch.nix index 29d2293..8e9633f 100644 --- a/overlays/pinch.nix +++ b/overlays/pinch.nix @@ -1,14 +1,39 @@ -self: super: { - pinch = if builtins.hasAttr "pinch" super then - super.pinch - else - super.writeShellScriptBin "pinch" '' - exec ${self.python3}/bin/python3 ${ - super.fetchgit { - url = "https://scottworley.com/pinch.git"; - rev = "1.3"; - sha256 = "1l2pq0pqmjh5q8ggmz6sw6bz0nnz0jy92l5qgax8bmpm1qcszmxf"; - } - }/pinch.py "$@" - ''; -} +self: super: +let + fallback-git-cache = self.python3Packages.callPackage + ({ buildPythonPackage, fetchgit, git, backoff, mypy, }: + buildPythonPackage rec { + pname = "git-cache"; + version = "1.5.0"; + src = fetchgit { + url = "https://git.scottworley.com/pub/git/git-cache"; + rev = "v${version}"; + hash = "sha256-g4TS/zX3e29Q3ThsCAX2wLLlYbi8fdux5uqAc+b/Oww="; + }; + propagatedBuildInputs = [ backoff ]; + nativeCheckInputs = [ git mypy ]; + doCheck = true; + checkPhase = "./test.sh"; + }) { }; + + fallback-pinch = self.python3Packages.callPackage + ({ buildPythonPackage, fetchgit, nix_2_3, git, makeWrapper, mypy, git-cache, }: + buildPythonPackage rec { + pname = "pinch"; + version = "3.1.0"; + src = fetchgit { + url = "https://git.scottworley.com/pub/git/pinch"; + rev = "v${version}"; + hash = "sha256-qwbYDSGE6p1YU3AnOatXNoTUc284D1xPQs/tRS++VOM="; + }; + buildInputs = [ makeWrapper ]; + propagatedBuildInputs = [ git-cache ]; + nativeCheckInputs = [ nix_2_3 git mypy ]; + postInstall = '' + wrapProgram "$out/bin/pinch" --prefix PATH : ${nix_2_3}/bin + ''; + doCheck = true; + checkPhase = "./test.sh"; + }) { git-cache = self.python3Packages.git-cache or fallback-git-cache; }; + +in { pinch = super.pinch or fallback-pinch; }