Skip to content

Commit

Permalink
Fix CI and enable Python bindings for Qt6
Browse files Browse the repository at this point in the history
  • Loading branch information
dantti committed Nov 5, 2023
1 parent b264d03 commit 0d1e017
Show file tree
Hide file tree
Showing 2 changed files with 41 additions and 14 deletions.
49 changes: 36 additions & 13 deletions .github/workflows/build.yml
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@

name: CI

on:
push:
branches:
- master
Expand All @@ -28,30 +29,50 @@ jobs:
- Debug
- Release

qt:
- version: "5.15.2"
requested: "5.15"
- version: "6.3.2" # Qt 6.3 is not an LTS version, so '6.3.*' always resolves to '6.3.2'
requested: "6.3.*"
config:
- qt_version: "5.15"
- qt_version: "6.6.0"

commonCMakeArgs=["--warn-uninitialized",
"-Werror=dev",
"-DKDReports_TESTS=TRUE",
"-DKDReports_EXAMPLES=TRUE"
]
include:
- os: ubuntu-22.04
build_type: Release
config:
qt_version: "6.6.0"
apt_pgks:
- llvm
pip_pgks:
- shiboken6-generator==6.6.0 pyside6==6.6.0

steps:
- name: Install Qt with options and default aqtversion
uses: jurplel/install-qt-action@v3
with:
aqtversion: null # use whatever the default is
modules: ${{ matrix.qt.modules }}
version: ${{ matrix.qt.requested }}
modules: ${{ matrix.config.modules }}
version: ${{ matrix.config.qt_version }}
cache: true

- name: Checkout sources
uses: actions/checkout@v4

- name: Install dependencies on Ubuntu (${{ join(matrix.config.apt_pgks, ' ') }})
if: ${{ runner.os == 'Linux' && matrix.config.apt_pgks }}
run: |
sudo apt update -qq
echo ${{ join(matrix.config.apt_pgks, ' ') }} | xargs sudo apt install -y
- name: Install Python dependencies (${{ join(matrix.config.pip_pgks, ' ') }})
if: ${{ matrix.config.pip_pgks }}
run: echo ${{ join(matrix.config.pip_pgks, ' ') }} | xargs pip install

- name: Hackery due Shiboken hardcoded paths
if: ${{ matrix.config.pip_pgks }}
run: |
sudo mkdir -p /opt/rh/gcc-toolset-10/root/usr/bin/
sudo cp /usr/bin/g++-10 /opt/rh/gcc-toolset-10/root/usr/bin/c++
sudo mkdir -p /opt/rh/gcc-toolset-10/root/usr/lib/gcc/x86_64-linux-gnu/10/
sudo cp /usr/lib/gcc/x86_64-linux-gnu/10/cc1plus /opt/rh/gcc-toolset-10/root/usr/lib/gcc/x86_64-linux-gnu/10/
- name: Install ninja-build tool (must be after Qt due PATH changes)
uses: turtlesec-no/get-ninja@main

Expand All @@ -64,7 +85,9 @@ jobs:
-DCMAKE_BUILD_TYPE=${{ matrix.build_type }}
--warn-uninitialized
-Werror=dev
-DKDReports_QT6=${{ startsWith(matrix.qt.version, '6.') }}
-DKDReports_QT6=${{ startsWith(matrix.config.qt_version, '6.') }}
-DKDReports_PYTHON_BINDINGS=${{ matrix.config.pip_pgks }}
-DPython3_FIND_VIRTUALENV=ONLY
-DKDReports_TESTS=${{ matrix.build_type == 'Debug' }}
-DKDReports_EXAMPLES=${{ matrix.build_type == 'Debug' }}
-DKDReports_DOCS=${{ matrix.build_type == 'Debug' && runner.os == 'Linux' }}
Expand Down
6 changes: 5 additions & 1 deletion cmake/KDAB/modules/KDPySide6ModuleBuild.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -115,7 +115,11 @@ macro(
PROPERTY INCLUDE_DIRECTORIES
)
make_path(python_dir_include_dirs ${raw_python_dir_include_dirs})
set(shiboken_include_dirs "${shiboken_include_dirs}${PATH_SEP}${python_dir_include_dirs}")
# Maybe check if python_dir_include_dirs is empty?
# this causes ${shiboken_include_dirs} to have a trailing ':' (${PATH_SEP}) at the
# end making shiboken misbehaving
# https://bugreports.qt.io/browse/PYSIDE-2505
#set(shiboken_include_dirs "${shiboken_include_dirs}${PATH_SEP}${python_dir_include_dirs}")

set(shiboken_framework_include_dirs_option "")
if(CMAKE_HOST_APPLE)
Expand Down

0 comments on commit 0d1e017

Please sign in to comment.