add python 3.4.0rc2
This commit is contained in:
parent
6a9168ad06
commit
83771bd926
88
pkgs/development/interpreters/python/3.4/default.nix
Normal file
88
pkgs/development/interpreters/python/3.4/default.nix
Normal file
@ -0,0 +1,88 @@
|
|||||||
|
{ stdenv, fetchurl
|
||||||
|
, bzip2
|
||||||
|
, db
|
||||||
|
, gdbm
|
||||||
|
, libX11, xproto
|
||||||
|
, ncurses
|
||||||
|
, openssl
|
||||||
|
, readline
|
||||||
|
, sqlite
|
||||||
|
, tcl, tk
|
||||||
|
, zlib
|
||||||
|
}:
|
||||||
|
|
||||||
|
assert readline != null -> ncurses != null;
|
||||||
|
|
||||||
|
with stdenv.lib;
|
||||||
|
|
||||||
|
let
|
||||||
|
majorVersion = "3.4";
|
||||||
|
version = "${majorVersion}.0";
|
||||||
|
fullVersion = "${version}rc2";
|
||||||
|
|
||||||
|
buildInputs = filter (p: p != null) [
|
||||||
|
zlib bzip2 gdbm sqlite db readline ncurses openssl tcl tk libX11 xproto
|
||||||
|
];
|
||||||
|
in
|
||||||
|
stdenv.mkDerivation {
|
||||||
|
name = "python3-${fullVersion}";
|
||||||
|
inherit majorVersion version;
|
||||||
|
|
||||||
|
src = fetchurl {
|
||||||
|
url = "http://www.python.org/ftp/python/${version}/Python-${fullVersion}.tar.xz";
|
||||||
|
sha256 = "0v37mlkwzbc8m54h3nb04x6xm2yx5fmd7flq2shn37ixf9d0ih6z";
|
||||||
|
};
|
||||||
|
|
||||||
|
NIX_LDFLAGS = stdenv.lib.optionalString stdenv.isLinux "-lgcc_s";
|
||||||
|
|
||||||
|
preConfigure = ''
|
||||||
|
for i in /usr /sw /opt /pkg; do # improve purity
|
||||||
|
substituteInPlace ./setup.py --replace $i /no-such-path
|
||||||
|
done
|
||||||
|
${optionalString stdenv.isDarwin ''export NIX_CFLAGS_COMPILE="$NIX_CFLAGS_COMPILE -msse2"''}
|
||||||
|
|
||||||
|
configureFlagsArray=( --enable-shared --with-threads
|
||||||
|
CPPFLAGS="${concatStringsSep " " (map (p: "-I${p}/include") buildInputs)}"
|
||||||
|
LDFLAGS="${concatStringsSep " " (map (p: "-L${p}/lib") buildInputs)}"
|
||||||
|
LIBS="-lcrypt ${optionalString (ncurses != null) "-lncurses"}"
|
||||||
|
)
|
||||||
|
'';
|
||||||
|
|
||||||
|
setupHook = ./setup-hook.sh;
|
||||||
|
|
||||||
|
postInstall = ''
|
||||||
|
rm -rf "$out/lib/python${majorVersion}/test"
|
||||||
|
ln -s "$out/include/python${majorVersion}m" "$out/include/python${majorVersion}"
|
||||||
|
'';
|
||||||
|
|
||||||
|
passthru = {
|
||||||
|
zlibSupport = zlib != null;
|
||||||
|
sqliteSupport = sqlite != null;
|
||||||
|
dbSupport = db != null;
|
||||||
|
readlineSupport = readline != null;
|
||||||
|
opensslSupport = openssl != null;
|
||||||
|
tkSupport = (tk != null) && (tcl != null) && (libX11 != null) && (xproto != null);
|
||||||
|
libPrefix = "python${majorVersion}";
|
||||||
|
executable = "python3.4m";
|
||||||
|
is_py3k = true;
|
||||||
|
};
|
||||||
|
|
||||||
|
enableParallelBuilding = true;
|
||||||
|
|
||||||
|
meta = {
|
||||||
|
homepage = http://python.org;
|
||||||
|
description = "A high-level dynamically-typed programming language";
|
||||||
|
longDescription = ''
|
||||||
|
Python is a remarkably powerful dynamic programming language that
|
||||||
|
is used in a wide variety of application domains. Some of its key
|
||||||
|
distinguishing features include: clear, readable syntax; strong
|
||||||
|
introspection capabilities; intuitive object orientation; natural
|
||||||
|
expression of procedural code; full modularity, supporting
|
||||||
|
hierarchical packages; exception-based error handling; and very
|
||||||
|
high level dynamic data types.
|
||||||
|
'';
|
||||||
|
license = stdenv.lib.licenses.psfl;
|
||||||
|
platforms = stdenv.lib.platforms.linux;
|
||||||
|
maintainers = with stdenv.lib.maintainers; [ simons chaoflow iElectric ];
|
||||||
|
};
|
||||||
|
}
|
15
pkgs/development/interpreters/python/3.4/setup-hook.sh
Normal file
15
pkgs/development/interpreters/python/3.4/setup-hook.sh
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
addPythonPath() {
|
||||||
|
addToSearchPathWithCustomDelimiter : PYTHONPATH $1/lib/python3.4/site-packages
|
||||||
|
}
|
||||||
|
|
||||||
|
toPythonPath() {
|
||||||
|
local paths="$1"
|
||||||
|
local result=
|
||||||
|
for i in $paths; do
|
||||||
|
p="$i/lib/python3.4/site-packages"
|
||||||
|
result="${result}${result:+:}$p"
|
||||||
|
done
|
||||||
|
echo $result
|
||||||
|
}
|
||||||
|
|
||||||
|
envHooks=(${envHooks[@]} addPythonPath)
|
@ -3243,8 +3243,9 @@ let
|
|||||||
};
|
};
|
||||||
|
|
||||||
python3 = hiPrio (callPackage ../development/interpreters/python/3.3 { });
|
python3 = hiPrio (callPackage ../development/interpreters/python/3.3 { });
|
||||||
python33 = callPackage ../development/interpreters/python/3.3 { };
|
|
||||||
python32 = callPackage ../development/interpreters/python/3.2 { };
|
python32 = callPackage ../development/interpreters/python/3.2 { };
|
||||||
|
python33 = callPackage ../development/interpreters/python/3.3 { };
|
||||||
|
python34 = callPackage ../development/interpreters/python/3.4 { };
|
||||||
|
|
||||||
python = python27;
|
python = python27;
|
||||||
python26 = callPackage ../development/interpreters/python/2.6 {
|
python26 = callPackage ../development/interpreters/python/2.6 {
|
||||||
@ -6061,6 +6062,12 @@ let
|
|||||||
python = python33;
|
python = python33;
|
||||||
});
|
});
|
||||||
|
|
||||||
|
python34Packages = import ./python-packages.nix {
|
||||||
|
inherit pkgs;
|
||||||
|
inherit (lib) lowPrio;
|
||||||
|
python = python34;
|
||||||
|
};
|
||||||
|
|
||||||
python32Packages = import ./python-packages.nix {
|
python32Packages = import ./python-packages.nix {
|
||||||
inherit pkgs;
|
inherit pkgs;
|
||||||
inherit (lib) lowPrio;
|
inherit (lib) lowPrio;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user