sigstore-python VS cibuildwheel

Compare sigstore-python vs cibuildwheel and see what are their differences.

InfluxDB - Power Real-Time Data Analytics at Scale
Get real-time insights from all types of time series data with InfluxDB. Ingest, query, and analyze billions of data points in real-time with unbounded cardinality.
www.influxdata.com
featured
SaaSHub - Software Alternatives and Reviews
SaaSHub helps you find the best software and product alternatives
www.saashub.com
featured
sigstore-python cibuildwheel
4 8
210 1,726
0.5% 0.9%
9.3 9.3
7 days ago 3 days ago
Python Python
GNU General Public License v3.0 or later GNU General Public License v3.0 or later
The number of mentions indicates the total number of mentions that we've tracked plus the number of user suggested alternatives.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.

sigstore-python

Posts with mentions or reviews of sigstore-python. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-01-15.
  • How to improve Python packaging, or why 14 tools are at least 12 too many
    9 projects | news.ycombinator.com | 15 Jan 2023
    You could use `pip-compile` if you want full pinning. That's what we do on another project -- we use GitHub Actions with `pip-compile` to provide a fully frozen copy of the dependency tree for users who'd like that[1].

    In the context of `pip-audit`, that makes a little less sense: most of our dependencies are semantically versioned, and we'd rather users receive patches and fixes to our subdependencies automatically, rather than having to wait for us to release a corresponding fix version. Similarly, we expect users to install `pip-audit` into pre-existing virtual environments, meaning that excessive pinning will produce overly conservative dependency conflict errors.

    [1]: https://github.com/sigstore/sigstore-python/tree/main/instal...

  • Use `Python -m Pip`
    10 projects | news.ycombinator.com | 19 Jul 2022
    The conflicting advice is a serious problem.

    I hope you'll forgive me for adding one additional piece of advice: for many Python packages, the only packaging metadata you need is `pyproject.toml`. You don't even need `setup.py` anymore, so long as you're using a build backend that supports editable installs with `pyproject.toml`.

    Here's an example of a Python package that does everything in `pyproject.toml`[1]. You should be able to copy that into any of your projects, edit it to match your metadata, and everything will work exactly as if you have a `setup.cfg` or `setup.py`.

    [1]: https://github.com/sigstore/sigstore-python

  • Bundling binary tools in Python wheels
    6 projects | news.ycombinator.com | 17 Jun 2022
    You're right, both the infrastructure and metadata for cryptographic signatures on Python packages (both wheels and sdists) isn't quite there yet.

    At the moment, we're working towards the "e2e" scheme you've described by adding support for Sigstore[1] certificates and signatures, which will allow any number of identities (including email addresses and individual GitHub release workflows) to sign for packages. The integrity/availability of those signing artifacts will in turn be enforced through TUF, like you mentioned.

    You can follow some of the related Sigstore-in-Python work here[2], and the ongoing Warehouse (PyPI) TUF work here[3]. We're also working on adding OpenID Connect token consumption[4] to Warehouse itself, meaning that you'll be able to bootstrap from a trusted GitHub workflow to a PyPI release token without needing to share any secrets.

    [1]: https://www.sigstore.dev/

    [2]: https://github.com/sigstore/sigstore-python

    [3]: https://github.com/pypa/warehouse/pull/10870

    [4]: https://github.com/pypa/warehouse/pull/11272

  • Project sigstore (free software signing service) just released a library to sign and verify python packages
    2 projects | /r/Python | 28 Apr 2022

cibuildwheel

Posts with mentions or reviews of cibuildwheel. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-10-19.
  • Balm in GILead: Fast string construction for CPython extensions
    1 project | news.ycombinator.com | 17 Dec 2023
    It doesn't work with any version of the public API, Limited, Stable, or Unstable, because this is not a part of the API. It's more of an application of [Hyrum's Law](https://www.hyrumslaw.com/).

    That said, assuming the structures themselves exist on the versions of Python you're targeting in a format compatible with whatever hacking you're doing on them, it's very easy to compile for lots of Python versions using [cibuildwheel](https://github.com/pypa/cibuildwheel) and the rest of the PyPA ecosystem.

    I don't think the Limited API is very useful, as a practical matter for the common distribution methods you need the wheel to be built with the target Python version.

  • Rip ā€“ Rust crate to resolve and install Python packages
    4 projects | news.ycombinator.com | 19 Oct 2023
    pypa/cibuildwheel: https://github.com/pypa/cibuildwheel :

    > Example setup: To build manylinux, musllinux, macOS, and Windows wheels on GitHub Actions, you could use this .github/workflows/wheels.yml

  • Bundling binary tools in Python wheels
    6 projects | news.ycombinator.com | 17 Jun 2022
    > size of wheels you can upload is constrained by PyPi

    I feel PyPi is pretty generous with their limits. You can even request more once you hit the ceiling, i think itā€™s around 60MB [1]. There are some wheels that are crazy large, tensorflow-gpu [2] are around 500MB each. I think thereā€™s discussions out there to try and find ways of alleviating this problem on PyPi.

    > difficult to support multiple versions across multiple operating systems, unless you provide a source distribution, which is thenā€¦

    This can be a problem but Iā€™ve found that recently the problem has improved quite a lot. You can create manylinux wheels for both x86, x64, and arm64 which cover pretty a lot of the Linux distributions using glibc. A musllinux tag was recently added to cover musl based distributions like Alpine. MacOS wheels support both x64, arm64, and can even be a universal2 wheel. Windows is still purely x86 or x64 for now but Iā€™ve seen some people work on arm64 support support in CPython and once thatā€™s in Iā€™m sure PyPi wonā€™t be too far around. There are also some great tools like cibuildwheel [3] that make building and testing these wheels pretty simple.

    > Still a nightmare on Windows

    Iā€™m actually curious what is a nightmare about Windows. I found that Windows is probably the easiest of all the platforms to build and upload wheels for. You arenā€™t limited to a tiny subset of system libs, like you are on Linux, and building them is mostly the same process. Probably the hardest thing is ensuring you have tue correct vs build kit installed but thatā€™s not insurmountable.

    [1] https://pypi.org/help/#file-size-limit

    [2] https://pypi.org/project/tensorflow-gpu/#files

    [3] https://github.com/pypa/cibuildwheel

  • cibuildwheel added support for building wheels on CPython 3.11
    1 project | /r/Python | 30 May 2022
  • Using GitHub Action to Build Python Wheel Package for Dynamsoft C++ Barcode SDK
    3 projects | dev.to | 26 May 2022
    Click set up a workflow yourself to create a custom workflow. We can refer to the examples provided by cibuildwheel.
  • Cibuildwheel: Build Python wheels for all the platforms on CI
    1 project | news.ycombinator.com | 9 Mar 2022
  • šŸŽ” cibuildwheel: Build Python wheels for 55 different platform/CPU/ABI combinations with minimal configuration
    2 projects | /r/Python | 1 Feb 2022

What are some alternatives?

When comparing sigstore-python and cibuildwheel you can also consider the following projects:

sampleproject - A sample project that exists for PyPUG's "Tutorial on Packaging and Distributing Projects"

tox - Command line driven CI frontend and development task automation tool.

publishing-python-packages - Examples and exercises for Publishing Python Packages from Manning Books šŸ šŸ“¦ ā¬†ļø

twisted-iocpsupport - `twisted-iocpsupport` is an extension module for the Twisted `iocp` reactor to use the Windows I/O Completion Ports (IOCP) networking API. You should not need to install it directly or interact with its API; it is a dependency of Twisted on Windows platforms.

pigar - :coffee: A tool to generate requirements.txt for Python project, and more than that. (IT IS NOT A PACKAGE MANAGEMENT TOOL)

releasezri - Meaningful and minimalist release notes for developers

Nuitka - Nuitka is a Python compiler written in Python. It's fully compatible with Python 2.6, 2.7, 3.4, 3.5, 3.6, 3.7, 3.8, 3.9, 3.10, and 3.11. You feed it your Python app, it does a lot of clever things, and spits out an executable or extension module.

twine - Utilities for interacting with PyPI

auditwheel - Auditing and relabeling cross-distribution Linux wheels.

easierlog - The easy way to inspect variables in Python.

pip-audit - Audits Python environments, requirements files and dependency trees for known security vulnerabilities, and can automatically fix them

rattler - Rust crates to work with the Conda ecosystem.