From 49c789703ccb70acebfaec4388f543a9ad63520a Mon Sep 17 00:00:00 2001 From: hlolli Date: Sat, 14 Nov 2020 00:55:44 +0100 Subject: [PATCH 1/2] fetchMavenArtifact: support artifact classifier syntax --- .../fetchmavenartifact/default.nix | 19 ++++++++++++++----- 1 file changed, 14 insertions(+), 5 deletions(-) diff --git a/pkgs/build-support/fetchmavenartifact/default.nix b/pkgs/build-support/fetchmavenartifact/default.nix index 583a9ea396cf..2058600960ae 100644 --- a/pkgs/build-support/fetchmavenartifact/default.nix +++ b/pkgs/build-support/fetchmavenartifact/default.nix @@ -36,19 +36,28 @@ assert (repos != []) || (url != "") || (urls != []); let + classifierSplit = + with stdenv.lib.strings; + splitString "$" artifactId; + artifactId_ = builtins.head classifierSplit; + classifier = + with stdenv.lib; + if builtins.length classifierSplit > 1 + then concatStrings ["-" (builtins.elemAt classifierSplit 1)] + else ""; name_ = with stdenv.lib; concatStrings [ (replaceChars ["."] ["_"] groupId) "_" - (replaceChars ["."] ["_"] artifactId) "-" + (replaceChars ["."] ["_"] artifactId_) "-" version ]; mkJarUrl = repoUrl: with stdenv.lib; concatStringsSep "/" [ (removeSuffix "/" repoUrl) (replaceChars ["."] ["/"] groupId) - artifactId + artifactId_ version - "${artifactId}-${version}.jar" + "${artifactId_}-${version}${classifier}.jar" ]; urls_ = if url != "" then [url] @@ -57,7 +66,7 @@ let jar = fetchurl ( builtins.removeAttrs args ["groupId" "artifactId" "version" "repos" "url" ] - // { urls = urls_; name = "${name_}.jar"; } + // { urls = urls_; name = "${name_}${classifier}.jar"; } ); in stdenv.mkDerivation { @@ -67,7 +76,7 @@ in # packages packages that mention this derivation in their buildInputs. installPhase = '' mkdir -p $out/share/java - ln -s ${jar} $out/share/java/${artifactId}-${version}.jar + ln -s ${jar} $out/share/java/${artifactId_}-${version}${classifier}.jar ''; # We also add a `jar` attribute that can be used to easily obtain the path # to the downloaded jar file. From 38ad37822813692de906c87f47801370ac1bcf1a Mon Sep 17 00:00:00 2001 From: hlolli Date: Sat, 5 Dec 2020 18:56:46 +0100 Subject: [PATCH 2/2] add classifier as an argument --- .../fetchmavenartifact/default.nix | 23 +++++++------------ 1 file changed, 8 insertions(+), 15 deletions(-) diff --git a/pkgs/build-support/fetchmavenartifact/default.nix b/pkgs/build-support/fetchmavenartifact/default.nix index 2058600960ae..42ad7603a8f7 100644 --- a/pkgs/build-support/fetchmavenartifact/default.nix +++ b/pkgs/build-support/fetchmavenartifact/default.nix @@ -17,6 +17,8 @@ args@ artifactId , # Example: "4.3.6" version +, # Example: "jdk11" + classifier ? null , # List of maven repositories from where to fetch the artifact. # Example: [ http://oss.sonatype.org/content/repositories/public ]. repos ? defaultRepos @@ -36,28 +38,19 @@ assert (repos != []) || (url != "") || (urls != []); let - classifierSplit = - with stdenv.lib.strings; - splitString "$" artifactId; - artifactId_ = builtins.head classifierSplit; - classifier = - with stdenv.lib; - if builtins.length classifierSplit > 1 - then concatStrings ["-" (builtins.elemAt classifierSplit 1)] - else ""; name_ = with stdenv.lib; concatStrings [ (replaceChars ["."] ["_"] groupId) "_" - (replaceChars ["."] ["_"] artifactId_) "-" + (replaceChars ["."] ["_"] artifactId) "-" version ]; mkJarUrl = repoUrl: with stdenv.lib; concatStringsSep "/" [ (removeSuffix "/" repoUrl) (replaceChars ["."] ["/"] groupId) - artifactId_ + artifactId version - "${artifactId_}-${version}${classifier}.jar" + "${artifactId}-${version}-${optionalString (!isNull classifier) "-${classifier}"}.jar" ]; urls_ = if url != "" then [url] @@ -65,8 +58,8 @@ let else map mkJarUrl repos; jar = fetchurl ( - builtins.removeAttrs args ["groupId" "artifactId" "version" "repos" "url" ] - // { urls = urls_; name = "${name_}${classifier}.jar"; } + builtins.removeAttrs args ["groupId" "artifactId" "version" "classifier" "repos" "url" ] + // { urls = urls_; name = "${name_}.jar"; } ); in stdenv.mkDerivation { @@ -76,7 +69,7 @@ in # packages packages that mention this derivation in their buildInputs. installPhase = '' mkdir -p $out/share/java - ln -s ${jar} $out/share/java/${artifactId_}-${version}${classifier}.jar + ln -s ${jar} $out/share/java/${artifactId}-${version}.jar ''; # We also add a `jar` attribute that can be used to easily obtain the path # to the downloaded jar file.