{ fetchurl, stdenv, pythonPackages, makeWrapper, lib , xpdf, mesa, freeglut }: let inherit (pythonPackages) python pyopengl pygame setuptools pillow; version = "0.10.5"; in stdenv.mkDerivation { # This project was formerly known as KeyJNote. # See http://keyj.s2000.ws/?p=77 for details. name = "impressive-${version}"; src = fetchurl { url = "mirror://sourceforge/impressive/Impressive-${version}.tar.gz"; sha256 = "0fz1zahxlfjang53wn06svy4s4aw28c79v24gwadvjvv3h1g5wam"; }; # Note: We need to have `setuptools' in the path to be able to use # PyOpenGL. buildInputs = [ makeWrapper xpdf pillow pyopengl pygame ]; configurePhase = '' sed -i "impressive.py" \ -e 's|^#!/usr/bin/env.*$|#!${python}/bin/python|g' ''; installPhase = '' mkdir -p "$out/bin" "$out/share/doc/impressive" mv impressive.py "$out/bin/impressive" mv * "$out/share/doc/impressive" # XXX: We have to reiterate PyOpenGL's dependencies here. # # `setuptools' must be in the Python path as it's used by # PyOpenGL. # # We set $LIBRARY_PATH (no `LD_'!) so that ctypes can find # `libGL.so', which it does by running `gcc', which in turn # honors $LIBRARY_PATH. See # http://python.net/crew/theller/ctypes/reference.html#id1 . wrapProgram "$out/bin/impressive" \ --prefix PATH ":" "${xpdf}" \ --prefix PYTHONPATH ":" \ ${lib.concatStringsSep ":" (map (path: path + "/lib/${python.libPrefix}/site-packages") [ pillow pyopengl pygame setuptools ])} \ --prefix LIBRARY_PATH ":" "${lib.makeLibraryPath [ mesa freeglut ]}" ''; meta = { description = "Impressive, an effect-rich presentation tool for PDFs"; longDescription = '' Impressive is a program that displays presentation slides. But unlike OpenOffice.org Impress or other similar applications, it does so with style. Smooth alpha-blended slide transitions are provided for the sake of eye candy, but in addition to this, Impressive offers some unique tools that are really useful for presentations. Read below if you want to know more about these features. Creating presentations for Impressive is very simple: You just need to export a PDF file from your presentation software. This means that you can create slides in the application of your choice and use Impressive for displaying them. If your application does not support PDF output, you can alternatively use a set of pre-rendered image files – or you use Impressive to make a slideshow with your favorite photos. ''; homepage = http://impressive.sourceforge.net/; license = stdenv.lib.licenses.gpl2; maintainers = [ ]; platforms = stdenv.lib.platforms.mesaPlatforms; }; }