Some refactorings in builderDefs. Psi is a simple showcase. TeXLive now works as far as English is concerned, and it is also updated up to newest builderDefs.

svn path=/nixpkgs/trunk/; revision=11235
This commit is contained in:
Michael Raskin 2008-03-20 15:40:26 +00:00
parent 95f0e6a1a7
commit 5f2bcdbdb6
6 changed files with 123 additions and 110 deletions

View File

@ -1,30 +1,20 @@
args : with args;
rec {
src = fetchurl {
url = ftp://ftp.ru.debian.org/debian/pool/main/p/psi/psi_0.11.orig.tar.gz;
sha256 = "1rgjahngari4pwhi0zz9mricaaqxkk8ry8w6s1vgsq3zwa2l5x57";
};
args : with args; with builderDefs {src="";} null; buildInputs = [aspell qt zlib sox openssl libX11 xproto
let localDefs = builderDefs (rec { libSM libICE];
src = /* put a fetchurl here */ configureFlags = [" --with-zlib-inc=${zlib}/include "
fetchurl { " --with-openssl-inc=${openssl}/include "
url = ftp://ftp.ru.debian.org/debian/pool/main/p/psi/psi_0.11.orig.tar.gz; ];
sha256 = "1rgjahngari4pwhi0zz9mricaaqxkk8ry8w6s1vgsq3zwa2l5x57";
};
buildInputs = [aspell qt zlib sox openssl libX11 xproto phaseNames = ["doConfigure" "doMakeInstall"];
libSM libICE];
configureFlags = [" --with-zlib-inc=${zlib}/include " name = "psi-" + version;
" --with-openssl-inc=${openssl}/include " meta = {
]; description = "Psi, an XMPP (Jabber) client";
}) args null; /* null is a terminator for sumArgs */ };
in with localDefs;
stdenv.mkDerivation rec {
name = "psi-"+version;
MAKE="make";
builder = writeScript (name + "-builder")
(textClosure localDefs
["doConfigure" "doMakeInstall" doForceShare doPropagate]);
meta = {
description = "
Psi, an XMPP (Jabber) client.
";
inherit src;
};
} }

View File

@ -1,73 +1,79 @@
args : with args; with builderDefs {src="";} null; args : with args;
let localDefs = builderDefs (rec { rec {
src = /* put a fetchurl here */ src = fetchurl {
fetchurl { url = mirror://debian/pool/main/t/texlive-bin/texlive-bin_2007.orig.tar.gz;
url = debian://pool/main/t/texlive-bin/texlive-bin_2007.orig.tar.gz; sha256 = "1fz5lqbigdrdg0pmaynissd7wn59p2yj9f203nl93dcpffrapxjv";
sha256 = "1fz5lqbigdrdg0pmaynissd7wn59p2yj9f203nl93dcpffrapxjv"; };
};
texmfSrc =
fetchurl {
url = debian://pool/main/t/texlive-base/texlive-base_2007.orig.tar.gz;
sha256 = "16a4dyliidk43qj0m4gpsl9ln7nqsdcdx1lkbk4wrm03xpx87zvh";
};
setupHook = ./setup-hook.sh; texmfSrc = fetchurl {
url = mirror://debian/pool/main/t/texlive-base/texlive-base_2007.orig.tar.gz;
sha256 = "16a4dyliidk43qj0m4gpsl9ln7nqsdcdx1lkbk4wrm03xpx87zvh";
};
doInstall = FullDepEntry ('' langTexmfSrc = fetchurl {
ensureDir $out url = mirror://debian/pool/main/t/texlive-lang/texlive-lang_2007.orig.tar.gz;
ensureDir $out/nix-support sha256 = "0cmd9ryd57rzzg7g2gm3qn4ijakkacy810h5zncqd39p3i1yn6nx";
cp ${setupHook} $out/nix-support/setup-hook.sh };
ensureDir $out/share
tar xf ${texmfSrc} -C $out/share --strip-components=1 setupHook = ./setup-hook.sh;
cd build/source
sed -e s@/usr/bin/@@g -i $(grep /usr/bin/ -rl . ) doPreConfigure = FullDepEntry (''
sed -e '/ubidi_open/i#include <unicode/urename.h>' -i $(find . -name configure) ensureDir $out
sed -e s@ncurses/curses.h@curses.h@g -i $(grep ncurses/curses.h -rl . ) ensureDir $out/nix-support
NIX_CFLAGS_COMPILE="$NIX_CFLAGS_COMPILE -I${freetype}/include/freetype2" cp ${setupHook} $out/nix-support/setup-hook.sh
echo NIX_CFLAGS_COMPILE="$NIX_CFLAGS_COMPILE -I${icu}/include/unicode" ensureDir $out/share
NIX_CFLAGS_COMPILE="$NIX_CFLAGS_COMPILE -I${icu}/include/layout"; tar xf ${texmfSrc} -C $out/share --strip-components=1
./configure --prefix=$out \ tar xf ${langTexmfSrc} -C $out/share --strip-components=1
--with-x11 \ cp -r texmf* $out/share
--with-system-zlib \ cd build/source
--with-system-freetype2 \ sed -e s@/usr/bin/@@g -i $(grep /usr/bin/ -rl . )
--with-system-t1lib \ sed -e '/ubidi_open/i#include <unicode/urename.h>' -i $(find . -name configure)
--with-system-pnglib \ sed -e s@ncurses/curses.h@curses.h@g -i $(grep ncurses/curses.h -rl . )
--with-system-gd \ sed -e 's/.*pyhyph.*/=&/' -i $out/share/texmf-config/tex/generic/config/language.dat
--with-system-icu \
--with-system-ncurses \ updmap --syncwithtrees
--enable-ipc \
--with-mktexfmt NIX_CFLAGS_COMPILE="$NIX_CFLAGS_COMPILE -I${freetype}/include/freetype2"
make NIX_CFLAGS_COMPILE="$NIX_CFLAGS_COMPILE -I${icu}/include/layout";
make install '') ["minInit" "doUnpack" "addInputs" "defEnsureDir"];
mv $out/bin $out/libexec
ensureDir $out/bin doPostInstall = FullDepEntry(''
for i in $out/libexec/*/*; do mv $out/bin $out/libexec
echo -ne "#! /bin/sh\\n$i \"\$@\"" >$out/bin/$(basename $i) ensureDir $out/bin
chmod a+x $out/bin/$(basename $i) for i in $out/libexec/*/*; do
done echo -ne "#! /bin/sh\\n$i \"\$@\"" >$out/bin/$(basename $i)
texmf_var=$(mktemp -d /var/tmp/texmf-varXXXXXXXX) chmod a+x $out/bin/$(basename $i)
mv $out/share/texmf-var/* $texmf_var/ done
chmod -R a+rwX $texmf_var texmf_var=$(mktemp -d /var/tmp/texmf-varXXXXXXXX)
ln -s $texmf_var $out/share/texmf-var mv $out/share/texmf-var/* $texmf_var/
ln -s $out/share/texmf $out/share/texmf-config chmod -R a+rwX $texmf_var
'') ["minInit" "defEnsureDir" "doUnpack" "addInputs"]; rm -r $out/share/texmf-var
buildInputs = [zlib bzip2 ncurses libpng ed flex bison libX11 xproto rm -r /var/tmp/texmf-var
freetype t1lib gd libXaw icu ghostscript ln -sfT $texmf_var $out/share/texmf-var
libXt libXpm libXmu libXext xextproto perl libSM ln -sfT $texmf_var /var/tmp/texmf-var
libICE]; ln -s $out/share/texmf $out/share/texmf-config
configureFlags = []; PATH=$PATH:$out/bin mktexlsr $out/share/texmf*
}) args null; /* null is a terminator for sumArgs */ '') ["minInit" "defEnsureDir" "doUnpack" "doMakeInstall"];
in with localDefs;
stdenv.mkDerivation rec { buildInputs = [
name = "TeXLive-core-2007"; zlib bzip2 ncurses libpng flex bison libX11 libICE
builder = writeScript (name + "-builder") xproto freetype t1lib gd libXaw icu ghostscript ed
(textClosure localDefs libXt libXpm libXmu libXext xextproto perl libSM
[doInstall doForceShare doPropagate]); ];
meta = {
description = " configureFlags = [ "--with-x11" "--with-system-zlib"
TeX distribution. "--with-system-freetype2" "--with-system-t1lib"
"; "--with-system-pnglib" "--with-system-gd"
inherit src; "--with-system-icu" "--with-system-ncurses"
srcs = [texmfSrc]; "--enable-ipc" "--with-mktexfmt"
}; ];
phaseNames = ["doPreConfigure" "doConfigure"
"doMakeInstall" "doPostInstall"];
name = "texlive-core-2007";
meta = {
description = "A TeX distribution";
srcs = [texmfSrc langTexmfSrc];
};
} }

View File

@ -270,6 +270,9 @@ let pkgs = rec {
inherit stringsWithDeps lib stdenv writeScript fetchurl; inherit stringsWithDeps lib stdenv writeScript fetchurl;
}; };
builderDefsPackage = expr: lib.sumArgs
(((builderDefs null).builderDefsPackage builderDefs) expr);
stringsWithDeps = import ../lib/strings-with-deps.nix { stringsWithDeps = import ../lib/strings-with-deps.nix {
inherit stdenv lib; inherit stdenv lib;
}; };
@ -6076,11 +6079,13 @@ let pkgs = rec {
inherit fetchurl stdenv tetex lazylist; inherit fetchurl stdenv tetex lazylist;
}; };
psiFun = lib.sumArgs (selectVersion ../applications/networking/instant-messengers/psi "0.11") { psiFun = builderDefsPackage
inherit builderDefs zlib aspell sox openssl; (selectVersion ../applications/networking/instant-messengers/psi "0.11")
inherit (xlibs) xproto libX11 libSM libICE; {
qt = qt4; inherit builderDefs zlib aspell sox openssl;
}; inherit (xlibs) xproto libX11 libSM libICE;
qt = qt4;
};
psi = psiFun null; psi = psiFun null;
@ -6146,7 +6151,7 @@ let pkgs = rec {
inherit stdenv perl tetex graphviz ghostscript; inherit stdenv perl tetex graphviz ghostscript;
}; };
texLiveFun = lib.sumArgs (import ../misc/tex/texlive) { texLiveFun = builderDefsPackage (import ../misc/tex/texlive) {
inherit builderDefs zlib bzip2 ncurses libpng ed inherit builderDefs zlib bzip2 ncurses libpng ed
gd t1lib freetype icu perl; gd t1lib freetype icu perl;
inherit (xlibs) libXaw libX11 xproto libXt libXpm inherit (xlibs) libXaw libX11 xproto libXt libXpm

View File

@ -3,6 +3,8 @@ args: with args; with stringsWithDeps; with lib;
{ {
inherit writeScript; inherit writeScript;
src = getAttr ["src"] "" args;
addSbinPath = getAttr ["addSbinPath"] false args; addSbinPath = getAttr ["addSbinPath"] false args;
forceShare = if args ? forceShare then args.forceShare else ["man" "doc" "info"]; forceShare = if args ? forceShare then args.forceShare else ["man" "doc" "info"];
@ -385,4 +387,18 @@ args: with args; with stringsWithDeps; with lib;
GHC_PACKAGE_PATH=\$PACKAGE_DB ./register.sh GHC_PACKAGE_PATH=\$PACKAGE_DB ./register.sh
" ["defCreateEmptyPackageDatabaseAndSetupHook" "defCabalSetupCmd"]; " ["defCreateEmptyPackageDatabaseAndSetupHook" "defCabalSetupCmd"];
phaseNames = args.phaseNames ++
["doForceShare" "doPropagate"];
builderDefsPackage = bd: func: args: (
let localDefs = bd (func ((bd null) // args)) args null; in
stdenv.mkDerivation (rec {
inherit (localDefs) name;
builder = writeScript (name + "-builder")
(textClosure localDefs localDefs.phaseNames);
meta = localDefs.meta // {inherit src;};
})
);
}) // args }) // args

View File

@ -16,9 +16,7 @@ stdenv.mkDerivation rec {
builder = writeScript (name + "-builder") builder = writeScript (name + "-builder")
(textClosure localDefs [(abort "Check phases") doMakeInstall doForceShare doPropagate]); (textClosure localDefs [(abort "Check phases") doMakeInstall doForceShare doPropagate]);
meta = { meta = {
description = " description = "${(abort "Specify description")}";
${(abort "Specify description")}
";
inherit src; inherit src;
}; };
} }

View File

@ -1,4 +1,4 @@
args : with args; with builderDefs {src="";} null; args : with args; with builderDefs null;
let localDefs = builderDefs (rec { let localDefs = builderDefs (rec {
src = /* put a fetchurl here */ src = /* put a fetchurl here */
@ -12,9 +12,7 @@ stdenv.mkDerivation rec {
(textClosure localDefs (textClosure localDefs
[(abort "Specify phases - defined here or in builderDefs") doForceShare doPropagate]); [(abort "Specify phases - defined here or in builderDefs") doForceShare doPropagate]);
meta = { meta = {
description = " description = "${abort "Write a description"}";
${abort "Write a description"}
";
inherit src; inherit src;
}; };
} }