harfbuzz: 2.6.7 → 2.7.1

* Upstream changed from freedesktop.org to GitHub,
  so updateWalker is disabled and fetchFromGitHub used
* Build system now based on meson/ninja
* python3 instead of python
* postInstall hook moved to postFixup since it depends on
  some files being moved around in fixupPhase
* Build developer manual using gtk-doc
This commit is contained in:
sternenseemann 2020-08-23 19:56:44 +02:00 committed by Frederik Rietdijk
parent f85263a97f
commit c9a7fdfcfb

View file

@ -1,28 +1,34 @@
{ stdenv, fetchurl, pkgconfig, glib, freetype, cairo, libintl { stdenv, fetchFromGitHub, pkgconfig, glib, freetype, cairo, libintl
, meson, ninja
, gobject-introspection , gobject-introspection
, icu, graphite2, harfbuzz # The icu variant uses and propagates the non-icu one. , icu, graphite2, harfbuzz # The icu variant uses and propagates the non-icu one.
, ApplicationServices, CoreText , ApplicationServices, CoreText
, withCoreText ? false , withCoreText ? false
, withIcu ? false # recommended by upstream as default, but most don't needed and it's big , withIcu ? false # recommended by upstream as default, but most don't needed and it's big
, withGraphite2 ? true # it is small and major distros do include it , withGraphite2 ? true # it is small and major distros do include it
, python , python3
, gtk-doc, docbook-xsl-nons, docbook_xml_dtd_43
}: }:
let let
version = "2.6.7"; version = "2.7.1";
inherit (stdenv.lib) optional optionals optionalString; inherit (stdenv.lib) optional optionals optionalString;
mesonFeatureFlag = opt: b:
"-D${opt}=${if b then "enabled" else "disabled"}";
in in
stdenv.mkDerivation { stdenv.mkDerivation {
name = "harfbuzz${optionalString withIcu "-icu"}-${version}"; name = "harfbuzz${optionalString withIcu "-icu"}-${version}";
src = fetchurl { src = fetchFromGitHub {
url = "https://www.freedesktop.org/software/harfbuzz/release/harfbuzz-${version}.tar.xz"; owner = "harfbuzz";
sha256 = "065jg6s8xix45s4msj0l2r0iycw5yyyjdylripv7pyfzdk883r29"; repo = "harfbuzz";
rev = version;
sha256 = "172jmwp666xbs6yy1pc2495gnkz8xw11b8zkz3j19jxlvvp4mxcs";
}; };
postPatch = '' postPatch = ''
patchShebangs src/gen-def.py patchShebangs src/*.py
patchShebangs test patchShebangs test
'' + stdenv.lib.optionalString stdenv.isDarwin '' '' + stdenv.lib.optionalString stdenv.isDarwin ''
# ApplicationServices.framework headers have cast-align warnings. # ApplicationServices.framework headers have cast-align warnings.
@ -30,22 +36,25 @@ stdenv.mkDerivation {
--replace '#pragma GCC diagnostic error "-Wcast-align"' "" --replace '#pragma GCC diagnostic error "-Wcast-align"' ""
''; '';
outputs = [ "out" "dev" ]; outputs = [ "out" "dev" "devdoc" ];
outputBin = "dev"; outputBin = "dev";
configureFlags = [ mesonFlags = [
# not auto-detected by default (mesonFeatureFlag "graphite" withGraphite2)
"--with-graphite2=${if withGraphite2 then "yes" else "no"}" (mesonFeatureFlag "icu" withIcu)
"--with-icu=${if withIcu then "yes" else "no"}" (mesonFeatureFlag "coretext" withCoreText)
"--with-gobject=yes" ];
"--enable-introspection=yes"
]
++ stdenv.lib.optional withCoreText "--with-coretext=yes";
nativeBuildInputs = [ nativeBuildInputs = [
meson
ninja
gobject-introspection gobject-introspection
libintl libintl
pkgconfig pkgconfig
python3
gtk-doc
docbook-xsl-nons
docbook_xml_dtd_43
]; ];
buildInputs = [ glib freetype cairo ] # recommended by upstream buildInputs = [ glib freetype cairo ] # recommended by upstream
@ -55,11 +64,10 @@ stdenv.mkDerivation {
++ optional withGraphite2 graphite2 ++ optional withGraphite2 graphite2
++ optionals withIcu [ icu harfbuzz ]; ++ optionals withIcu [ icu harfbuzz ];
checkInputs = [ python ]; doCheck = true;
doInstallCheck = false; # fails, probably a bug
# Slightly hacky; some pkgs expect them in a single directory. # Slightly hacky; some pkgs expect them in a single directory.
postInstall = optionalString withIcu '' postFixup = optionalString withIcu ''
rm "$out"/lib/libharfbuzz.* "$dev/lib/pkgconfig/harfbuzz.pc" rm "$out"/lib/libharfbuzz.* "$dev/lib/pkgconfig/harfbuzz.pc"
ln -s {'${harfbuzz.out}',"$out"}/lib/libharfbuzz.la ln -s {'${harfbuzz.out}',"$out"}/lib/libharfbuzz.la
ln -s {'${harfbuzz.dev}',"$dev"}/lib/pkgconfig/harfbuzz.pc ln -s {'${harfbuzz.dev}',"$dev"}/lib/pkgconfig/harfbuzz.pc
@ -71,12 +79,9 @@ stdenv.mkDerivation {
meta = with stdenv.lib; { meta = with stdenv.lib; {
description = "An OpenType text shaping engine"; description = "An OpenType text shaping engine";
homepage = "http://www.freedesktop.org/wiki/Software/HarfBuzz"; homepage = "https://harfbuzz.github.io/";
downloadPage = "https://www.freedesktop.org/software/harfbuzz/release/";
maintainers = [ maintainers.eelco ]; maintainers = [ maintainers.eelco ];
license = licenses.mit; license = licenses.mit;
platforms = with platforms; linux ++ darwin; platforms = with platforms; linux ++ darwin;
inherit version;
updateWalker = true;
}; };
} }