178 lines
		
	
	
	
		
			6.7 KiB
		
	
	
	
		
			Scheme
		
	
	
	
	
	
			
		
		
	
	
			178 lines
		
	
	
	
		
			6.7 KiB
		
	
	
	
		
			Scheme
		
	
	
	
	
	
| ;;; GNU Guix --- Functional package management for GNU
 | |
| ;;; Copyright © 2015, 2020 Efraim Flashner <efraim@flashner.co.il>
 | |
| ;;; Copyright © 2016 Leo Famulari <leo@famulari.name>
 | |
| ;;; Copyright © 2020 Marius Bakke <mbakke@fastmail.com>
 | |
| ;;; Copyright © 2020 Tanguy Le Carrour <tanguy@bioneland.org>
 | |
| ;;; Copyright © 2018, 2021 Maxim Cournoyer <maxim.cournoyer@gmail.com>
 | |
| ;;; Copyright © 2021 Tobias Geerinckx-Rice <me@tobias.gr>
 | |
| ;;; Copyright © 2021 Ricardo Wurmus <rekado@elephly.net>
 | |
| ;;;
 | |
| ;;; This file is part of GNU Guix.
 | |
| ;;;
 | |
| ;;; GNU Guix is free software; you can redistribute it and/or modify it
 | |
| ;;; under the terms of the GNU General Public License as published by
 | |
| ;;; the Free Software Foundation; either version 3 of the License, or (at
 | |
| ;;; your option) any later version.
 | |
| ;;;
 | |
| ;;; GNU Guix is distributed in the hope that it will be useful, but
 | |
| ;;; WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
| ;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
| ;;; GNU General Public License for more details.
 | |
| ;;;
 | |
| ;;; You should have received a copy of the GNU General Public License
 | |
| ;;; along with GNU Guix.  If not, see <http://www.gnu.org/licenses/>.
 | |
| 
 | |
| (define-module (gnu packages python-build)
 | |
|   #:use-module ((guix licenses) #:prefix license:)
 | |
|   #:use-module (guix build-system python)
 | |
|   #:use-module (guix download)
 | |
|   #:use-module (guix packages))
 | |
| 
 | |
| ;;; Commentary:
 | |
| ;;;
 | |
| ;;; Python packages to build... Python packages.  Since they are bound to be
 | |
| ;;; relied on by many, their dependencies should be kept minimal, and this
 | |
| ;;; module should not depend on other modules containing Python packages.
 | |
| ;;;
 | |
| ;;; Code:
 | |
| 
 | |
| (define-public python-wheel
 | |
|   (package
 | |
|     (name "python-wheel")
 | |
|     (version "0.36.2")
 | |
|     (source
 | |
|       (origin
 | |
|         (method url-fetch)
 | |
|         (uri (pypi-uri "wheel" version))
 | |
|         (sha256
 | |
|          (base32
 | |
|           "0pi4w0brz7a86ddk6pm8p6j0w6d7jgacgxm0c2dab3k5cb8yy7p1"))))
 | |
|     (build-system python-build-system)
 | |
|     (arguments
 | |
|      ;; FIXME: The test suite runs "python setup.py bdist_wheel", which in turn
 | |
|      ;; fails to find the newly-built bdist_wheel library, even though it is
 | |
|      ;; available on PYTHONPATH.  What search path is consulted by setup.py?
 | |
|      '(#:tests? #f))
 | |
|     (home-page "https://bitbucket.org/pypa/wheel/")
 | |
|     (synopsis "Format for built Python packages")
 | |
|     (description
 | |
|      "A wheel is a ZIP-format archive with a specially formatted filename and
 | |
| the @code{.whl} extension.  It is designed to contain all the files for a PEP
 | |
| 376 compatible install in a way that is very close to the on-disk format.  Many
 | |
| packages will be properly installed with only the @code{Unpack} step and the
 | |
| unpacked archive preserves enough information to @code{Spread} (copy data and
 | |
| scripts to their final locations) at any later time.  Wheel files can be
 | |
| installed with a newer @code{pip} or with wheel's own command line utility.")
 | |
|     (license license:expat)))
 | |
| 
 | |
| (define-public python2-wheel
 | |
|   (package-with-python2 python-wheel))
 | |
| 
 | |
| ;;; XXX: Not really at home, but this seems the best place to prevent circular
 | |
| ;;; module dependencies.
 | |
| (define-public python-toml
 | |
|   (package
 | |
|     (name "python-toml")
 | |
|     (version "0.10.2")
 | |
|     (source
 | |
|      (origin
 | |
|        (method url-fetch)
 | |
|        (uri (pypi-uri "toml" version))
 | |
|        (sha256
 | |
|         (base32 "13z6rff86bzdpl094x0vmfvls779931xj90dlbs9kpfm138s3gdk"))))
 | |
|     (build-system python-build-system)
 | |
|     (arguments
 | |
|      `(#:tests? #f))                     ;no tests suite in release
 | |
|     (home-page "https://github.com/uiri/toml")
 | |
|     (synopsis "Library for TOML")
 | |
|     (description
 | |
|      "@code{toml} is a library for parsing and creating Tom's Obvious, Minimal
 | |
| Language (TOML) configuration files.")
 | |
|     (license license:expat)))
 | |
| 
 | |
| (define-public python-pytoml
 | |
|   (package
 | |
|     (name "python-pytoml")
 | |
|     (version "0.1.21")
 | |
|     (source
 | |
|      (origin
 | |
|        (method url-fetch)
 | |
|        (uri (pypi-uri "pytoml" version))
 | |
|        (sha256
 | |
|         (base32
 | |
|          "1rv1byiw82k7mj6aprcrqi2vdabs801y97xhfnrz7kxds34ggv4f"))))
 | |
|     (build-system python-build-system)
 | |
|     (home-page "https://github.com/avakar/pytoml")
 | |
|     (synopsis "Parser for TOML")
 | |
|     (description "This package provides a Python parser for TOML-0.4.0.")
 | |
|     (license license:expat)))
 | |
| 
 | |
| (define-public python-pep517-bootstrap
 | |
|   (hidden-package
 | |
|    (package
 | |
|      (name "python-pep517-bootstrap")
 | |
|      (version "0.9.1")
 | |
|      (source
 | |
|       (origin
 | |
|         (method url-fetch)
 | |
|         (uri (pypi-uri "pep517" version))
 | |
|         (sha256
 | |
|          (base32
 | |
|           "0zqidxah03qpnp6zkg3zd1kmd5f79hhdsfmlc0cldaniy80qddxf"))))
 | |
|      (build-system python-build-system)
 | |
|      (arguments
 | |
|       `(#:tests? #f))                     ;to avoid circular dependencies
 | |
|      (propagated-inputs
 | |
|       `(("python-toml" ,python-toml)
 | |
|         ("python-wheel" ,python-wheel)))
 | |
|      (home-page "https://github.com/pypa/pep517")
 | |
|      (synopsis "Wrappers to build Python packages using PEP 517 hooks")
 | |
|      (description
 | |
|       "Wrappers to build Python packages using PEP 517 hooks.")
 | |
|      (license license:expat))))
 | |
| 
 | |
| ;;; The name 'python-pypa-build' is chosen rather than 'python-build' to avoid
 | |
| ;;; a name clash with python-build from (guix build-system python).
 | |
| (define-public python-pypa-build
 | |
|   (package
 | |
|     (name "python-pypa-build")
 | |
|     (version "0.1.0")
 | |
|     (source (origin
 | |
|               (method url-fetch)
 | |
|               (uri (pypi-uri "build" version))
 | |
|               (sha256
 | |
|                (base32
 | |
|                 "1d6m21lijwm04g50nwgsgj7x3vhblzw7jv05ah8psqgzk20bbch8"))))
 | |
|     (build-system python-build-system)
 | |
|     (arguments
 | |
|      `(#:tests? #f))                    ;to tests in the PyPI release
 | |
|     (propagated-inputs
 | |
|      `(("python-pep517", python-pep517-bootstrap)
 | |
|        ("python-toml" ,python-toml)))
 | |
|     (home-page "https://pypa-build.readthedocs.io/en/latest/")
 | |
|     (synopsis "Simple Python PEP 517 package builder")
 | |
|     (description "The @command{build} command invokes the PEP 517 hooks to
 | |
| build a distribution package.  It is a simple build tool and does not perform
 | |
| any dependency management.  It aims to keep dependencies to a minimum, in
 | |
| order to make bootstrapping easier.")
 | |
|     (license license:expat)))
 | |
| 
 | |
| (define-public python-poetry-core
 | |
|   (package
 | |
|     (name "python-poetry-core")
 | |
|     (version "1.0.3")
 | |
|     (source
 | |
|      (origin
 | |
|        (method url-fetch)
 | |
|        (uri (pypi-uri "poetry-core" version))
 | |
|        (sha256
 | |
|         (base32 "1ichii48zkywcnj8v3bcn9vk09v69jv6h65805w21hwz4hlcj593"))))
 | |
|     (build-system python-build-system)
 | |
|     (home-page "https://github.com/python-poetry/poetry-core")
 | |
|     (synopsis "Poetry PEP 517 build back-end")
 | |
|     (description
 | |
|      "The @code{poetry-core} module provides a PEP 517 build back-end
 | |
| implementation developed for Poetry.  This project is intended to be
 | |
| a light weight, fully compliant, self-contained package allowing PEP 517
 | |
| compatible build front-ends to build Poetry managed projects.")
 | |
|     (license license:expat)))
 |