mirror of
https://github.com/NixOS/nixpkgs.git
synced 2025-01-20 20:03:24 +00:00
Merge pull request #102982 from NeQuissimus/coursier_update
coursier: Add update script
This commit is contained in:
commit
21d863f7e0
@ -1,18 +1,25 @@
|
|||||||
{ stdenv, fetchurl, makeWrapper, jre }:
|
{ stdenv, fetchurl, makeWrapper, jre, writeScript, common-updater-scripts
|
||||||
|
, coreutils, git, gnused, nix, nixfmt }:
|
||||||
|
|
||||||
let
|
let
|
||||||
zshCompletion = version: fetchurl {
|
|
||||||
url = "https://raw.githubusercontent.com/coursier/coursier/v${version}/modules/cli/src/main/resources/completions/zsh";
|
|
||||||
sha256 = "0afxzrk9w1qinfsz55jjrxydw0fcv6p722g1q955dl7f6xbab1jh";
|
|
||||||
};
|
|
||||||
in
|
|
||||||
stdenv.mkDerivation rec {
|
|
||||||
pname = "coursier";
|
|
||||||
version = "2.0.6";
|
version = "2.0.6";
|
||||||
|
|
||||||
|
zshCompletion = fetchurl {
|
||||||
|
url =
|
||||||
|
"https://raw.githubusercontent.com/coursier/coursier/v${version}/modules/cli/src/main/resources/completions/zsh";
|
||||||
|
sha256 = "0afxzrk9w1qinfsz55jjrxydw0fcv6p722g1q955dl7f6xbab1jh";
|
||||||
|
};
|
||||||
|
|
||||||
|
repo = "git@github.com:coursier/coursier.git";
|
||||||
|
in stdenv.mkDerivation rec {
|
||||||
|
inherit version;
|
||||||
|
|
||||||
|
pname = "coursier";
|
||||||
|
|
||||||
src = fetchurl {
|
src = fetchurl {
|
||||||
url = "https://github.com/coursier/coursier/releases/download/v${version}/coursier";
|
url =
|
||||||
sha256 = "0zg07bi44a5p0zfc77i1vmjz9rwzxzf6p0xsybsv3n1saq884wij";
|
"https://github.com/coursier/coursier/releases/download/v${version}/coursier";
|
||||||
|
sha256 = "MnKCEFY62LH18rqDa9zvn+f0Zd0hnsPcB7coQuI64H0=";
|
||||||
};
|
};
|
||||||
|
|
||||||
nativeBuildInputs = [ makeWrapper ];
|
nativeBuildInputs = [ makeWrapper ];
|
||||||
@ -23,12 +30,42 @@ stdenv.mkDerivation rec {
|
|||||||
wrapProgram $out/bin/coursier --prefix PATH ":" ${jre}/bin
|
wrapProgram $out/bin/coursier --prefix PATH ":" ${jre}/bin
|
||||||
|
|
||||||
# copy zsh completion
|
# copy zsh completion
|
||||||
install -Dm755 ${zshCompletion version} $out/share/zsh/site-functions/_coursier
|
install -Dm755 ${zshCompletion} $out/share/zsh/site-functions/_coursier
|
||||||
|
'';
|
||||||
|
|
||||||
|
passthru.updateScript = writeScript "update.sh" ''
|
||||||
|
#!${stdenv.shell}
|
||||||
|
set -o errexit
|
||||||
|
PATH=${
|
||||||
|
stdenv.lib.makeBinPath [
|
||||||
|
common-updater-scripts
|
||||||
|
coreutils
|
||||||
|
git
|
||||||
|
gnused
|
||||||
|
nix
|
||||||
|
nixfmt
|
||||||
|
]
|
||||||
|
}
|
||||||
|
oldVersion="$(nix-instantiate --eval -E "with import ./. {}; lib.getVersion ${pname}" | tr -d '"')"
|
||||||
|
latestTag="$(git -c 'versionsort.suffix=-' ls-remote --exit-code --refs --sort='version:refname' --tags ${repo} 'v*.*.*' | tail --lines=1 | cut --delimiter='/' --fields=3 | sed 's|^v||g')"
|
||||||
|
if [ "$oldVersion" != "$latestTag" ]; then
|
||||||
|
nixpkgs="$(git rev-parse --show-toplevel)"
|
||||||
|
default_nix="$nixpkgs/pkgs/development/tools/coursier/default.nix"
|
||||||
|
update-source-version ${pname} "$latestTag" --version-key=version --print-changes
|
||||||
|
url="${builtins.head zshCompletion.urls}"
|
||||||
|
completion_url=$(echo $url | sed "s|$oldVersion|$latestTag|g")
|
||||||
|
completion_sha256="$(nix-prefetch-url --type sha256 $completion_url)"
|
||||||
|
sed -i "s|${zshCompletion.outputHash}|$completion_sha256|g" "$default_nix"
|
||||||
|
nixfmt "$default_nix"
|
||||||
|
else
|
||||||
|
echo "${pname} is already up-to-date"
|
||||||
|
fi
|
||||||
'';
|
'';
|
||||||
|
|
||||||
meta = with stdenv.lib; {
|
meta = with stdenv.lib; {
|
||||||
homepage = "https://get-coursier.io/";
|
homepage = "https://get-coursier.io/";
|
||||||
description = "A Scala library to fetch dependencies from Maven / Ivy repositories";
|
description =
|
||||||
|
"A Scala library to fetch dependencies from Maven / Ivy repositories";
|
||||||
license = licenses.asl20;
|
license = licenses.asl20;
|
||||||
maintainers = with maintainers; [ adelbertc nequissimus ];
|
maintainers = with maintainers; [ adelbertc nequissimus ];
|
||||||
};
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user