Giter VIP home page Giter VIP logo

wheel2deb's Introduction

wheel2deb: python wheel to debian package converter

Build Status Coverage Status Codacy Badge

wheel2deb basically takes a list of wheels as input and produces a list of debian binary CPython packages (those prefixed with python- or python3-).

asciicast

Quick Example

The following shows how to convert numpy and pytest, along with their dependencies into a list of debian packages:

# Download (and build if needed) pytest, numpy and their requirements
pip3 wheel pytest numpy
# Convert all wheels to debian source packages
wheel2deb --map attrs=attr
# Call dpkg-buildpackages for each source package
wheel2deb build
ls -l output/*.deb
# Install generated packages
dpkg -i output/*.deb
# Run pytest on numpy
python3 -c "import numpy; numpy.test()"

Project scope

  • Python 2.7 and 3
  • CPython only for now
  • support for non pure python wheels
  • support debian architectures all, armhf, amd64, i686
  • tested on jessie, stretch, buster so far, ubuntu should also work

Requirements

wheel2deb uses python3-apt to search for debian packages, dpkg-shlibdeps to calculate shared library dependencies and apt-file to search packages providing shared library dependencies. wheel2deb build requires the usual tools to build a debian package:

apt update
apt install python3-apt apt-file dpkg-dev fakeroot build-essential devscripts debhelper
apt-file update

If you want to cross build packages for ARM, you will also need to install binutils-arm-linux-gnueabihf.

Converting pure python wheels, don't actually requires apt-file and dpkg-dev.

Keep in mind that you should only convert wheels that have been built for your distribution and architecture. wheel2deb will not warn you about ABI compatibility issues.

Installation

wheel2deb is available from pypi:

pip install wheel2deb

Docker images for jessie, stretch and buster are also available from the docker hub:

docker run -ti -v $(pwd):/data wheel2deb:stretch

Features

  • guess debian package names from wheel names and search for them in the cache
  • search packages providing shared library dependencies for wheels with native code
  • handle entrypoints and scripts (those will be installed in /usr/bin with a proper shebang)
  • try to locate licence files and to generate a debian/copyright file

Options

Use wheel2deb --help and wheel2deb build --help to check all supported options

Option Description
-v Enable debug logs.
-x List of search paths where to look for python wheels. Defaults to current directory. Not recursive.
-o Output directory where debian source packages will be produced. Defaults to ./output
-i List of wheel names to convert. By default all found wheels are included.
--python-version cpython version on the target debian distribution. Defaults to platform version (example: 3.4).
--map list of string pairs to explicitely map python dist names to debian package names. For instance: "--map foo:bar attrs:attr" will tell wheel2deb to map foo to python-bar and attrs to python-attr.
--depends List of additional debian dependencies.
--epoch Debian package epoch. Defaults to 0.
--revision Debian package revision. Defaults to 1.
--ignore-entry-points Don't include the wheel entrypoints in the debian package.
--ignore-upstream-version Ignore version specifiers from wheel requirements. For instance, if foo requires bar>=3.0.0, using this option will produce a debian package simply depending on bar instead of "bar (>= 3.0.0)".

Bugs/Requests

Please use the GitHub issue tracker to submit bugs or request features.

License

Copyright Parkoview SA 2019.

Distributed under the terms of the MIT license, wheel2deb is free and open source software.

wheel2deb's People

Contributors

supersandro2000 avatar

Stargazers

 avatar

Watchers

 avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.