forked from mirrors/nixpkgs
gimp: 2.8.22 → 2.10.0
This commit is contained in:
parent
3ebb162d90
commit
b0d3ed3484
|
@ -1,57 +0,0 @@
|
||||||
{ stdenv, fetchurl, pkgconfig, intltool, babl, gegl, gtk2, glib, gdk_pixbuf
|
|
||||||
, pango, cairo, freetype, fontconfig, lcms, libpng, libjpeg, poppler, libtiff
|
|
||||||
, webkit, libmng, librsvg, libwmf, zlib, libzip, ghostscript, aalib, jasper
|
|
||||||
, python2Packages, libexif, gettext, xorg
|
|
||||||
, AppKit, Cocoa, gtk-mac-integration }:
|
|
||||||
|
|
||||||
let
|
|
||||||
inherit (python2Packages) pygtk wrapPython python;
|
|
||||||
in stdenv.mkDerivation rec {
|
|
||||||
name = "gimp-${version}";
|
|
||||||
version = "2.8.22";
|
|
||||||
|
|
||||||
# This declarations for `gimp-with-plugins` wrapper,
|
|
||||||
# (used for determining $out/lib/gimp/${majorVersion}/ paths)
|
|
||||||
majorVersion = "2.0";
|
|
||||||
targetPluginDir = "$out/lib/gimp/${majorVersion}/plug-ins";
|
|
||||||
targetScriptDir = "$out/lib/gimp/${majorVersion}/scripts";
|
|
||||||
|
|
||||||
src = fetchurl {
|
|
||||||
url = "http://download.gimp.org/pub/gimp/v2.8/${name}.tar.bz2";
|
|
||||||
sha256 = "12k3lp938qdc9cqj29scg55f3bb8iav2fysd29w0s49bqmfa71wi";
|
|
||||||
};
|
|
||||||
|
|
||||||
buildInputs =
|
|
||||||
[ pkgconfig intltool babl gegl gtk2 glib gdk_pixbuf pango cairo
|
|
||||||
freetype fontconfig lcms libpng libjpeg poppler libtiff webkit
|
|
||||||
libmng librsvg libwmf zlib libzip ghostscript aalib jasper
|
|
||||||
python pygtk libexif gettext xorg.libXpm
|
|
||||||
wrapPython
|
|
||||||
]
|
|
||||||
++ stdenv.lib.optionals stdenv.isDarwin [ AppKit Cocoa gtk-mac-integration ];
|
|
||||||
|
|
||||||
pythonPath = [ pygtk ];
|
|
||||||
|
|
||||||
postFixup = ''
|
|
||||||
wrapPythonProgramsIn $out/lib/gimp/2.0/plug-ins/
|
|
||||||
wrapProgram $out/bin/gimp \
|
|
||||||
--prefix PYTHONPATH : "$PYTHONPATH" \
|
|
||||||
--set GDK_PIXBUF_MODULE_FILE "$GDK_PIXBUF_MODULE_FILE"
|
|
||||||
'';
|
|
||||||
|
|
||||||
passthru = { gtk = gtk2; }; # probably its a good idea to use the same gtk in plugins ?
|
|
||||||
|
|
||||||
#configureFlags = [ "--disable-print" ];
|
|
||||||
|
|
||||||
enableParallelBuilding = true;
|
|
||||||
|
|
||||||
# "screenshot" needs this.
|
|
||||||
NIX_LDFLAGS = "-rpath ${xorg.libX11.out}/lib";
|
|
||||||
|
|
||||||
meta = {
|
|
||||||
description = "The GNU Image Manipulation Program";
|
|
||||||
homepage = https://www.gimp.org/;
|
|
||||||
license = stdenv.lib.licenses.gpl3Plus;
|
|
||||||
platforms = stdenv.lib.platforms.unix;
|
|
||||||
};
|
|
||||||
}
|
|
95
pkgs/applications/graphics/gimp/default.nix
Normal file
95
pkgs/applications/graphics/gimp/default.nix
Normal file
|
@ -0,0 +1,95 @@
|
||||||
|
{ stdenv, fetchurl, fetchpatch, autoreconfHook, pkgconfig, intltool, babl, gegl, gtk2, glib, gdk_pixbuf, isocodes
|
||||||
|
, pango, cairo, freetype, fontconfig, lcms, libpng, libjpeg, poppler, poppler_data, libtiff
|
||||||
|
, libmng, librsvg, libwmf, zlib, libzip, ghostscript, aalib, shared-mime-info
|
||||||
|
, python2Packages, libexif, gettext, xorg, glib-networking, libmypaint, gexiv2
|
||||||
|
, harfbuzz, mypaint-brushes, libwebp, libgudev, openexr
|
||||||
|
, AppKit, Cocoa, gtk-mac-integration }:
|
||||||
|
|
||||||
|
let
|
||||||
|
inherit (python2Packages) pygtk wrapPython python;
|
||||||
|
in stdenv.mkDerivation rec {
|
||||||
|
name = "gimp-${version}";
|
||||||
|
version = "2.10.0";
|
||||||
|
|
||||||
|
src = fetchurl {
|
||||||
|
url = "http://download.gimp.org/pub/gimp/v${stdenv.lib.versions.majorMinor version}/${name}.tar.bz2";
|
||||||
|
sha256 = "1qkxaigbfkx26xym5nzrgfrmn97cbnhn63v1saaha2nbi3xrdk3z";
|
||||||
|
};
|
||||||
|
|
||||||
|
patches = [
|
||||||
|
# fix rpath of python library https://bugzilla.gnome.org/show_bug.cgi?id=795620
|
||||||
|
(fetchurl {
|
||||||
|
url = https://bugzilla.gnome.org/attachment.cgi?id=371482;
|
||||||
|
sha256 = "18bysndh61pvlv255xapdrfpsl5ivm51wp1w7xgk9vky9z2y3llc";
|
||||||
|
})
|
||||||
|
|
||||||
|
# fix absolute paths stored in configuration
|
||||||
|
(fetchpatch {
|
||||||
|
url = https://git.gnome.org/browse/gimp/patch/?id=0fce8fdb3c056acead8322c976a96fb6fba793b6;
|
||||||
|
sha256 = "09845i3bdpdbf13razr04ksvwydxcvzhjwlb4dfgdv5q203g2ris";
|
||||||
|
})
|
||||||
|
(fetchpatch {
|
||||||
|
url = https://git.gnome.org/browse/gimp/patch/?id=f6b586237cb8c912c1503f8e6086edd17f07d4df;
|
||||||
|
sha256 = "0s68885ip2wgjvsl5vqi2f1xhxdjpzqprifzgdl1vnv6gqmfy3bh";
|
||||||
|
})
|
||||||
|
|
||||||
|
# fix pc file (needed e.g. for building plug-ins)
|
||||||
|
(fetchpatch {
|
||||||
|
url = https://git.gnome.org/browse/gimp/patch/?id=7e19906827d301eb70275dba089849a632a0eabe;
|
||||||
|
sha256 = "0cbjfbwvzg2hqihg3rpsga405v7z2qahj22dfqn2jrb2gbhrjcp1";
|
||||||
|
})
|
||||||
|
];
|
||||||
|
|
||||||
|
nativeBuildInputs = [ autoreconfHook pkgconfig intltool gettext wrapPython ];
|
||||||
|
propagatedBuildInputs = [ gegl ]; # needed by gimp-2.0.pc
|
||||||
|
buildInputs = [
|
||||||
|
babl gegl gtk2 glib gdk_pixbuf pango cairo gexiv2 harfbuzz isocodes libgudev
|
||||||
|
freetype fontconfig lcms libpng libjpeg poppler poppler_data libtiff openexr
|
||||||
|
libmng librsvg libwmf zlib libzip ghostscript aalib shared-mime-info libwebp
|
||||||
|
python pygtk libexif xorg.libXpm glib-networking libmypaint mypaint-brushes
|
||||||
|
] ++ stdenv.lib.optionals stdenv.isDarwin [ AppKit Cocoa gtk-mac-integration ];
|
||||||
|
|
||||||
|
pythonPath = [ pygtk ];
|
||||||
|
|
||||||
|
# Check if librsvg was built with --disable-pixbuf-loader.
|
||||||
|
PKG_CONFIG_GDK_PIXBUF_2_0_GDK_PIXBUF_MODULEDIR = "${librsvg}/${gdk_pixbuf.moduleDir}";
|
||||||
|
|
||||||
|
preConfigure = ''
|
||||||
|
# The check runs before glib-networking is registered
|
||||||
|
export GIO_EXTRA_MODULES="${glib-networking}/lib/gio/modules:$GIO_EXTRA_MODULES"
|
||||||
|
'';
|
||||||
|
|
||||||
|
postFixup = ''
|
||||||
|
wrapPythonProgramsIn $out/lib/gimp/${passthru.majorVersion}/plug-ins/
|
||||||
|
wrapProgram $out/bin/gimp-${stdenv.lib.versions.majorMinor version} \
|
||||||
|
--prefix PYTHONPATH : "$PYTHONPATH" \
|
||||||
|
--set GDK_PIXBUF_MODULE_FILE "$GDK_PIXBUF_MODULE_FILE"
|
||||||
|
'';
|
||||||
|
|
||||||
|
passthru = rec {
|
||||||
|
# The declarations for `gimp-with-plugins` wrapper,
|
||||||
|
# used for determining plug-in installation paths
|
||||||
|
majorVersion = "${stdenv.lib.versions.major version}.0";
|
||||||
|
targetPluginDir = "lib/gimp/${majorVersion}/plug-ins";
|
||||||
|
targetScriptDir = "lib/gimp/${majorVersion}/scripts";
|
||||||
|
|
||||||
|
# probably its a good idea to use the same gtk in plugins ?
|
||||||
|
gtk = gtk2;
|
||||||
|
};
|
||||||
|
|
||||||
|
configureFlags = [
|
||||||
|
"--without-webkit" # old version is required
|
||||||
|
];
|
||||||
|
|
||||||
|
doCheck = true;
|
||||||
|
|
||||||
|
enableParallelBuilding = true;
|
||||||
|
|
||||||
|
meta = with stdenv.lib; {
|
||||||
|
description = "The GNU Image Manipulation Program";
|
||||||
|
homepage = https://www.gimp.org/;
|
||||||
|
maintainers = with maintainers; [ jtojnar ];
|
||||||
|
license = licenses.gpl3Plus;
|
||||||
|
platforms = platforms.unix;
|
||||||
|
};
|
||||||
|
}
|
|
@ -12,12 +12,12 @@ let
|
||||||
prePhases = "extraLib";
|
prePhases = "extraLib";
|
||||||
extraLib = ''
|
extraLib = ''
|
||||||
installScripts(){
|
installScripts(){
|
||||||
mkdir -p ${targetScriptDir};
|
mkdir -p $out/${targetScriptDir};
|
||||||
for p in "$@"; do cp "$p" ${targetScriptDir}; done
|
for p in "$@"; do cp "$p" $out/${targetScriptDir}; done
|
||||||
}
|
}
|
||||||
installPlugins(){
|
installPlugins(){
|
||||||
mkdir -p ${targetPluginDir};
|
mkdir -p $out/${targetPluginDir};
|
||||||
for p in "$@"; do cp "$p" ${targetPluginDir}; done
|
for p in "$@"; do cp "$p" $out/${targetPluginDir}; done
|
||||||
}
|
}
|
||||||
'';
|
'';
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,6 +4,7 @@ let
|
||||||
allPlugins = lib.filter (pkg: builtins.isAttrs pkg && pkg.type == "derivation") (lib.attrValues gimpPlugins);
|
allPlugins = lib.filter (pkg: builtins.isAttrs pkg && pkg.type == "derivation") (lib.attrValues gimpPlugins);
|
||||||
selectedPlugins = if plugins == null then allPlugins else plugins;
|
selectedPlugins = if plugins == null then allPlugins else plugins;
|
||||||
extraArgs = map (x: x.wrapArgs or "") selectedPlugins;
|
extraArgs = map (x: x.wrapArgs or "") selectedPlugins;
|
||||||
|
versionBranch = stdenv.lib.versions.majorMinor gimp.version;
|
||||||
|
|
||||||
in symlinkJoin {
|
in symlinkJoin {
|
||||||
name = "gimp-with-plugins-${gimp.version}";
|
name = "gimp-with-plugins-${gimp.version}";
|
||||||
|
@ -13,14 +14,14 @@ in symlinkJoin {
|
||||||
buildInputs = [ makeWrapper ];
|
buildInputs = [ makeWrapper ];
|
||||||
|
|
||||||
postBuild = ''
|
postBuild = ''
|
||||||
for each in gimp-2.8 gimp-console-2.8; do
|
for each in gimp-${versionBranch} gimp-console-${versionBranch}; do
|
||||||
wrapProgram $out/bin/$each \
|
wrapProgram $out/bin/$each \
|
||||||
--set GIMP2_PLUGINDIR "$out/lib/gimp/2.0" \
|
--set GIMP2_PLUGINDIR "$out/lib/gimp/2.0" \
|
||||||
${toString extraArgs}
|
${toString extraArgs}
|
||||||
done
|
done
|
||||||
set +x
|
set +x
|
||||||
for each in gimp gimp-console; do
|
for each in gimp gimp-console; do
|
||||||
ln -sf "$each-2.8" $out/bin/$each
|
ln -sf "$each-${versionBranch}" $out/bin/$each
|
||||||
done
|
done
|
||||||
'';
|
'';
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,9 +1,9 @@
|
||||||
{ stdenv, fetchurl, sane-backends, sane-frontends, libX11, gtk2, pkgconfig, libpng
|
{ stdenv, fetchurl, sane-backends, sane-frontends, libX11, gtk2, pkgconfig, libpng
|
||||||
, libusb ? null
|
, libusb ? null
|
||||||
, gimpSupport ? false, gimp_2_8 ? null
|
, gimpSupport ? false, gimp ? null
|
||||||
}:
|
}:
|
||||||
|
|
||||||
assert gimpSupport -> gimp_2_8 != null;
|
assert gimpSupport -> gimp != null;
|
||||||
|
|
||||||
stdenv.mkDerivation rec {
|
stdenv.mkDerivation rec {
|
||||||
name = "xsane-0.999";
|
name = "xsane-0.999";
|
||||||
|
@ -21,7 +21,7 @@ stdenv.mkDerivation rec {
|
||||||
nativeBuildInputs = [ pkgconfig ];
|
nativeBuildInputs = [ pkgconfig ];
|
||||||
buildInputs = [libpng sane-backends sane-frontends libX11 gtk2 ]
|
buildInputs = [libpng sane-backends sane-frontends libX11 gtk2 ]
|
||||||
++ (if libusb != null then [libusb] else [])
|
++ (if libusb != null then [libusb] else [])
|
||||||
++ stdenv.lib.optional gimpSupport gimp_2_8;
|
++ stdenv.lib.optional gimpSupport gimp;
|
||||||
|
|
||||||
meta = {
|
meta = {
|
||||||
homepage = http://www.sane-project.org/;
|
homepage = http://www.sane-project.org/;
|
||||||
|
|
|
@ -15868,16 +15868,14 @@ with pkgs;
|
||||||
|
|
||||||
ghq = gitAndTools.ghq;
|
ghq = gitAndTools.ghq;
|
||||||
|
|
||||||
gimp_2_8 = callPackage ../applications/graphics/gimp/2.8.nix {
|
gimp = callPackage ../applications/graphics/gimp {
|
||||||
webkit = null;
|
gegl = gegl_0_4;
|
||||||
lcms = lcms2;
|
lcms = lcms2;
|
||||||
|
inherit (gnome3) gexiv2;
|
||||||
inherit (darwin.apple_sdk.frameworks) AppKit Cocoa;
|
inherit (darwin.apple_sdk.frameworks) AppKit Cocoa;
|
||||||
};
|
};
|
||||||
|
|
||||||
gimp = gimp_2_8;
|
|
||||||
|
|
||||||
gimp-with-plugins = callPackage ../applications/graphics/gimp/wrapper.nix {
|
gimp-with-plugins = callPackage ../applications/graphics/gimp/wrapper.nix {
|
||||||
gimp = gimp_2_8;
|
|
||||||
plugins = null; # All packaged plugins enabled, if not explicit plugin list supplied
|
plugins = null; # All packaged plugins enabled, if not explicit plugin list supplied
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue