mirror of
https://github.com/ilyakooo0/nixpkgs.git
synced 2024-09-25 14:48:25 +03:00
Revert "Revert commit 4b2f3971981272b79da7f87b639ca8854a6ea89c"
This reverts commit 85ae7137ac
.
This commit is contained in:
parent
001a84f22a
commit
ae8b7a189a
@ -4,39 +4,72 @@
|
|||||||
|
|
||||||
let
|
let
|
||||||
pname = "gdk-pixbuf";
|
pname = "gdk-pixbuf";
|
||||||
version = "2.36.7";
|
version = "2.36.12";
|
||||||
# TODO: since 2.36.8 gdk-pixbuf gets configured to use mime-type sniffing,
|
|
||||||
# which apparently requires access to shared-mime-info files during runtime.
|
|
||||||
in
|
in
|
||||||
stdenv.mkDerivation rec {
|
stdenv.mkDerivation rec {
|
||||||
name = "${pname}-${version}";
|
name = "${pname}-${version}";
|
||||||
|
|
||||||
src = fetchurl {
|
# TODO: Change back once tests/bug753605-atsize.jpg is part of the dist tarball
|
||||||
url = "mirror://gnome/sources/${pname}/${gnome3.versionBranch version}/${name}.tar.xz";
|
# src = fetchurl {
|
||||||
sha256 = "1b6e5eef09d98f05f383014ecd3503e25dfb03d7e5b5f5904e5a65b049a6a4d8";
|
# url = "mirror://gnome/sources/${pname}/${gnome3.versionBranch version}/${name}.tar.xz";
|
||||||
|
# sha256 = "0d534ysa6n9prd17wwzisq7mj6qkhwh8wcf8qgin1ar3hbs5ry7z";
|
||||||
|
# };
|
||||||
|
src = fetchgit {
|
||||||
|
url = https://gitlab.gnome.org/GNOME/gdk-pixbuf.git;
|
||||||
|
rev = version;
|
||||||
|
sha256 = "18lwqg63vyap2m1mw049rnb8fm869429xbf7636a2n21gs3d3jwv";
|
||||||
};
|
};
|
||||||
|
|
||||||
outputs = [ "out" "dev" "devdoc" ];
|
patches = [
|
||||||
|
# TODO: since 2.36.8 gdk-pixbuf gets configured to use mime-type sniffing,
|
||||||
|
# which requires access to shared-mime-info files during runtime.
|
||||||
|
# For now, we are patching the build script to avoid the dependency.
|
||||||
|
./no-mime-sniffing.patch
|
||||||
|
|
||||||
|
# Fix installed tests with meson
|
||||||
|
# https://bugzilla.gnome.org/show_bug.cgi?id=795527
|
||||||
|
(fetchurl {
|
||||||
|
url = https://bugzilla.gnome.org/attachment.cgi?id=371381;
|
||||||
|
sha256 = "0nl1cixkjfa5kcfh0laz8h6hdsrpdkxqn7a1k35jrb6zwc9hbydn";
|
||||||
|
})
|
||||||
|
|
||||||
|
# Add missing test file bug753605-atsize.jpg
|
||||||
|
(fetchpatch {
|
||||||
|
url = https://gitlab.gnome.org/GNOME/gdk-pixbuf/commit/87f8f4bf01dfb9982c1ef991e4060a5e19fdb7a7.patch;
|
||||||
|
sha256 = "1slzywwnrzfx3zjzdsxrvp4g2q4skmv50pdfmyccp41j7bfyb2j0";
|
||||||
|
})
|
||||||
|
|
||||||
|
# Move installed tests to a separate output
|
||||||
|
./installed-tests-path.patch
|
||||||
|
];
|
||||||
|
|
||||||
|
outputs = [ "out" "dev" "man" "devdoc" "installedTests" ];
|
||||||
|
|
||||||
setupHook = ./setup-hook.sh;
|
setupHook = ./setup-hook.sh;
|
||||||
|
|
||||||
enableParallelBuilding = true;
|
|
||||||
|
|
||||||
# !!! We might want to factor out the gdk-pixbuf-xlib subpackage.
|
# !!! We might want to factor out the gdk-pixbuf-xlib subpackage.
|
||||||
buildInputs = [ libX11 gobjectIntrospection ];
|
buildInputs = [ libX11 ];
|
||||||
|
|
||||||
nativeBuildInputs = [ pkgconfig ]
|
nativeBuildInputs = [
|
||||||
|
meson ninja pkgconfig gettext python3 libxml2 libxslt docbook_xsl docbook_xml_dtd_43
|
||||||
|
gtk-doc gobjectIntrospection makeWrapper
|
||||||
|
]
|
||||||
++ stdenv.lib.optional stdenv.isDarwin fixDarwinDylibNames;
|
++ stdenv.lib.optional stdenv.isDarwin fixDarwinDylibNames;
|
||||||
|
|
||||||
propagatedBuildInputs = [ glib libtiff libjpeg libpng jasper ];
|
propagatedBuildInputs = [ glib libtiff libjpeg libpng jasper ];
|
||||||
|
|
||||||
configureFlags = "--with-libjasper --with-x11"
|
mesonFlags = [
|
||||||
+ stdenv.lib.optionalString (gobjectIntrospection != null) " --enable-introspection=yes"
|
"-Ddocs=true"
|
||||||
;
|
"-Djasper=true"
|
||||||
|
"-Dx11=true"
|
||||||
|
"-Dgir=${if gobjectIntrospection != null then "true" else "false"}"
|
||||||
|
];
|
||||||
|
|
||||||
# on darwin, tests don't link
|
postPatch = ''
|
||||||
preBuild = stdenv.lib.optionalString (stdenv.isDarwin && !doCheck) ''
|
chmod +x build-aux/* # patchShebangs only applies to executables
|
||||||
substituteInPlace Makefile --replace "docs tests" "docs"
|
patchShebangs build-aux
|
||||||
|
|
||||||
|
substituteInPlace tests/meson.build --subst-var-by installedtestsprefix "$installedTests"
|
||||||
'';
|
'';
|
||||||
|
|
||||||
postInstall =
|
postInstall =
|
||||||
@ -44,6 +77,9 @@ stdenv.mkDerivation rec {
|
|||||||
''
|
''
|
||||||
moveToOutput "bin" "$dev"
|
moveToOutput "bin" "$dev"
|
||||||
moveToOutput "bin/gdk-pixbuf-thumbnailer" "$out"
|
moveToOutput "bin/gdk-pixbuf-thumbnailer" "$out"
|
||||||
|
|
||||||
|
# We need to install 'loaders.cache' in lib/gdk-pixbuf-2.0/2.10.0/
|
||||||
|
$dev/bin/gdk-pixbuf-query-loaders --update-cache
|
||||||
'';
|
'';
|
||||||
|
|
||||||
# The fixDarwinDylibNames hook doesn't patch library references or binaries.
|
# The fixDarwinDylibNames hook doesn't patch library references or binaries.
|
||||||
|
@ -0,0 +1,13 @@
|
|||||||
|
--- a/tests/meson.build
|
||||||
|
+++ b/tests/meson.build
|
||||||
|
@@ -85,8 +85,8 @@
|
||||||
|
'aero.gif',
|
||||||
|
]
|
||||||
|
|
||||||
|
-installed_test_bindir = join_paths(gdk_pixbuf_libexecdir, 'installed-tests', meson.project_name())
|
||||||
|
-installed_test_datadir = join_paths(gdk_pixbuf_datadir, 'installed-tests', meson.project_name())
|
||||||
|
+installed_test_bindir = join_paths('@installedtestsprefix@', 'libexec', 'installed-tests', meson.project_name())
|
||||||
|
+installed_test_datadir = join_paths('@installedtestsprefix@', 'share', 'installed-tests', meson.project_name())
|
||||||
|
|
||||||
|
install_data(test_data, install_dir: installed_test_bindir)
|
||||||
|
install_subdir('test-images', install_dir: installed_test_bindir)
|
18
pkgs/development/libraries/gdk-pixbuf/no-mime-sniffing.patch
Normal file
18
pkgs/development/libraries/gdk-pixbuf/no-mime-sniffing.patch
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
--- a/meson.build
|
||||||
|
+++ b/meson.build
|
||||||
|
@@ -186,13 +186,8 @@
|
||||||
|
gmodule_dep = dependency('gmodule-no-export-2.0')
|
||||||
|
gio_dep = dependency('gio-2.0')
|
||||||
|
|
||||||
|
-# On non-Windows/macOS systems we always required shared-mime-info and GIO
|
||||||
|
-if host_system != 'windows' and host_system != 'darwin'
|
||||||
|
- shared_mime_dep = dependency('shared-mime-info')
|
||||||
|
- gdk_pixbuf_conf.set('GDK_PIXBUF_USE_GIO_MIME', 1)
|
||||||
|
-else
|
||||||
|
- shared_mime_dep = []
|
||||||
|
-endif
|
||||||
|
+# No MIME sniffing for now
|
||||||
|
+shared_mime_dep = []
|
||||||
|
|
||||||
|
gdk_pixbuf_deps = [ mathlib_dep, gobject_dep, gmodule_dep, gio_dep, shared_mime_dep ]
|
||||||
|
|
Loading…
Reference in New Issue
Block a user