Skip to content

chuckyblack/py2deb

 
 

Repository files navigation

py2deb: Python to Debian package converter

image

image

The Python package py2deb converts Python source distributions to Debian binary packages (the ones used for installation). It uses pip-accel to download, unpack and compile Python packages. Because of this py2deb is compatible with the command line interface of the pip install command. For example you can specify packages to convert as command line arguments but you can also use requirement files if you want.

During the conversion process dependencies are automatically taken into account and converted as well so you don't actually have to use requirement files including transitive dependencies. In fact you might prefer not explicitly listing your transitive dependencies in requirement files because py2deb will translate the version constraints of Python packages into Debian package relationships.

The py2deb package is currently tested on Python 2.6, 2.7, 3.4 and 3.5 (although Python 3.x support isn't being used extensively yet, so you may run into some sharp edges). For usage instructions please refer to the documentation hosted on Read The Docs.

local

Installation

The py2deb package is available on PyPI, so installation is very simple:

$ pip install py2deb

There are some system dependencies which you have to install as well:

$ sudo apt-get install dpkg-dev fakeroot

Optionally you can also install Lintian (which is not a hard dependency but more of a "nice to have"):

$ sudo apt-get install lintian

When Lintian is installed it will be run automatically to sanity check converted packages. This slows down the conversion process somewhat but can be very useful, especially when working on py2deb itself. Currently py2deb doesn't fail when Lintian reports errors, this is due to the unorthodox ways in which py2deb can be used. This may change in the future as py2deb becomes more mature.

Usage

There are two ways to use the py2deb package: As the command line program py2deb and as a Python API. For details about the Python API please refer to the API documentation hosted on Read the Docs. The command line interface is described below.

Command line

Usage: py2deb [OPTIONS] ...

Convert Python packages to Debian packages according to the given command line options (see below). The command line arguments are the same as accepted by the "pip install" command because py2deb invokes pip during the conversion process. This means you can name the package(s) to convert on the command line but you can also use "requirement files" if you prefer.

If you want to pass command line options to pip (e.g. because you want to use a custom index URL or a requirements file) then you will need to tell py2deb where the options for py2deb stop and the options for pip begin. In such cases you can use the following syntax:

$ py2deb -r /tmp -- -r requirements.txt

So the "--" marker separates the py2deb options from the pip options.

Supported options:

Future improvements

Some random ideas for possible improvements to py2deb (in no specific order):

  • Find a way to facilitate (explicit / opt-in) installation of system wide files (not related to Python per se) based on a Python distribution? This could significantly reduce the need for "wrapper packages" that basically just pull in packages converted by py2deb and drop a few configuration files into place.
  • Investigate the feasability of supporting conversion of binary wheels. Slowly but surely the Python community seems to be gravitating towards (binary) wheels and once gravity has shifted we don't want to be left in the dust! ;-)
  • Make it possible to "replace" Python requirements in a requirement set with a Debian package that's included in the official repositories (e.g. Pillow becomes python-imaging or python-pil). There are some hairy details involved here.
  • Dive into PEP-440 and see if there is a way to fully support it? Then this question on Reddit can finally get a satisfying answer :-).

Similar projects

There are several projects out there that share similarities with py2deb, for example I know of stdeb, dh-virtualenv and fpm. The documentation includes a fairly detailed comparison with each of these projects.

Contact

If you have questions, bug reports, suggestions, etc. please create an issue on the GitHub project page. The latest version of py2deb will always be available on GitHub. The internal API documentation is hosted on Read The Docs.

License

This software is licensed under the MIT license.

© 2016 Peter Odding, Arjan Verwer and Paylogic International.

About

Python to Debian package converter

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Python 96.3%
  • Makefile 2.0%
  • Shell 1.7%