Merge pull request #17819 from abbradar/printing-updates
Printing and PDF-related updates
This commit is contained in:
commit
edb9416228
@ -1,7 +1,7 @@
|
|||||||
{ stdenv, fetchurl
|
{ stdenv, fetchurl
|
||||||
, ghostscript, atk, gtk, glib, fontconfig, freetype
|
, ghostscript, atk, gtk, glib, fontconfig, freetype
|
||||||
, libgnomecanvas, libgnomeprint, libgnomeprintui
|
, libgnomecanvas, libgnomeprint, libgnomeprintui
|
||||||
, pango, libX11, xproto, zlib, poppler, poppler_data
|
, pango, libX11, xproto, zlib, poppler
|
||||||
, autoconf, automake, libtool, pkgconfig}:
|
, autoconf, automake, libtool, pkgconfig}:
|
||||||
stdenv.mkDerivation rec {
|
stdenv.mkDerivation rec {
|
||||||
version = "0.4.8";
|
version = "0.4.8";
|
||||||
@ -14,12 +14,12 @@ stdenv.mkDerivation rec {
|
|||||||
buildInputs = [
|
buildInputs = [
|
||||||
ghostscript atk gtk glib fontconfig freetype
|
ghostscript atk gtk glib fontconfig freetype
|
||||||
libgnomecanvas libgnomeprint libgnomeprintui
|
libgnomecanvas libgnomeprint libgnomeprintui
|
||||||
pango libX11 xproto zlib poppler poppler_data
|
pango libX11 xproto zlib poppler
|
||||||
];
|
];
|
||||||
|
|
||||||
nativeBuildInputs = [ autoconf automake libtool pkgconfig ];
|
nativeBuildInputs = [ autoconf automake libtool pkgconfig ];
|
||||||
|
|
||||||
NIX_LDFLAGS="-lX11 -lz";
|
NIX_LDFLAGS = [ "-lX11" "-lz" ];
|
||||||
|
|
||||||
meta = {
|
meta = {
|
||||||
homepage = http://xournal.sourceforge.net/;
|
homepage = http://xournal.sourceforge.net/;
|
||||||
|
@ -18,17 +18,32 @@ stdenv.mkDerivation rec {
|
|||||||
url = "http://git.ghostscript.com/?p=mupdf.git;a=commitdiff_plain;h=39b0f07dd960f34e7e6bf230ffc3d87c41ef0f2e;hp=fa1936405b6a84e5c9bb440912c23d532772f958";
|
url = "http://git.ghostscript.com/?p=mupdf.git;a=commitdiff_plain;h=39b0f07dd960f34e7e6bf230ffc3d87c41ef0f2e;hp=fa1936405b6a84e5c9bb440912c23d532772f958";
|
||||||
sha256 = "1g9fkd1f5rx1z043vr9dj4934qf7i4nkvbwjc61my9azjrrc3jv7";
|
sha256 = "1g9fkd1f5rx1z043vr9dj4934qf7i4nkvbwjc61my9azjrrc3jv7";
|
||||||
})
|
})
|
||||||
|
# Compatibility with new openjpeg
|
||||||
|
(fetchpatch {
|
||||||
|
name = "mupdf-1.5-openjpeg-2.1.0.patch";
|
||||||
|
url = "https://git.archlinux.org/svntogit/community.git/plain/trunk/mupdf-1.5-openjpeg-2.1.0.patch?h=packages/mupdf&id=ca5e3ef6c7788ccfb6011d785078bc47762f19e5";
|
||||||
|
sha256 = "0f18793q9fd22h3lclm8wahvc8az4v08an6lzy8mczrkl8mcgm3k";
|
||||||
|
})
|
||||||
];
|
];
|
||||||
|
|
||||||
NIX_CFLAGS_COMPILE= [ "-fPIC" ];
|
NIX_CFLAGS_COMPILE= [ "-fPIC" ];
|
||||||
|
makeFlags = [ "prefix=$(out)" ];
|
||||||
nativeBuildInputs = [ pkgconfig ];
|
nativeBuildInputs = [ pkgconfig ];
|
||||||
buildInputs = [ zlib freetype libX11 libXcursor libXext harfbuzz mesa libXrandr libXinerama ];
|
buildInputs = [ zlib libX11 libXcursor libXext harfbuzz mesa libXrandr libXinerama freetype libjpeg jbig2dec openjpeg ];
|
||||||
|
outputs = [ "out" "bin" "doc" ];
|
||||||
|
|
||||||
installPhase = ''
|
preConfigure = ''
|
||||||
make install prefix=$out
|
# Don't remove mujs because upstream version is incompatible
|
||||||
gcc -shared -o $out/lib/libmupdf.so.${version} -Wl,--whole-archive $out/lib/libmupdf.a -Wl,--no-whole-archive
|
rm -rf thirdparty/{curl,freetype,glfw,harfbuzz,jbig2dec,jpeg,openjpeg,zlib}
|
||||||
|
'';
|
||||||
|
|
||||||
ln -s $out/lib/libmupdf.so.${version} $out/lib/libmupdf.so
|
postInstall = ''
|
||||||
|
for i in $out/lib/*.a; do
|
||||||
|
so="''${i%.a}.so"
|
||||||
|
gcc -shared -o $so.${version} -Wl,--whole-archive $i -Wl,--no-whole-archive
|
||||||
|
ln -s $so.${version} $so
|
||||||
|
rm $i
|
||||||
|
done
|
||||||
|
|
||||||
mkdir -p "$out/lib/pkgconfig"
|
mkdir -p "$out/lib/pkgconfig"
|
||||||
cat >"$out/lib/pkgconfig/mupdf.pc" <<EOF
|
cat >"$out/lib/pkgconfig/mupdf.pc" <<EOF
|
||||||
@ -38,23 +53,24 @@ stdenv.mkDerivation rec {
|
|||||||
|
|
||||||
Name: mupdf
|
Name: mupdf
|
||||||
Description: Library for rendering PDF documents
|
Description: Library for rendering PDF documents
|
||||||
Requires: freetype2 libopenjp2 libcrypto
|
|
||||||
Version: ${version}
|
Version: ${version}
|
||||||
Libs: -L$out/lib -lmupdf
|
Libs: -L$out/lib -lmupdf -lmupdfthird
|
||||||
Cflags: -I$out/include
|
Cflags: -I$out/include
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
mkdir -p $out/share/applications
|
moveToOutput "bin" "$bin"
|
||||||
cat > $out/share/applications/mupdf.desktop <<EOF
|
mkdir -p $bin/share/applications
|
||||||
|
cat > $bin/share/applications/mupdf.desktop <<EOF
|
||||||
[Desktop Entry]
|
[Desktop Entry]
|
||||||
Type=Application
|
Type=Application
|
||||||
Version=1.0
|
Version=1.0
|
||||||
Name=mupdf
|
Name=mupdf
|
||||||
Comment=PDF viewer
|
Comment=PDF viewer
|
||||||
Exec=$out/bin/mupdf-x11 %f
|
Exec=$bin/bin/mupdf-x11 %f
|
||||||
Terminal=false
|
Terminal=false
|
||||||
EOF
|
EOF
|
||||||
'';
|
'';
|
||||||
|
|
||||||
enableParallelBuilding = true;
|
enableParallelBuilding = true;
|
||||||
|
|
||||||
meta = with stdenv.lib; {
|
meta = with stdenv.lib; {
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
{ fetchurl, stdenv, cmake }:
|
{ fetchurl, stdenv }:
|
||||||
|
|
||||||
stdenv.mkDerivation rec {
|
stdenv.mkDerivation rec {
|
||||||
name = "poppler-data-0.4.7";
|
name = "poppler-data-0.4.7";
|
||||||
@ -8,22 +8,17 @@ stdenv.mkDerivation rec {
|
|||||||
sha256 = "1pm7wg6xqj4sppb5az4pa7psfdk4yxxkw52j85bm9fksibcb0lp7";
|
sha256 = "1pm7wg6xqj4sppb5az4pa7psfdk4yxxkw52j85bm9fksibcb0lp7";
|
||||||
};
|
};
|
||||||
|
|
||||||
buildInputs = [ cmake ];
|
postPatch = ''
|
||||||
|
sed -i 's,$(datadir)/pkgconfig,$(prefix)/lib/pkgconfig,g' Makefile
|
||||||
# TODO: actually use $prefix/etc/profile.d in NixOS
|
|
||||||
postInstall =
|
|
||||||
''
|
|
||||||
mkdir -pv ''${out}/etc/profile.d
|
|
||||||
echo "export POPPLER_DATADIR=''${out}/share/poppler" |
|
|
||||||
tee ''${out}/etc/profile.d/60-poppler.sh
|
|
||||||
chmod -c +x ''${out}/etc/profile.d/60-poppler.sh
|
|
||||||
'';
|
'';
|
||||||
|
|
||||||
meta = {
|
installFlags = [ "prefix=$(out)" ];
|
||||||
|
|
||||||
|
meta = with stdenv.lib; {
|
||||||
homepage = http://poppler.freedesktop.org/;
|
homepage = http://poppler.freedesktop.org/;
|
||||||
description = "Encoding files for Poppler, a PDF rendering library";
|
description = "Encoding files for Poppler, a PDF rendering library";
|
||||||
platforms = stdenv.lib.platforms.all;
|
platforms = platforms.all;
|
||||||
license = stdenv.lib.licenses.free; # more free licenses combined
|
license = licenses.free; # more free licenses combined
|
||||||
maintainers = [ stdenv.lib.maintainers.urkud ];
|
maintainers = with maintainers; [ urkud ];
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
@ -1,13 +0,0 @@
|
|||||||
diff --git a/poppler/GlobalParams.cc b/poppler/GlobalParams.cc
|
|
||||||
index 2e11bb0..a277ab9 100644
|
|
||||||
--- a/poppler/GlobalParams.cc
|
|
||||||
+++ b/poppler/GlobalParams.cc
|
|
||||||
@@ -748,7 +748,7 @@ GlobalParams::GlobalParams(const char *customPopplerDataDir)
|
|
||||||
void GlobalParams::scanEncodingDirs() {
|
|
||||||
GDir *dir;
|
|
||||||
GDirEntry *entry;
|
|
||||||
- const char *dataRoot = popplerDataDir ? popplerDataDir : POPPLER_DATADIR;
|
|
||||||
+ const char *dataRoot = popplerDataDir ? popplerDataDir : ( getenv("POPPLER_DATADIR") ? getenv("POPPLER_DATADIR") : POPPLER_DATADIR );
|
|
||||||
|
|
||||||
// allocate buffer large enough to append "/nameToUnicode"
|
|
||||||
size_t bufSize = strlen(dataRoot) + strlen("/nameToUnicode") + 1;
|
|
@ -1,14 +1,15 @@
|
|||||||
{ stdenv, lib, fetchurl, fetchpatch, pkgconfig, libiconv, libintlOrEmpty
|
{ stdenv, lib, fetchurl, fetchpatch, pkgconfig, libiconv, libintlOrEmpty
|
||||||
, zlib, curl, cairo, freetype, fontconfig, lcms, libjpeg, openjpeg
|
, zlib, curl, cairo, freetype, fontconfig, lcms, libjpeg, openjpeg
|
||||||
, minimal ? false
|
, withData ? false, poppler_data
|
||||||
, qt4Support ? false, qt4 ? null
|
, qt4Support ? false, qt4 ? null
|
||||||
, qt5Support ? false, qtbase ? null
|
, qt5Support ? false, qtbase ? null
|
||||||
, utils ? false, suffix ? "glib"
|
, utils ? false
|
||||||
|
, minimal ? false, suffix ? "glib"
|
||||||
}:
|
}:
|
||||||
|
|
||||||
let # beware: updates often break cups_filters build
|
let # beware: updates often break cups_filters build
|
||||||
version = "0.43.0"; # even major numbers are stable
|
version = "0.46.0"; # even major numbers are stable
|
||||||
sha256 = "0mi4zf0pz3x3fx3ir7szz1n57nywgbpd4mp2r7mvf47f4rmf4867";
|
sha256 = "11z4d5vrrd0m7w9bfydwabksk273z7z0xf2nwvzf5pk17p8kazcn";
|
||||||
in
|
in
|
||||||
stdenv.mkDerivation rec {
|
stdenv.mkDerivation rec {
|
||||||
name = "poppler-${suffix}-${version}";
|
name = "poppler-${suffix}-${version}";
|
||||||
@ -20,22 +21,19 @@ stdenv.mkDerivation rec {
|
|||||||
|
|
||||||
outputs = [ "dev" "out" ];
|
outputs = [ "dev" "out" ];
|
||||||
|
|
||||||
patches = [ ./datadir_env.patch ];
|
buildInputs = [ libiconv ] ++ libintlOrEmpty ++ lib.optional withData poppler_data;
|
||||||
|
|
||||||
# TODO: reduce propagation to necessary libs
|
# TODO: reduce propagation to necessary libs
|
||||||
propagatedBuildInputs = with lib;
|
propagatedBuildInputs = with lib;
|
||||||
[ zlib freetype fontconfig libjpeg ]
|
[ zlib freetype fontconfig libjpeg openjpeg ]
|
||||||
++ optionals (!minimal) [ cairo lcms curl openjpeg ]
|
++ optionals (!minimal) [ cairo lcms curl ]
|
||||||
++ optional qt4Support qt4
|
++ optional qt4Support qt4
|
||||||
++ optional qt5Support qtbase;
|
++ optional qt5Support qtbase;
|
||||||
|
|
||||||
nativeBuildInputs = [ pkgconfig libiconv ] ++ libintlOrEmpty;
|
nativeBuildInputs = [ pkgconfig ];
|
||||||
|
|
||||||
NIX_CFLAGS_COMPILE = [ "-DQT_NO_DEBUG" ];
|
NIX_CFLAGS_COMPILE = [ "-DQT_NO_DEBUG" ];
|
||||||
|
|
||||||
# Any package depending on Qt >= 5.7 must build using the C++11 standard.
|
|
||||||
CXXFLAGS = lib.optional qt5Support "-std=c++11";
|
|
||||||
|
|
||||||
configureFlags = with lib;
|
configureFlags = with lib;
|
||||||
[
|
[
|
||||||
"--enable-xpdf-headers"
|
"--enable-xpdf-headers"
|
||||||
@ -45,7 +43,7 @@ stdenv.mkDerivation rec {
|
|||||||
]
|
]
|
||||||
++ optionals minimal [
|
++ optionals minimal [
|
||||||
"--disable-poppler-glib" "--disable-poppler-cpp"
|
"--disable-poppler-glib" "--disable-poppler-cpp"
|
||||||
"--disable-libopenjpeg" "--disable-libcurl"
|
"--disable-libcurl"
|
||||||
]
|
]
|
||||||
++ optional (!utils) "--disable-utils" ;
|
++ optional (!utils) "--disable-utils" ;
|
||||||
|
|
||||||
|
@ -5,17 +5,17 @@
|
|||||||
|
|
||||||
### IMPORTANT: before updating cups, make sure the nixos/tests/printing.nix test
|
### IMPORTANT: before updating cups, make sure the nixos/tests/printing.nix test
|
||||||
### works at least for your platform.
|
### works at least for your platform.
|
||||||
let version = "2.1.3"; in
|
|
||||||
|
|
||||||
with stdenv.lib;
|
with stdenv.lib;
|
||||||
stdenv.mkDerivation {
|
stdenv.mkDerivation rec {
|
||||||
name = "cups-${version}";
|
name = "cups-${version}";
|
||||||
|
version = "2.1.4";
|
||||||
|
|
||||||
passthru = { inherit version; };
|
passthru = { inherit version; };
|
||||||
|
|
||||||
src = fetchurl {
|
src = fetchurl {
|
||||||
url = "https://www.cups.org/software/${version}/cups-${version}-source.tar.bz2";
|
url = "https://github.com/apple/cups/releases/download/release-${version}/cups-${version}-source.tar.gz";
|
||||||
sha256 = "1lyl3z01xhg9xb9c8m42398c6h9kw8qr6jwiv8bjdsjab11hv9rn";
|
sha256 = "13bjxw256wd1nff22vj2z25mdhllj2h6d9xypsg55b40661zs52b";
|
||||||
};
|
};
|
||||||
|
|
||||||
# FIXME: the cups libraries contains some $out/share strings so can't be split.
|
# FIXME: the cups libraries contains some $out/share strings so can't be split.
|
||||||
|
@ -8,11 +8,11 @@ let
|
|||||||
|
|
||||||
in stdenv.mkDerivation rec {
|
in stdenv.mkDerivation rec {
|
||||||
name = "cups-filters-${version}";
|
name = "cups-filters-${version}";
|
||||||
version = "1.5.0";
|
version = "1.11.1";
|
||||||
|
|
||||||
src = fetchurl {
|
src = fetchurl {
|
||||||
url = "http://openprinting.org/download/cups-filters/${name}.tar.xz";
|
url = "http://openprinting.org/download/cups-filters/${name}.tar.xz";
|
||||||
sha256 = "0cjrh4wpdhkvmahfkg8f2a2qzilcq12i78q5arwr7dnmx1j8hapj";
|
sha256 = "0x0jxn1hnif92m7dyqrqh015gpsf79dviarb7dfl0zya2drlk1m8";
|
||||||
};
|
};
|
||||||
|
|
||||||
nativeBuildInputs = [ pkgconfig makeWrapper ];
|
nativeBuildInputs = [ pkgconfig makeWrapper ];
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
{ fetchurl, stdenv, pkgconfig, poppler, poppler_data, makeWrapper }:
|
{ fetchurl, stdenv, pkgconfig, poppler, makeWrapper }:
|
||||||
|
|
||||||
stdenv.mkDerivation rec {
|
stdenv.mkDerivation rec {
|
||||||
name = "pdfgrep-${version}";
|
name = "pdfgrep-${version}";
|
||||||
@ -9,19 +9,13 @@ stdenv.mkDerivation rec {
|
|||||||
sha256 = "6e8bcaf8b219e1ad733c97257a97286a94124694958c27506b2ea7fc8e532437";
|
sha256 = "6e8bcaf8b219e1ad733c97257a97286a94124694958c27506b2ea7fc8e532437";
|
||||||
};
|
};
|
||||||
|
|
||||||
buildInputs = [ pkgconfig poppler poppler_data makeWrapper ];
|
buildInputs = [ pkgconfig poppler makeWrapper ];
|
||||||
|
|
||||||
patchPhase = ''
|
patchPhase = ''
|
||||||
sed -i -e "s%cpp/poppler-document.h%poppler/cpp/poppler-document.h%" pdfgrep.cc
|
sed -i -e "s%cpp/poppler-document.h%poppler/cpp/poppler-document.h%" pdfgrep.cc
|
||||||
sed -i -e "s%cpp/poppler-page.h%poppler/cpp/poppler-page.h%" pdfgrep.cc
|
sed -i -e "s%cpp/poppler-page.h%poppler/cpp/poppler-page.h%" pdfgrep.cc
|
||||||
'';
|
'';
|
||||||
|
|
||||||
# workarround since it can't be hardcoded in pdfgrep
|
|
||||||
preFixup = ''
|
|
||||||
wrapProgram "$out/bin/pdfgrep" \
|
|
||||||
--set POPPLER_DATADIR "${poppler_data}/share/poppler"
|
|
||||||
'';
|
|
||||||
|
|
||||||
meta = {
|
meta = {
|
||||||
description = "A tool to search text in PDF files";
|
description = "A tool to search text in PDF files";
|
||||||
homepage = http://pdfgrep.sourceforge.net/;
|
homepage = http://pdfgrep.sourceforge.net/;
|
||||||
|
@ -14133,9 +14133,7 @@ in
|
|||||||
|
|
||||||
pdfdiff = callPackage ../applications/misc/pdfdiff { };
|
pdfdiff = callPackage ../applications/misc/pdfdiff { };
|
||||||
|
|
||||||
mupdf = callPackage ../applications/misc/mupdf {
|
mupdf = callPackage ../applications/misc/mupdf { };
|
||||||
openjpeg = openjpeg_2_0;
|
|
||||||
};
|
|
||||||
|
|
||||||
diffpdf = callPackage ../applications/misc/diffpdf { };
|
diffpdf = callPackage ../applications/misc/diffpdf { };
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user