forked from mirrors/nixpkgs
commit
a6018ad946
|
@ -10,7 +10,8 @@ die() {
|
||||||
|
|
||||||
usage() {
|
usage() {
|
||||||
echo "Usage: $scriptName <attr> <version> [<new-source-hash>] [<new-source-url>]"
|
echo "Usage: $scriptName <attr> <version> [<new-source-hash>] [<new-source-url>]"
|
||||||
echo " [--version-key=<version-key>] [--system=<system>] [--file=<file-to-update>] [--rev=<revision>]"
|
echo " [--version-key=<version-key>] [--source-key=<source-key>]"
|
||||||
|
echo " [--system=<system>] [--file=<file-to-update>] [--rev=<revision>]"
|
||||||
echo " [--ignore-same-hash] [--print-changes]"
|
echo " [--ignore-same-hash] [--print-changes]"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -25,6 +26,9 @@ for arg in "$@"; do
|
||||||
--version-key=*)
|
--version-key=*)
|
||||||
versionKey="${arg#*=}"
|
versionKey="${arg#*=}"
|
||||||
;;
|
;;
|
||||||
|
--source-key=*)
|
||||||
|
sourceKey="${arg#*=}"
|
||||||
|
;;
|
||||||
--file=*)
|
--file=*)
|
||||||
nixFile="${arg#*=}"
|
nixFile="${arg#*=}"
|
||||||
if [[ ! -f "$nixFile" ]]; then
|
if [[ ! -f "$nixFile" ]]; then
|
||||||
|
@ -79,6 +83,10 @@ if [[ -z "$versionKey" ]]; then
|
||||||
versionKey=version
|
versionKey=version
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
if [[ -z "$sourceKey" ]]; then
|
||||||
|
sourceKey=src
|
||||||
|
fi
|
||||||
|
|
||||||
# Allow finding packages among flake outputs in repos using flake-compat.
|
# Allow finding packages among flake outputs in repos using flake-compat.
|
||||||
pname=$(nix-instantiate $systemArg --eval --strict -A "$attr.name" || echo)
|
pname=$(nix-instantiate $systemArg --eval --strict -A "$attr.name" || echo)
|
||||||
if [[ -z "$pname" ]]; then
|
if [[ -z "$pname" ]]; then
|
||||||
|
@ -106,7 +114,7 @@ if [[ -z "$nixFile" ]]; then
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# flake-compat will return paths in the Nix store, we need to correct for that.
|
# flake-compat will return paths in the Nix store, we need to correct for that.
|
||||||
possiblyOutPath=$(nix-instantiate $systemArg --eval -E "with $importTree; outPath" | tr -d '"')
|
possiblyOutPath=$(nix-instantiate $systemArg --eval -E "with $importTree; outPath" 2>/dev/null | tr -d '"')
|
||||||
if [[ -n "$possiblyOutPath" ]]; then
|
if [[ -n "$possiblyOutPath" ]]; then
|
||||||
outPathEscaped=$(echo "$possiblyOutPath" | sed 's#[$^*\\.[|]#\\&#g')
|
outPathEscaped=$(echo "$possiblyOutPath" | sed 's#[$^*\\.[|]#\\&#g')
|
||||||
pwdEscaped=$(echo "$PWD" | sed 's#[$^*\\.[|]#\\&#g')
|
pwdEscaped=$(echo "$PWD" | sed 's#[$^*\\.[|]#\\&#g')
|
||||||
|
@ -114,21 +122,21 @@ if [[ -z "$nixFile" ]]; then
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
oldHashAlgo=$(nix-instantiate $systemArg --eval --strict -A "$attr.src.drvAttrs.outputHashAlgo" | tr -d '"')
|
oldHashAlgo=$(nix-instantiate $systemArg --eval --strict -A "$attr.$sourceKey.drvAttrs.outputHashAlgo" | tr -d '"')
|
||||||
oldHash=$(nix-instantiate $systemArg --eval --strict -A "$attr.src.drvAttrs.outputHash" | tr -d '"')
|
oldHash=$(nix-instantiate $systemArg --eval --strict -A "$attr.$sourceKey.drvAttrs.outputHash" | tr -d '"')
|
||||||
|
|
||||||
if [[ -z "$oldHashAlgo" || -z "$oldHash" ]]; then
|
if [[ -z "$oldHashAlgo" || -z "$oldHash" ]]; then
|
||||||
die "Couldn't evaluate old source hash from '$attr.src'!"
|
die "Couldn't evaluate old source hash from '$attr.$sourceKey'!"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ $(grep --count "$oldHash" "$nixFile") != 1 ]]; then
|
if [[ $(grep --count "$oldHash" "$nixFile") != 1 ]]; then
|
||||||
die "Couldn't locate old source hash '$oldHash' (or it appeared more than once) in '$nixFile'!"
|
die "Couldn't locate old source hash '$oldHash' (or it appeared more than once) in '$nixFile'!"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
oldUrl=$(nix-instantiate $systemArg --eval -E "with $importTree; builtins.elemAt ($attr.src.drvAttrs.urls or [ $attr.src.url ]) 0" | tr -d '"')
|
oldUrl=$(nix-instantiate $systemArg --eval -E "with $importTree; builtins.elemAt ($attr.$sourceKey.drvAttrs.urls or [ $attr.$sourceKey.url ]) 0" | tr -d '"')
|
||||||
|
|
||||||
if [[ -z "$oldUrl" ]]; then
|
if [[ -z "$oldUrl" ]]; then
|
||||||
die "Couldn't evaluate source url from '$attr.src'!"
|
die "Couldn't evaluate source url from '$attr.$sourceKey'!"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
oldVersion=$(nix-instantiate $systemArg --eval -E "with $importTree; $attr.${versionKey} or (builtins.parseDrvName $attr.name).version" | tr -d '"')
|
oldVersion=$(nix-instantiate $systemArg --eval -E "with $importTree; $attr.${versionKey} or (builtins.parseDrvName $attr.name).version" | tr -d '"')
|
||||||
|
@ -146,9 +154,9 @@ if [[ "$oldVersion" = "$newVersion" ]]; then
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ -n "$newRevision" ]]; then
|
if [[ -n "$newRevision" ]]; then
|
||||||
oldRevision=$(nix-instantiate $systemArg --eval -E "with $importTree; $attr.src.rev" | tr -d '"')
|
oldRevision=$(nix-instantiate $systemArg --eval -E "with $importTree; $attr.$sourceKey.rev" | tr -d '"')
|
||||||
if [[ -z "$oldRevision" ]]; then
|
if [[ -z "$oldRevision" ]]; then
|
||||||
die "Couldn't evaluate source revision from '$attr.src'!"
|
die "Couldn't evaluate source revision from '$attr.$sourceKey'!"
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
@ -228,7 +236,7 @@ fi
|
||||||
|
|
||||||
# If new hash not given on the command line, recalculate it ourselves.
|
# If new hash not given on the command line, recalculate it ourselves.
|
||||||
if [[ -z "$newHash" ]]; then
|
if [[ -z "$newHash" ]]; then
|
||||||
nix-build $systemArg --no-out-link -A "$attr.src" 2>"$attr.fetchlog" >/dev/null || true
|
nix-build $systemArg --no-out-link -A "$attr.$sourceKey" 2>"$attr.fetchlog" >/dev/null || true
|
||||||
# FIXME: use nix-build --hash here once https://github.com/NixOS/nix/issues/1172 is fixed
|
# FIXME: use nix-build --hash here once https://github.com/NixOS/nix/issues/1172 is fixed
|
||||||
newHash=$(sed '1,/hash mismatch in fixed-output derivation/d' "$attr.fetchlog" | grep --perl-regexp --only-matching 'got: +.+[:-]\K.+')
|
newHash=$(sed '1,/hash mismatch in fixed-output derivation/d' "$attr.fetchlog" | grep --perl-regexp --only-matching 'got: +.+[:-]\K.+')
|
||||||
|
|
||||||
|
@ -242,12 +250,12 @@ fi
|
||||||
|
|
||||||
if [[ -z "$newHash" ]]; then
|
if [[ -z "$newHash" ]]; then
|
||||||
cat "$attr.fetchlog" >&2
|
cat "$attr.fetchlog" >&2
|
||||||
die "Couldn't figure out new hash of '$attr.src'!"
|
die "Couldn't figure out new hash of '$attr.$sourceKey'!"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ -z "${ignoreSameHash}" && "$oldVersion" != "$newVersion" && "$oldHash" = "$newHash" ]]; then
|
if [[ -z "${ignoreSameHash}" && "$oldVersion" != "$newVersion" && "$oldHash" = "$newHash" ]]; then
|
||||||
mv "$nixFile.bak" "$nixFile"
|
mv "$nixFile.bak" "$nixFile"
|
||||||
die "Both the old and new source hashes of '$attr.src' were equivalent. Please fix the package's source URL to be dependent on '\${version}'!"
|
die "Both the old and new source hashes of '$attr.$sourceKey' were equivalent. Please fix the package's source URL to be dependent on '\${version}'!"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
sed -i "$nixFile" -re "s|\"$tempHashEscaped\"|\"$newHash\"|"
|
sed -i "$nixFile" -re "s|\"$tempHashEscaped\"|\"$newHash\"|"
|
||||||
|
|
|
@ -1,10 +1,8 @@
|
||||||
{ lib
|
{ lib
|
||||||
, mkDerivation
|
, mkDerivation
|
||||||
, fetchurl
|
, fetchurl
|
||||||
, fetchpatch
|
|
||||||
, variant ? "standalone"
|
, variant ? "standalone"
|
||||||
, fetchFromGitHub
|
, fetchFromGitHub
|
||||||
, fetchFromGitLab
|
|
||||||
, cmake
|
, cmake
|
||||||
, pkg-config
|
, pkg-config
|
||||||
, opencv3
|
, opencv3
|
||||||
|
@ -20,6 +18,12 @@
|
||||||
, gimp ? null
|
, gimp ? null
|
||||||
, qtbase
|
, qtbase
|
||||||
, qttools
|
, qttools
|
||||||
|
, writeShellScript
|
||||||
|
, common-updater-scripts
|
||||||
|
, gnugrep
|
||||||
|
, gnused
|
||||||
|
, coreutils
|
||||||
|
, jq
|
||||||
}:
|
}:
|
||||||
|
|
||||||
let
|
let
|
||||||
|
@ -52,61 +56,42 @@ assert lib.assertMsg (builtins.all (d: d != null) variants.${variant}.extraDeps
|
||||||
|
|
||||||
mkDerivation rec {
|
mkDerivation rec {
|
||||||
pname = "gmic-qt${lib.optionalString (variant != "standalone") "-${variant}"}";
|
pname = "gmic-qt${lib.optionalString (variant != "standalone") "-${variant}"}";
|
||||||
version = "2.7.1";
|
version = "3.0.0";
|
||||||
|
|
||||||
gmic-community = fetchFromGitHub {
|
gmic-community = fetchFromGitHub {
|
||||||
owner = "dtschump";
|
owner = "dtschump";
|
||||||
repo = "gmic-community";
|
repo = "gmic-community";
|
||||||
rev = "3fd528f20a2a7d651e96078c205ff21efb9cdd1a";
|
rev = "df23b08bc52767762f0e38d040cd8ffeea4b865e";
|
||||||
sha256 = "08d37b49qgh5d4rds7hvr5wjj4p1y8cnbidz1cyqsibq0555pwq2";
|
sha256 = "euk5RsFPBgx2czAukPRdi/O4ahgXO8J8VJdiGHNge5M=";
|
||||||
};
|
};
|
||||||
|
|
||||||
CImg = fetchFromGitLab {
|
CImg = fetchFromGitHub {
|
||||||
domain = "framagit.org";
|
|
||||||
owner = "dtschump";
|
owner = "dtschump";
|
||||||
repo = "CImg";
|
repo = "CImg";
|
||||||
rev = "v.${version}";
|
rev = "v.${version}";
|
||||||
sha256 = "1mfkjvf5r3ppc1dd6yvqn7xlhgzfg9k1k5v2sq2k9m70g8p7rgpd";
|
sha256 = "dC4VuWTz0uyFxLjBQ+2ggndHaCErcoI7tJMfkqbWmeg=";
|
||||||
};
|
};
|
||||||
|
|
||||||
gmic_stdlib = fetchurl {
|
gmic_stdlib = fetchurl {
|
||||||
name = "gmic_stdlib.h";
|
name = "gmic_stdlib.h";
|
||||||
url = "http://gmic.eu/gmic_stdlib${lib.replaceStrings ["."] [""] version}.h";
|
url = "http://gmic.eu/gmic_stdlib${lib.replaceStrings ["."] [""] version}.h";
|
||||||
sha256 = "0v12smknr1s44s6wq2gbnw0hb98xrwp6i3zg9wf49cl7s9qf76j3";
|
sha256 = "CAYSxw5NCmE29hie1/J1csBcdQvIrmZ/+mNMl0sLLGI=";
|
||||||
};
|
};
|
||||||
|
|
||||||
gmic = fetchFromGitHub {
|
gmic = fetchFromGitHub {
|
||||||
owner = "dtschump";
|
owner = "dtschump";
|
||||||
repo = "gmic";
|
repo = "gmic";
|
||||||
rev = "v.${version}";
|
rev = "v.${version}";
|
||||||
sha256 = "0pa6kflr1gqgzh8rk7bylvkxs989r5jy0q7b62mnzx8895slwfb5";
|
sha256 = "PyeJmjOqjbHlZ1Xl3IpoOD6oZEcUrHNHqF7Ft1RZDL4=";
|
||||||
};
|
};
|
||||||
|
|
||||||
gmic_qt = fetchFromGitHub {
|
gmic_qt = fetchFromGitHub {
|
||||||
owner = "c-koi";
|
owner = "c-koi";
|
||||||
repo = "gmic-qt";
|
repo = "gmic-qt";
|
||||||
rev = "v.${version}";
|
rev = "v.${version}";
|
||||||
sha256 = "08a0660083wv5fb1w9qqhm4f8cfwbqq723qzqq647mid1n7sy959";
|
sha256 = "nENXumOArRAHENqnBUjM7m+I5hf/WAFTVfm6cJgnv+0=";
|
||||||
};
|
};
|
||||||
|
|
||||||
patches = [
|
|
||||||
# Install GIMP plug-in to a correct destination
|
|
||||||
# https://github.com/c-koi/gmic-qt/pull/78
|
|
||||||
./fix-gimp-plugin-path.patch
|
|
||||||
];
|
|
||||||
|
|
||||||
unpackPhase = ''
|
|
||||||
cp -r ${gmic} gmic
|
|
||||||
ln -s ${gmic-community} gmic-community
|
|
||||||
cp -r ${gmic_qt} gmic_qt
|
|
||||||
chmod -R +w gmic gmic_qt
|
|
||||||
ln -s ${CImg} CImg
|
|
||||||
|
|
||||||
cp ${gmic_stdlib} gmic/src/gmic_stdlib.h
|
|
||||||
|
|
||||||
cd gmic_qt
|
|
||||||
'';
|
|
||||||
|
|
||||||
nativeBuildInputs = [
|
nativeBuildInputs = [
|
||||||
cmake
|
cmake
|
||||||
pkg-config
|
pkg-config
|
||||||
|
@ -130,15 +115,54 @@ mkDerivation rec {
|
||||||
"-DGMIC_QT_HOST=${if variant == "standalone" then "none" else variant}"
|
"-DGMIC_QT_HOST=${if variant == "standalone" then "none" else variant}"
|
||||||
];
|
];
|
||||||
|
|
||||||
postFixup = lib.optionalString (variant == "gimp") ''
|
unpackPhase = ''
|
||||||
echo "wrapping $out/${gimp.targetPluginDir}/gmic_gimp_qt"
|
cp -r ${gmic} gmic
|
||||||
wrapQtApp "$out/${gimp.targetPluginDir}/gmic_gimp_qt"
|
ln -s ${gmic-community} gmic-community
|
||||||
|
cp -r ${gmic_qt} gmic_qt
|
||||||
|
chmod -R +w gmic gmic_qt
|
||||||
|
ln -s ${CImg} CImg
|
||||||
|
|
||||||
|
cp ${gmic_stdlib} gmic/src/gmic_stdlib.h
|
||||||
|
|
||||||
|
cd gmic_qt
|
||||||
'';
|
'';
|
||||||
|
|
||||||
|
postFixup = lib.optionalString (variant == "gimp") ''
|
||||||
|
echo "wrapping $out/${gimp.targetPluginDir}/gmic_gimp_qt/gmic_gimp_qt"
|
||||||
|
wrapQtApp "$out/${gimp.targetPluginDir}/gmic_gimp_qt/gmic_gimp_qt"
|
||||||
|
'';
|
||||||
|
|
||||||
|
passthru = {
|
||||||
|
updateScript = writeShellScript "${pname}-update-script" ''
|
||||||
|
set -o errexit
|
||||||
|
PATH=${lib.makeBinPath [ common-updater-scripts curl gnugrep gnused coreutils jq ]}
|
||||||
|
|
||||||
|
latestVersion=$(curl 'https://gmic.eu/files/source/' | grep -E 'gmic_[^"]+\.tar\.gz' | sed -E 's/.+<a href="gmic_([^"]+)\.tar\.gz".+/\1/g' | sort --numeric-sort --reverse | head -n1)
|
||||||
|
|
||||||
|
if [[ "${version}" = "$latestVersion" ]]; then
|
||||||
|
echo "The new version same as the old version."
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
# gmic-community is not versioned so let’s just update to master.
|
||||||
|
communityLatestCommit=$(curl "https://api.github.com/repos/dtschump/gmic-community/commits/master")
|
||||||
|
communityLatestSha=$(echo "$communityLatestCommit" | jq .sha --raw-output)
|
||||||
|
communityLatestDate=$(echo "$communityLatestCommit" | jq .commit.committer.date --raw-output | sed 's/T.\+//')
|
||||||
|
update-source-version --source-key=gmic-community "gmic-qt" "unstable-$communityLatestDate" --rev="$communityLatestSha"
|
||||||
|
|
||||||
|
for component in CImg gmic_stdlib gmic gmic_qt; do
|
||||||
|
# The script will not perform an update when the version attribute is up to date from previous platform run
|
||||||
|
# We need to clear it before each run
|
||||||
|
update-source-version "--source-key=$component" "gmic-qt" 0 "$(printf '0%.0s' {1..64})"
|
||||||
|
update-source-version "--source-key=$component" "gmic-qt" $latestVersion
|
||||||
|
done
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
meta = with lib; {
|
meta = with lib; {
|
||||||
description = variants.${variant}.description;
|
description = variants.${variant}.description;
|
||||||
homepage = "http://gmic.eu/";
|
homepage = "http://gmic.eu/";
|
||||||
license = licenses.gpl3;
|
license = licenses.gpl3Plus;
|
||||||
platforms = platforms.unix;
|
platforms = platforms.unix;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,21 +0,0 @@
|
||||||
diff --git a/CMakeLists.txt b/CMakeLists.txt
|
|
||||||
index 1483056..26d2b9a 100644
|
|
||||||
--- a/CMakeLists.txt
|
|
||||||
+++ b/CMakeLists.txt
|
|
||||||
@@ -473,6 +473,7 @@
|
|
||||||
|
|
||||||
execute_process(COMMAND gimptool-2.0 --libs-noui OUTPUT_VARIABLE GIMP2_LIBRARIES OUTPUT_STRIP_TRAILING_WHITESPACE)
|
|
||||||
execute_process(COMMAND gimptool-2.0 --cflags-noui OUTPUT_VARIABLE GIMP2_INCLUDE_DIRS OUTPUT_STRIP_TRAILING_WHITESPACE)
|
|
||||||
+ execute_process(COMMAND pkg-config gimp-2.0 --define-variable=prefix=${CMAKE_INSTALL_PREFIX} --variable gimplibdir OUTPUT_VARIABLE GIMP2_PKGLIBDIR OUTPUT_STRIP_TRAILING_WHITESPACE)
|
|
||||||
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${GIMP2_INCLUDE_DIRS}")
|
|
||||||
|
|
||||||
set (gmic_qt_SRCS ${gmic_qt_SRCS} src/Host/Gimp/host_gimp.cpp)
|
|
||||||
@@ -484,7 +485,7 @@
|
|
||||||
${GIMP2_LIBRARIES}
|
|
||||||
${gmic_qt_LIBRARIES}
|
|
||||||
)
|
|
||||||
- install(TARGETS gmic_gimp_qt RUNTIME DESTINATION bin)
|
|
||||||
+ install(TARGETS gmic_gimp_qt RUNTIME DESTINATION "${GIMP2_PKGLIBDIR}/plug-ins")
|
|
||||||
|
|
||||||
elseif (${GMIC_QT_HOST} STREQUAL "krita")
|
|
||||||
|
|
Loading…
Reference in a new issue