Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

add CMake build system support #240

Open
wants to merge 5 commits into
base: master
Choose a base branch
from

Conversation

feihong-gz
Copy link

No description provided.

Copy link
Contributor

@mrbean-bremen mrbean-bremen left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for this - this should actually be the default way to build Qt at least for Qt6.
It would also make sense to add workflows in the CI to build the latest Qt5 and Qt6 version, to be able to test this - for the time being probably parallel to the existing workflows using qmake.

CMakeLists.txt Outdated
endif()
# elseif(${QT_VERSION_MAJOR} VERSION_EQUAL 6)
else()
message(FATAL "No generated sources exist for Qt${QT_VERSION}")
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This does not handle the (actually preferred) case of self-generated wrappers in generated_cpp, as done in the qmake file. Especially this will not work for Qt6, unless I'm missing something.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm trying to build generator using CMake, and so far it's testing well.

extensions/PythonQt_QtAll/CMakeLists.txt Show resolved Hide resolved
@jamesobutler
Copy link

@jcfr This may be a PR of interest to you based on your previous work from 2019 to CMake’ify PythonQt as completed in https://github.com/commontk/PythonQt/blob/patched-9/CMakeLists.txt (though currently for Qt5 PythonQt only).

@mrbean-bremen
Copy link
Contributor

@feihong-gz - I forgot about this PR... what is the state here? Is this ready to merge?

It would really be helpful to add some CI builds using CMake - for example by adding it as an extra option to the existing builds.

Something like:

jobs:
  build:
    strategy:
      fail-fast: false
      matrix:
        os: ['ubuntu', 'windows']
        qt-version: [ '5.12.*', '5.15.*', '6.7.*' ]
        python-version: [ '3.12' ]
        build-tool: [qmake, cmake]  # new configuration
...

    - name: Build generator Ubuntu / qmake  # existing build
      shell: bash
      if: ${{ matrix.os == 'ubuntu' && matrix.build-tool == 'qmake' }} 
      run: |
        cd generator
        qmake -r generator.pro CONFIG+=ccache CONFIG+=release CONFIG-=debug_and_release CONFIG+=force_debug_info \
        CONFIG+=sanitizer CONFIG+=sanitize_undefined CONFIG+=sanitize_address
        make -j $(nproc)

    - name: Build generator Ubuntu / cmake  # new cmake build
      shell: bash
      if: ${{ matrix.os == 'ubuntu' && matrix.build-tool == 'cmake' }} 
      run: |
        cd generator
        cmake ...
...

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants