Skip to content

Commit

Permalink
Build: Added from source QT build
Browse files Browse the repository at this point in the history
- Allows to build QT from the same toolchain than the executable, and not rely on the system libraries.

 - This fixes incompatible linking symbols in case the user needs to compile with older versions of his compiler to access CUDA features.
  • Loading branch information
HamilcarR committed Sep 16, 2024
1 parent dddbbc8 commit 140afa9
Show file tree
Hide file tree
Showing 7 changed files with 91 additions and 23 deletions.
11 changes: 1 addition & 10 deletions .github/workflows/cmake-single-platform.yml
Original file line number Diff line number Diff line change
Expand Up @@ -19,15 +19,6 @@ jobs:
steps:
- uses: actions/checkout@v4

- name: Install Qt
uses: jurplel/install-qt-action@v4
with:
version: '6.3.*'
host: 'linux'
target: 'desktop'
arch: 'gcc_64'
install-deps : 'true'

- name: Install Axomae dependencies
run: |
cd ${{github.workspace}} && ./scripts/update_deps.sh
Expand All @@ -37,7 +28,7 @@ jobs:
sudo apt-get install -y libgl1-mesa-dev libglew-dev
- name: Configure CMake
run: cmake -B ${{github.workspace}}/../build -DCMAKE_BUILD_TYPE=${{env.BUILD_TYPE}} -DAXOMAE_BUILD_TESTS:BOOL=${{env.BUILD_TESTS}} -DAXOMAE_LUT_MEDIUMP:BOOL=ON
run: cmake -B ${{github.workspace}}/../build -DCMAKE_BUILD_TYPE=${{env.BUILD_TYPE}} -DAXOMAE_BUILD_TESTS:BOOL=${{env.BUILD_TESTS}} -DAXOMAE_LUT_MEDIUMP:BOOL=ON -DAXOMAE_FROMSOURCE_QT_BUILD=ON

- name: Build
run: cmake --build ${{github.workspace}}/../build --config ${{env.BUILD_TYPE}}
Expand Down
4 changes: 3 additions & 1 deletion .gitmodules
Original file line number Diff line number Diff line change
Expand Up @@ -64,17 +64,19 @@
path = vendor/SDL_image
url = https://github.com/libsdl-org/SDL_image
branch = SDL2
ignore = all
fetchRecurseSubmodules = true

[submodule "vendor/SDL"]
path = vendor/SDL
url = https://github.com/libsdl-org/SDL
branch = SDL2
ignore = all
fetchRecurseSubmodules = true

[submodule "vendor/qt"]
path = vendor/qt
url = https://code.qt.io/qt/qt5.git
branch = 6.7.2
branch = 6.8.0
ignore = all
fetchRecurseSubmodules = false
9 changes: 8 additions & 1 deletion CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -34,9 +34,16 @@ option(AXOMAE_LUT_HIGHP "Enable high precision when computing lookup tables." OF
option(AXOMAE_LUT_MEDIUMP "Enable medium precision when computing lookup tables." ON)
option(AXOMAE_LUT_LOWP "Enable low precision when computing lookup tables." OFF)
option(AXOMAE_BUILD_TESTS "Build unit tests." ON)

option(AXOMAE_FROMSOURCE_QT_BUILD "Build QT from source." ON)
#****************************************************************************************************
# Dependencies
if(AXOMAE_FROMSOURCE_QT_BUILD)
include(cmake/BuildQt6.cmake)
else()
find_package(Qt6 COMPONENTS Gui REQUIRED)
find_package(Qt6 COMPONENTS OpenGLWidgets REQUIRED)
find_package(Qt6 COMPONENTS Widgets REQUIRED)
endif()
include(cmake/FindDependencies.cmake)

if(NOT CUDAToolkit_FOUND)
Expand Down
6 changes: 6 additions & 0 deletions Documentation/Requirements.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
Ninja (only for building QT6 from source)
QT6
GCC (version depends on desired cuda version if gpgpu used)
Opengl
Glew
Cuda (if AXOMAE_USE_CUDA set to ON)
67 changes: 60 additions & 7 deletions cmake/BuildQt6.cmake
Original file line number Diff line number Diff line change
@@ -1,12 +1,65 @@

set(QT_BUILD_DIR ${CMAKE_CURRENT_BINARY_DIR}/qt)
set(QT_SOURCE_DIR ${CMAKE_CURRENT_SOURCE_DIR}/qt)
set(QT_BUILD_DIR ${CMAKE_CURRENT_BINARY_DIR}/vendor/qt)
set(QT_SOURCE_DIR ${CMAKE_CURRENT_SOURCE_DIR}/vendor/qt)
set(QTBASE_BUILD_DIR ${QT_BUILD_DIR}/qtbase)
set(QTBASE_SOURCE_DIR ${QT_SOURCE_DIR}/qtbase)
message(STATUS "Building QT from source in ${QT_BUILD_DIR}")

message(STATUS "Configuring QT6 core library...")
file(MAKE_DIRECTORY ${QTBASE_BUILD_DIR})
execute_process(COMMAND ${QTBASE_SOURCE_DIR}/configure --prefix ${QTBASE_BUILD_DIR}
WORKING_DIRECTORY ${QTBASE_BUILD_DIR}
message(STATUS "Building QT from source : ${QT_SOURCE_DIR}")
message(STATUS "Build directory is : ${QT_BUILD_DIR}")

message(STATUS "Initializing qt repository ...")

message(STATUS "Configuring qtbase...")
if(NOT EXISTS "${QT_BUILD_DIR}")
file(MAKE_DIRECTORY ${QT_BUILD_DIR})
endif()
execute_process(COMMAND bash ${QT_SOURCE_DIR}/configure
-submodules qtbase
-prefix ${QT_BUILD_DIR}

WORKING_DIRECTORY ${QT_BUILD_DIR}
ERROR_VARIABLE ERROR_MSG
)

message(STATUS ${ERROR_MSG})

message(STATUS "Building qtbase ...")
execute_process(COMMAND cmake --build . --parallel 4
WORKING_DIRECTORY ${QT_BUILD_DIR}
)

message(STATUS "Installing qtbase ...")
execute_process(COMMAND cmake --install .
WORKING_DIRECTORY ${QT_BUILD_DIR}
)


list(APPEND CMAKE_MODULE_PATH ${QT_BUILD_DIR}/lib/cmake)
list(APPEND CMAKE_PREFIX_PATH ${QT_BUILD_DIR}/lib/cmake)
message(STATUS "Setting up local qt build path ...")
find_package(Qt6
COMPONENTS Gui OpenGLWidgets Widgets
REQUIRED
PATHS ${CMAKE_PREFIX_PATH}
CONFIG
NO_DEFAULT_PATH
)

message(STATUS "Qt6_DIR: ${Qt6_DIR}")
message(STATUS "Qt6Gui_DIR: ${Qt6Gui_DIR}")
message(STATUS "Qt6OpenGLWidgets_DIR: ${Qt6OpenGLWidgets_DIR}")
message(STATUS "Qt6Widgets_DIR: ${Qt6Widgets_DIR}")














3 changes: 0 additions & 3 deletions cmake/FindDependencies.cmake
Original file line number Diff line number Diff line change
@@ -1,6 +1,3 @@
find_package(Qt6 COMPONENTS Gui REQUIRED)
find_package(Qt6 COMPONENTS OpenGLWidgets REQUIRED)
find_package(Qt6 COMPONENTS Widgets REQUIRED)
find_package(GLEW REQUIRED)
find_package(OpenGL REQUIRED)
find_package(CUDAToolkit)
Expand Down
14 changes: 13 additions & 1 deletion scripts/update_deps.sh
Original file line number Diff line number Diff line change
@@ -1,3 +1,15 @@
#!/bin/bash

git submodule update --init --force
ROOT="$(pwd)"
echo 'Downloading dependencies ...'
git submodule update --init --remote

if [ -d "$ROOT/vendor/qt" ]; then
cd $ROOT/vendor/qt || exit
else
echo 'Error: The QT directory has not been created by submodule update ...'
fi
echo 'Dependencies downloaded ...'

echo 'Setting up required QT submodules ...'
./init-repository.pl --force --module-subset=qtbase

0 comments on commit 140afa9

Please sign in to comment.