Merge branch 'builds' into drag-and-drop
This commit is contained in:
		
						commit
						5118726cde
					
				
							
								
								
									
										102
									
								
								.github/workflows/all-builds.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										102
									
								
								.github/workflows/all-builds.yml
									
									
									
									
										vendored
									
									
								
							@ -6,9 +6,9 @@ on:
 | 
				
			|||||||
  workflow_dispatch:
 | 
					  workflow_dispatch:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
jobs:
 | 
					jobs:
 | 
				
			||||||
  Build-Qtk:
 | 
					  Qtk:
 | 
				
			||||||
    env:
 | 
					    env:
 | 
				
			||||||
      CONFIG: -DQTK_UPDATE_SUBMODULES=ON -DQTK_DEBUG=OFF -DQTK_ENABLE_CCACHE=OFF -DQTK_BUILD_GUI=ON -DQTK_INSTALL_LIBRARY=ON -DQTK_INSTALL_PLUGINS=OFF
 | 
					      CONFIG: -DQTK_SUBMODULES=ON -DQTK_DEBUG=OFF -DQTK_CCACHE=OFF -DQTK_GUI=ON -DQTK_PLUGINS=OFF -DQTK_EXAMPLE=ON
 | 
				
			||||||
    strategy:
 | 
					    strategy:
 | 
				
			||||||
      fail-fast: false
 | 
					      fail-fast: false
 | 
				
			||||||
      matrix:
 | 
					      matrix:
 | 
				
			||||||
@ -16,10 +16,13 @@ jobs:
 | 
				
			|||||||
        include:
 | 
					        include:
 | 
				
			||||||
          - os: ubuntu-latest
 | 
					          - os: ubuntu-latest
 | 
				
			||||||
            cmake: -DCMAKE_PREFIX_PATH=/home/runner/work/qtk/Qt/6.5.0/gcc_64/ $CONFIG
 | 
					            cmake: -DCMAKE_PREFIX_PATH=/home/runner/work/qtk/Qt/6.5.0/gcc_64/ $CONFIG
 | 
				
			||||||
 | 
					            flags: -j $(nproc)
 | 
				
			||||||
          - os: windows-latest
 | 
					          - os: windows-latest
 | 
				
			||||||
            cmake: -DCMAKE_PREFIX_PATH=D:/a/qtk/qtk/Qt/6.5.0/mingw81_64/ $CONFIG
 | 
					            cmake: -DCMAKE_PREFIX_PATH=D:/a/qtk/qtk/Qt/6.5.0/mingw81_64/ $CONFIG
 | 
				
			||||||
 | 
					            flags: ''
 | 
				
			||||||
          - os: macos-latest
 | 
					          - os: macos-latest
 | 
				
			||||||
            cmake: -DCMAKE_PREFIX_PATH=/home/runner/work/qtk/Qt/6.5.0/gcc_64/ $CONFIG
 | 
					            cmake: -DCMAKE_PREFIX_PATH=/home/runner/work/qtk/Qt/6.5.0/gcc_64/ $CONFIG
 | 
				
			||||||
 | 
					            flags: -j $(nproc)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    runs-on: ${{ matrix.os }}
 | 
					    runs-on: ${{ matrix.os }}
 | 
				
			||||||
    steps:
 | 
					    steps:
 | 
				
			||||||
@ -44,33 +47,24 @@ jobs:
 | 
				
			|||||||
          sudo apt update -y
 | 
					          sudo apt update -y
 | 
				
			||||||
          sudo apt install libxcb-cursor0 -y
 | 
					          sudo apt install libxcb-cursor0 -y
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      - name: Configure Qtk Application (Windows)
 | 
					      - name: Configure Qtk Application
 | 
				
			||||||
        if: matrix.os == 'windows-latest'
 | 
					 | 
				
			||||||
        shell: bash
 | 
					        shell: bash
 | 
				
			||||||
        run: cmake -B build/ ${{ matrix.cmake }}
 | 
					        run: cmake -B build/ ${{ matrix.cmake }}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      - name: Build Qtk Application (Windows)
 | 
					      - name: Build Qtk Application
 | 
				
			||||||
        if: matrix.os == 'windows-latest'
 | 
					 | 
				
			||||||
        shell: bash
 | 
					        shell: bash
 | 
				
			||||||
        run: cmake --build build/ --config Release
 | 
					        run: cmake --build build/ --config Release --target qtk_gui ${{ matrix.flags }}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      # OSX / Linux
 | 
					      - name: Build Qtk Example
 | 
				
			||||||
 | 
					 | 
				
			||||||
      - name: Configure Qtk Application (OSX / Linux)
 | 
					 | 
				
			||||||
        if: matrix.os != 'windows-latest'
 | 
					        if: matrix.os != 'windows-latest'
 | 
				
			||||||
        shell: bash
 | 
					        shell: bash
 | 
				
			||||||
        run: cmake -B build/ ${{ matrix.cmake }}
 | 
					        run: cmake --build build/ --config Release --target qtk_example ${{ matrix.flags }}
 | 
				
			||||||
 | 
					 | 
				
			||||||
      - name: Build Qtk Application (OSX / Linux)
 | 
					 | 
				
			||||||
        if: matrix.os != 'windows-latest'
 | 
					 | 
				
			||||||
        shell: bash
 | 
					 | 
				
			||||||
        run: cmake --build build/ --config Release --target qtk_app -- -j $(nproc)
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
      # Packaging
 | 
					      # Packaging
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      - name: Install Qtk Application
 | 
					      - name: Install Qtk Application
 | 
				
			||||||
        shell: bash
 | 
					        shell: bash
 | 
				
			||||||
        run: cmake --install build/ --config Release --prefix=$(pwd)/install --component qtk
 | 
					        run: cmake --install build/ --config Release --component qtk_gui
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      - name: Package Qtk Application
 | 
					      - name: Package Qtk Application
 | 
				
			||||||
        shell: bash
 | 
					        shell: bash
 | 
				
			||||||
@ -87,7 +81,7 @@ jobs:
 | 
				
			|||||||
        if: matrix.os == 'ubuntu-latest'
 | 
					        if: matrix.os == 'ubuntu-latest'
 | 
				
			||||||
        uses: actions/upload-artifact@v3
 | 
					        uses: actions/upload-artifact@v3
 | 
				
			||||||
        with:
 | 
					        with:
 | 
				
			||||||
          name: qtk-app-${{ matrix.os }}
 | 
					          name: qtk-gui-${{ matrix.os }}
 | 
				
			||||||
          path: |
 | 
					          path: |
 | 
				
			||||||
            build/packages/*.deb
 | 
					            build/packages/*.deb
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -102,7 +96,7 @@ jobs:
 | 
				
			|||||||
        if: matrix.os == 'windows-latest'
 | 
					        if: matrix.os == 'windows-latest'
 | 
				
			||||||
        uses: actions/upload-artifact@v3
 | 
					        uses: actions/upload-artifact@v3
 | 
				
			||||||
        with:
 | 
					        with:
 | 
				
			||||||
          name: qtk-app-${{ matrix.os }}
 | 
					          name: qtk-gui-${{ matrix.os }}
 | 
				
			||||||
          path: |
 | 
					          path: |
 | 
				
			||||||
            build/packages/*.exe
 | 
					            build/packages/*.exe
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -117,14 +111,14 @@ jobs:
 | 
				
			|||||||
        if: matrix.os == 'macos-latest'
 | 
					        if: matrix.os == 'macos-latest'
 | 
				
			||||||
        uses: actions/upload-artifact@v3
 | 
					        uses: actions/upload-artifact@v3
 | 
				
			||||||
        with:
 | 
					        with:
 | 
				
			||||||
          name: qtk-app-${{ matrix.os }}
 | 
					          name: qtk-gui-${{ matrix.os }}
 | 
				
			||||||
          path: |
 | 
					          path: |
 | 
				
			||||||
            build/packages/*.tar.gz
 | 
					            build/packages/*.tar.gz
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      - name: Upload Qtk install directory
 | 
					      - name: Upload Qtk install directory
 | 
				
			||||||
        uses: actions/upload-artifact@v3
 | 
					        uses: actions/upload-artifact@v3
 | 
				
			||||||
        with:
 | 
					        with:
 | 
				
			||||||
          name: qtk-app-${{ matrix.os }}-install
 | 
					          name: qtk-gui-${{ matrix.os }}-installdir
 | 
				
			||||||
          path: install/*
 | 
					          path: install/*
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# TODO: Enable after trimming resources.
 | 
					# TODO: Enable after trimming resources.
 | 
				
			||||||
@ -142,9 +136,9 @@ jobs:
 | 
				
			|||||||
#            build/packages/*
 | 
					#            build/packages/*
 | 
				
			||||||
#            !build/packages/_CPack_Packages/*
 | 
					#            !build/packages/_CPack_Packages/*
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  Build-Qtk-Library:
 | 
					  Qtk-Library:
 | 
				
			||||||
    env:
 | 
					    env:
 | 
				
			||||||
      CONFIG: -DQTK_UPDATE_SUBMODULES=ON -DQTK_DEBUG=OFF -DQTK_ENABLE_CCACHE=OFF -DQTK_BUILD_GUI=OFF -DQTK_INSTALL_LIBRARY=ON -DQTK_INSTALL_PLUGINS=OFF
 | 
					      CONFIG: -DQTK_SUBMODULES=ON -DQTK_DEBUG=OFF -DQTK_CCACHE=OFF -DQTK_GUI=OFF -DQTK_PLUGINS=OFF -DQTK_EXAMPLE=OFF
 | 
				
			||||||
    strategy:
 | 
					    strategy:
 | 
				
			||||||
      fail-fast: false
 | 
					      fail-fast: false
 | 
				
			||||||
      matrix:
 | 
					      matrix:
 | 
				
			||||||
@ -152,10 +146,13 @@ jobs:
 | 
				
			|||||||
        include:
 | 
					        include:
 | 
				
			||||||
          - os: ubuntu-latest
 | 
					          - os: ubuntu-latest
 | 
				
			||||||
            cmake: -DCMAKE_PREFIX_PATH=/home/runner/work/qtk/Qt/6.5.0/gcc_64/ $CONFIG
 | 
					            cmake: -DCMAKE_PREFIX_PATH=/home/runner/work/qtk/Qt/6.5.0/gcc_64/ $CONFIG
 | 
				
			||||||
 | 
					            flags: -j $(nproc)
 | 
				
			||||||
          - os: windows-latest
 | 
					          - os: windows-latest
 | 
				
			||||||
            cmake: -DCMAKE_PREFIX_PATH=D:/a/qtk/qtk/Qt/6.5.0/mingw81_64/ $CONFIG
 | 
					            cmake: -DCMAKE_PREFIX_PATH=D:/a/qtk/qtk/Qt/6.5.0/mingw81_64/ $CONFIG
 | 
				
			||||||
 | 
					            flags: ''
 | 
				
			||||||
          - os: macos-latest
 | 
					          - os: macos-latest
 | 
				
			||||||
            cmake: -DCMAKE_PREFIX_PATH=/home/runner/work/qtk/Qt/6.5.0/gcc_64/ $CONFIG
 | 
					            cmake: -DCMAKE_PREFIX_PATH=/home/runner/work/qtk/Qt/6.5.0/gcc_64/ $CONFIG
 | 
				
			||||||
 | 
					            flags: -j $(nproc)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    runs-on: ${{ matrix.os }}
 | 
					    runs-on: ${{ matrix.os }}
 | 
				
			||||||
    steps:
 | 
					    steps:
 | 
				
			||||||
@ -174,33 +171,19 @@ jobs:
 | 
				
			|||||||
        with:
 | 
					        with:
 | 
				
			||||||
          args: install pkgconfiglite --checksum e87b5ea3c9142256af60f2d5b917aa63b571e6a0 --checksum-type sha1
 | 
					          args: install pkgconfiglite --checksum e87b5ea3c9142256af60f2d5b917aa63b571e6a0 --checksum-type sha1
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      - name: Configure Qtk Library (Windows)
 | 
					      - name: Configure Qtk Library
 | 
				
			||||||
        if: matrix.os == 'windows-latest'
 | 
					 | 
				
			||||||
        shell: bash
 | 
					        shell: bash
 | 
				
			||||||
        run: cmake -B build/ ${{ matrix.cmake }}
 | 
					        run: cmake -B build/ ${{ matrix.cmake }}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      - name: Build Qtk Library (Windows)
 | 
					      - name: Build Qtk Library
 | 
				
			||||||
        if: matrix.os == 'windows-latest'
 | 
					 | 
				
			||||||
        shell: bash
 | 
					        shell: bash
 | 
				
			||||||
        run: cmake --build build/ --config Release
 | 
					        run: cmake --build build/ --config Release --target qtk_library -- ${{ matrix.flags }}
 | 
				
			||||||
 | 
					 | 
				
			||||||
      # OSX / Linux
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      - name: Configure Qtk Library (OSX / Linux)
 | 
					 | 
				
			||||||
        if: matrix.os != 'windows-latest'
 | 
					 | 
				
			||||||
        shell: bash
 | 
					 | 
				
			||||||
        run: cmake -B build/ ${{ matrix.cmake }}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      - name: Build Qtk Library (OSX / Linux)
 | 
					 | 
				
			||||||
        if: matrix.os != 'windows-latest'
 | 
					 | 
				
			||||||
        shell: bash
 | 
					 | 
				
			||||||
        run: cmake --build build/ --config Release --target qtk_library -- -j $(nproc)
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
      # Packaging
 | 
					      # Packaging
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      - name: Install Qtk Library
 | 
					      - name: Install Qtk Library
 | 
				
			||||||
        shell: bash
 | 
					        shell: bash
 | 
				
			||||||
        run: cmake --install build/ --config Release --prefix=$(pwd)/install --component libqtk
 | 
					        run: cmake --install build/ --config Release --prefix=$(pwd)/install --component qtk_library
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      - name: Package Qtk Library
 | 
					      - name: Package Qtk Library
 | 
				
			||||||
        shell: bash
 | 
					        shell: bash
 | 
				
			||||||
@ -255,12 +238,12 @@ jobs:
 | 
				
			|||||||
        uses: actions/upload-artifact@v3
 | 
					        uses: actions/upload-artifact@v3
 | 
				
			||||||
        if: always()
 | 
					        if: always()
 | 
				
			||||||
        with:
 | 
					        with:
 | 
				
			||||||
          name: libqtk-${{ matrix.os }}-install
 | 
					          name: libqtk-${{ matrix.os }}-installdir
 | 
				
			||||||
          path: install/*
 | 
					          path: install/*
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  Build-Qtk-Plugins:
 | 
					  Qtk-Plugins:
 | 
				
			||||||
    env:
 | 
					    env:
 | 
				
			||||||
      CONFIG: -DQTK_UPDATE_SUBMODULES=ON -DQTK_DEBUG=OFF -DQTK_ENABLE_CCACHE=OFF -DQTK_BUILD_GUI=OFF -DQTK_INSTALL_LIBRARY=OFF -DQTK_INSTALL_PLUGINS=ON
 | 
					      CONFIG: -DQTK_SUBMODULES=ON -DQTK_DEBUG=OFF -DQTK_CCACHE=OFF -DQTK_GUI=OFF -DQTK_PLUGINS=ON -DQTK_EXAMPLE=OFF
 | 
				
			||||||
    strategy:
 | 
					    strategy:
 | 
				
			||||||
      fail-fast: false
 | 
					      fail-fast: false
 | 
				
			||||||
      matrix:
 | 
					      matrix:
 | 
				
			||||||
@ -268,10 +251,13 @@ jobs:
 | 
				
			|||||||
        include:
 | 
					        include:
 | 
				
			||||||
          - os: ubuntu-latest
 | 
					          - os: ubuntu-latest
 | 
				
			||||||
            cmake: -DCMAKE_PREFIX_PATH=/home/runner/work/qtk/Qt/6.5.0/gcc_64/ $CONFIG
 | 
					            cmake: -DCMAKE_PREFIX_PATH=/home/runner/work/qtk/Qt/6.5.0/gcc_64/ $CONFIG
 | 
				
			||||||
 | 
					            flags: -j $(nproc)
 | 
				
			||||||
          - os: windows-latest
 | 
					          - os: windows-latest
 | 
				
			||||||
            cmake: -DCMAKE_PREFIX_PATH=D:/a/qtk/qtk/Qt/6.5.0/mingw81_64/ $CONFIG
 | 
					            cmake: -DCMAKE_PREFIX_PATH=D:/a/qtk/qtk/Qt/6.5.0/mingw81_64/ $CONFIG
 | 
				
			||||||
 | 
					            flags: ''
 | 
				
			||||||
          - os: macos-latest
 | 
					          - os: macos-latest
 | 
				
			||||||
            cmake: -DCMAKE_PREFIX_PATH=/home/runner/work/qtk/Qt/6.5.0/gcc_64/ $CONFIG
 | 
					            cmake: -DCMAKE_PREFIX_PATH=/home/runner/work/qtk/Qt/6.5.0/gcc_64/ $CONFIG
 | 
				
			||||||
 | 
					            flags: -j $(nproc)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    runs-on: ${{ matrix.os }}
 | 
					    runs-on: ${{ matrix.os }}
 | 
				
			||||||
    steps:
 | 
					    steps:
 | 
				
			||||||
@ -282,43 +268,27 @@ jobs:
 | 
				
			|||||||
        with:
 | 
					        with:
 | 
				
			||||||
          version: '6.5.0'
 | 
					          version: '6.5.0'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      # Windows
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      - name: Chocolatey Action
 | 
					      - name: Chocolatey Action
 | 
				
			||||||
        if: matrix.os == 'windows-latest'
 | 
					        if: matrix.os == 'windows-latest'
 | 
				
			||||||
        uses: crazy-max/ghaction-chocolatey@v2
 | 
					        uses: crazy-max/ghaction-chocolatey@v2
 | 
				
			||||||
        with:
 | 
					        with:
 | 
				
			||||||
          args: install pkgconfiglite --checksum e87b5ea3c9142256af60f2d5b917aa63b571e6a0 --checksum-type sha1
 | 
					          args: install pkgconfiglite --checksum e87b5ea3c9142256af60f2d5b917aa63b571e6a0 --checksum-type sha1
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      - name: Configure Qtk Plugins (Windows)
 | 
					      - name: Configure Qtk Plugins
 | 
				
			||||||
        if: matrix.os == 'windows-latest'
 | 
					 | 
				
			||||||
        shell: bash
 | 
					        shell: bash
 | 
				
			||||||
        run: cmake -B build/ ${{ matrix.cmake }}
 | 
					        run: cmake -B build/ ${{ matrix.cmake }}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      - name: Build Qtk Plugins (Windows)
 | 
					      - name: Build Qtk Plugins
 | 
				
			||||||
        if: matrix.os == 'windows-latest'
 | 
					 | 
				
			||||||
        shell: bash
 | 
					        shell: bash
 | 
				
			||||||
        run: cmake --build build/ --config Release --target qtk_collection
 | 
					        run: cmake --build build/ --config Release --target qtk_plugins -- ${{ matrix.flags }}
 | 
				
			||||||
 | 
					 | 
				
			||||||
      # OSX / Linux
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      - name: Configure Qtk Plugins (OSX / Linux)
 | 
					 | 
				
			||||||
        if: matrix.os != 'windows-latest'
 | 
					 | 
				
			||||||
        shell: bash
 | 
					 | 
				
			||||||
        run: cmake -B build/ ${{ matrix.cmake }}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      - name: Build Qtk Plugins (OSX / Linux)
 | 
					 | 
				
			||||||
        if: matrix.os != 'windows-latest'
 | 
					 | 
				
			||||||
        shell: bash
 | 
					 | 
				
			||||||
        run: cmake --build build/ --config Release --target qtk_collection -- -j $(nproc)
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
      # Packaging
 | 
					      # Packaging
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      - name: Install Qtk Plugins
 | 
					      - name: Install Qtk Plugins
 | 
				
			||||||
        shell: bash
 | 
					        shell: bash
 | 
				
			||||||
        run: cmake --install build/ --config Release --prefix=$(pwd)/install --component collection
 | 
					        run: cmake --install build/ --config Release --component qtk_plugins
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  Build-Qtk-Assimp-Targets:
 | 
					  Qtk-Assimp-Targets:
 | 
				
			||||||
    strategy:
 | 
					    strategy:
 | 
				
			||||||
      fail-fast: false
 | 
					      fail-fast: false
 | 
				
			||||||
      matrix:
 | 
					      matrix:
 | 
				
			||||||
@ -352,7 +322,7 @@ jobs:
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
      - name: Configure Qtk
 | 
					      - name: Configure Qtk
 | 
				
			||||||
        shell: bash
 | 
					        shell: bash
 | 
				
			||||||
        run: cmake -B build/ ${{ matrix.cmake }} -DQTK_ENABLE_CCACHE=OFF
 | 
					        run: cmake -B build/ ${{ matrix.cmake }} -DQTK_CCACHE=OFF
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      - name: Build Qtk
 | 
					      - name: Build Qtk
 | 
				
			||||||
        shell: bash
 | 
					        shell: bash
 | 
				
			||||||
 | 
				
			|||||||
							
								
								
									
										4
									
								
								.github/workflows/linting.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/workflows/linting.yml
									
									
									
									
										vendored
									
									
								
							@ -21,8 +21,8 @@ jobs:
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
      - name: Build Qtk
 | 
					      - name: Build Qtk
 | 
				
			||||||
        run: |
 | 
					        run: |
 | 
				
			||||||
          cmake -B build -DQTK_UPDATE_SUBMODULES=OFF -DQTK_ENABLE_CCACHE=OFF
 | 
					          cmake -B build -DQTK_SUBMODULES=OFF -DQTK_CCACHE=OFF -DQTK_PLUGINS=OFF -DQTK_GUI=ON
 | 
				
			||||||
          cmake --build build
 | 
					          cmake --build build --target qtk_gui -- -j $(nproc)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      - uses: cpp-linter/cpp-linter-action@v2
 | 
					      - uses: cpp-linter/cpp-linter-action@v2
 | 
				
			||||||
        id: linter
 | 
					        id: linter
 | 
				
			||||||
 | 
				
			|||||||
@ -46,14 +46,13 @@ include(GNUInstallDirs)
 | 
				
			|||||||
# Options
 | 
					# Options
 | 
				
			||||||
################################################################################
 | 
					################################################################################
 | 
				
			||||||
option(QTK_DEBUG "Enable debugger" OFF)
 | 
					option(QTK_DEBUG "Enable debugger" OFF)
 | 
				
			||||||
option(QTK_UPDATE_SUBMODULES "Update external project (assimp) submodule" OFF)
 | 
					option(QTK_SUBMODULES "Update external project (assimp) submodule" OFF)
 | 
				
			||||||
option(QTK_BUILD_GUI "Build the Qtk desktop application" ON)
 | 
					option(QTK_GUI "Build the Qtk desktop application" ON)
 | 
				
			||||||
option(QTK_INSTALL_LIBRARY "Install libqtk to CMAKE_INSTALL_PREFIX path." ON)
 | 
					option(QTK_PLUGINS "Install Qtk plugins to Qt Creator path." OFF)
 | 
				
			||||||
option(QTK_INSTALL_PLUGINS "Install Qtk plugin collection to Qt Creator." OFF)
 | 
					option(QTK_EXAMPLE "Build the Qtk example desktop application" ON)
 | 
				
			||||||
option(QTK_BUILD_EXAMPLE "Build the Qtk example desktop application" ON)
 | 
					option(QTK_CCACHE "Enable ccache" ON)
 | 
				
			||||||
option(QTK_ENABLE_CCACHE "Enable ccache" ON)
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
if (QTK_ENABLE_CCACHE)
 | 
					if (QTK_CCACHE)
 | 
				
			||||||
  set(CMAKE_CXX_COMPILER_LAUNCHER ccache)
 | 
					  set(CMAKE_CXX_COMPILER_LAUNCHER ccache)
 | 
				
			||||||
endif()
 | 
					endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -61,28 +60,41 @@ endif()
 | 
				
			|||||||
option(QTK_PREFIX_QTCREATOR "Install Qtk to Qt Creator. Untested." OFF)
 | 
					option(QTK_PREFIX_QTCREATOR "Install Qtk to Qt Creator. Untested." OFF)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Option for bringing your own assimp installation; Otherwise not needed
 | 
					# Option for bringing your own assimp installation; Otherwise not needed
 | 
				
			||||||
# + If assimp is available system-wide we can just set QTK_UPDATE_SUBMODULES OFF
 | 
					# + If assimp is available system-wide we can just set QTK_SUBMODULES OFF
 | 
				
			||||||
option(
 | 
					option(
 | 
				
			||||||
    QTK_ASSIMP_NEW_INTERFACE
 | 
					    QTK_ASSIMP_NEW_INTERFACE
 | 
				
			||||||
    "Use the assimp::assimp interface (WIN / OSX)"
 | 
					    "Use the assimp::assimp interface (WIN / OSX)"
 | 
				
			||||||
    OFF
 | 
					    OFF
 | 
				
			||||||
)
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if(NOT QTK_DEBUG)
 | 
					if(QTK_DEBUG OR CMAKE_BUILD_TYPE MATCHES "^[Dd][Ee][Bb][Uu][Gg]$")
 | 
				
			||||||
  set(CMAKE_BUILD_TYPE Release)
 | 
					  set(QTK_DEBUG ON)
 | 
				
			||||||
else()
 | 
					 | 
				
			||||||
  set(CMAKE_BUILD_TYPE Debug)
 | 
					  set(CMAKE_BUILD_TYPE Debug)
 | 
				
			||||||
 | 
					else()
 | 
				
			||||||
 | 
					  set(QTK_DEBUG OFF)
 | 
				
			||||||
 | 
					  set(CMAKE_BUILD_TYPE Release)
 | 
				
			||||||
endif()
 | 
					endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# This should be set to your Qt6 installation directory.
 | 
					# This should be set to your Qt6 installation directory.
 | 
				
			||||||
set(QT_INSTALL_DIR "$ENV{HOME}/Qt/6.5.0/gcc_64" CACHE PATH "Path to Qt6 install.")
 | 
					set(QT_INSTALL_DIR "$ENV{HOME}/Qt/6.5.0/gcc_64/lib/cmake" CACHE PATH "Path to Qt6 install.")
 | 
				
			||||||
 | 
					if(CMAKE_INSTALL_PREFIX_INITIALIZED_TO_DEFAULT)
 | 
				
			||||||
 | 
					  set(CMAKE_INSTALL_PREFIX  "${CMAKE_BINARY_DIR}/install")
 | 
				
			||||||
 | 
					endif ()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					set(QTK_RESOURCES "${CMAKE_SOURCE_DIR}/resources")
 | 
				
			||||||
 | 
					set(QTK_OSX_ICONS ${CMAKE_SOURCE_DIR}/resources/icons/osx/kilroy.icns)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# Print all QTK options and their values at the end of configuration.
 | 
				
			||||||
 | 
					get_cmake_property(VAR_NAMES VARIABLES)
 | 
				
			||||||
 | 
					list(FILTER VAR_NAMES INCLUDE REGEX "^Q[tT][kK]_.*$")
 | 
				
			||||||
 | 
					list(SORT VAR_NAMES)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					################################################################################
 | 
				
			||||||
 | 
					# External Dependencies
 | 
				
			||||||
 | 
					################################################################################
 | 
				
			||||||
# Point CMAKE_PREFIX_PATH to Qt6 install directory
 | 
					# Point CMAKE_PREFIX_PATH to Qt6 install directory
 | 
				
			||||||
# If Qtk is built within Qt Creator this is not required.
 | 
					# If Qtk is built within Qt Creator this is not required.
 | 
				
			||||||
list(APPEND CMAKE_PREFIX_PATH "${QT_INSTALL_DIR}")
 | 
					list(APPEND CMAKE_PREFIX_PATH "${QT_INSTALL_DIR}")
 | 
				
			||||||
if (QTK_PREFIX_QTCREATOR)
 | 
					 | 
				
			||||||
  # TODO: This might be a bit strange and needs more testing.
 | 
					 | 
				
			||||||
  set(CMAKE_INSTALL_PREFIX  "${QT_INSTALL_DIR}")
 | 
					 | 
				
			||||||
endif()
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
set(
 | 
					set(
 | 
				
			||||||
    QT_CREATOR_DIR
 | 
					    QT_CREATOR_DIR
 | 
				
			||||||
@ -133,8 +145,32 @@ if(NOT Qt6_FOUND)
 | 
				
			|||||||
  )
 | 
					  )
 | 
				
			||||||
endif()
 | 
					endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# To use custom plugins, set QT_PLUGIN_PATH environment variable before running designer
 | 
				
			||||||
 | 
					# Or, we can install plugins to the designer for use across all projects.
 | 
				
			||||||
 | 
					# Qt Creator on linux will look here for widget plugins in the integrated designer
 | 
				
			||||||
 | 
					#   /home/shaun/Qt/Tools/QtCreator/lib/Qt/lib
 | 
				
			||||||
 | 
					# Qt Designer will use the following path on linux
 | 
				
			||||||
 | 
					#   /home/shaun/Qt/6.5.0/gcc_64/plugins/designer/
 | 
				
			||||||
 | 
					# We can use this path after find_package(Qt6) to install our plugins on all systems
 | 
				
			||||||
 | 
					#   ${QT6_INSTALL_PREFIX}/${QT6_INSTALL_PLUGINS}/designer
 | 
				
			||||||
 | 
					# And run designer at ${QT6_INSTALL_PREFIX}/bin/designer
 | 
				
			||||||
 | 
					# Use cmake -DQTK_PLUGIN_INSTALL_DIR=/some/path to override this install path
 | 
				
			||||||
 | 
					set(
 | 
				
			||||||
 | 
					    QTK_PLUGIN_INSTALL_DIR
 | 
				
			||||||
 | 
					    "${QT6_INSTALL_PREFIX}/${QT6_INSTALL_PLUGINS}/designer" CACHE PATH
 | 
				
			||||||
 | 
					    "Path to install Qtk plugin collection."
 | 
				
			||||||
 | 
					)
 | 
				
			||||||
 | 
					# See cmake configure output for values of these variables on your system
 | 
				
			||||||
 | 
					set(
 | 
				
			||||||
 | 
					  VAR_PATHS
 | 
				
			||||||
 | 
					   CMAKE_PREFIX_PATH CMAKE_INSTALL_PREFIX QTK_PLUGIN_INSTALL_DIR QT6_INSTALL_PREFIX
 | 
				
			||||||
 | 
					   QT_INSTALL_DIR
 | 
				
			||||||
 | 
					)
 | 
				
			||||||
 | 
					list(APPEND VAR_NAMES QT6_INSTALL_PLUGINS)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Find Assimp.
 | 
					# Find Assimp.
 | 
				
			||||||
if(QTK_UPDATE_SUBMODULES)
 | 
					if(QTK_SUBMODULES)
 | 
				
			||||||
  # Required to statically link.
 | 
					  # Required to statically link.
 | 
				
			||||||
  add_compile_options(-fPIC)
 | 
					  add_compile_options(-fPIC)
 | 
				
			||||||
  set(BUILD_SHARED_LIBS OFF CACHE STRING "Build static assimp libs" FORCE)
 | 
					  set(BUILD_SHARED_LIBS OFF CACHE STRING "Build static assimp libs" FORCE)
 | 
				
			||||||
@ -166,8 +202,18 @@ endif()
 | 
				
			|||||||
################################################################################
 | 
					################################################################################
 | 
				
			||||||
add_subdirectory(src)
 | 
					add_subdirectory(src)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if(QTK_BUILD_EXAMPLE)
 | 
					if(QTK_EXAMPLE)
 | 
				
			||||||
  # Create a namespaced alias for linking with qtk_library in the example.
 | 
					  # Create a namespaced alias for linking with qtk_library in the example.
 | 
				
			||||||
  add_library(${PROJECT_NAME}::qtk_library ALIAS qtk_library)
 | 
					  add_library(${PROJECT_NAME}::qtk_library ALIAS qtk_library)
 | 
				
			||||||
  add_subdirectory(example-app)
 | 
					  add_subdirectory(example-app EXCLUDE_FROM_ALL)
 | 
				
			||||||
endif()
 | 
					endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					foreach(VAR_NAME IN LISTS VAR_NAMES VAR_PATHS)
 | 
				
			||||||
 | 
					  if(VAR_NAME IN_LIST VAR_PATHS)
 | 
				
			||||||
 | 
					    # Print absolute if variable is path
 | 
				
			||||||
 | 
					    get_filename_component(VAR_REALPATH "${${VAR_NAME}}" REALPATH)
 | 
				
			||||||
 | 
					    message(STATUS "[Qtk] ${VAR_NAME}=${VAR_REALPATH}")
 | 
				
			||||||
 | 
					  else()
 | 
				
			||||||
 | 
					    message(STATUS "[Qtk] ${VAR_NAME}=${${VAR_NAME}}")
 | 
				
			||||||
 | 
					  endif()
 | 
				
			||||||
 | 
					endforeach()
 | 
				
			||||||
 | 
				
			|||||||
							
								
								
									
										130
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										130
									
								
								README.md
									
									
									
									
									
								
							@ -48,80 +48,51 @@ your system, **version 6.5.0** or later.
 | 
				
			|||||||
Be sure to take note of the Qt6 installation directory, as we will need it to
 | 
					Be sure to take note of the Qt6 installation directory, as we will need it to
 | 
				
			||||||
correctly set our `CMAKE_PREFIX_PATH` in the next steps.
 | 
					correctly set our `CMAKE_PREFIX_PATH` in the next steps.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					If you are building on **Windows / Mac**, consider setting
 | 
				
			||||||
 | 
					the `-DASSIMP_NEW_INTERFACE` build flag.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
If the build is configured with all options enabled, we can subsequently install
 | 
					If the build is configured with all options enabled, we can subsequently install
 | 
				
			||||||
individual components as needed with cmake.
 | 
					individual components as needed with cmake.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
```bash
 | 
					```bash
 | 
				
			||||||
cmake -B build-all/ -DQTK_BUILD_GUI=ON -DQTK_INSTALL_LIBRARY=ON -DQTK_INSTALL_PLUGINS=ON
 | 
					sudo apt update -y && sudo apt install libassimp-dev cmake build-essential git ccache libgl1-mesa-dev libglvnd-dev -y
 | 
				
			||||||
```
 | 
					git clone https://github.com/shaunrd0/qtk
 | 
				
			||||||
 | 
					cd qtk
 | 
				
			||||||
 | 
					# Configure the build with all components enabled
 | 
				
			||||||
 | 
					cmake -B build-all -DQTK_GUI=ON -DQTK_PLUGINS=ON -DQTK_EXAMPLE=ON -DCMAKE_PREFIX_PATH=$HOME/Qt/6.5.0/gcc_64
 | 
				
			||||||
 | 
					# Build all targets
 | 
				
			||||||
 | 
					cmake --build build-all/
 | 
				
			||||||
 | 
					````
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					By default, the build will not initialize Assimp as a git submodule and build
 | 
				
			||||||
 | 
					from source.
 | 
				
			||||||
 | 
					We can turn this on by setting the `-DQTK_SUBMODULES=ON` flag when running
 | 
				
			||||||
 | 
					CMake.
 | 
				
			||||||
 | 
					Building using this option will fetch and build Assimp for us, but builds will
 | 
				
			||||||
 | 
					take longer as a result.
 | 
				
			||||||
 | 
					Using `-DQTK_SUBMODULES=ON` supports providing assimp on cross-platform builds (
 | 
				
			||||||
 | 
					Windows / Mac / Linux) and may be easier
 | 
				
			||||||
 | 
					to configure.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
```bash
 | 
					```bash
 | 
				
			||||||
# Install libqtk only
 | 
					cmake -B build-all -DQTK_GUI=ON -DQTK_PLUGINS=ON -DQTK_EXAMPLE=ON -DQTK_SUBMODULES=ON -DCMAKE_PREFIX_PATH=$HOME/Qt/6.5.0/gcc_64
 | 
				
			||||||
cmake --install build-all/ --prefix=$(pwd)/install --component libqtk
 | 
					 | 
				
			||||||
-- Install configuration: "Release"
 | 
					 | 
				
			||||||
-- Up-to-date: /home/shaun/Code/qtk/install/lib/cmake/Qtk/QtkConfig.cmake
 | 
					 | 
				
			||||||
-- Up-to-date: /home/shaun/Code/qtk/install/lib/cmake/Qtk/QtkConfigVersion.cmake
 | 
					 | 
				
			||||||
-- Up-to-date: /home/shaun/Code/qtk/install/lib/cmake/Qtk/QtkTargets.cmake
 | 
					 | 
				
			||||||
-- Up-to-date: /home/shaun/Code/qtk/install/lib/cmake/Qtk/QtkTargets-release.cmake
 | 
					 | 
				
			||||||
-- Up-to-date: /home/shaun/Code/qtk/install/lib/static/libqtk_library.a
 | 
					 | 
				
			||||||
-- Up-to-date: /home/shaun/Code/qtk/install/include/qtk/camera3d.h
 | 
					 | 
				
			||||||
-- Up-to-date: /home/shaun/Code/qtk/install/include/qtk/input.h
 | 
					 | 
				
			||||||
-- Up-to-date: /home/shaun/Code/qtk/install/include/qtk/meshrenderer.h
 | 
					 | 
				
			||||||
-- Up-to-date: /home/shaun/Code/qtk/install/include/qtk/model.h
 | 
					 | 
				
			||||||
-- Up-to-date: /home/shaun/Code/qtk/install/include/qtk/modelmesh.h
 | 
					 | 
				
			||||||
-- Up-to-date: /home/shaun/Code/qtk/install/include/qtk/object.h
 | 
					 | 
				
			||||||
-- Up-to-date: /home/shaun/Code/qtk/install/include/qtk/qtkapi.h
 | 
					 | 
				
			||||||
-- Up-to-date: /home/shaun/Code/qtk/install/include/qtk/qtkiostream.h
 | 
					 | 
				
			||||||
-- Up-to-date: /home/shaun/Code/qtk/install/include/qtk/qtkiosystem.h
 | 
					 | 
				
			||||||
-- Up-to-date: /home/shaun/Code/qtk/install/include/qtk/scene.h
 | 
					 | 
				
			||||||
-- Up-to-date: /home/shaun/Code/qtk/install/include/qtk/shape.h
 | 
					 | 
				
			||||||
-- Up-to-date: /home/shaun/Code/qtk/install/include/qtk/skybox.h
 | 
					 | 
				
			||||||
-- Up-to-date: /home/shaun/Code/qtk/install/include/qtk/texture.h
 | 
					 | 
				
			||||||
-- Up-to-date: /home/shaun/Code/qtk/install/include/qtk/transform3D.h
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# Install Qtk widget collection to use Qt Designer
 | 
					 | 
				
			||||||
cmake --install build-all/ --prefix=$(pwd)/install --component collection
 | 
					 | 
				
			||||||
-- Install configuration: "Release"
 | 
					 | 
				
			||||||
-- Up-to-date: /home/shaun/Qt/6.5.0/gcc_64/../../Tools/QtCreator/lib/Qt/lib/libqtk_library.a
 | 
					 | 
				
			||||||
-- Up-to-date: /home/shaun/Qt/6.5.0/gcc_64/../../Tools/QtCreator/lib/Qt/lib/libqtk_plugin_library.a
 | 
					 | 
				
			||||||
-- Up-to-date: /home/shaun/Qt/6.5.0/gcc_64/../../Tools/QtCreator/lib/Qt/plugins/designer/libqtk_collection.so
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# Install Qtk desktop application (output removed)
 | 
					 | 
				
			||||||
cmake --install build-all/ --prefix=$(pwd)/install --component qtk
 | 
					 | 
				
			||||||
```
 | 
					```
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#### Qtk GUI
 | 
					#### Qtk GUI
 | 
				
			||||||
 | 
					
 | 
				
			||||||
Once Qt6 is installed, to build and run `qtk` on Ubuntu -
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
```bash
 | 
					```bash
 | 
				
			||||||
sudo apt update -y && sudo apt install libassimp-dev cmake build-essential git ccache -y
 | 
					cmake --build build-all/ --target qtk_gui -- -j $(nproc)
 | 
				
			||||||
git clone https://github.com/shaunrd0/qtk
 | 
					# Install Qtk desktop application (output removed)
 | 
				
			||||||
cmake -S qtk/ -B qtk/build/ -DCMAKE_PREFIX_PATH=$HOME/Qt/6.5.0/gcc_64
 | 
					# Installation prefix path must be absolute, since Qtk uses Qt deploy tools.
 | 
				
			||||||
cmake --build qtk/build/ -j $(nproc --ignore=2)
 | 
					cmake --install build-all/ --component qtk_gui --prefix=$(pwd)/install
 | 
				
			||||||
./qtk/build/bin/qtk-main
 | 
					./install/bin/qtk_gui
 | 
				
			||||||
```
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
By default, the build will not initialize Assimp as a git submodule and build
 | 
					 | 
				
			||||||
from source.
 | 
					 | 
				
			||||||
We can turn this on by setting the `-DQTK_UPDATE_SUBMODULES=ON` flag when
 | 
					 | 
				
			||||||
running CMake.
 | 
					 | 
				
			||||||
Building using this option will fetch and build Assimp for us, but builds will
 | 
					 | 
				
			||||||
take longer as a result.
 | 
					 | 
				
			||||||
Using `-DQTK_UPDATE_SUBMODULES=ON` supports providing assimp on cross-platform
 | 
					 | 
				
			||||||
builds (Windows / Mac / Linux) and may be easier to configure.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
```bash
 | 
					 | 
				
			||||||
cmake -S qtk/ -B qtk/build/ -DQTK_UPDATE_SUBMODULES=ON -DCMAKE_PREFIX_PATH=$HOME/Qt/6.5.0/gcc_64
 | 
					 | 
				
			||||||
cmake --build qtk/build/ -j $(nproc --ignore=2)
 | 
					 | 
				
			||||||
./qtk/build/bin/qtk-main
 | 
					 | 
				
			||||||
```
 | 
					```
 | 
				
			||||||
 | 
					
 | 
				
			||||||
If any errors are encountered loading plugins, we can debug plugin loading by
 | 
					If any errors are encountered loading plugins, we can debug plugin loading by
 | 
				
			||||||
setting the following environment variable -
 | 
					setting the following environment variable -
 | 
				
			||||||
 | 
					
 | 
				
			||||||
```bash
 | 
					```bash
 | 
				
			||||||
QT_DEBUG_PLUGINS=1 ./qtk-main
 | 
					QT_DEBUG_PLUGINS=1 ./install/bin/qtk_gui
 | 
				
			||||||
```
 | 
					```
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#### Qtk Library
 | 
					#### Qtk Library
 | 
				
			||||||
@ -131,12 +102,10 @@ We can install this library on a system path or a custom path and then
 | 
				
			|||||||
set `CMAKE_PREFIX_PATH` to point to this location when building an application
 | 
					set `CMAKE_PREFIX_PATH` to point to this location when building an application
 | 
				
			||||||
using libqtk.
 | 
					using libqtk.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
Below is an example of installing on a system path.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
```bash
 | 
					```bash
 | 
				
			||||||
cmake -S qtk/ -B qtk/build/ -DCMAKE_PREFIX_PATH=$HOME/Qt/6.5.0/gcc_64 -DQTK_BUILD_GUI=OFF -DQTK_INSTALL_PLUGINS=OFF -DQTK_DEBUG=OFF
 | 
					# Install libqtk only
 | 
				
			||||||
cmake --build qtk/build/ -j $(nproc --ignore=2)
 | 
					cmake --build build-all/ --target qtk_library -- -j $(nproc)
 | 
				
			||||||
sudo cmake --install . --prefix=/usr/local
 | 
					cmake --install build-all/ --component qtk_library --prefix=/usr/local
 | 
				
			||||||
-- Install configuration: "Release"
 | 
					-- Install configuration: "Release"
 | 
				
			||||||
-- Installing: /usr/local/lib/cmake/Qtk/QtkConfig.cmake
 | 
					-- Installing: /usr/local/lib/cmake/Qtk/QtkConfig.cmake
 | 
				
			||||||
-- Installing: /usr/local/lib/cmake/Qtk/QtkConfigVersion.cmake
 | 
					-- Installing: /usr/local/lib/cmake/Qtk/QtkConfigVersion.cmake
 | 
				
			||||||
@ -175,9 +144,14 @@ interfaces.
 | 
				
			|||||||
To build and install the Qtk plugin collection -
 | 
					To build and install the Qtk plugin collection -
 | 
				
			||||||
 | 
					
 | 
				
			||||||
```bash
 | 
					```bash
 | 
				
			||||||
cmake -S /path/to/qtk -B /path/to/qtk/build -DCMAKE_PREFIX_PATH=$HOME/Qt/6.5.0/gcc_64 -DQTK_INSTALL_PLUGINS=ON -DQTK_BUILD_GUI=OFF -DQTK_INSTALL_LIBRARY=OFF
 | 
					cmake --build build-all/ --target qtk_plugins -- -j $(nproc)
 | 
				
			||||||
cmake --build /path/to/qtk/build
 | 
					# Install Qtk widget collection to use Qt Designer
 | 
				
			||||||
cmake --install /path/to/qtk/build
 | 
					# The path here should be initialized during build configuration, so no need for --prefix
 | 
				
			||||||
 | 
					cmake --install build-all/ --component qtk_plugins
 | 
				
			||||||
 | 
					-- Install configuration: "Release"
 | 
				
			||||||
 | 
					-- Up-to-date: /home/shaun/Qt/6.5.0/gcc_64/../../Tools/QtCreator/lib/Qt/lib/libqtk_library.a
 | 
				
			||||||
 | 
					-- Up-to-date: /home/shaun/Qt/6.5.0/gcc_64/../../Tools/QtCreator/lib/Qt/lib/libqtk_plugin_library.a
 | 
				
			||||||
 | 
					-- Up-to-date: /home/shaun/Qt/6.5.0/gcc_64/../../Tools/QtCreator/lib/Qt/plugins/designer/libqtk_collection.so
 | 
				
			||||||
```
 | 
					```
 | 
				
			||||||
 | 
					
 | 
				
			||||||
To uninstall after a previous installation, we can run the following command
 | 
					To uninstall after a previous installation, we can run the following command
 | 
				
			||||||
@ -187,16 +161,22 @@ from the root of the repository.
 | 
				
			|||||||
xargs rm < build/install_manifest.txt
 | 
					xargs rm < build/install_manifest.txt
 | 
				
			||||||
```
 | 
					```
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#### Windows / MacOS
 | 
					#### Qtk Example
 | 
				
			||||||
 | 
					
 | 
				
			||||||
If you are building on **Windows / Mac**, consider setting
 | 
					There is a simple example of using libqtk in the [example-app/](example-app)
 | 
				
			||||||
the `-DASSIMP_NEW_INTERFACE` build flag.
 | 
					directory. The example can be built standalone using `find_package` or as a
 | 
				
			||||||
 | 
					target within any qtk build.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
```bash
 | 
					```bash
 | 
				
			||||||
cmake -S qtk/ -B qtk/build/  -DASSIMP_NEW_INTERFACE=ON -DCMAKE_PREFIX_PATH=$HOME/Qt/6.5.0/gcc_64;/path/to/assimp/
 | 
					# Build the example from a configured qtk build tree
 | 
				
			||||||
cmake --build qtk/build/ -j $(nproc --ignore=2)
 | 
					cmake --build build-all/ --target qtk_example -- -j $(nproc)
 | 
				
			||||||
 | 
					cmake --install build-all/ --component qtk_example --prefix=install
 | 
				
			||||||
 | 
					./install/bin/qtk_example
 | 
				
			||||||
```
 | 
					```
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					See the README in the [example-app/](example-app) subdirectory for instructions
 | 
				
			||||||
 | 
					on standalone builds.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
### Controls
 | 
					### Controls
 | 
				
			||||||
 | 
					
 | 
				
			||||||
You can fly around the scene if you hold the right mouse button and use WASD.
 | 
					You can fly around the scene if you hold the right mouse button and use WASD.
 | 
				
			||||||
@ -253,7 +233,7 @@ CLion automatically.
 | 
				
			|||||||
# Move to the root of the repo
 | 
					# Move to the root of the repo
 | 
				
			||||||
cd qtk
 | 
					cd qtk
 | 
				
			||||||
# Build
 | 
					# Build
 | 
				
			||||||
cmake -B build && cmake --build build
 | 
					cmake -B build && cmake --build build -- -j $(nproc)
 | 
				
			||||||
clang-tidy -p build/ --fix --config-file=.clang-tidy src/*.cpp src/*.h app/*.cpp app/*.h
 | 
					clang-tidy -p build/ --fix --config-file=.clang-tidy src/*.cpp src/*.h app/*.cpp app/*.h
 | 
				
			||||||
```
 | 
					```
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -261,7 +241,7 @@ Last we need to run `clang-format`, this can be done with the command directly.
 | 
				
			|||||||
This will reformat all the code in the repository.
 | 
					This will reformat all the code in the repository.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
```bash
 | 
					```bash
 | 
				
			||||||
clang-format -i --style=file:.clang-format src/*.cpp src/*.h app/*.cpp app/*.h
 | 
					clang-format -i --style=file:.clang-format src/app/*.cpp src/app/*.h src/qtk/*.cpp src/qtk/*.h example-app/*.cpp example-app/*.h
 | 
				
			||||||
```
 | 
					```
 | 
				
			||||||
 | 
					
 | 
				
			||||||
`clang-format` can be run with git integration (or CLion if you prefer).
 | 
					`clang-format` can be run with git integration (or CLion if you prefer).
 | 
				
			||||||
@ -320,12 +300,8 @@ Any of the above options can be appended with `--trace-expand` to debug package
 | 
				
			|||||||
generation issues.
 | 
					generation issues.
 | 
				
			||||||
The contents of all packages will depend on how the build was configured.
 | 
					The contents of all packages will depend on how the build was configured.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
If we are generating packages for *only* libqtk, we
 | 
					 | 
				
			||||||
set `-DQTK_INSTALL_LIBRARY=ON`
 | 
					 | 
				
			||||||
during the cmake configuration step.
 | 
					 | 
				
			||||||
To generate packages for Qtk desktop application, we should
 | 
					To generate packages for Qtk desktop application, we should
 | 
				
			||||||
set `-DQTK_BUILD_GUI=ON`, and optionally `-DQTK_INSTALL_LIBRARY=ON` if we would
 | 
					set `-DQTK_GUI=ON`. If this option is not set we will only package libqtk.
 | 
				
			||||||
like to bundle libqtk with the desktop application.
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
The NSIS installer will allow component-specific path modification for all of
 | 
					The NSIS installer will allow component-specific path modification for all of
 | 
				
			||||||
these installation components through a GUI install application.
 | 
					these installation components through a GUI install application.
 | 
				
			||||||
 | 
				
			|||||||
@ -10,7 +10,7 @@ find_package(Git)
 | 
				
			|||||||
# _PATH: Path to git submodule location that we want to update
 | 
					# _PATH: Path to git submodule location that we want to update
 | 
				
			||||||
# + submodule_update(extern/assimp)
 | 
					# + submodule_update(extern/assimp)
 | 
				
			||||||
function(submodule_update _PATH)
 | 
					function(submodule_update _PATH)
 | 
				
			||||||
  if (NOT QTK_UPDATE_SUBMODULES)
 | 
					  if (NOT QTK_SUBMODULES)
 | 
				
			||||||
    return()
 | 
					    return()
 | 
				
			||||||
  endif()
 | 
					  endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -2,8 +2,12 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
include("${CMAKE_CURRENT_LIST_DIR}/QtkTargets.cmake")
 | 
					include("${CMAKE_CURRENT_LIST_DIR}/QtkTargets.cmake")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
set_and_check(QTK_EXECUTABLE "${PACKAGE_PREFIX_DIR}/bin/qtk_app")
 | 
					set_and_check(QTK_EXECUTABLE "${PACKAGE_PREFIX_DIR}/bin/qtk_gui")
 | 
				
			||||||
set_and_check(QTK_INCLUDE_DIR "${PACKAGE_PREFIX_DIR}/include")
 | 
					set_and_check(QTK_INCLUDE_DIR "${PACKAGE_PREFIX_DIR}/include")
 | 
				
			||||||
set_and_check(QTK_LIBRARIES "${PACKAGE_PREFIX_DIR}/lib")
 | 
					set_and_check(QTK_LIBRARIES "${PACKAGE_PREFIX_DIR}/lib")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					set_and_check(Qtk_EXECUTABLE "${PACKAGE_PREFIX_DIR}/bin/qtk_gui")
 | 
				
			||||||
 | 
					set_and_check(Qtk_INCLUDE_DIR "${PACKAGE_PREFIX_DIR}/include")
 | 
				
			||||||
 | 
					set_and_check(Qtk_LIBRARIES "${PACKAGE_PREFIX_DIR}/lib")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
check_required_components(Qtk)
 | 
					check_required_components(Qtk)
 | 
				
			||||||
 | 
				
			|||||||
@ -22,7 +22,11 @@ if(CMAKE_CXX_COMPILER_ID MATCHES "MSVC")
 | 
				
			|||||||
endif()
 | 
					endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# If you did not install Qtk on a system path, point cmake to installation.
 | 
					# If you did not install Qtk on a system path, point cmake to installation.
 | 
				
			||||||
set(QTK_PATH /usr/local CACHE PATH  "Path to installation of Qtk")
 | 
					set(
 | 
				
			||||||
 | 
					    QTK_PATH ../build/install/lib/cmake/Qtk
 | 
				
			||||||
 | 
					    CACHE PATH  "Path to installation of Qtk"
 | 
				
			||||||
 | 
					    FORCE
 | 
				
			||||||
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# If you did not install Qt6 on a system path, point cmake to installation.
 | 
					# If you did not install Qt6 on a system path, point cmake to installation.
 | 
				
			||||||
set(QT_INSTALL_DIR "$ENV{HOME}/Qt/6.5.0/gcc_64/" CACHE PATH "Path to Qt6")
 | 
					set(QT_INSTALL_DIR "$ENV{HOME}/Qt/6.5.0/gcc_64/" CACHE PATH "Path to Qt6")
 | 
				
			||||||
@ -40,12 +44,6 @@ project(
 | 
				
			|||||||
list(APPEND CMAKE_PREFIX_PATH "${QTK_PATH}")
 | 
					list(APPEND CMAKE_PREFIX_PATH "${QTK_PATH}")
 | 
				
			||||||
list(APPEND CMAKE_PREFIX_PATH "${QT_INSTALL_DIR}")
 | 
					list(APPEND CMAKE_PREFIX_PATH "${QT_INSTALL_DIR}")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Allow add_subdirectory on this project to use target ALIAS if available.
 | 
					 | 
				
			||||||
# If this example project is opened standalone we will use find_package.
 | 
					 | 
				
			||||||
if(NOT TARGET Qtk::qtk_library)
 | 
					 | 
				
			||||||
  find_package(Qtk 0.2 REQUIRED)
 | 
					 | 
				
			||||||
endif()
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# Print all QTK variables
 | 
					# Print all QTK variables
 | 
				
			||||||
if (NOT Qtk_IS_TOP_LEVEL)
 | 
					if (NOT Qtk_IS_TOP_LEVEL)
 | 
				
			||||||
  get_cmake_property(VAR_NAMES VARIABLES)
 | 
					  get_cmake_property(VAR_NAMES VARIABLES)
 | 
				
			||||||
@ -56,6 +54,12 @@ if (NOT Qtk_IS_TOP_LEVEL)
 | 
				
			|||||||
  endforeach()
 | 
					  endforeach()
 | 
				
			||||||
endif()
 | 
					endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# Allow add_subdirectory on this project to use target ALIAS if available.
 | 
				
			||||||
 | 
					# If this example project is opened standalone we will use find_package.
 | 
				
			||||||
 | 
					if(NOT TARGET Qtk::qtk_library)
 | 
				
			||||||
 | 
					  find_package(Qtk 0.2 REQUIRED)
 | 
				
			||||||
 | 
					endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
find_package(Qt6 COMPONENTS Core Widgets OpenGLWidgets REQUIRED)
 | 
					find_package(Qt6 COMPONENTS Core Widgets OpenGLWidgets REQUIRED)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
set(
 | 
					set(
 | 
				
			||||||
@ -65,6 +69,28 @@ set(
 | 
				
			|||||||
    examplewidget.cpp examplewidget.h
 | 
					    examplewidget.cpp examplewidget.h
 | 
				
			||||||
)
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
add_executable(example_app ${EXAMPLE_SOURCES})
 | 
					configure_file(
 | 
				
			||||||
target_link_libraries(example_app PUBLIC Qt6::Widgets Qt6::OpenGLWidgets Qt6::Core)
 | 
					    #[[INPUT]] "${CMAKE_CURRENT_SOURCE_DIR}/resources.h.in"
 | 
				
			||||||
target_link_libraries(example_app PUBLIC Qtk::qtk_library)
 | 
					    #[[OUTPUT]] "${CMAKE_CURRENT_BINARY_DIR}/resources.h"
 | 
				
			||||||
 | 
					    @ONLY
 | 
				
			||||||
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					qt_add_executable(qtk_example ${EXAMPLE_SOURCES})
 | 
				
			||||||
 | 
					target_link_libraries(qtk_example PUBLIC Qt6::Widgets Qt6::OpenGLWidgets Qt6::Core)
 | 
				
			||||||
 | 
					target_link_libraries(qtk_example PUBLIC Qtk::qtk_library)
 | 
				
			||||||
 | 
					target_include_directories(qtk_example PRIVATE "${CMAKE_CURRENT_BINARY_DIR}")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					install(
 | 
				
			||||||
 | 
					    TARGETS qtk_example
 | 
				
			||||||
 | 
					    COMPONENT qtk_example
 | 
				
			||||||
 | 
					    BUNDLE DESTINATION .
 | 
				
			||||||
 | 
					    LIBRARY DESTINATION lib
 | 
				
			||||||
 | 
					    ARCHIVE DESTINATION lib/static
 | 
				
			||||||
 | 
					    RUNTIME DESTINATION bin
 | 
				
			||||||
 | 
					)
 | 
				
			||||||
 | 
					qt_generate_deploy_app_script(
 | 
				
			||||||
 | 
					    TARGET qtk_example
 | 
				
			||||||
 | 
					    OUTPUT_SCRIPT QTK_EXAMPLE_DEPLOY_SCRIPT
 | 
				
			||||||
 | 
					    NO_UNSUPPORTED_PLATFORM_ERROR
 | 
				
			||||||
 | 
					)
 | 
				
			||||||
 | 
					install(SCRIPT ${QTK_EXAMPLE_DEPLOY_SCRIPT} COMPONENT qtk_example)
 | 
				
			||||||
 | 
				
			|||||||
@ -62,11 +62,12 @@ custom installation directory.
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
```bash
 | 
					```bash
 | 
				
			||||||
cmake -S /path/to/qtk/example-app/ -B /path/to/qtk/example-app/build -DQTK_PATH=/path/to/qtk/install/
 | 
					cmake -S /path/to/qtk/example-app/ -B /path/to/qtk/example-app/build -DQTK_PATH=/path/to/qtk/install/
 | 
				
			||||||
cmake --build /path/to/qtk/example-app/build
 | 
					cmake --build /path/to/qtk/example-app/build --target qtk_example -- -j $(nproc)
 | 
				
			||||||
 | 
					cmake --install build/ --component qtk_example
 | 
				
			||||||
```
 | 
					```
 | 
				
			||||||
 | 
					
 | 
				
			||||||
After this, we can run the example application -
 | 
					After this, we can run the example application -
 | 
				
			||||||
 | 
					
 | 
				
			||||||
```bash
 | 
					```bash
 | 
				
			||||||
./path/to/qtk/example-app/build/bin/example
 | 
					./path/to/qtk/example-app/build/install/bin/example
 | 
				
			||||||
```
 | 
					```
 | 
				
			||||||
 | 
				
			|||||||
@ -7,6 +7,7 @@
 | 
				
			|||||||
##############################################################################*/
 | 
					##############################################################################*/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#include "examplescene.h"
 | 
					#include "examplescene.h"
 | 
				
			||||||
 | 
					#include <resources.h>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
using namespace Qtk;
 | 
					using namespace Qtk;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -23,8 +24,10 @@ void ExampleScene::init() {
 | 
				
			|||||||
  setSkybox(skybox);
 | 
					  setSkybox(skybox);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  auto spartan = new Model(
 | 
					  auto spartan = new Model(
 | 
				
			||||||
      "spartan", "/home/kapper/Code/qtk/resources/models/spartan/spartan.obj");
 | 
					      "spartan", std::string(QTK_EXAMPLE_SOURCE_DIR)
 | 
				
			||||||
 | 
					                     + "/../resources/models/spartan/spartan.obj");
 | 
				
			||||||
  addObject(spartan);
 | 
					  addObject(spartan);
 | 
				
			||||||
 | 
					  spartan->getTransform().setTranslation(-4.0f, 0.0f, 0.0f);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  auto mesh = addObject(
 | 
					  auto mesh = addObject(
 | 
				
			||||||
      new Qtk::MeshRenderer("rightTriangle", Triangle(QTK_DRAW_ARRAYS)));
 | 
					      new Qtk::MeshRenderer("rightTriangle", Triangle(QTK_DRAW_ARRAYS)));
 | 
				
			||||||
 | 
				
			|||||||
							
								
								
									
										6
									
								
								example-app/resources.h.in
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								example-app/resources.h.in
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,6 @@
 | 
				
			|||||||
 | 
					#ifndef QTK_RESOURCES_H_IN_H
 | 
				
			||||||
 | 
					#define QTK_RESOURCES_H_IN_H
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define QTK_EXAMPLE_SOURCE_DIR "@CMAKE_CURRENT_SOURCE_DIR@"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#endif  // QTK_RESOURCES_H_IN_H
 | 
				
			||||||
@ -13,14 +13,14 @@ install(
 | 
				
			|||||||
    FILES
 | 
					    FILES
 | 
				
			||||||
    "${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}Config.cmake"
 | 
					    "${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}Config.cmake"
 | 
				
			||||||
    "${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}ConfigVersion.cmake"
 | 
					    "${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}ConfigVersion.cmake"
 | 
				
			||||||
    COMPONENT libqtk
 | 
					    COMPONENT qtk_library
 | 
				
			||||||
    DESTINATION lib/cmake/${PROJECT_NAME}
 | 
					    DESTINATION lib/cmake/${PROJECT_NAME}
 | 
				
			||||||
)
 | 
					)
 | 
				
			||||||
install(
 | 
					install(
 | 
				
			||||||
    EXPORT qtk_export
 | 
					    EXPORT qtk_export
 | 
				
			||||||
    FILE ${PROJECT_NAME}Targets.cmake
 | 
					    FILE ${PROJECT_NAME}Targets.cmake
 | 
				
			||||||
    NAMESPACE ${PROJECT_NAME}::
 | 
					    NAMESPACE ${PROJECT_NAME}::
 | 
				
			||||||
    COMPONENT libqtk
 | 
					    COMPONENT qtk_library
 | 
				
			||||||
    DESTINATION lib/cmake/${PROJECT_NAME}
 | 
					    DESTINATION lib/cmake/${PROJECT_NAME}
 | 
				
			||||||
)
 | 
					)
 | 
				
			||||||
# System install for qtk_library
 | 
					# System install for qtk_library
 | 
				
			||||||
@ -28,53 +28,45 @@ install(
 | 
				
			|||||||
    TARGETS qtk_library
 | 
					    TARGETS qtk_library
 | 
				
			||||||
    # Associate qtk_library target with qtk-export
 | 
					    # Associate qtk_library target with qtk-export
 | 
				
			||||||
    EXPORT qtk_export
 | 
					    EXPORT qtk_export
 | 
				
			||||||
    COMPONENT libqtk
 | 
					    COMPONENT qtk_library
 | 
				
			||||||
    FILE_SET HEADERS DESTINATION include
 | 
					    FILE_SET HEADERS DESTINATION include
 | 
				
			||||||
    INCLUDES DESTINATION include
 | 
					    INCLUDES DESTINATION include
 | 
				
			||||||
    LIBRARY DESTINATION lib
 | 
					    LIBRARY DESTINATION lib
 | 
				
			||||||
    ARCHIVE DESTINATION lib/static
 | 
					    ARCHIVE DESTINATION lib
 | 
				
			||||||
    RUNTIME DESTINATION bin
 | 
					    RUNTIME DESTINATION bin
 | 
				
			||||||
)
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Qtk Application
 | 
					# Qtk Application
 | 
				
			||||||
if(QTK_BUILD_GUI OR QTK_INSTALL_PLUGINS)
 | 
					if(QTK_GUI OR QTK_PLUGINS)
 | 
				
			||||||
  add_subdirectory(app)
 | 
					  add_subdirectory(app)
 | 
				
			||||||
endif()
 | 
					endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if(QTK_INSTALL_PLUGINS)
 | 
					if(QTK_PLUGINS)
 | 
				
			||||||
  # Optionally install custom Qtk plugins for Qt Designer.
 | 
					 | 
				
			||||||
  install(
 | 
					  install(
 | 
				
			||||||
      TARGETS qtk_library qtk_plugin_library
 | 
					      TARGETS qtk_plugins qtk_library qtk_plugin_library
 | 
				
			||||||
      COMPONENT collection
 | 
					      COMPONENT qtk_plugins
 | 
				
			||||||
      LIBRARY DESTINATION "${QTK_PLUGIN_LIBRARY_DIR}"
 | 
					 | 
				
			||||||
      ARCHIVE DESTINATION "${QTK_PLUGIN_LIBRARY_DIR}"
 | 
					 | 
				
			||||||
      RUNTIME DESTINATION "${QTK_PLUGIN_LIBRARY_DIR}"
 | 
					 | 
				
			||||||
  )
 | 
					 | 
				
			||||||
  install(
 | 
					 | 
				
			||||||
      TARGETS qtk_collection
 | 
					 | 
				
			||||||
      COMPONENT collection
 | 
					 | 
				
			||||||
      LIBRARY DESTINATION "${QTK_PLUGIN_INSTALL_DIR}"
 | 
					      LIBRARY DESTINATION "${QTK_PLUGIN_INSTALL_DIR}"
 | 
				
			||||||
      ARCHIVE DESTINATION "${QTK_PLUGIN_INSTALL_DIR}"
 | 
					      ARCHIVE DESTINATION "${QTK_PLUGIN_INSTALL_DIR}"
 | 
				
			||||||
      RUNTIME DESTINATION "${QTK_PLUGIN_INSTALL_DIR}"
 | 
					      RUNTIME DESTINATION "${QTK_PLUGIN_INSTALL_DIR}"
 | 
				
			||||||
  )
 | 
					  )
 | 
				
			||||||
endif()
 | 
					endif()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if(QTK_BUILD_GUI)
 | 
					if(QTK_GUI)
 | 
				
			||||||
  install(
 | 
					  install(
 | 
				
			||||||
      TARGETS qtk_app
 | 
					      TARGETS qtk_gui
 | 
				
			||||||
      COMPONENT qtk
 | 
					      COMPONENT qtk_gui
 | 
				
			||||||
      BUNDLE DESTINATION .
 | 
					      BUNDLE DESTINATION .
 | 
				
			||||||
      LIBRARY DESTINATION lib
 | 
					      LIBRARY DESTINATION lib
 | 
				
			||||||
      ARCHIVE DESTINATION lib/static
 | 
					      ARCHIVE DESTINATION lib
 | 
				
			||||||
      RUNTIME DESTINATION bin
 | 
					      RUNTIME DESTINATION bin
 | 
				
			||||||
  )
 | 
					  )
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  qt_generate_deploy_app_script(
 | 
					  qt_generate_deploy_app_script(
 | 
				
			||||||
      TARGET qtk_app
 | 
					      TARGET qtk_gui
 | 
				
			||||||
      OUTPUT_SCRIPT QTK_DEPLOY_SCRIPT
 | 
					      OUTPUT_SCRIPT QTK_DEPLOY_SCRIPT
 | 
				
			||||||
      NO_UNSUPPORTED_PLATFORM_ERROR
 | 
					      NO_UNSUPPORTED_PLATFORM_ERROR
 | 
				
			||||||
  )
 | 
					  )
 | 
				
			||||||
  install(SCRIPT ${QTK_DEPLOY_SCRIPT} COMPONENT qtk)
 | 
					  install(SCRIPT ${QTK_DEPLOY_SCRIPT} COMPONENT qtk_gui)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  if(WIN32)
 | 
					  if(WIN32)
 | 
				
			||||||
    if(MSVC AND TARGET Qt6::qmake)
 | 
					    if(MSVC AND TARGET Qt6::qmake)
 | 
				
			||||||
@ -87,7 +79,7 @@ if(QTK_BUILD_GUI)
 | 
				
			|||||||
      )
 | 
					      )
 | 
				
			||||||
      file(TO_NATIVE_PATH "${QT6_INSTALL_PREFIX}/bin" QT6_INSTALL_PREFIX)
 | 
					      file(TO_NATIVE_PATH "${QT6_INSTALL_PREFIX}/bin" QT6_INSTALL_PREFIX)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      set(VSUSER_FILE "${CMAKE_CURRENT_BINARY_DIR}/qtk_app.vcxproj.user")
 | 
					      set(VSUSER_FILE "${CMAKE_CURRENT_BINARY_DIR}/qtk_gui.vcxproj.user")
 | 
				
			||||||
      file(WRITE ${VSUSER_FILE} "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n")
 | 
					      file(WRITE ${VSUSER_FILE} "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n")
 | 
				
			||||||
      file(APPEND ${VSUSER_FILE} "<Project xmlns=\"http://schemas.microsoft.com/developer/msbuild/2003\">\n")
 | 
					      file(APPEND ${VSUSER_FILE} "<Project xmlns=\"http://schemas.microsoft.com/developer/msbuild/2003\">\n")
 | 
				
			||||||
      file(APPEND ${VSUSER_FILE} "  <PropertyGroup>\n")
 | 
					      file(APPEND ${VSUSER_FILE} "  <PropertyGroup>\n")
 | 
				
			||||||
@ -124,7 +116,7 @@ set(CPACK_THREADS 0)
 | 
				
			|||||||
set(CPACK_PACKAGE_INSTALL_DIRECTORY "Qtk")
 | 
					set(CPACK_PACKAGE_INSTALL_DIRECTORY "Qtk")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Remove any assimp components if defined by submodule.
 | 
					# Remove any assimp components if defined by submodule.
 | 
				
			||||||
if (QTK_UPDATE_SUBMODULES)
 | 
					if (QTK_SUBMODULES)
 | 
				
			||||||
  get_cmake_property(CPACK_COMPONENTS_ALL COMPONENTS)
 | 
					  get_cmake_property(CPACK_COMPONENTS_ALL COMPONENTS)
 | 
				
			||||||
  list(FILTER CPACK_COMPONENTS_ALL EXCLUDE REGEX .*assimp.*)
 | 
					  list(FILTER CPACK_COMPONENTS_ALL EXCLUDE REGEX .*assimp.*)
 | 
				
			||||||
  list(REMOVE_ITEM CPACK_COMPONENTS_ALL Unspecified)
 | 
					  list(REMOVE_ITEM CPACK_COMPONENTS_ALL Unspecified)
 | 
				
			||||||
@ -136,7 +128,7 @@ set(CPACK_NSIS_ENABLE_UNINSTALL_BEFORE_INSTALL ON)
 | 
				
			|||||||
# https://nsis.sourceforge.io/Reference/CreateShortCut
 | 
					# https://nsis.sourceforge.io/Reference/CreateShortCut
 | 
				
			||||||
set(
 | 
					set(
 | 
				
			||||||
    CPACK_NSIS_CREATE_ICONS_EXTRA
 | 
					    CPACK_NSIS_CREATE_ICONS_EXTRA
 | 
				
			||||||
    "CreateShortCut '$SMPROGRAMS\\\\$STARTMENU_FOLDER\\\\Qtk.lnk' '$INSTDIR\\\\bin\\\\qtk_app.exe'"
 | 
					    "CreateShortCut '$SMPROGRAMS\\\\$STARTMENU_FOLDER\\\\Qtk.lnk' '$INSTDIR\\\\bin\\\\qtk_gui.exe'"
 | 
				
			||||||
)
 | 
					)
 | 
				
			||||||
set(
 | 
					set(
 | 
				
			||||||
    CPACK_NSIS_DELETE_ICONS_EXTRA
 | 
					    CPACK_NSIS_DELETE_ICONS_EXTRA
 | 
				
			||||||
@ -152,7 +144,7 @@ set(CPACK_DEBIAN_PACKAGE_SHLIBDEPS ON)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
# OSX
 | 
					# OSX
 | 
				
			||||||
set(CPACK_BUNDLE_NAME ${PROJECT_NAME})
 | 
					set(CPACK_BUNDLE_NAME ${PROJECT_NAME})
 | 
				
			||||||
set(CPACK_BUNDLE_PLIST $<TARGET_BUNDLE_CONTENT_DIR:qtk_app>/Info.plist)
 | 
					set(CPACK_BUNDLE_PLIST $<TARGET_BUNDLE_CONTENT_DIR:qtk_gui>/Info.plist)
 | 
				
			||||||
set(CPACK_BUNDLE_ICON ${QTK_OSX_ICONS})
 | 
					set(CPACK_BUNDLE_ICON ${QTK_OSX_ICONS})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Platform defaults for source bundles.
 | 
					# Platform defaults for source bundles.
 | 
				
			||||||
 | 
				
			|||||||
@ -33,32 +33,32 @@ target_sources(
 | 
				
			|||||||
target_link_libraries(qtk_plugin_library PUBLIC Qt6::UiPlugin qtk_library)
 | 
					target_link_libraries(qtk_plugin_library PUBLIC Qt6::UiPlugin qtk_library)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
################################################################################
 | 
					################################################################################
 | 
				
			||||||
# Qtk Widget Collection Plugin
 | 
					# Qtk Widget Plugins
 | 
				
			||||||
################################################################################
 | 
					################################################################################
 | 
				
			||||||
# Create a Qt Designer plugin for a collection of widgets from our library.
 | 
					# Create a Qt Designer plugin for a collection of widgets from our library.
 | 
				
			||||||
qt_add_plugin(qtk_collection SHARED)
 | 
					qt_add_plugin(qtk_plugins SHARED)
 | 
				
			||||||
target_sources(
 | 
					target_sources(
 | 
				
			||||||
    qtk_collection PRIVATE
 | 
					    qtk_plugins PRIVATE
 | 
				
			||||||
    widgetplugincollection.cpp widgetplugincollection.h
 | 
					    widgetplugincollection.cpp widgetplugincollection.h
 | 
				
			||||||
    widgetplugin.cpp widgetplugin.h
 | 
					    widgetplugin.cpp widgetplugin.h
 | 
				
			||||||
)
 | 
					)
 | 
				
			||||||
target_link_libraries(qtk_collection PUBLIC qtk_plugin_library)
 | 
					target_link_libraries(qtk_plugins PUBLIC qtk_plugin_library)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
################################################################################
 | 
					################################################################################
 | 
				
			||||||
# Final Qtk Application
 | 
					# Final Qtk Application
 | 
				
			||||||
################################################################################
 | 
					################################################################################
 | 
				
			||||||
 | 
					
 | 
				
			||||||
set(
 | 
					set(
 | 
				
			||||||
    QTK_APP_SOURCES
 | 
					    QTK_GUI_SOURCES
 | 
				
			||||||
    qtkscene.cpp qtkscene.h
 | 
					    qtkscene.cpp qtkscene.h
 | 
				
			||||||
    main.cpp
 | 
					    main.cpp
 | 
				
			||||||
)
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
qt_add_executable(qtk_app ${QTK_APP_SOURCES})
 | 
					qt_add_executable(qtk_gui ${QTK_GUI_SOURCES})
 | 
				
			||||||
target_link_libraries(qtk_app PRIVATE qtk_plugin_library)
 | 
					target_link_libraries(qtk_gui PRIVATE qtk_plugin_library)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
set_target_properties(
 | 
					set_target_properties(
 | 
				
			||||||
    qtk_app PROPERTIES
 | 
					    qtk_gui PROPERTIES
 | 
				
			||||||
      WIN32_EXECUTABLE TRUE
 | 
					      WIN32_EXECUTABLE TRUE
 | 
				
			||||||
      MACOSX_BUNDLE TRUE
 | 
					      MACOSX_BUNDLE TRUE
 | 
				
			||||||
      MACOSX_BUNDLE_BUNDLE_NAME Qtk
 | 
					      MACOSX_BUNDLE_BUNDLE_NAME Qtk
 | 
				
			||||||
 | 
				
			|||||||
@ -10,6 +10,11 @@
 | 
				
			|||||||
#include <QVBoxLayout>
 | 
					#include <QVBoxLayout>
 | 
				
			||||||
#include <QMimeData>
 | 
					#include <QMimeData>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include <qtk/input.h>
 | 
				
			||||||
 | 
					#include <qtk/scene.h>
 | 
				
			||||||
 | 
					#include <qtk/shape.h>
 | 
				
			||||||
 | 
					#include <QVBoxLayout>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#include <qtk/input.h>
 | 
					#include <qtk/input.h>
 | 
				
			||||||
#include <qtk/scene.h>
 | 
					#include <qtk/scene.h>
 | 
				
			||||||
#include <qtk/shape.h>
 | 
					#include <qtk/shape.h>
 | 
				
			||||||
@ -29,22 +34,8 @@ QtkWidget::QtkWidget(QWidget * parent) : QtkWidget(parent, "QtkWidget") {}
 | 
				
			|||||||
QtkWidget::QtkWidget(QWidget * parent, const QString & name) :
 | 
					QtkWidget::QtkWidget(QWidget * parent, const QString & name) :
 | 
				
			||||||
    QtkWidget(parent, name, Q_NULLPTR) {}
 | 
					    QtkWidget(parent, name, Q_NULLPTR) {}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
QtkWidget::QtkWidget(QWidget * parent, const QString & name, Scene * scene) :
 | 
					QtkWidget::QtkWidget(const QSurfaceFormat & format) :
 | 
				
			||||||
    QOpenGLWidget(parent), mDebugLogger(Q_NULLPTR),
 | 
					    mScene(Q_NULLPTR), mDebugLogger(Q_NULLPTR) {
 | 
				
			||||||
    mConsole(new DebugConsole(this, name)), mScene(Q_NULLPTR) {
 | 
					 | 
				
			||||||
  setAcceptDrops(true);
 | 
					 | 
				
			||||||
  setScene(scene);
 | 
					 | 
				
			||||||
  setObjectName(name);
 | 
					 | 
				
			||||||
  QSurfaceFormat format;
 | 
					 | 
				
			||||||
  format.setRenderableType(QSurfaceFormat::OpenGL);
 | 
					 | 
				
			||||||
  format.setProfile(QSurfaceFormat::CoreProfile);
 | 
					 | 
				
			||||||
  format.setVersion(4, 6);
 | 
					 | 
				
			||||||
  // Set the number of samples used for glEnable(GL_MULTISAMPLING)
 | 
					 | 
				
			||||||
  format.setSamples(4);
 | 
					 | 
				
			||||||
  // Set the size of the depth bufer for glEnable(GL_DEPTH_TEST)
 | 
					 | 
				
			||||||
  format.setDepthBufferSize(16);
 | 
					 | 
				
			||||||
  // If QTK_DEBUG is set, enable debug context
 | 
					 | 
				
			||||||
  format.setOption(QSurfaceFormat::DebugContext);
 | 
					 | 
				
			||||||
  setFormat(format);
 | 
					  setFormat(format);
 | 
				
			||||||
  setFocusPolicy(Qt::ClickFocus);
 | 
					  setFocusPolicy(Qt::ClickFocus);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
@ -198,6 +189,31 @@ void QtkWidget::mouseReleaseEvent(QMouseEvent * event) {
 | 
				
			|||||||
  Input::registerMouseRelease(event->button());
 | 
					  Input::registerMouseRelease(event->button());
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void QtkWidget::keyPressEvent(QKeyEvent * event) {
 | 
				
			||||||
 | 
					  if(event->isAutoRepeat()) {
 | 
				
			||||||
 | 
					    // Do not repeat input while a key is held down
 | 
				
			||||||
 | 
					    event->ignore();
 | 
				
			||||||
 | 
					  } else {
 | 
				
			||||||
 | 
					    Input::registerKeyPress(event->key());
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void QtkWidget::keyReleaseEvent(QKeyEvent * event) {
 | 
				
			||||||
 | 
					  if(event->isAutoRepeat()) {
 | 
				
			||||||
 | 
					    event->ignore();
 | 
				
			||||||
 | 
					  } else {
 | 
				
			||||||
 | 
					    Input::registerKeyRelease(event->key());
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void QtkWidget::mousePressEvent(QMouseEvent * event) {
 | 
				
			||||||
 | 
					  Input::registerMousePress(event->button());
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void QtkWidget::mouseReleaseEvent(QMouseEvent * event) {
 | 
				
			||||||
 | 
					  Input::registerMouseRelease(event->button());
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void QtkWidget::update() {
 | 
					void QtkWidget::update() {
 | 
				
			||||||
  updateCameraInput();
 | 
					  updateCameraInput();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -283,6 +299,44 @@ void QtkWidget::messageLogged(const QOpenGLDebugMessage & msg) {
 | 
				
			|||||||
void QtkWidget::teardownGL() { /* Nothing to teardown yet... */
 | 
					void QtkWidget::teardownGL() { /* Nothing to teardown yet... */
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void QtkWidget::updateCameraInput() {
 | 
				
			||||||
 | 
					  Input::update();
 | 
				
			||||||
 | 
					  // Camera Transformation
 | 
				
			||||||
 | 
					  if(Input::buttonPressed(Qt::RightButton)) {
 | 
				
			||||||
 | 
					    static const float transSpeed = 0.1f;
 | 
				
			||||||
 | 
					    static const float rotSpeed = 0.5f;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // Handle rotations
 | 
				
			||||||
 | 
					    Scene::getCamera().getTransform().rotate(
 | 
				
			||||||
 | 
					        -rotSpeed * Input::mouseDelta().x(), Camera3D::LocalUp);
 | 
				
			||||||
 | 
					    Scene::getCamera().getTransform().rotate(
 | 
				
			||||||
 | 
					        -rotSpeed * Input::mouseDelta().y(), Scene::getCamera().getRight());
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // Handle translations
 | 
				
			||||||
 | 
					    QVector3D translation;
 | 
				
			||||||
 | 
					    if(Input::keyPressed(Qt::Key_W)) {
 | 
				
			||||||
 | 
					      translation += Scene::getCamera().getForward();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    if(Input::keyPressed(Qt::Key_S)) {
 | 
				
			||||||
 | 
					      translation -= Scene::getCamera().getForward();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    if(Input::keyPressed(Qt::Key_A)) {
 | 
				
			||||||
 | 
					      translation -= Scene::getCamera().getRight();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    if(Input::keyPressed(Qt::Key_D)) {
 | 
				
			||||||
 | 
					      translation += Scene::getCamera().getRight();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    if(Input::keyPressed(Qt::Key_Q)) {
 | 
				
			||||||
 | 
					      translation -= Scene::getCamera().getUp() / 2.0f;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    if(Input::keyPressed(Qt::Key_E)) {
 | 
				
			||||||
 | 
					      translation += Scene::getCamera().getUp() / 2.0f;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    Scene::getCamera().getTransform().translate(transSpeed * translation);
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					void QtkWidget::teardownGL() { /* Nothing to teardown yet... */
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void QtkWidget::updateCameraInput() {
 | 
					void QtkWidget::updateCameraInput() {
 | 
				
			||||||
  Input::update();
 | 
					  Input::update();
 | 
				
			||||||
  // Camera Transformation
 | 
					  // Camera Transformation
 | 
				
			||||||
 | 
				
			|||||||
@ -68,7 +68,7 @@ target_link_libraries(
 | 
				
			|||||||
    Qt6::Core Qt6::OpenGLWidgets Qt6::Widgets
 | 
					    Qt6::Core Qt6::OpenGLWidgets Qt6::Widgets
 | 
				
			||||||
)
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if(QTK_UPDATE_SUBMODULES OR NOT ASSIMP_NEW_INTERFACE)
 | 
					if(QTK_SUBMODULES OR NOT ASSIMP_NEW_INTERFACE)
 | 
				
			||||||
  target_link_libraries(qtk_library PUBLIC assimp)
 | 
					  target_link_libraries(qtk_library PUBLIC assimp)
 | 
				
			||||||
elseif(ASSIMP_NEW_INTERFACE)
 | 
					elseif(ASSIMP_NEW_INTERFACE)
 | 
				
			||||||
  target_link_libraries(qtk_library PUBLIC assimp::assimp)
 | 
					  target_link_libraries(qtk_library PUBLIC assimp::assimp)
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user