diff --git a/.github/workflows/cmake-multi-platform.yml b/.github/workflows/cmake-multi-platform.yml index 7ab1b4d..699723c 100644 --- a/.github/workflows/cmake-multi-platform.yml +++ b/.github/workflows/cmake-multi-platform.yml @@ -1,6 +1,4 @@ -# This starter workflow is for a CMake project running on multiple platforms. There is a different starter workflow if you just want a single platform. -# See: https://github.com/actions/starter-workflows/blob/main/ci/cmake-single-platform.yml -name: CMake on multiple platforms +name: Build and Release on: push: @@ -10,66 +8,77 @@ on: jobs: build: - runs-on: ${{ matrix.os }} - strategy: - # Set fail-fast to false to ensure that feedback is delivered for all matrix combinations. Consider changing this to true when your workflow is stable. - fail-fast: false - - # Set up a matrix to run the following 3 configurations: - # 1. - # 2. - # 3. - # - # To add more build types (Release, Debug, RelWithDebInfo, etc.) customize the build_type list. matrix: os: [ubuntu-latest, windows-latest] - build_type: [Release] - c_compiler: [gcc, clang, cl] - include: - - os: windows-latest - c_compiler: cl - cpp_compiler: cl - - os: ubuntu-latest - c_compiler: gcc - cpp_compiler: g++ - - os: ubuntu-latest - c_compiler: clang - cpp_compiler: clang++ - exclude: - - os: windows-latest - c_compiler: gcc - - os: windows-latest - c_compiler: clang - - os: ubuntu-latest - c_compiler: cl + runs-on: ${{ matrix.os }} steps: - - uses: actions/checkout@v4 + - name: Checkout Repository + uses: actions/checkout@v4 + + # Linux Build Steps + - name: Install Dependencies (Linux) + if: runner.os == 'Linux' + run: | + sudo apt-get update + sudo apt-get install -y \ + build-essential \ + cmake \ + libsdl2-dev \ + libsdl2-image-dev \ + libsdl2-ttf-dev + + - name: Configure CMake (Linux) + if: runner.os == 'Linux' + run: cmake -S . -B build -DCMAKE_BUILD_TYPE=Release + + - name: Build (Linux) + if: runner.os == 'Linux' + run: cmake --build build --config Release - - name: Set reusable strings - # Turn repeated input strings (such as the build output directory) into step outputs. These step outputs can be used throughout the workflow file. - id: strings - shell: bash + - name: Prepare Release Directory (Linux) + if: runner.os == 'Linux' run: | - echo "build-output-dir=${{ github.workspace }}/build" >> "$GITHUB_OUTPUT" + mkdir -p release + cp build/campo_de_batalha release/ + cp -r resources release/ - - name: Configure CMake - # Configure CMake in a 'build' subdirectory. `CMAKE_BUILD_TYPE` is only required if you are using a single-configuration generator such as make. - # See https://cmake.org/cmake/help/latest/variable/CMAKE_BUILD_TYPE.html?highlight=cmake_build_type - run: > - cmake -B ${{ steps.strings.outputs.build-output-dir }} - -DCMAKE_CXX_COMPILER=${{ matrix.cpp_compiler }} - -DCMAKE_C_COMPILER=${{ matrix.c_compiler }} - -DCMAKE_BUILD_TYPE=${{ matrix.build_type }} - -S ${{ github.workspace }} + - name: Upload Release Artifact (Linux) + if: runner.os == 'Linux' + uses: actions/upload-artifact@v3 + with: + name: CampoDeBatalha-Linux + path: release/ - - name: Build - # Build your program with the given configuration. Note that --config is needed because the default Windows generator is a multi-config generator (Visual Studio generator). - run: cmake --build ${{ steps.strings.outputs.build-output-dir }} --config ${{ matrix.build_type }} + # Windows Build Steps (Placeholder) + - name: Install Dependencies (Windows) + if: runner.os == 'Windows' + run: | + echo "Installing dependencies on Windows..." + # TODO: Add Windows dependency installation commands here + + - name: Configure CMake (Windows) + if: runner.os == 'Windows' + run: | + echo "Configuring CMake on Windows..." + # TODO: Add CMake configuration commands for Windows + + - name: Build (Windows) + if: runner.os == 'Windows' + run: | + echo "Building on Windows..." + # TODO: Add build commands for Windows + + - name: Prepare Release Directory (Windows) + if: runner.os == 'Windows' + run: | + echo "Preparing release directory on Windows..." + # TODO: Add commands to prepare the release directory on Windows - - name: Test - working-directory: ${{ steps.strings.outputs.build-output-dir }} - # Execute tests defined by the CMake configuration. Note that --build-config is needed because the default Windows generator is a multi-config generator (Visual Studio generator). - # See https://cmake.org/cmake/help/latest/manual/ctest.1.html for more detail - run: ctest --build-config ${{ matrix.build_type }} + - name: Upload Release Artifact (Windows) + if: runner.os == 'Windows' + uses: actions/upload-artifact@v3 + with: + name: CampoDeBatalha-Windows + path: release/ diff --git a/Makefile b/Makefile index 02144f6..e0bec48 100644 --- a/Makefile +++ b/Makefile @@ -42,6 +42,15 @@ build-linux: @cd $(BUILD_DIR) && $(CMAKE) $(CMAKE_GENERATOR_LINUX) .. && $(MAKE_CMD) @mv $(BUILD_DIR)/$(PROJECT) . +build-linux-release: + @echo "Starting release build process on Linux..." + @mkdir -p $(BUILD_DIR) + @cd $(BUILD_DIR) && $(CMAKE) $(CMAKE_GENERATOR_LINUX) .. && $(MAKE_CMD) + @rm -rf release + @mkdir release + @cp $(BUILD_DIR)/$(PROJECT) release/ + @cp -r resources release/ + # Clean target clean: @echo "Cleaning project..."