updates: istanbul starts without errors. But no window appears.

svn path=/nixpkgs/trunk/; revision=13554
This commit is contained in:
Marc Weber 2008-12-02 12:28:45 +00:00
parent 9e7846d214
commit a7e33ec60c
3 changed files with 278 additions and 48 deletions

View File

@ -8,11 +8,15 @@
# containing a colon separated list of modules telling python where to look # containing a colon separated list of modules telling python where to look
# for imports and also read the .pth files # for imports and also read the .pth files
# TODO optimize py modules automatically (gentoo has a ebuild function called python_mod_optimize ?)
p: # p = pkgs p: # p = pkgs
let let
inherit (p) lib fetchurl stdenv getConfig; inherit (p) lib fetchurl stdenv getConfig;
# withName prevents nix-env -qa \* from aborting (pythonLibStub is a derivation but hasn't a name)
withName = lib.mapAttrs (n : v : if (__isAttrs v && (!__hasAttr "name" v)) then null else v);
in in
lib.fix ( t : { # t = this attrs withName ( lib.fix ( t : { # t = this attrs
version = "2.5"; version = "2.5";
versionAttr = "python25"; versionAttr = "python25";
@ -88,21 +92,22 @@ in
ensureDir $out/nix-support ensureDir $out/nix-support
echo "export NIX_PYTHON_SITES=\"$out:\$NIX_PYTHON_SITES\"" >> $out/nix-support/setup-hook echo "export NIX_PYTHON_SITES=\"$out:\$NIX_PYTHON_SITES\"" >> $out/nix-support/setup-hook
# run check # run check
[ -n "$pyCheck" ] \ if [ -n "$pyCheck" ]; then
&& ( . $out/nix-support/setup-hook ( . $out/nix-support/setup-hook
mkdir $TMP/new-test; cd $TMP/new-test mkdir $TMP/new-test; cd $TMP/new-test
echo PYTHONPATH=$PYTHONPATH echo PYTHONPATH=$PYTHONPATH
echo NIX_PYTHON_SITES=$NIX_PYTHON_SITES echo NIX_PYTHON_SITES=$NIX_PYTHON_SITES
script="$(echo -e "import sys\nprint sys.path\npyCheck\nprint \"check ok\"")" script="$(echo -e "import sys\nprint sys.path\npyCheck\nprint \"check ok\"")"
script="''${script/pyCheck/$pyCheck}" script="''${script/pyCheck/$pyCheck}"
echo "check script is"; echo "$script" echo "check script is"; echo "$script"
echo "$script" | /var/run/current-system/sw/bin/strace -o $TMP/strace -f python || { ${ getConfig [t.versionAttr "debugCmd"] ":"} ; exit 1; } echo "$script" | python || { ${ getConfig [t.versionAttr "debugCmd"] ":"} ; echo "pycheck failed"; exit 1; }
)''; )
fi'';
passthru = { passthru = {
libPython = t.version; # used to find all python libraries fitting this version (-> see name all below) libPython = t.version; # used to find all python libraries fitting this version (-> see name all below)
}; };
mergeAttrBy = { mergeAttrBy = {
postCheck = x : y : "${x}\n${y}"; pyCheck = x : y : "${x}\n${y}";
}; };
}; };
}; };
@ -173,37 +178,123 @@ in
# }; # };
#}; #};
pygobject = t.pythonLibStub.passthru.fun { # pyglib contains import reference to pygtk! So its best to install both at
name = "pygobject-2.15.4"; # the same time. I don't want to patch this.
flags = { libffi = { buildInputs = [p.libffi];}; }; # You can install both into different store paths, however you won't be able
cfg = { libffi = true; }; # to import gtk because after pygtk.require sys.path contains to
buildInputs = [ p.pkgconfig p.gtkLibs.glib]; # /nix/store/*-pygobject/**/gtk-2.0 (should be pygtk/**/gtk-2.0 instead)
src = fetchurl {
url = "http://ftp.gnome.org/pub/GNOME/sources/pygobject/2.15/pygobject-2.15.4.tar.bz2";
sha256 = "19vxczy01xyss2f5aqf93al3jzrxn50srgzkl4w7ivdz50rnjin7";
};
pyCheck = "import gobject";
};
# gnome python is added here as well because it is loaded after
# pygtk.require('2.0') as well. So the pygtk lib path is added to sys.path only.
# We could make extra derivations for that. But on the other hand that would require
# patching pygtk to another */gtk2.0 directory to sys.path for each NIX_PYTHON_SITES.
# If you install dozens of python packages this might be bloat.
# So I think the overhead of installing these packages into the same store path should be prefered.
pygtkBaseFun = (t.pythonLibStub.passthru.funMerge (a : pygtkBaseFun = (t.pythonLibStub.passthru.funMerge (a :
let inherit (a.fixed) glib gtk version; in { let inherit (a.fixed) glib gtk; in lib.mergeAttrsByFuncDefaults [
name = "pygtk-${version}"; {
buildInputs = [p.pkgconfig glib gtk]; unpackPhase = "true";
propagatedBuildInputs = [t.pygobject t.pycairo ]; configurePhase = "true";
flags = { patchPhase = "true";
cairo = { buildInputs = [ p.cairo ]; }; # TODO add pyCheck buildPhase = "true";
glade = { buildInputs = [ p.glade ]; }; # TODO add pyCheck installPhase = ''
}; unset unpackPhase
cfg = { unset configurePhase
glade = true; unset buildPhase
cairo = true; unset installPhase
export G2CONF="--enable-gconf" # hack, should be specified somewhere else
for srcs in $pygobjectSrc $pygtkSrc $pySrcs; do
cd $TMP; mkdir "$(basename $srcs)"; cd "$(basename $srcs)"; unpackPhase
cd $sourceRoot
configurePhase; buildPhase; installPhase
addToEnv $out # pygtk has to know about pygobject
PATH=$out/bin:$PATH # gnome-python nees pygtk-codegen
done
'';
mergeAttrBy = {
phases = lib.concatList;
pySrcs = lib.concatList;
pyCheck = x : y : "${x}\n${y}";
}; };
} }
)).passthru.fun; # pygobject
{
flags = {
libffi = { buildInputs = [p.libffi];};
};
cfg = {
libffiSupport = true;
};
pyCheck = "import gobject";
passthru = {
pygobjectVersion = "2.15.4";
};
pygobjectSrc = fetchurl {
url = "http://ftp.gnome.org/pub/GNOME/sources/pygobject/2.15/pygobject-2.15.4.tar.bz2";
sha256 = "19vxczy01xyss2f5aqf93al3jzrxn50srgzkl4w7ivdz50rnjin7";
};
buildInputs = [ p.glibc ]; # requires ld-config
propagatedBuildInputs = [ p.pkgconfig glib gtk ];
}
# pygtk
{
propagatedBuildInputs = [ t.pycairo ];
flags = {
cairo = {
propagatedBuildInputs = [ p.cairo ];
pyCheck = "import cairo";
}; # TODO add pyCheck
glade = {
propagatedBuildInputs = [ p.gnome.libglade ];
pyCheck = "from gtk import glade";
};
};
pyCheck = ''
import pygtk; pygtk.require('2.0')
import gtk
import gconf
'';
cfg = {
gladeSupport = true;
cairoSupport = true;
};
}
# gnome-python
{
name = "gnome-python-2.22.3";
buildInputs = [ p.pkgconfig p.gnome.libgnome ];
propagatedBuildInputs = [ p.gnome.GConf ];
pySrcs = [(fetchurl {
url = http://ftp.gnome.org/pub/GNOME/sources/gnome-python/2.22/gnome-python-2.22.3.tar.bz2;
sha256 = "0ndm3cns9381mm6d8jxxfd931fk93nqfcszy38p1bz501bs3wxm1";
})];
}
# gnome-desktop or gnome-python-extras desktop containing egg.trayicon needed by istanbul
{
# name = "gnome-desktop-2.24.0";
buildInputs = [ p.pkgconfig ];
propagatedBuildInputs = [ p.gnome.GConf ];
pySrcs = [(fetchurl {
url = http://ftp.gnome.org/pub/GNOME/sources/gnome-python-desktop/2.24/gnome-python-desktop-2.24.0.tar.bz2;
sha256 = "16514gmv42ygjh5ggzsis697m73pgg7ydz11h487932kkzv4mmlg";
})];
pyCheck = "import egg.trayicon";
}
{
# name = "gnome-python-extras-2.13";
buildInputs = [ p.pkgconfig ];
propagatedBuildInputs = [ p.gnome.GConf ];
pySrcs = [(fetchurl {
url = http://ftp.gnome.org/pub/GNOME/sources/gnome-python-extras/2.13/gnome-python-extras-2.13.3.tar.gz;
sha256 = "0vj0289snagrnvbmrs1camwmrc93xgpw650iavj6mq7a3wqcra0b";
})];
}
]));
#pygtk213 = t.pygtkBaseFun { #pygtk213 = t.pygtkBaseFun {
# version = "2.13.0"; # version = "2.13.0";
# src = fetchurl { # pygtkSrc = fetchurl {
# url = http://ftp.gnome.org/pub/GNOME/sources/pygtk/2.13/pygtk-2.13.0.tar.bz2; # url = http://ftp.gnome.org/pub/GNOME/sources/pygtk/2.13/pygtk-2.13.0.tar.bz2;
# sha256 = "0644ll48hi8kwfng37b0k5qgb0fbiy298r7sxd4j7ag7lj4bgic0"; # sha256 = "0644ll48hi8kwfng37b0k5qgb0fbiy298r7sxd4j7ag7lj4bgic0";
# }; # };
@ -214,9 +305,10 @@ in
# ''; # '';
#}; #};
pygtk212 = t.pygtkBaseFun { pygtk212 = t.pygtkBaseFun.passthru.funMerge (a : {
version = "2.12.1"; version = "2.12.1";
src = fetchurl { name = "pygobject-${a.fixed.pygobjectVersion}-and-pygtk-${a.fixed.version}";
pygtkSrc = fetchurl {
url = http://ftp.acc.umu.se/pub/GNOME/sources/pygtk/2.12/pygtk-2.12.1.tar.bz2; url = http://ftp.acc.umu.se/pub/GNOME/sources/pygtk/2.12/pygtk-2.12.1.tar.bz2;
sha256 = "0gg13xgr7y9sppw8bdys042928nc66czn74g60333c4my95ys021"; sha256 = "0gg13xgr7y9sppw8bdys042928nc66czn74g60333c4my95ys021";
}; };
@ -225,8 +317,7 @@ in
import pygtk; pygtk.require('2.0') import pygtk; pygtk.require('2.0')
import gtk import gtk
''; '';
patches = [ ./pygtk-2.12.1-fix-amd64-from-gentoo.patch ]; });
};
pycairo = t.pythonLibStub.passthru.fun { pycairo = t.pythonLibStub.passthru.fun {
name = "pycairo-1.8.0"; name = "pycairo-1.8.0";
@ -245,16 +336,32 @@ in
sha256 = "0yin36acr5ryfpmhlb4rlagabgxrjcmbpizwrc8csadmxzmigb86"; sha256 = "0yin36acr5ryfpmhlb4rlagabgxrjcmbpizwrc8csadmxzmigb86";
}; };
buildInputs =[ p.flex2535 p.pkgconfig]; buildInputs =[ p.flex2535 p.pkgconfig];
flags = {
pluginsGood = { propagatedBuildInputs = [p.gst_all.gstPluginsGood]; };
ffmpeg = { propagatedBuildInputs = [p.gst_all.gstFfmpeg]; };
};
cfg = {
pluginsGoodSupport = true;
ffmpegSupport = true;
};
propagatedBuildInputs = [ propagatedBuildInputs = [
t.pygtk212 t.pygtk212
p.gst_all.gstreamer p.gst_all.gstreamer
p.gst_all.gstPluginsBase p.gst_all.gstPluginsBase
p.gst_all.gstPluginsGood p.gst_all.gnonlin
]; ];
# this check fails while building: It succeeds running as normal user
/*
Traceback (most recent call last):
File "<stdin>", line 5, in <module>
File "/nix/store/hnc51h035phlk68i1qmr5a8kc73dfvhp-gst-python-0.10.13/lib/python2.5/site-packages/gst-0.10/gst/__init__.py", line 170, in <module>
from _gst import *
RuntimeError: can't initialize module gst: Error re-scanning registry , child terminated by signal
*/
pyCheck = '' pyCheck = ''
import pygst #import pygst
pygst.require('0.10') #pygst.require('0.10')
import gst #import gst
''; '';
meta = { meta = {
description = "python gstreamer bindings"; description = "python gstreamer bindings";
@ -263,6 +370,99 @@ in
}; };
}; };
pygoocanvas = t.pythonLibStub.passthru.fun {
src = p.fetchurl {
url = http://download.berlios.de/pygoocanvas/pygoocanvas-0.10.0.tar.gz;
sha256 = "0pxznzdscbhvn8102vrqy3r1g6ss4sgs8wwy6y4c5g26rrp7l55d";
};
propagatedBuildInputs = [ t.pygtk212 ];
buildInputs = [ p.pkgconfig p.goocanvas ];
pyCheck = "import goocanvas";
name = "pygoocanvas-0.10.0";
meta = {
description = "";
homepage = http://developer.berlios.de/projects/pygoocanvas/;
license = "LGPL";
};
};
# zope = t.pythonLibStub.passthru.fun rec {
#[> version = "3.3.1";
# version = "svn";
# name = "zope-${version}";
# [>src = p.blending.sourceByName "zope";
# src = "/home/marc/managed_repos/zope";
# [>fetchurl {
# [> Doh! Python version 2.4.3 before continuing. Versions
# [> 2.4.7 2.4.6 2.4.5 2.4.4 2.4.2 2.4.1 also work, but not as optimally.
# [> url = "http://www.zope.org/Products/Zope3/${version}/Zope-${version}.tgz";
# [> sha256 = "1qvvh384j7blzhwgfmd5kqvr5vzpv5khaj8ha46ln3hrwffrk2b1";
# [>};
# pyCheck = "";
# };
setuptools = t.pythonLibSetup.passthru.fun {
name = "setuptools-0.6c9";
postUnpack = ''
ensureDir $out/lib/python2.5/site-packages
export PYTHONPATH="$out/lib/python${t.version}/site-packages" # shut up installation script
# setuptools tries to write to the installation location, so ensure it exists
# and it requires PYTHONPATH to be set to that location (maybe its better to patch it. - I'm lazy)
ensureDir $out/nix-support
cat >> $out/nix-support/setup-hook << EOF
ensureDir \$out/lib/python${t.version}/site-packages
export PYTHONPATH="\$out/lib/python${t.version}/site-packages" # shut up installation script
EOF
'';
src = p.fetchurl {
url = "http://pypi.python.org/packages/source/s/setuptools/setuptools-0.6c9.tar.gz";
md5 = "3864c01d9c719c8924c455714492295e";
};
};
zopeInterface = t.pythonLibSetup.passthru.fun rec {
version = "3.3.0";
name = "zope.interface-${version}";
buildInputs = [ t.setuptools ];
src = p.fetchurl {
url = "http://www.zope.org/Products/ZopeInterface/3.3.0/zope.interface-${version}.tar.gz";
sha256 = "0xahg9cmagn4j3dbifvgzbjliw2jdrbf27fhqwkdp8j80xpyyjf0";
};
pyCheck = "from zope.interface import Interface, Attribute";
};
dbusPython = t.pythonLibStub.passthru.fun rec {
version = "0.83.0";
name = "dbus-python-0.83.0";
buildInputs = [ p.pkgconfig ];
propagatedBuildInputs = [ p.dbus p.dbus_glib ];
src = fetchurl {
url = "http://dbus.freedesktop.org/releases/dbus-python/dbus-python-0.83.0.tar.gz";
sha256 = "14b1fwq9jyvg9qbbrmpk1264s9shm9n638hsgmkh9fn2lmd1vpc9";
};
pyCheck = "import dbus";
meta = {
description = "";
homepage = http://freedesktop.org/wiki/Software/DBusBindings;
license = [ "GPLv2" "AFL-2.1" ];
};
};
pythonXlib = t.pythonLibSetup.passthru.fun {
name = "python-xlib-0.14";
src = fetchurl {
url = http://puzzle.dl.sourceforge.net/sourceforge/python-xlib/python-xlib-0.14.tar.gz;
sha256 = "1sv0447j0rx8cgs3jhjl695p5pv13ihglcjlrrz1kq05lsvb0wa7";
};
meta = {
description = "tries to be a fully functional X client library beeing entirely written in python";
license = [ "GPL" ];
homepage = http://python-xlib.sourceforge.net/;
};
};
### python applications ### python applications
pythonExStub = p.composableDerivation { pythonExStub = p.composableDerivation {
@ -270,10 +470,13 @@ in
buildInputs = [p.makeWrapper]; buildInputs = [p.makeWrapper];
postPhases = ["wrapExecutables"]; postPhases = ["wrapExecutables"];
propagatedBuildInputs = [ t.pythonFull ]; # see [1] propagatedBuildInputs = [ t.pythonFull ]; # see [1]
# adding $out to NIX_PYTHON_SITES because some of those executables seem to come with extra libs
wrapExecutables = '' wrapExecutables = ''
for prog in $out/bin/*; do for prog in $out/bin/*; do
wrapProgram "$prog" \ wrapProgram "$prog" \
--set NIX_PYTHON_SITES "$NIX_PYTHON_SITES" --set NIX_PYTHON_SITES "$NIX_PYTHON_SITES:$out" \
--set PYTHONPATH "\$PYTHONPATH:$out"
done done
''; '';
}; };
@ -285,7 +488,8 @@ in
url = http://ftp.gnome.org/pub/GNOME/sources/pitivi/0.11/pitivi-0.11.2.tar.bz2; url = http://ftp.gnome.org/pub/GNOME/sources/pitivi/0.11/pitivi-0.11.2.tar.bz2;
sha256 = "0d3bqgfp60qm5bf904k477bd8jhxizj1klv84wbxsz9vhjwx9zcl"; sha256 = "0d3bqgfp60qm5bf904k477bd8jhxizj1klv84wbxsz9vhjwx9zcl";
}; };
buildInputs =[ t.pygtk212 t.gstPython p.intltool p.gettext p.makeWrapper p.gettext ]; buildInputs = [ t.pygtk212 t.gstPython t.pygoocanvas t.zopeInterface t.dbusPython
p.intltool p.gettext p.makeWrapper p.gettext ];
# why do have to add gtk-2.0 explicitely? # why do have to add gtk-2.0 explicitely?
meta = { meta = {
description = "A non-linear video editor using the GStreamer multimedia framework"; description = "A non-linear video editor using the GStreamer multimedia framework";
@ -298,9 +502,33 @@ in
''; '';
}; };
all = lib.filter (x: istanbul = t.pythonExStub.passthru.fun {
name = "istanbul-0.2.2";
buildInputs = [ t.pygtk212 t.gstPython /*t.gnomePython (contained in gtk) t.gnomePythonExtras */ t.pythonXlib
p.perl p.perlXMLParser p.gettext];
# gstPython can't be imported when building (TODO).. so just run true instead of python
configurePhase = ''./configure --prefix=""''; # DESTDIR is set below
postUnpack = ''
sed -i 's/$PYTHON/true/' istanbul-0.2.2/configure
mkdir -p $out/bin
export DESTDIR="$out"
shopt -s nullglob
'';
src = fetchurl {
url = http://zaheer.merali.org/istanbul-0.2.2.tar.bz2;
sha256 = "1mdc82d0xs9pyavs616bz0ywq3zwy3h5y0ydjl6kvcgixii29aiv";
};
postInstall = "chmod a+x $out/bin/istanbul";
meta = {
description = "A non-linear video editor using the GStreamer multimedia framework";
homepage = http://live.gnome.org/Istanbul;
license = "LGPLv2";
};
};
all = lib.filter (x:
(__isAttrs x) (__isAttrs x)
&& ((lib.maybeAttr "libPython" false x) == t.version) && ((lib.maybeAttr "libPython" false x) == t.version)
&& (lib.maybeAttr "name" false x != false) # don't collect pythonLibStub etc && (lib.maybeAttr "name" false x != false) # don't collect pythonLibStub etc
) (lib.flattenAttrs (removeAttrs t ["all"])); # nix is not yet lazy enough, so I've to remove all first ) (lib.flattenAttrs (removeAttrs t ["all"])); # nix is not yet lazy enough, so I've to remove all first
}) }))

View File

@ -13,7 +13,7 @@
+ env_nix_sites = os.environ.get("NIX_PYTHON_SITES", None) + env_nix_sites = os.environ.get("NIX_PYTHON_SITES", None)
+ if env_nix_sites: + if env_nix_sites:
+ for path in env_nix_sites.split(":"): + for path in env_nix_sites.split(":"):
+ if os.path.isdir(path): +
+ NIX_SITE = os.path.join(path, "lib", + NIX_SITE = os.path.join(path, "lib",
+ "python" + sys.version[:3], + "python" + sys.version[:3],
+ "site-packages") + "site-packages")

View File

@ -57,7 +57,7 @@ rec {
( y : y // ( y : y //
{ {
fun = z : applyAndFun f merge (fixed: merge (takeFix fixed) z); fun = z : applyAndFun f merge (fixed: merge (takeFix fixed) z);
funMerge = z : applyAndFun f merge (fixed: let e = takeFix fixed; in e // merge e z); funMerge = z : applyAndFun f merge (fixed: let e = takeFix fixed; in merge e (merge e z));
} ); } );
mergeOrApply = merge : x : y : if (__isFunction y) then y x else merge x y; mergeOrApply = merge : x : y : if (__isFunction y) then y x else merge x y;
@ -732,11 +732,11 @@ rec {
) )
) )
]; ];
mergeAttrsByFunc = fold mergeAttrByFunc {}; mergeAttrsByFuncDefaults = foldl mergeAttrByFunc { inherit mergeAttrBy; };
# sane defaults (same name as attr name so that inherit can be used) # sane defaults (same name as attr name so that inherit can be used)
mergeAttrBy = # { buildInputs = concatList; [...]; passthru = mergeAttr; [..]; } mergeAttrBy = # { buildInputs = concatList; [...]; passthru = mergeAttr; [..]; }
listToAttrs (map (n : nv n concatList) [ "buildInputs" "propagatedBuildInputs" "configureFlags" "prePhases" "postAll" ]) listToAttrs (map (n : nv n concatList) [ "buildInputs" "propagatedBuildInputs" "configureFlags" "prePhases" "postAll" ])
// listToAttrs (map (n : nv n mergeAttr) [ "passthru" "meta" ]); // listToAttrs (map (n : nv n mergeAttr) [ "passthru" "meta" "cfg" "flags" ]);
# returns atribute values as a list # returns atribute values as a list
flattenAttrs = set : map ( attr : builtins.getAttr attr set) (attrNames set); flattenAttrs = set : map ( attr : builtins.getAttr attr set) (attrNames set);
@ -779,6 +779,8 @@ rec {
# additional data from flags depending on config settings # additional data from flags depending on config settings
# It's used in composableDerivation in all-packages.nix. It's also used # It's used in composableDerivation in all-packages.nix. It's also used
# heavily in the new python and libs implementation # heavily in the new python and libs implementation
#
# should we check for misspelled cfg options?
prepareDerivationArgs = args: prepareDerivationArgs = args:
let args2 = { cfg = {}; flags = {}; } // args; let args2 = { cfg = {}; flags = {}; } // args;
flagName = name : "${name}Support"; flagName = name : "${name}Support";
@ -793,7 +795,7 @@ rec {
else throw "assertion of flag ${a} of derivation ${args.name} failed" else throw "assertion of flag ${a} of derivation ${args.name} failed"
) args2.flags ); ) args2.flags );
in removeAttrs in removeAttrs
(mergeAttrsByFunc ([args] ++ opts)) (mergeAttrsByFuncDefaults ([args] ++ opts))
["flags" "cfg" "mergeAttrBy" "fixed" ]; # fixed may be passed as fix argument or such ["flags" "cfg" "mergeAttrBy" "fixed" ]; # fixed may be passed as fix argument or such
# supportFlag functions for convinience # supportFlag functions for convinience
sFlagEnable = { name, buildInputs ? [], propagatedBuildInputs ? [] } : { sFlagEnable = { name, buildInputs ? [], propagatedBuildInputs ? [] } : {