.. toctree:: :hidden: self applications modules application-modules tools
This document aims to guide you through the process of porting your Python 2 RPM package to Python 3.
Note
If you struggle with the porting of your package and would like help or more information, please contact us at the python-devel mailing list (also accessible through a web interface) and we will try to help you and/or improve the guide accordingly.
If you've spotted any errors, have any suggestions or think some section(s) could be expanded, please create an Issue or a Pull request on our GitHub.
Table of Contents
First thing you need to figure out is if the software you're packaging is ready to be packaged for Python 3.
Look upstream and try to find out if the software is released with Python 3 support. First look at the front page of the project, Python compatibility is oftentimes listed there. There is also a good chance the project will have this information listed on PyPI. If not, look at release notes or the changelog history. You can also look at issues and pull requests.
However, the important thing to note is that the Python 3 support needs to be released, not just committed in the version control system (git, mercurial,...).
Before you start porting, it's imperative that you check that all the dependencies of your package are also ported to Python 3 in the distribution you are packaging for (Fedora, CentOS, RHEL or any other RPM-based distribution).
You may encounter a situation where your software is Python 3 ready upstream, but it uses some dependencies that are packaged only for Python 2 in your distribution. In that case try to communicate with the maintainer of the needed package and try to motivate and/or help them with porting of the package.
There are four distinct types of Python packages, each with different instructions for porting, so be mindful of which you chose.
In rare cases your package might not nicely fall into either of these categories. In that case use the relevant parts from multiple sections or contact us on the mailing list.
See: :doc:`applications`
If your package is being imported by third-party projects, but does not have any executables, you're dealing with a Python module.
See: :doc:`modules`
See: :doc:`application-modules`
See: :doc:`tools`