Getting Started on Linux ========================== Requirements ------------ * Qt package from `here`_ or a custom build of Qt (preferably Qt 5.12 or greater) * A Python interpreter (version Python 3.5+ or Python 2.7). You can either use the one provided by your OS, or get it from the `official website`_. * GCC * `CMake`_ version 3.1 or greater * Git version 2 or greater * `libclang`_ from your system or the prebuilt version from the ``Qt Downloads`` page is recommended. * ``virtualenv`` is strongly recommended, but optional. * ``sphinx`` package for the documentation (optional). * Depending on your linux distribution, the following dependencies might also be required: * ``libgl-dev``, * ``python-dev``, * ``python-distutils``, * and ``python-setuptools``. .. _here: https://qt.io/download .. _official website: https://www.python.org/downloads/ .. _CMake: https://cmake.org/download/ .. _libclang: http://download.qt.io/development_releases/prebuilt/libclang/ Building from source -------------------- Creating a virtual environment ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ ``virtualenv`` allows you to create a local, user-writeable copy of a python environment into which arbitrary modules can be installed and which can be removed after use:: virtualenv testenv source testenv/bin/activate pip install sphinx # optional: documentation pip install numpy PyOpenGL # optional: for examples will create and use a new virtual environment, which is indicated by the command prompt changing. Setting up CLANG ~~~~~~~~~~~~~~~~ If you don't have libclang already in your system, you can download from the Qt servers:: wget https://download.qt.io/development_releases/prebuilt/libclang/libclang-release_60-linux-Rhel7.2-gcc5.3-x86_64-clazy.7z Extract the files, and leave it on any desired path, and then set these two required environment variables:: 7z x libclang-release_60-linux-Rhel7.2-gcc5.3-x86_64-clazy.7z export CLANG_INSTALL_DIR=$PWD/libclang Getting PySide2 ~~~~~~~~~~~~~~~ Cloning the official repository can be done by:: git clone --recursive https://code.qt.io/pyside/pyside-setup Checking out the version that we want to build, e.g. 5.14:: cd pyside-setup && git checkout 5.14 .. note:: Keep in mind you need to use the same version as your Qt installation. Additionally, ``git checkout -b 5.14 --track origin/5.14`` could be a better option in case you want to work on it. Building PySide2 ~~~~~~~~~~~~~~~~ Check your Qt installation path, to specifically use that version of qmake to build PySide2. e.g. ``/opt/Qt/5.14.0/gcc_64/bin/qmake``. Build can take a few minutes, so it is recommended to use more than one CPU core:: python setup.py build --qmake=/opt/Qt/5.14.0/gcc_64/bin/qmake --build-tests --ignore-git --parallel=8 Installing PySide2 ~~~~~~~~~~~~~~~~~~ To install on the current directory, just run:: python setup.py install --qmake=/opt/Qt/5.14.0/gcc_64/bin/qmake --build-tests --ignore-git --parallel=8 Test installation ~~~~~~~~~~~~~~~~~ You can execute one of the examples to verify the process is properly working. Remember to properly set the environment variables for Qt and PySide2:: python examples/widgets/widgets/tetrix.py