aboutsummaryrefslogtreecommitdiff
path: root/nixpkgs/pkgs/development/libraries/gobject-introspection/default.nix
diff options
context:
space:
mode:
Diffstat (limited to 'nixpkgs/pkgs/development/libraries/gobject-introspection/default.nix')
-rw-r--r--nixpkgs/pkgs/development/libraries/gobject-introspection/default.nix110
1 files changed, 74 insertions, 36 deletions
diff --git a/nixpkgs/pkgs/development/libraries/gobject-introspection/default.nix b/nixpkgs/pkgs/development/libraries/gobject-introspection/default.nix
index 0d514c3fd7d..03b0d1767d9 100644
--- a/nixpkgs/pkgs/development/libraries/gobject-introspection/default.nix
+++ b/nixpkgs/pkgs/development/libraries/gobject-introspection/default.nix
@@ -1,61 +1,97 @@
-{ stdenv, fetchurl, glib, flex, bison, meson, ninja, pkgconfig, libffi, python3
-, libintl, cctools, cairo, gnome3, glibcLocales
-, substituteAll, nixStoreDir ? builtins.storeDir
+{ stdenv
+, fetchurl
+, glib
+, flex
+, bison
+, meson
+, ninja
+, gtk-doc
+, docbook-xsl-nons
+, docbook_xml_dtd_43
+, docbook_xml_dtd_45
+, pkg-config
+, libffi
+, python3
+, cctools
+, cairo
+, gnome3
+, substituteAll
+, nixStoreDir ? builtins.storeDir
, x11Support ? true
}:
+
# now that gobject-introspection creates large .gir files (eg gtk3 case)
# it may be worth thinking about using multiple derivation outputs
# In that case its about 6MB which could be separated
-with stdenv.lib;
stdenv.mkDerivation rec {
pname = "gobject-introspection";
version = "1.64.1";
+ # outputs TODO: share/gobject-introspection-1.0/tests is needed during build
+ # by pygobject3 (and maybe others), but it's only searched in $out
+ outputs = [ "out" "dev" "devdoc" "man" ];
+ outputBin = "dev";
+
src = fetchurl {
url = "mirror://gnome/sources/${pname}/${stdenv.lib.versions.majorMinor version}/${pname}-${version}.tar.xz";
sha256 = "19vz7vp10h0zj3f491yk72dp89bix6rgkzxg4qcm4d6151ksxgl0";
};
- outputs = [ "out" "dev" "man" ];
- outputBin = "dev";
+ patches = [
+ # Make g-ir-scanner put absolute path to GIR files it generates
+ # so that programs can just dlopen them without having to muck
+ # with LD_LIBRARY_PATH environment variable.
+ (substituteAll {
+ src = ./absolute_shlib_path.patch;
+ inherit nixStoreDir;
+ })
+ ] ++ stdenv.lib.optionals x11Support [
+ # Hardcode the cairo shared library path in the Cairo gir shipped with this package.
+ # https://github.com/NixOS/nixpkgs/issues/34080
+ (substituteAll {
+ src = ./absolute_gir_path.patch;
+ cairoLib = "${stdenv.lib.getLib cairo}/lib";
+ })
+ ];
- LC_ALL = "en_US.UTF-8"; # for tests
+ nativeBuildInputs = [
+ meson
+ ninja
+ pkg-config
+ flex
+ bison
+ gtk-doc
+ docbook-xsl-nons
+ docbook_xml_dtd_43 # FIXME: remove in next release
+ docbook_xml_dtd_45
+ python3
+ setupHook # move .gir files
+ ];
- nativeBuildInputs = [ meson ninja pkgconfig libintl glibcLocales ];
- buildInputs = [ flex bison python3 setupHook/*move .gir*/ ]
- ++ stdenv.lib.optional stdenv.isDarwin cctools;
- propagatedBuildInputs = [ libffi glib ];
+ buildInputs = [
+ python3
+ ];
+
+ checkInputs = stdenv.lib.optionals stdenv.isDarwin [
+ cctools # for otool
+ ];
+
+ propagatedBuildInputs = [
+ libffi
+ glib
+ ];
mesonFlags = [
"--datadir=${placeholder "dev"}/share"
"-Ddoctool=disabled"
"-Dcairo=disabled"
+ "-Dgtk_doc=true"
];
- # outputs TODO: share/gobject-introspection-1.0/tests is needed during build
- # by pygobject3 (and maybe others), but it's only searched in $out
-
- setupHook = ./setup-hook.sh;
-
- patches = [
- (substituteAll {
- src = ./test_shlibs.patch;
- inherit nixStoreDir;
- })
- (substituteAll {
- src = ./absolute_shlib_path.patch;
- inherit nixStoreDir;
- })
- ] ++ stdenv.lib.optional x11Support # https://github.com/NixOS/nixpkgs/issues/34080
- (substituteAll {
- src = ./absolute_gir_path.patch;
- cairoLib = "${getLib cairo}/lib";
- });
-
doCheck = !stdenv.isAarch64;
- preBuild = ''
+ preCheck = ''
# Our gobject-introspection patches make the shared library paths absolute
# in the GIR files. When running tests, the library is not yet installed,
# though, so we need to replace the absolute path with a local one during build.
@@ -64,10 +100,12 @@ stdenv.mkDerivation rec {
ln -s $PWD/tests/scanner/libregress-1.0${stdenv.targetPlatform.extensions.sharedLibrary} $out/lib/libregress-1.0${stdenv.targetPlatform.extensions.sharedLibrary}
'';
- preInstall = ''
+ postCheck = ''
rm $out/lib/libregress-1.0${stdenv.targetPlatform.extensions.sharedLibrary}
'';
+ setupHook = ./setup-hook.sh;
+
passthru = {
updateScript = gnome3.updateScript {
packageName = pname;
@@ -76,9 +114,9 @@ stdenv.mkDerivation rec {
meta = with stdenv.lib; {
description = "A middleware layer between C libraries and language bindings";
- homepage = "http://live.gnome.org/GObjectIntrospection";
- maintainers = with maintainers; [ lovek323 lethalman ];
- platforms = platforms.unix;
+ homepage = "https://gi.readthedocs.io/";
+ maintainers = teams.gnome.members ++ (with maintainers; [ lovek323 ]);
+ platforms = platforms.unix;
license = with licenses; [ gpl2 lgpl2 ];
longDescription = ''