summaryrefslogtreecommitdiff
path: root/pkgs/development/interpreters/python/cpython/3.5/default.nix
diff options
context:
space:
mode:
Diffstat (limited to 'pkgs/development/interpreters/python/cpython/3.5/default.nix')
-rw-r--r--pkgs/development/interpreters/python/cpython/3.5/default.nix65
1 files changed, 31 insertions, 34 deletions
diff --git a/pkgs/development/interpreters/python/cpython/3.5/default.nix b/pkgs/development/interpreters/python/cpython/3.5/default.nix
index 69d3df32a326..dd2cce707efe 100644
--- a/pkgs/development/interpreters/python/cpython/3.5/default.nix
+++ b/pkgs/development/interpreters/python/cpython/3.5/default.nix
@@ -1,55 +1,49 @@
{ stdenv, fetchurl
, bzip2
, gdbm
-, libX11, xproto
, lzma
, ncurses
, openssl
, readline
, sqlite
-, tcl, tk
+, tcl ? null, tk ? null, libX11 ? null, xproto ? null, x11Support ? false
, zlib
, callPackage
, self
, python35Packages
-
, CF, configd
}:
-assert readline != null -> ncurses != null;
+assert x11Support -> tcl != null
+ && tk != null
+ && xproto != null
+ && libX11 != null;
with stdenv.lib;
let
majorVersion = "3.5";
+ minorVersion = "2";
+ minorVersionSuffix = "";
pythonVersion = majorVersion;
- version = "${majorVersion}.2";
- fullVersion = "${version}";
+ version = "${majorVersion}.${minorVersion}${minorVersionSuffix}";
+ libPrefix = "python${majorVersion}";
+ sitePackages = "lib/${libPrefix}/site-packages";
buildInputs = filter (p: p != null) [
- zlib
- bzip2
- lzma
- gdbm
- sqlite
- readline
- ncurses
- openssl
- tcl
- tk
- libX11
- xproto
- ] ++ optionals stdenv.isDarwin [ CF configd ];
-in
-stdenv.mkDerivation {
- name = "python3-${fullVersion}";
+ zlib bzip2 lzma gdbm sqlite readline ncurses openssl ]
+ ++ optionals x11Support [ tcl tk libX11 xproto ]
+ ++ optionals stdenv.isDarwin [ CF configd ];
+
+in stdenv.mkDerivation {
+ name = "python3-${version}";
pythonVersion = majorVersion;
inherit majorVersion version;
inherit buildInputs;
src = fetchurl {
- url = "http://www.python.org/ftp/python/${version}/Python-${fullVersion}.tar.xz";
+ url = "https://www.python.org/ftp/python/${majorVersion}.${minorVersion}/Python-${version}.tar.xz";
sha256 = "0h6a5fr7ram2s483lh0pnmc4ncijb8llnpfdxdcl5dxr01hza400";
};
@@ -92,12 +86,23 @@ stdenv.mkDerivation {
ln -s "$out/include/python${majorVersion}m" "$out/include/python${majorVersion}"
paxmark E $out/bin/python${majorVersion}
+
+ # Python on Nix is not manylinux1 compatible. https://github.com/NixOS/nixpkgs/issues/18484
+ echo "manylinux1_compatible=False" >> $out/lib/${libPrefix}/_manylinux.py
+
+ # Use Python3 as default python
+ ln -s "$out/bin/idle3" "$out/bin/idle"
+ ln -s "$out/bin/pip3" "$out/bin/pip"
+ ln -s "$out/bin/pydoc3" "$out/bin/pydoc"
+ ln -s "$out/bin/python3" "$out/bin/python"
+ ln -s "$out/bin/python3-config" "$out/bin/python-config"
+ ln -s "$out/lib/pkgconfig/python3.pc" "$out/lib/pkgconfig/python.pc"
'';
postFixup = ''
# Get rid of retained dependencies on -dev packages, and remove
# some $TMPDIR references to improve binary reproducibility.
- for i in $out/lib//python${majorVersion}/_sysconfigdata.py $out/lib/python${majorVersion}/config-${majorVersion}m/Makefile; do
+ for i in $out/lib/python${majorVersion}/_sysconfigdata.py $out/lib/python${majorVersion}/config-${majorVersion}m/Makefile; do
sed -i $i -e "s|-I/nix/store/[^ ']*||g" -e "s|-L/nix/store/[^ ']*||g" -e "s|$TMPDIR|/no-such-path|g"
done
@@ -106,20 +111,12 @@ stdenv.mkDerivation {
'';
passthru = rec {
- zlibSupport = zlib != null;
- sqliteSupport = sqlite != null;
- dbSupport = false;
- readlineSupport = readline != null;
- opensslSupport = openssl != null;
- tkSupport = (tk != null) && (tcl != null) && (libX11 != null) && (xproto != null);
- libPrefix = "python${majorVersion}";
- executable = "python${majorVersion}m";
+ inherit libPrefix sitePackages x11Support;
+ executable = "${libPrefix}m";
buildEnv = callPackage ../../wrapper.nix { python = self; };
withPackages = import ../../with-packages.nix { inherit buildEnv; pythonPackages = python35Packages; };
isPy3 = true;
isPy35 = true;
- is_py3k = true; # deprecated
- sitePackages = "lib/${libPrefix}/site-packages";
interpreter = "${self}/bin/${executable}";
};