ci: Improve/Fix MacOS and Ubuntu builds
Builds on Ubuntu incorrectly used gcc instead of g++ for C++ building, resulting in files that should never have worked. Switching this to g++ should drastically improve the stability of StreamFX on Linux. Also on MacOS we use Homebrew to install the remaining tools, but failed to correctly install a specific version of it. As Homebrew only installs the latest version of a package to the global search path, this adjustment should fix the issue with clang-format. Finally since I was already at it, I added clang-tidy integration and made the clang integration global. This way it does not need to be called on a per-project basis any more.
This commit is contained in:
		
							parent
							
								
									2871b9ccef
								
							
						
					
					
						commit
						980c15efa6
					
				|  | @ -83,7 +83,67 @@ jobs: | ||||||
|         submodules: recursive |         submodules: recursive | ||||||
|         fetch-depth: 0 |         fetch-depth: 0 | ||||||
| 
 | 
 | ||||||
|     - name: "Gather Information" |     - name: "Install Build Tools (Ubuntu)" | ||||||
|  |       if: startsWith( matrix.runner, 'ubuntu' ) | ||||||
|  |       shell: bash | ||||||
|  |       run: | | ||||||
|  |         sudo apt-get -qq update | ||||||
|  |         sudo apt-get purge libjpeg9-dev:amd64 libjpeg8-dev:amd64 libjpeg-turbo8-dev:amd64 | ||||||
|  |         sudo apt-get install \ | ||||||
|  |           build-essential \ | ||||||
|  |           checkinstall \ | ||||||
|  |           pkg-config \ | ||||||
|  |           cmake \ | ||||||
|  |           ninja-build \ | ||||||
|  |           git \ | ||||||
|  |           gcc-10 g++10 | ||||||
|  |         sudo update-alternatives --install /usr/bin/gcc gcc /usr/bin/gcc-10 800 --slave /usr/bin/g++ g++ /usr/bin/g++-10 | ||||||
|  | 
 | ||||||
|  |     - name: "Install LLVM/Clang (Windows)" | ||||||
|  |       if: startsWith( matrix.runner, 'windows' ) | ||||||
|  |       run: | | ||||||
|  |         curl "-kL" "https://github.com/llvm/llvm-project/releases/download/llvmorg-14.0.4/LLVM-14.0.4-win64.exe" "-f" "--retry" "5" "-o" "llvm.exe" | ||||||
|  |         7z x -y -o"C:\Program Files\LLVM" llvm.exe "bin" "include" "lib" "libexec" "share" "Uninstall.exe" | ||||||
|  |         echo "CLANG_PATH=\"C:\\Program Files\\LLVM\\bin\"" >> "${GITHUB_ENV}" | ||||||
|  |     - name: "Install LLVM/Clang (Ubuntu)" | ||||||
|  |       if: startsWith( matrix.runner, 'ubuntu' ) | ||||||
|  |       shell: bash | ||||||
|  |       run: | | ||||||
|  |         curl -jLo /tmp/llvm.sh "https://apt.llvm.org/llvm.sh" | ||||||
|  |         chmod +x /tmp/llvm.sh | ||||||
|  |         sudo /tmp/llvm.sh 14 all | ||||||
|  |         sudo update-alternatives --install /usr/bin/clang clang /usr/bin/clang-14 800 | ||||||
|  |         sudo update-alternatives --install /usr/bin/clangd clangd /usr/bin/clangd-14 800 | ||||||
|  |         sudo update-alternatives --install /usr/bin/clang++ clang++ /usr/bin/clang++-14 800 | ||||||
|  |         sudo update-alternatives --install /usr/bin/lld lld /usr/bin/lld-14 800 | ||||||
|  |         sudo update-alternatives --install /usr/bin/lldb lldb /usr/bin/lldb-14 800 | ||||||
|  |         sudo update-alternatives --install /usr/bin/clang-format clang-format /usr/bin/clang-format-14 800 | ||||||
|  |         sudo update-alternatives --install /usr/bin/clang-tidy clang-tidy /usr/bin/clang-tidy-14 800 | ||||||
|  |         echo "CLANG_PATH=/usr/bin" >> "${GITHUB_ENV}" | ||||||
|  |     - name: "Install LLVM/Clang (MacOS)" | ||||||
|  |       if: startsWith( matrix.runner, 'macos' ) | ||||||
|  |       shell: bash | ||||||
|  |       run: | | ||||||
|  |         brew install llvm@14 | ||||||
|  |         LLVM_LOC=$(brew --prefix llvm@14) | ||||||
|  |         echo "CLANG_PATH=${LLVM_LOC}/bin/" >> "${GITHUB_ENV}" | ||||||
|  | 
 | ||||||
|  |     - name: "Install InnoSetup (Windows)" | ||||||
|  |       if: startsWith( matrix.runner, 'windows' ) | ||||||
|  |       run: | | ||||||
|  |         curl "-kL" "https://cdn.xaymar.com/ci/innosetup-6.2.1.exe" "-f" "--retry" "5" "-o" "inno.exe" | ||||||
|  |         .\inno.exe /VERYSILENT /SP- /SUPPRESSMSGBOXES /NORESTART | ||||||
|  | 
 | ||||||
|  |     - name: 'Install Packages (MacOS)' | ||||||
|  |       if: startsWith( matrix.runner, 'macos' ) | ||||||
|  |       shell: bash | ||||||
|  |       run: | | ||||||
|  |         curl -kL https://cdn.xaymar.com/ci/Packages-1.2.10.dmg -f --retry 5 -o "Packages.dmg" | ||||||
|  |         sudo hdiutil attach ./Packages.dmg | ||||||
|  |         pushd /Volumes/Packages* | ||||||
|  |         sudo installer -pkg ./Install\ Packages.pkg -target / | ||||||
|  | 
 | ||||||
|  |     - name: "Setup build Tools and gather Information" | ||||||
|       id: info |       id: info | ||||||
|       shell: bash |       shell: bash | ||||||
|       run: | |       run: | | ||||||
|  | @ -118,64 +178,18 @@ jobs: | ||||||
|           echo "cmake_generator_platform=-A \"${{ matrix.CMAKE_GENERATOR_PLATFORM }}\"" >> $GITHUB_ENV |           echo "cmake_generator_platform=-A \"${{ matrix.CMAKE_GENERATOR_PLATFORM }}\"" >> $GITHUB_ENV | ||||||
|         fi |         fi | ||||||
| 
 | 
 | ||||||
|     - name: "Dependencies: Windows" |         # Compiler Setup | ||||||
|       if: startsWith( matrix.runner, 'windows' ) |         if [[ "${{ matrix.runner }}" = ubuntu* ]]; then | ||||||
|       run: | |  | ||||||
|         curl "-kL" "https://github.com/llvm/llvm-project/releases/download/llvmorg-14.0.4/LLVM-14.0.4-win64.exe" "-f" "--retry" "5" "-o" "llvm.exe" |  | ||||||
|         7z x -y -o"C:\Program Files\LLVM" llvm.exe "bin" "include" "lib" "libexec" "share" "Uninstall.exe" |  | ||||||
|         echo "CLANG_PATH=\"C:\\Program Files\\LLVM\\bin\"" >> "${GITHUB_ENV}" |  | ||||||
|         curl "-kL" "https://cdn.xaymar.com/ci/innosetup-6.2.1.exe" "-f" "--retry" "5" "-o" "inno.exe" |  | ||||||
|         .\inno.exe /VERYSILENT /SP- /SUPPRESSMSGBOXES /NORESTART |  | ||||||
| 
 |  | ||||||
|     - name: "Dependencies: Linux" |  | ||||||
|       if: startsWith( matrix.runner, 'ubuntu' ) |  | ||||||
|       shell: bash |  | ||||||
|       run: | |  | ||||||
|         sudo apt-get -qq update |  | ||||||
|         sudo apt-get purge libjpeg9-dev:amd64 libjpeg8-dev:amd64 libjpeg-turbo8-dev:amd64 |  | ||||||
|         sudo apt-get install \ |  | ||||||
|           build-essential \ |  | ||||||
|           checkinstall \ |  | ||||||
|           pkg-config \ |  | ||||||
|           cmake \ |  | ||||||
|           ninja-build \ |  | ||||||
|           git |  | ||||||
| 
 |  | ||||||
|         # clang-format, clang-tidy |  | ||||||
|         curl -jLo /tmp/llvm.sh "https://apt.llvm.org/llvm.sh" |  | ||||||
|         chmod +x /tmp/llvm.sh |  | ||||||
|         sudo /tmp/llvm.sh 14 all |  | ||||||
|         sudo update-alternatives --install /usr/bin/clang-format clang-format /usr/bin/clang-format-14 800 |  | ||||||
|         sudo update-alternatives --install /usr/bin/clang-tidy clang-tidy /usr/bin/clang-tidy-14 800 |  | ||||||
|         echo "CLANG_PATH=/usr/bin" >> "${GITHUB_ENV}" |  | ||||||
| 
 |  | ||||||
|         # Compiler |  | ||||||
|           if [[ "${{ matrix.generator }}" = "GCC" ]]; then |           if [[ "${{ matrix.generator }}" = "GCC" ]]; then | ||||||
|           sudo apt-get install gcc-10 g++10 |  | ||||||
|           sudo update-alternatives --install /usr/bin/gcc gcc /usr/bin/gcc-10 800 --slave /usr/bin/g++ g++ /usr/bin/g++-10 |  | ||||||
|             echo "CC=gcc-10" >> "${GITHUB_ENV}" |             echo "CC=gcc-10" >> "${GITHUB_ENV}" | ||||||
|           echo "CXX=gcc-10" >> "${GITHUB_ENV}" |             echo "CXX=g++-10" >> "${GITHUB_ENV}" | ||||||
|             echo "LD=ld" >> "${GITHUB_ENV}" |             echo "LD=ld" >> "${GITHUB_ENV}" | ||||||
|           elif [[ "${{ matrix.generator }}" = "Clang" ]]; then |           elif [[ "${{ matrix.generator }}" = "Clang" ]]; then | ||||||
|           sudo update-alternatives --install /usr/bin/clang clang /usr/bin/clang-14 800 |  | ||||||
|           sudo update-alternatives --install /usr/bin/clangd clangd /usr/bin/clangd-14 800 |  | ||||||
|           sudo update-alternatives --install /usr/bin/clang++ clang++ /usr/bin/clang++-14 800 |  | ||||||
|           sudo update-alternatives --install /usr/bin/lld lld /usr/bin/lld-14 800 |  | ||||||
|           sudo update-alternatives --install /usr/bin/lldb lldb /usr/bin/lldb-14 800 |  | ||||||
|             echo "CC=clang-14" >> "${GITHUB_ENV}" |             echo "CC=clang-14" >> "${GITHUB_ENV}" | ||||||
|             echo "CXX=clang++-14" >> "${GITHUB_ENV}" |             echo "CXX=clang++-14" >> "${GITHUB_ENV}" | ||||||
|             echo "LD=lld" >> "${GITHUB_ENV}" |             echo "LD=lld" >> "${GITHUB_ENV}" | ||||||
|           fi |           fi | ||||||
| 
 |         fi | ||||||
|     - name: 'Dependencies: MacOS' |  | ||||||
|       if: startsWith( matrix.runner, 'macos' ) |  | ||||||
|       shell: bash |  | ||||||
|       run: | |  | ||||||
|         curl -kL https://cdn.xaymar.com/ci/Packages-1.2.10.dmg -f --retry 5 -o "Packages.dmg" |  | ||||||
|         sudo hdiutil attach ./Packages.dmg |  | ||||||
|         pushd /Volumes/Packages* |  | ||||||
|         sudo installer -pkg ./Install\ Packages.pkg -target / |  | ||||||
|         echo "CLANG_PATH=$(brew --prefix llvm@14)/bin/" >> "${GITHUB_ENV}" |  | ||||||
| 
 | 
 | ||||||
|     - name: "Dependency: Qt (Cache)" |     - name: "Dependency: Qt (Cache)" | ||||||
|       id: qt-cache |       id: qt-cache | ||||||
|  | @ -263,6 +277,9 @@ jobs: | ||||||
|           ${{ env.cmake_generator }} \ |           ${{ env.cmake_generator }} \ | ||||||
|           ${{ env.cmake_generator_toolset }} \ |           ${{ env.cmake_generator_toolset }} \ | ||||||
|           ${{ env.cmake_generator_platform }} \ |           ${{ env.cmake_generator_platform }} \ | ||||||
|  |           -DCMAKE_C_COMPILER="${{ env.CC }}" \ | ||||||
|  |           -DCMAKE_CXX_COMPILER="${{ env.CXX }}" \ | ||||||
|  |           -DCMAKE_LINKER="${{ env.LD }}" \ | ||||||
|           -DCMAKE_OSX_ARCHITECTURES="${{ matrix.CMAKE_OSX_ARCHITECTURES }}" \ |           -DCMAKE_OSX_ARCHITECTURES="${{ matrix.CMAKE_OSX_ARCHITECTURES }}" \ | ||||||
|           -DCMAKE_OSX_DEPLOYMENT_TARGET="${{ matrix.CMAKE_OSX_DEPLOYMENT_TARGET }}" \ |           -DCMAKE_OSX_DEPLOYMENT_TARGET="${{ matrix.CMAKE_OSX_DEPLOYMENT_TARGET }}" \ | ||||||
|           -DCMAKE_SYSTEM_VERSION="${{ matrix.CMAKE_SYSTEM_VERSION }}" \ |           -DCMAKE_SYSTEM_VERSION="${{ matrix.CMAKE_SYSTEM_VERSION }}" \ | ||||||
|  | @ -293,6 +310,9 @@ jobs: | ||||||
|           ${{ env.cmake_generator }} \ |           ${{ env.cmake_generator }} \ | ||||||
|           ${{ env.cmake_generator_toolset }} \ |           ${{ env.cmake_generator_toolset }} \ | ||||||
|           ${{ env.cmake_generator_platform }} \ |           ${{ env.cmake_generator_platform }} \ | ||||||
|  |           -DCMAKE_C_COMPILER="${{ env.CC }}" \ | ||||||
|  |           -DCMAKE_CXX_COMPILER="${{ env.CXX }}" \ | ||||||
|  |           -DCMAKE_LINKER="${{ env.LD }}" \ | ||||||
|           -DCMAKE_OSX_ARCHITECTURES="${{ matrix.CMAKE_OSX_ARCHITECTURES }}" \ |           -DCMAKE_OSX_ARCHITECTURES="${{ matrix.CMAKE_OSX_ARCHITECTURES }}" \ | ||||||
|           -DCMAKE_OSX_DEPLOYMENT_TARGET="${{ matrix.CMAKE_OSX_DEPLOYMENT_TARGET }}" \ |           -DCMAKE_OSX_DEPLOYMENT_TARGET="${{ matrix.CMAKE_OSX_DEPLOYMENT_TARGET }}" \ | ||||||
|           -DCMAKE_SYSTEM_VERSION="${{ matrix.CMAKE_SYSTEM_VERSION }}" \ |           -DCMAKE_SYSTEM_VERSION="${{ matrix.CMAKE_SYSTEM_VERSION }}" \ | ||||||
|  | @ -313,7 +333,6 @@ jobs: | ||||||
|         elif [[ "${{ matrix.runner }}" = macos* ]]; then |         elif [[ "${{ matrix.runner }}" = macos* ]]; then | ||||||
|           cmake --build "build/debug" --config ${{ env.CMAKE_BUILD_TYPE }} --target install |           cmake --build "build/debug" --config ${{ env.CMAKE_BUILD_TYPE }} --target install | ||||||
|         fi |         fi | ||||||
| 
 |  | ||||||
|     - name: "Configure & Build (Release)" |     - name: "Configure & Build (Release)" | ||||||
|       shell: bash |       shell: bash | ||||||
|       env: |       env: | ||||||
|  | @ -325,6 +344,9 @@ jobs: | ||||||
|           ${{ env.cmake_generator }} \ |           ${{ env.cmake_generator }} \ | ||||||
|           ${{ env.cmake_generator_toolset }} \ |           ${{ env.cmake_generator_toolset }} \ | ||||||
|           ${{ env.cmake_generator_platform }} \ |           ${{ env.cmake_generator_platform }} \ | ||||||
|  |           -DCMAKE_C_COMPILER="${{ env.CC }}" \ | ||||||
|  |           -DCMAKE_CXX_COMPILER="${{ env.CXX }}" \ | ||||||
|  |           -DCMAKE_LINKER="${{ env.LD }}" \ | ||||||
|           -DCMAKE_OSX_ARCHITECTURES="${{ matrix.CMAKE_OSX_ARCHITECTURES }}" \ |           -DCMAKE_OSX_ARCHITECTURES="${{ matrix.CMAKE_OSX_ARCHITECTURES }}" \ | ||||||
|           -DCMAKE_OSX_DEPLOYMENT_TARGET="${{ matrix.CMAKE_OSX_DEPLOYMENT_TARGET }}" \ |           -DCMAKE_OSX_DEPLOYMENT_TARGET="${{ matrix.CMAKE_OSX_DEPLOYMENT_TARGET }}" \ | ||||||
|           -DCMAKE_SYSTEM_VERSION="${{ matrix.CMAKE_SYSTEM_VERSION }}" \ |           -DCMAKE_SYSTEM_VERSION="${{ matrix.CMAKE_SYSTEM_VERSION }}" \ | ||||||
|  | @ -346,30 +368,19 @@ jobs: | ||||||
|           cmake --build "build/release" --config ${{ env.CMAKE_BUILD_TYPE }} --target install |           cmake --build "build/release" --config ${{ env.CMAKE_BUILD_TYPE }} --target install | ||||||
|         fi |         fi | ||||||
| 
 | 
 | ||||||
|     - name: "Validate Formatting" |     - name: "Packages" | ||||||
|       shell: bash |  | ||||||
|       run: | |  | ||||||
|         cmake --build "${{ github.workspace }}/build/debug" --config Debug --target StreamFX_clang-format |  | ||||||
|         cmake --build "${{ github.workspace }}/build/release" --config RelWithDebInfo --target StreamFX_clang-format |  | ||||||
|         git --no-pager diff --patch --minimal HEAD -- |  | ||||||
|         git update-index --refresh |  | ||||||
|         git diff-index --quiet HEAD -- |  | ||||||
| 
 |  | ||||||
|     - name: "Package: Archives" |  | ||||||
|       shell: bash |       shell: bash | ||||||
|       run: | |       run: | | ||||||
|         mkdir "${{ github.workspace }}/build/package" |         mkdir "${{ github.workspace }}/build/package" | ||||||
|         cmake --build "${{ github.workspace }}/build/debug" --config Debug --target PACKAGE_7Z |         cmake --build "${{ github.workspace }}/build/debug" --config Debug --target PACKAGE_7Z | ||||||
|         cmake --build "${{ github.workspace }}/build/release" --config RelWithDebInfo --target PACKAGE_7Z |         cmake --build "${{ github.workspace }}/build/release" --config RelWithDebInfo --target PACKAGE_7Z | ||||||
| 
 |     - name: "Packages (Windows)" | ||||||
|     - name: "Package: Installer (Windows)" |  | ||||||
|       if: startsWith( matrix.runner, 'windows' ) |       if: startsWith( matrix.runner, 'windows' ) | ||||||
|       shell: cmd |       shell: cmd | ||||||
|       run: | |       run: | | ||||||
|         "C:\Program Files (x86)\Inno Setup 6\ISCC.exe" /V10 ".\build\debug\installer.iss" |         "C:\Program Files (x86)\Inno Setup 6\ISCC.exe" /V10 ".\build\debug\installer.iss" | ||||||
|         "C:\Program Files (x86)\Inno Setup 6\ISCC.exe" /V10 ".\build\release\installer.iss" |         "C:\Program Files (x86)\Inno Setup 6\ISCC.exe" /V10 ".\build\release\installer.iss" | ||||||
| 
 |     - name: "Packages (MacOS)" | ||||||
|     - name: "Package: Installer (MacOS)" |  | ||||||
|       if: startsWith( matrix.runner, 'macos' ) |       if: startsWith( matrix.runner, 'macos' ) | ||||||
|       shell: bash |       shell: bash | ||||||
|       run: | |       run: | | ||||||
|  | @ -381,3 +392,21 @@ jobs: | ||||||
|       with: |       with: | ||||||
|         name: "${{ matrix.runner }}-${{ matrix.generator }}-qt${{ matrix.qt }}" |         name: "${{ matrix.runner }}-${{ matrix.generator }}-qt${{ matrix.qt }}" | ||||||
|         path: "${{ github.workspace }}/build/package" |         path: "${{ github.workspace }}/build/package" | ||||||
|  | 
 | ||||||
|  |     - name: "Validate clang-format" | ||||||
|  |       shell: bash | ||||||
|  |       run: | | ||||||
|  |         cmake --build "${{ github.workspace }}/build/debug" --config Debug --target clang-format | ||||||
|  |         cmake --build "${{ github.workspace }}/build/release" --config RelWithDebInfo --target clang-format | ||||||
|  |         git --no-pager diff --patch --minimal HEAD -- | ||||||
|  |         git update-index --refresh | ||||||
|  |         git diff-index --quiet HEAD -- | ||||||
|  |     - name: "Validate clang-tidy" | ||||||
|  |       continue-on-error: true | ||||||
|  |       shell: bash | ||||||
|  |       run: | | ||||||
|  |         cmake --build "${{ github.workspace }}/build/debug" --config Debug --target clang-tidy | ||||||
|  |         cmake --build "${{ github.workspace }}/build/release" --config RelWithDebInfo --target clang-tidy | ||||||
|  |         git --no-pager diff --patch --minimal HEAD -- | ||||||
|  |         git update-index --refresh | ||||||
|  |         git diff-index --quiet HEAD -- | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue