Skip to main content

Extension of setuptools to support all core metadata fields

Project description

pypi actions codecov womm

setuptools-ext

This is a PEP 517 Build backend interface supporting fields in the Core metadata specifications which are otherwise difficult to provide using existing tools. Specifically, it allows declaring those fields marked with an “—” in the rightmost column of the table below by specifying them in a [tool.setuptools-ext] section of pyproject.toml. The backend otherwise functions identically to setuptools.build_meta, and is in fact a drop-in replacement for the default setuptools build backend.

Setuptools lacks a way to specify some fields, despite their validity in Python package metadata according to the spec. PEP 621 – Storing project metadata in pyproject.toml appears to have punted on some of the fields too.

Field

setup.py keyword

pyproject.toml name

Name

name

name

Version

version

version

Dynamic (multiple use)

dynamic

Platform (multiple use)

platforms

Supported-Platform (multiple use)

Summary

description

description

Description

long_description

readme

Description-Content-Type

long_description_content_type

readme

Keywords

keywords

keywords

Home-page

url

[project.urls]

Download-URL

download_url

Author

author

authors

Author-email

author_email

authors

Maintainer

maintainer

maintainers

Maintainer-email

maintainer_email

maintainers

License

license / license_files

license

Classifier (multiple use)

classifiers

classifiers

Requires-Dist (multiple use)

install_requires

dependencies

Requires-Python

python_requires

requires-python

Requires-External (multiple use)

Project-URL (multiple-use)

project_urls

[project.urls]

Provides-Extra (multiple use)

extras_require

[project.optional-dependencies]

Provides-Dist (multiple use)

Obsoletes-Dist (multiple use)

Reference links for the info above:

Usage

To offer a simple example, if you want to add a Supported-Platform and the Requires-External field three times, producing these lines in the .dist-info/METADATA file:

Supported-Platform: RedHat 8.3
Requires-External: C
Requires-External: libpng (>=1.5)
Requires-External: make; sys_platform != "win32"

You would configure the tool like this in pyproject.toml, specifying a build dependency on setuptools-ext and then adding the fields in a [tool.setuptools-ext] section:

[build-system]
requires = ["setuptools-ext"]
build-backend = "setuptools_ext"

...

[tool.setuptools-ext]
supported-platform = [
    "RedHat 8.3",
]
requires-external = [
    "C",
    "libpng (>=1.5)",
    'make; sys_platform != "win32"'
]

The metadata fields may then be consumed by automated tooling for building RPM packages with system dependencies, for example.

Note: This package does not add new keyword arguments to setup.py (that’s out of scope for a PEP 517 build backend).

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

setuptools-ext-0.4.tar.gz (5.6 kB view details)

Uploaded Source

Built Distribution

setuptools_ext-0.4-py2.py3-none-any.whl (5.9 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file setuptools-ext-0.4.tar.gz.

File metadata

  • Download URL: setuptools-ext-0.4.tar.gz
  • Upload date:
  • Size: 5.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.0 CPython/3.10.2

File hashes

Hashes for setuptools-ext-0.4.tar.gz
Algorithm Hash digest
SHA256 87ec568022de206e9337c59758491aecefe40dbded4fbab91bf69ca8194de364
MD5 7fda7259c1af468ae28d94b0a9b46f80
BLAKE2b-256 77c089315c6630b118a2904b8c7de293d88b4145b78faa68451a0dbdbbfbd146

See more details on using hashes here.

File details

Details for the file setuptools_ext-0.4-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for setuptools_ext-0.4-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 d474ca785fc67a54f1f814027f445d7823b6c867774b9419447b0eb0f6558ac8
MD5 8dded692ffa01e4d6a6c7d811f10fbe3
BLAKE2b-256 71ee6825c18c2ec06ed39b8392eceb0412a5e47ab7457a40ac2bb765c23c7f43

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page