gnu: pypy3: Rename to pypy and modernize definition.

* gnu/packages/python.scm (pypy3): Deprecate in favor of...
(pypy): ... this renamed package.
[native-inputs, inputs]: Move after arguments, use new style and sort.
[native-inputs]: Remove python2-hypothesis.
[phases]: Adjust to use gexps, with search-input-file and this-package-input.
This commit is contained in:
Maxim Cournoyer 2022-05-05 23:41:25 -04:00
parent 030e5793d6
commit 553c009d74
No known key found for this signature in database
GPG key ID: 1260E46482E63562

View file

@ -743,9 +743,9 @@ (define-public micropython
ease from the desktop to a microcontroller or embedded system.") ease from the desktop to a microcontroller or embedded system.")
(license license:expat))) (license license:expat)))
(define-public pypy3 (define-public pypy
(package (package
(name "pypy3") (name "pypy")
(version "7.3.5") (version "7.3.5")
(source (origin (source (origin
(method url-fetch) (method url-fetch)
@ -755,36 +755,17 @@ (define-public pypy3
(base32 (base32
"18lrdmpcczlbk3cfarkgwqdmilrybz56i1dafk8dkjlyk90gw86r")))) "18lrdmpcczlbk3cfarkgwqdmilrybz56i1dafk8dkjlyk90gw86r"))))
(build-system gnu-build-system) (build-system gnu-build-system)
(native-inputs
`(("python-2" ,python-2)
("pkg-config" ,pkg-config)
("tar" ,tar) ; Required for package.py
("python2-pycparser" ,python2-pycparser)
("python2-hypothesis" ,python2-hypothesis)
("nss-certs" ,nss-certs) ; For ssl tests
("gzip" ,gzip)))
(inputs
(list libffi
zlib
ncurses
openssl
expat
bzip2
sqlite
gdbm
tcl
tk
glibc
xz)) ; liblzma
(arguments (arguments
`(#:tests? #f ;FIXME: 43 out of 364 tests are failing (list
#:modules ((ice-9 ftw) (ice-9 match) #:tests? #f ;FIXME: 43 out of 364 tests are failing
#:modules '((ice-9 ftw) (ice-9 match)
(guix build utils) (guix build gnu-build-system)) (guix build utils) (guix build gnu-build-system))
#:disallowed-references (,nss-certs) #:disallowed-references (list nss-certs)
#:phases (modify-phases %standard-phases #:phases
#~(modify-phases %standard-phases
(delete 'configure) (delete 'configure)
(add-after 'unpack 'patch-source (add-after 'unpack 'patch-source
(lambda* (#:key inputs outputs #:allow-other-keys) (lambda* (#:key inputs #:allow-other-keys)
(substitute* '("rpython/rlib/clibffi.py") (substitute* '("rpython/rlib/clibffi.py")
;; find_library does not work for libc ;; find_library does not work for libc
(("ctypes\\.util\\.find_library\\('c'\\)") "'libc.so'")) (("ctypes\\.util\\.find_library\\('c'\\)") "'libc.so'"))
@ -799,29 +780,28 @@ (define-public pypy3
(("linklibs = \\['tcl', 'tk'\\]") (("linklibs = \\['tcl', 'tk'\\]")
"linklibs = ['tcl8.6', 'tk8.6']") "linklibs = ['tcl8.6', 'tk8.6']")
(("incdirs = \\[\\]") (("incdirs = \\[\\]")
(string-append "incdirs = ['" (string-append
(assoc-ref inputs "tcl") "incdirs = ['"
"/include', '" #$(this-package-input "tcl") "/include', '"
(assoc-ref inputs "tk") #$(this-package-input "tk") "/include']")))
"/include']")))
(substitute* '("lib_pypy/_curses_build.py") (substitute* '("lib_pypy/_curses_build.py")
;; Find curses ;; Find curses
(("/usr/local") (assoc-ref inputs "ncurses"))) (("/usr/local")
#$(this-package-input "ncurses")))
(substitute* '("lib_pypy/_dbm.py") (substitute* '("lib_pypy/_dbm.py")
;; Use gdbm compat library, so we dont need to pull ;; Use gdbm compat library, so we dont need to pull
;; in bdb. ;; in bdb.
(("ctypes.util.find_library\\('db'\\)") (("ctypes.util.find_library\\('db'\\)")
(format #f "'~a/lib/libgdbm_compat.so'" (format #f "~s" (search-input-file
(assoc-ref inputs "gdbm")))) inputs "lib/libgdbm_compat.so"))))
(substitute* '("lib_pypy/_sqlite3_build.py") (substitute* '("lib_pypy/_sqlite3_build.py")
;; Always use search paths ;; Always use search paths
(("sys\\.platform\\.startswith\\('freebsd'\\)") "True") (("sys\\.platform\\.startswith\\('freebsd'\\)") "True")
;; Find sqlite3 ;; Find sqlite3
(("/usr/local") (assoc-ref inputs "sqlite")) (("/usr/local") (assoc-ref inputs "sqlite"))
(("libname = 'sqlite3'") (("libname = 'sqlite3'")
(string-append "libname = '" (format #f "libname = ~s"
(assoc-ref inputs "sqlite") (search-input-file inputs "lib/libsqlite3.so.0"))))
"/lib/libsqlite3.so.0'")))
(substitute* '("lib-python/3/subprocess.py") (substitute* '("lib-python/3/subprocess.py")
;; Fix shell path ;; Fix shell path
(("/bin/sh") (("/bin/sh")
@ -829,8 +809,7 @@ (define-public pypy3
(substitute* '("lib-python/3/distutils/unixccompiler.py") (substitute* '("lib-python/3/distutils/unixccompiler.py")
;; gcc-toolchain does not provide symlink cc -> gcc ;; gcc-toolchain does not provide symlink cc -> gcc
(("\"cc\"") "\"gcc\"")))) (("\"cc\"") "\"gcc\""))))
(add-after (add-after 'unpack 'set-source-file-times-to-1980
'unpack 'set-source-file-times-to-1980
;; copied from python package, required by zip testcase ;; copied from python package, required by zip testcase
(lambda _ (lambda _
(let ((circa-1980 (* 10 366 24 60 60))) (let ((circa-1980 (* 10 366 24 60 60)))
@ -838,7 +817,7 @@ (define-public pypy3
(utime file circa-1980 circa-1980) (utime file circa-1980 circa-1980)
#t))))) #t)))))
(replace 'build (replace 'build
(lambda* (#:key inputs #:allow-other-keys) (lambda _
(with-directory-excursion "pypy/goal" (with-directory-excursion "pypy/goal"
;; Build with jit optimization. ;; Build with jit optimization.
(invoke "python2" (invoke "python2"
@ -859,18 +838,15 @@ (define-public pypy3
(begin (begin
(setenv "HOME" "/tmp") ; test_with_pip tries to (setenv "HOME" "/tmp") ; test_with_pip tries to
; access ~/.cache/pip ; access ~/.cache/pip
;; Run library tests only (no interpreter unit ;; Run library tests only (no interpreter unit tests).
;; tests). This is what Gentoo does. ;; This is what Gentoo does.
(invoke (invoke "python" "pypy/test_all.py"
"python2"
"pypy/test_all.py"
"--pypy=pypy/tool/release/pypy-dist/bin/pypy3" "--pypy=pypy/tool/release/pypy-dist/bin/pypy3"
"lib-python")) "lib-python"))
(format #t "test suite not run~%")))) (format #t "test suite not run~%"))))
(replace 'install (replace 'install
(lambda* (#:key inputs outputs #:allow-other-keys) (lambda* (#:key inputs outputs #:allow-other-keys)
(let* ((out (assoc-ref outputs "out")) (let* ((bin-pypy3 (string-append #$output "/bin/pypy3"))
(bin-pypy3 (string-append out "/bin/pypy3"))
(shebang-match-python "#!.+/bin/python") (shebang-match-python "#!.+/bin/python")
(shebang-pypy3 (string-append "#!" bin-pypy3)) (shebang-pypy3 (string-append "#!" bin-pypy3))
(dist-dir "pypy/tool/release/pypy-dist")) (dist-dir "pypy/tool/release/pypy-dist"))
@ -888,7 +864,7 @@ (define-public pypy3
"distutils/tests" "distutils/tests"
"ctypes/test" "ctypes/test"
"unittest/test")) "unittest/test"))
;; Patch shebang referencing python2 ;; Patch shebang referencing python.
(substitute* '("lib-python/3/cgi.py" (substitute* '("lib-python/3/cgi.py"
"lib-python/3/encodings/rot_13.py") "lib-python/3/encodings/rot_13.py")
((shebang-match-python) shebang-pypy3)) ((shebang-match-python) shebang-pypy3))
@ -897,6 +873,26 @@ (define-public pypy3
"lib_pypy/_sha1.py") "lib_pypy/_sha1.py")
((shebang-match-python) shebang-pypy3)))) ((shebang-match-python) shebang-pypy3))))
(copy-recursively dist-dir out))))))) (copy-recursively dist-dir out)))))))
(native-inputs
(list gzip
nss-certs ; For ssl tests
pkg-config
python-2
python2-pycparser
tar)) ; Required for package.py
(inputs
(list bzip2
expat
gdbm
glibc
libffi
ncurses
openssl
sqlite
tcl
tk
xz
zlib))
(home-page "https://www.pypy.org/") (home-page "https://www.pypy.org/")
(synopsis "Python implementation with just-in-time compilation") (synopsis "Python implementation with just-in-time compilation")
(description "PyPy is a faster, alternative implementation of the Python (description "PyPy is a faster, alternative implementation of the Python
@ -910,3 +906,5 @@ (define-public pypy3
(license:non-copyleft (license:non-copyleft
"http://www.unicode.org/copyright.html"))))) "http://www.unicode.org/copyright.html")))))
(define-public pypy3
(deprecated-package "pypy3" pypy))