Skip to content

Commit

Permalink
ghostscript: drop GNU fork and update
Browse files Browse the repository at this point in the history
  • Loading branch information
abbradar committed Nov 14, 2014
1 parent 4d59ac9 commit e723c51
Show file tree
Hide file tree
Showing 3 changed files with 42 additions and 98 deletions.
113 changes: 42 additions & 71 deletions pkgs/misc/ghostscript/default.nix
Original file line number Diff line number Diff line change
Expand Up @@ -3,70 +3,19 @@
, libiconvOrEmpty
, x11Support ? false, x11 ? null
, cupsSupport ? false, cups ? null
, gnuFork ? true
}:

assert x11Support -> x11 != null;
assert cupsSupport -> cups != null;

let
meta_common = {
homepage = "http://www.gnu.org/software/ghostscript/";
description = "PostScript interpreter (GNU version)";

longDescription = ''
Ghostscript is the name of a set of tools that provides (i) an
interpreter for the PostScript language and the PDF file format,
(ii) a set of C procedures (the Ghostscript library) that
implement the graphics capabilities that appear as primitive
operations in the PostScript language, and (iii) a wide variety
of output drivers for various file formats and printers.
'';

license = stdenv.lib.licenses.gpl3Plus;

platforms = stdenv.lib.platforms.all;
maintainers = [ stdenv.lib.maintainers.viric ];
};

gnuForkSrc = rec {
name = "ghostscript-9.04.1";
src = fetchurl {
url = "mirror://gnu/ghostscript/gnu-${name}.tar.bz2";
sha256 = "0zqa6ggbkdqiszsywgrra4ij0sddlmrfa50bx2mh568qid4ga0a2";
};

meta = meta_common;
patches = [ ./purity.patch ];
};
stdenv.mkDerivation rec {
name = "ghostscript-9.15";

mainlineSrc = rec {
name = "ghostscript-9.06";
src = fetchurl {
url = "http://downloads.ghostscript.com/public/${name}.tar.bz2";
sha256 = "014f10rxn4ihvcr1frby4szd1jvkrwvmdhnbivpp55c9fssx3b05";
};
meta = meta_common // {
homepage = "http://www.ghostscript.com/";
description = "PostScript interpreter (mainline version)";
};

preConfigure = ''
rm -R libpng jpeg lcms{,2} tiff freetype jbig2dec expat openjpeg
substituteInPlace base/unix-aux.mak --replace "INCLUDE=/usr/include" "INCLUDE=/no-such-path"
sed "s@if ( test -f \$(INCLUDE)[^ ]* )@if ( true )@" -i base/unix-aux.mak
'';
patches = [];
src = fetchurl {
url = "http://downloads.ghostscript.com/public/${name}.tar.bz2";
sha256 = "0p1isp6ssfay141klirn7n9s8b546vcz6paksfmksbwy0ljsypg6";
};

variant = if gnuFork then gnuForkSrc else mainlineSrc;

in

stdenv.mkDerivation rec {
inherit (variant) name src meta;

fonts = [
(fetchurl {
url = "mirror://sourceforge/gs-fonts/ghostscript-fonts-std-8.11.tar.gz";
Expand All @@ -91,34 +40,56 @@ stdenv.mkDerivation rec {
# [] # maybe sometimes jpeg2000 support
;

CFLAGS = "-fPIC";
NIX_LDFLAGS =
"-lz -rpath${ if stdenv.isDarwin then " " else "="}${freetype}/lib";
patches = [ ./urw-font-files.patch ];

patches = variant.patches ++ [ ./urw-font-files.patch ];

preConfigure = ''
# "ijs" is impure: it contains symlinks to /usr/share/automake etc.!
rm -rf ijs/ltmain.sh
# Don't install stuff in the Cups store path.
makeFlagsArray=(CUPSSERVERBIN=$out/lib/cups CUPSSERVERROOT=$out/etc/cups CUPSDATA=$out/share/cups)
'' + stdenv.lib.optionalString (variant ? preConfigure) variant.preConfigure;
makeFlags = [ "cups_serverroot=$(out)" "cups_serverbin=$(out)/lib/cups" ];

configureFlags =
[ "--with-system-libtiff"
[ "--with-system-libtiff" "--disable-sse2"

This comment has been minimized.

Copy link
@vcunat

vcunat Jul 26, 2015

Member

Why disable sse2?

This comment has been minimized.

Copy link
@abbradar

abbradar Jul 26, 2015

Author Member

I can't remember the reason at all, sorry. We can try enabling it back and see what happens.

"--enable-dynamic"
(if x11Support then "--with-x" else "--without-x")
(if cupsSupport then "--enable-cups --with-install-cups" else "--disable-cups")
(if cupsSupport then "--enable-cups" else "--disable-cups")
];

doCheck = true;

installTargets="install soinstall";

# ToDo: web says the fonts should be already included
#CFLAGS = "-fPIC";
#NIX_LDFLAGS =
# "-lz -rpath${ if stdenv.isDarwin then " " else "="}${freetype}/lib";

preConfigure = ''
rm -rf jpeg libpng zlib jasper expat tiff lcms{,2} jbig2dec openjpeg freetype cups/libs
sed "s@if ( test -f \$(INCLUDE)[^ ]* )@if ( true )@; s@INCLUDE=/usr/include@INCLUDE=/no-such-path@" -i base/unix-aux.mak
'';

postInstall = ''
# ToDo: web says the fonts should be already included
for i in $fonts; do
(cd $out/share/ghostscript && tar xvfz $i)
done
rm -rf $out/lib/cups/filter/{gstopxl,gstoraster}
'';

meta = {
homepage = "http://www.ghostscript.com/";
description = "PostScript interpreter (mainline version)";

longDescription = ''
Ghostscript is the name of a set of tools that provides (i) an
interpreter for the PostScript language and the PDF file format,
(ii) a set of C procedures (the Ghostscript library) that
implement the graphics capabilities that appear as primitive
operations in the PostScript language, and (iii) a wide variety
of output drivers for various file formats and printers.
'';

license = stdenv.lib.licenses.gpl3Plus;

platforms = stdenv.lib.platforms.all;
maintainers = [ stdenv.lib.maintainers.viric ];
};
}
26 changes: 0 additions & 26 deletions pkgs/misc/ghostscript/purity.patch

This file was deleted.

1 change: 0 additions & 1 deletion pkgs/top-level/all-packages.nix
Original file line number Diff line number Diff line change
Expand Up @@ -12363,7 +12363,6 @@ let
ghostscript = callPackage ../misc/ghostscript {
x11Support = false;
cupsSupport = config.ghostscript.cups or (!stdenv.isDarwin);
gnuFork = config.ghostscript.gnu or false;
};

ghostscriptX = appendToName "with-X" (ghostscript.override {
Expand Down

0 comments on commit e723c51

Please sign in to comment.