aboutsummaryrefslogtreecommitdiff
path: root/nixpkgs/pkgs/development/libraries/fontconfig/default.nix
diff options
context:
space:
mode:
Diffstat (limited to 'nixpkgs/pkgs/development/libraries/fontconfig/default.nix')
-rw-r--r--nixpkgs/pkgs/development/libraries/fontconfig/default.nix104
1 files changed, 71 insertions, 33 deletions
diff --git a/nixpkgs/pkgs/development/libraries/fontconfig/default.nix b/nixpkgs/pkgs/development/libraries/fontconfig/default.nix
index 0518cb257ab..72df121200e 100644
--- a/nixpkgs/pkgs/development/libraries/fontconfig/default.nix
+++ b/nixpkgs/pkgs/development/libraries/fontconfig/default.nix
@@ -1,47 +1,86 @@
-{ stdenv, substituteAll, fetchurl
-, pkgconfig, freetype, expat, libxslt, gperf, dejavu_fonts
+{ stdenv
+, fetchpatch
+, substituteAll
+, fetchurl
+, pkg-config
+, freetype
+, expat
+, libxslt
+, gperf
+, dejavu_fonts
+, autoreconfHook
}:
-/** Font configuration scheme
- - ./config-compat.patch makes fontconfig try the following root configs, in order:
- $FONTCONFIG_FILE, /etc/fonts/${configVersion}/fonts.conf, /etc/fonts/fonts.conf
- This is done not to override config of pre-2.11 versions (which just blow up)
- and still use *global* font configuration at both NixOS or non-NixOS.
- - NixOS creates /etc/fonts/${configVersion}/fonts.conf link to $out/etc/fonts/fonts.conf,
- and other modifications should go to /etc/fonts/${configVersion}/conf.d
- - See ./make-fonts-conf.xsl for config details.
-
-*/
-
-let
- configVersion = "2.11"; # bump whenever fontconfig breaks compatibility with older configurations
-in
stdenv.mkDerivation rec {
pname = "fontconfig";
- version = "2.12.6";
+ version = "2.13.92";
src = fetchurl {
- url = "http://fontconfig.org/release/${pname}-${version}.tar.bz2";
- sha256 = "05zh65zni11kgnhg726gjbrd55swspdvhqbcnj5a5xh8gn03036g";
+ url = "http://fontconfig.org/release/${pname}-${version}.tar.xz";
+ sha256 = "0kkfsvxcvcphm9zcgsh646gix3qn4spz555wa1jp5hbq70l62vjh";
};
patches = [
- (substituteAll {
- src = ./config-compat.patch;
- inherit configVersion;
+ # Fix fonts not being loaded when missing included configs that have ignore_missing="yes".
+ # https://bugzilla.redhat.com/show_bug.cgi?id=1744377
+ (fetchpatch {
+ url = "https://gitlab.freedesktop.org/fontconfig/fontconfig/commit/fcada522913e5e07efa6367eff87ace9f06d24c8.patch";
+ sha256 = "1jbm3vw45b3qjnqrh2545v1k8vmb29c09v2wj07jnrq3lnchbvmn";
})
+ # Register JoyPixels as an emoji font.
# https://gitlab.freedesktop.org/fontconfig/fontconfig/merge_requests/67
- ./fix-joypixels.patch
+ (fetchpatch {
+ url = "https://gitlab.freedesktop.org/fontconfig/fontconfig/commit/65087ac7ce4cc5f2109967c1380b474955dcb590.patch";
+ sha256 = "1dkrbqx1c1d8yfnx0igvv516wanw2ksrpm3fbpm2h9nw0hccwqvm";
+ })
+
+ # Fix invalid DTD in reset-dirs.
+ # https://gitlab.freedesktop.org/fontconfig/fontconfig/merge_requests/78
+ (fetchpatch {
+ url = "https://gitlab.freedesktop.org/fontconfig/fontconfig/commit/a4aa66a858f1ecd375c5efe5916398281f73f794.patch";
+ sha256 = "1j4ky8jhpllfm1lh2if34xglh2hl79nsa0xxgzxpj9sx6h4v99j5";
+ })
+
+ # Do not include its tags, they are external now and only cause warnings with old fontconfig clients.
+ # https://gitlab.freedesktop.org/fontconfig/fontconfig/merge_requests/97
+ (fetchpatch {
+ url = "https://gitlab.freedesktop.org/fontconfig/fontconfig/commit/528b17b2837c3b102acd90cc7548d07bacaccb1f.patch";
+ sha256 = "1zf4wcd2xlprh805jalfy8ja5c2qzgkh4fwd1m9d638nl9gx932m";
+ })
+ # https://gitlab.freedesktop.org/fontconfig/fontconfig/merge_requests/100
+ (fetchpatch {
+ url = "https://gitlab.freedesktop.org/fontconfig/fontconfig/commit/37c7c748740bf6f2468d59e67951902710240b34.patch";
+ sha256 = "1rz5zrfwhpn9g49wrzzrmdglj78pbvpnw8ksgsw6bxq8l5d84jfr";
+ })
+
+ # Show warning instead of error when encountering unknown attribute in config.
+ # https://gitlab.freedesktop.org/fontconfig/fontconfig/merge_requests/111
+ (fetchpatch {
+ url = "https://gitlab.freedesktop.org/fontconfig/fontconfig/commit/409b37c62780728755c908991c912a6b16f2389c.patch";
+ sha256 = "zJFh37QErSAINPGFkFVJyhYRP27BuIN7PIgoDl/PIwI=";
+ })
];
outputs = [ "bin" "dev" "lib" "out" ]; # $out contains all the config
- propagatedBuildInputs = [ freetype ];
- nativeBuildInputs = [ pkgconfig gperf libxslt ];
- buildInputs = [ expat ];
+ nativeBuildInputs = [
+ gperf
+ libxslt
+ pkg-config
+ autoreconfHook
+ ];
+
+ buildInputs = [
+ expat
+ ];
+
+ propagatedBuildInputs = [
+ freetype
+ ];
configureFlags = [
+ "--sysconfdir=/etc"
"--with-arch=${stdenv.hostPlatform.parsed.cpu.name}"
"--with-cache-dir=/var/cache/fontconfig" # otherwise the fallback is in $out/
"--disable-docs"
@@ -55,23 +94,22 @@ stdenv.mkDerivation rec {
doCheck = true;
- # Don't try to write to /var/cache/fontconfig at install time.
- installFlags = [ "fc_cachedir=$(TMPDIR)/dummy" "RUN_FC_CACHE_TEST=false" ];
+ installFlags = [
+ # Don't try to write to /var/cache/fontconfig at install time.
+ "fc_cachedir=$(TMPDIR)/dummy"
+ "RUN_FC_CACHE_TEST=false"
+ "sysconfdir=${placeholder "out"}/etc"
+ ];
postInstall = ''
cd "$out/etc/fonts"
xsltproc --stringparam fontDirectories "${dejavu_fonts.minimal}" \
- --stringparam fontconfigConfigVersion "${configVersion}" \
--path $out/share/xml/fontconfig \
${./make-fonts-conf.xsl} $out/etc/fonts/fonts.conf \
> fonts.conf.tmp
mv fonts.conf.tmp $out/etc/fonts/fonts.conf
'';
- passthru = {
- inherit configVersion;
- };
-
meta = with stdenv.lib; {
description = "A library for font customization and configuration";
homepage = "http://fontconfig.org/";