python: add alpha release of 3.6
This might be jumping the gun a little, but I needed to use 3.6 locally and thought I may as well push it upstream.
This commit is contained in:
parent
1109b236cf
commit
7c75fa4bc2
138
pkgs/development/interpreters/python/3.6/default.nix
Normal file
138
pkgs/development/interpreters/python/3.6/default.nix
Normal file
@ -0,0 +1,138 @@
|
|||||||
|
{ stdenv, fetchurl
|
||||||
|
, glibc
|
||||||
|
, bzip2
|
||||||
|
, db
|
||||||
|
, gdbm
|
||||||
|
, libX11, xproto
|
||||||
|
, lzma
|
||||||
|
, ncurses
|
||||||
|
, openssl
|
||||||
|
, readline
|
||||||
|
, sqlite
|
||||||
|
, tcl, tk
|
||||||
|
, zlib
|
||||||
|
, callPackage
|
||||||
|
, self
|
||||||
|
, python36Packages
|
||||||
|
|
||||||
|
, CF, configd
|
||||||
|
}:
|
||||||
|
|
||||||
|
assert readline != null -> ncurses != null;
|
||||||
|
|
||||||
|
with stdenv.lib;
|
||||||
|
|
||||||
|
let
|
||||||
|
majorVersion = "3.6";
|
||||||
|
pythonVersion = majorVersion;
|
||||||
|
version = "${majorVersion}.0a3";
|
||||||
|
fullVersion = "${version}";
|
||||||
|
|
||||||
|
buildInputs = filter (p: p != null) [
|
||||||
|
glibc
|
||||||
|
zlib
|
||||||
|
bzip2
|
||||||
|
lzma
|
||||||
|
gdbm
|
||||||
|
sqlite
|
||||||
|
db
|
||||||
|
readline
|
||||||
|
ncurses
|
||||||
|
openssl
|
||||||
|
tcl
|
||||||
|
tk
|
||||||
|
libX11
|
||||||
|
xproto
|
||||||
|
] ++ optionals stdenv.isDarwin [ CF configd ];
|
||||||
|
in
|
||||||
|
stdenv.mkDerivation {
|
||||||
|
name = "python3-${fullVersion}";
|
||||||
|
pythonVersion = majorVersion;
|
||||||
|
inherit majorVersion version;
|
||||||
|
|
||||||
|
inherit buildInputs;
|
||||||
|
|
||||||
|
src = fetchurl {
|
||||||
|
url = "https://www.python.org/ftp/python/${majorVersion}.0/Python-${fullVersion}.tar.xz";
|
||||||
|
sha256 = "08c3598bwihibwca9lwxq923sjq9shvgv3wxv4vkga2n6hf63l1c";
|
||||||
|
};
|
||||||
|
|
||||||
|
NIX_LDFLAGS = optionalString stdenv.isLinux "-lgcc_s";
|
||||||
|
|
||||||
|
prePatch = optionalString stdenv.isDarwin ''
|
||||||
|
substituteInPlace configure --replace '`/usr/bin/arch`' '"i386"'
|
||||||
|
'';
|
||||||
|
|
||||||
|
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"
|
||||||
|
export MACOSX_DEPLOYMENT_TARGET=10.6
|
||||||
|
''}
|
||||||
|
|
||||||
|
substituteInPlace ./Lib/plat-generic/regen --replace "/usr/include" ${glibc}/include
|
||||||
|
|
||||||
|
configureFlagsArray=( --enable-shared --with-threads
|
||||||
|
CPPFLAGS="${concatStringsSep " " (map (p: "-I${getDev p}/include") buildInputs)}"
|
||||||
|
LDFLAGS="${concatStringsSep " " (map (p: "-L${getLib p}/lib") buildInputs)}"
|
||||||
|
LIBS="${optionalString (!stdenv.isDarwin) "-lcrypt"} ${optionalString (ncurses != null) "-lncurses"}"
|
||||||
|
)
|
||||||
|
'';
|
||||||
|
|
||||||
|
setupHook = ./setup-hook.sh;
|
||||||
|
|
||||||
|
postInstall = ''
|
||||||
|
# needed for some packages, especially packages that backport functionality
|
||||||
|
# to 2.x from 3.x
|
||||||
|
for item in $out/lib/python${majorVersion}/test/*; do
|
||||||
|
if [[ "$item" != */test_support.py* ]]; then
|
||||||
|
rm -rf "$item"
|
||||||
|
else
|
||||||
|
echo $item
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
touch $out/lib/python${majorVersion}/test/__init__.py
|
||||||
|
|
||||||
|
ln -s "$out/include/python${majorVersion}m" "$out/include/python${majorVersion}"
|
||||||
|
paxmark E $out/bin/python${majorVersion}
|
||||||
|
'';
|
||||||
|
|
||||||
|
passthru = rec {
|
||||||
|
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 = "python${majorVersion}m";
|
||||||
|
buildEnv = callPackage ../wrapper.nix { python = self; };
|
||||||
|
withPackages = import ../with-packages.nix { inherit buildEnv; pythonPackages = python36Packages; };
|
||||||
|
isPy3 = true;
|
||||||
|
isPy35 = true;
|
||||||
|
is_py3k = true; # deprecated
|
||||||
|
sitePackages = "lib/${libPrefix}/site-packages";
|
||||||
|
interpreter = "${self}/bin/${executable}";
|
||||||
|
};
|
||||||
|
|
||||||
|
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 = licenses.psfl;
|
||||||
|
platforms = with platforms; linux ++ darwin;
|
||||||
|
maintainers = with maintainers; [ chaoflow domenkozar cstrahan kragniz ];
|
||||||
|
};
|
||||||
|
}
|
15
pkgs/development/interpreters/python/3.6/setup-hook.sh
Normal file
15
pkgs/development/interpreters/python/3.6/setup-hook.sh
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
addPythonPath() {
|
||||||
|
addToSearchPathWithCustomDelimiter : PYTHONPATH $1/lib/python3.6/site-packages
|
||||||
|
}
|
||||||
|
|
||||||
|
toPythonPath() {
|
||||||
|
local paths="$1"
|
||||||
|
local result=
|
||||||
|
for i in $paths; do
|
||||||
|
p="$i/lib/python3.6/site-packages"
|
||||||
|
result="${result}${result:+:}$p"
|
||||||
|
done
|
||||||
|
echo $result
|
||||||
|
}
|
||||||
|
|
||||||
|
envHooks+=(addPythonPath)
|
@ -5850,6 +5850,10 @@ in
|
|||||||
inherit (darwin) CF configd;
|
inherit (darwin) CF configd;
|
||||||
self = python35;
|
self = python35;
|
||||||
});
|
});
|
||||||
|
python36 = callPackage ../development/interpreters/python/3.6 {
|
||||||
|
inherit (darwin) CF configd;
|
||||||
|
self = python36;
|
||||||
|
};
|
||||||
pypy = callPackage ../development/interpreters/pypy {
|
pypy = callPackage ../development/interpreters/pypy {
|
||||||
self = pypy;
|
self = pypy;
|
||||||
};
|
};
|
||||||
@ -9899,6 +9903,11 @@ in
|
|||||||
self = python35Packages;
|
self = python35Packages;
|
||||||
});
|
});
|
||||||
|
|
||||||
|
python36Packages = (callPackage ./python-packages.nix {
|
||||||
|
python = python36;
|
||||||
|
self = python36Packages;
|
||||||
|
});
|
||||||
|
|
||||||
pypyPackages = callPackage ./python-packages.nix {
|
pypyPackages = callPackage ./python-packages.nix {
|
||||||
python = pypy;
|
python = pypy;
|
||||||
self = pypyPackages;
|
self = pypyPackages;
|
||||||
|
@ -10,6 +10,7 @@ let
|
|||||||
isPy33 = python.majorVersion == "3.3";
|
isPy33 = python.majorVersion == "3.3";
|
||||||
isPy34 = python.majorVersion == "3.4";
|
isPy34 = python.majorVersion == "3.4";
|
||||||
isPy35 = python.majorVersion == "3.5";
|
isPy35 = python.majorVersion == "3.5";
|
||||||
|
isPy36 = python.majorVersion == "3.6";
|
||||||
isPyPy = python.executable == "pypy";
|
isPyPy = python.executable == "pypy";
|
||||||
isPy3k = strings.substring 0 1 python.majorVersion == "3";
|
isPy3k = strings.substring 0 1 python.majorVersion == "3";
|
||||||
|
|
||||||
@ -30,6 +31,7 @@ let
|
|||||||
if isPy33 then "python33" else
|
if isPy33 then "python33" else
|
||||||
if isPy34 then "python34" else
|
if isPy34 then "python34" else
|
||||||
if isPy35 then "python35" else
|
if isPy35 then "python35" else
|
||||||
|
if isPy36 then "python36" else
|
||||||
if isPyPy then "pypy" else "";
|
if isPyPy then "pypy" else "";
|
||||||
|
|
||||||
modules = python.modules or {
|
modules = python.modules or {
|
||||||
@ -42,7 +44,7 @@ let
|
|||||||
|
|
||||||
in modules // {
|
in modules // {
|
||||||
|
|
||||||
inherit python bootstrapped-pip isPy26 isPy27 isPy33 isPy34 isPy35 isPyPy isPy3k pythonName buildPythonPackage buildPythonApplication;
|
inherit python bootstrapped-pip isPy26 isPy27 isPy33 isPy34 isPy35 isPy36 isPyPy isPy3k pythonName buildPythonPackage buildPythonApplication;
|
||||||
|
|
||||||
# helpers
|
# helpers
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user