Skip to main content

Packaging tool for PEP 518 projects with Setuptools backend.

Project description

Travis CI Status Documentation Status

Setl (pronounced like settle) is a simple way to work with PEP 518 projects with Setuptools as the backend.

The interface is strongly influenced by Flit.

Install

The recommended install method is pipx:

pipx install setl

Setl needs to be installed with Python 3.7 or later, but can be used to build projects using older Python with the --python option.

Quickstart for Setuptools Veterans

Aside from the usual Setuptools configurations, you need to create a file pyproject.toml beside setup.py, with the following content:

[build-system]
requires = ["setuptools>=43", "wheel"]

Command comparisons to Setuptools:

Setl

Setuptools approximation

setl develop

setup.py develop

setl build

setup.py egg_info build

setl dist

setup.py egg_info build sdist bdist_wheel

setl publish

setup.py egg_info build sdist bdist_wheel
twine upload

But Why?

The main difference is how build and runtime dependencies are installed.

Traditionally Setuptools projects use setup_requires, but that has various problems (e.g. fetch the dependencies as eggs) so pip discourages its usage, and advices using PEP 518 to specify build time dependencies instead. But Setuptools’s project management commands do not handle PEP 518 declarations, leaving the user to install those build dependencies manually before using setup.py. Setl commands mimic pip’s build setup before calling their setup.py counterparts, so the build environment stays up-to-date.

Similarly, setup.py develop installs runtime dependencies with easy_install, instead of pip. It therefore does not respect PEP 518 declarations in those dependencies, and may even fail if one of the dependencies does not support the “legacy mode” build process. setl develop works around this by pip install-ing runtime dependencies before calling setup.py develop --no-deps, so dependencies are installed in the modern format.

The rest are more about providing more useful defaults. It is easy to forget re-building egg-info when you modify metadata, so Setl tries to be helpful. Nowadays people almost always want to build both sdist and wheel, so Setl does it by default. The PyPA recommends against using setup.py upload, so Setl bundles it. Nothing rocket science.

Next Steps

  • Read the documentation for detailed command descriptions and inner workings.

  • View the source and help contribute to the project.

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

setl-0.9.0.tar.gz (15.3 kB view details)

Uploaded Source

Built Distribution

setl-0.9.0-py2.py3-none-any.whl (18.6 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file setl-0.9.0.tar.gz.

File metadata

  • Download URL: setl-0.9.0.tar.gz
  • Upload date:
  • Size: 15.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/42.0.2 requests-toolbelt/0.9.1 tqdm/4.41.0 CPython/3.8.1

File hashes

Hashes for setl-0.9.0.tar.gz
Algorithm Hash digest
SHA256 e29405d17b7873e5a22c942090db2bd3eaf16e841841630a75b9c29cf411a056
MD5 1df3b32311777a75b9496b31bedcec9e
BLAKE2b-256 67bb494d9eadbf5bf3fac20c2276674e7e8f408e9ebda2cedd9f88fc449a7de5

See more details on using hashes here.

Provenance

File details

Details for the file setl-0.9.0-py2.py3-none-any.whl.

File metadata

  • Download URL: setl-0.9.0-py2.py3-none-any.whl
  • Upload date:
  • Size: 18.6 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/42.0.2 requests-toolbelt/0.9.1 tqdm/4.41.0 CPython/3.8.1

File hashes

Hashes for setl-0.9.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 a62c5399508931d66e2a2ccde1d4d5fd43c99614cec92ebb785a87af25bdb345
MD5 4c26d6c4138f31225b3ca6c0ef6489a2
BLAKE2b-256 d39c7096ee59a13ec2e2960b817e4b0afbc61299e0dbe8b84ca67d38b5c76486

See more details on using hashes here.

Provenance

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