aboutsummaryrefslogtreecommitdiff
path: root/.github
diff options
context:
space:
mode:
author Spartan322 <Megacake1234@gmail.com>2023-09-02 15:03:14 +0200
committer Spartan322 <Megacake1234@gmail.com>2023-09-02 19:20:25 +0200
commitdbc66788a680daf3f8a1c0c6e7fbd1b77cc06864 (patch)
tree288a1530b1f3cd2d7ba2bb5821e2c4160725707c /.github
parentf990117e56060811ddd2a850ec712485aea79649 (diff)
Add github actions and workflow
Diffstat (limited to '.github')
-rw-r--r--.github/actions/dataloader-build/action.yml32
-rw-r--r--.github/actions/dataloader-cache/action.yml22
-rw-r--r--.github/actions/mingw-cache/action.yml18
-rw-r--r--.github/workflows/builds.yml140
4 files changed, 212 insertions, 0 deletions
diff --git a/.github/actions/dataloader-build/action.yml b/.github/actions/dataloader-build/action.yml
new file mode 100644
index 0000000..36caebd
--- /dev/null
+++ b/.github/actions/dataloader-build/action.yml
@@ -0,0 +1,32 @@
+name: Build OpenVic-Dataloader
+description: Build OpenVic-Dataloader with provided options.
+inputs:
+ target:
+ description: Build target (editor, template_release, template_debug).
+ default: "template_release"
+ platform:
+ description: Target platform.
+ required: false
+ sconsflags:
+ default: ""
+ scons-cache:
+ description: The scons cache path.
+ default: "${{ github.workspace }}/.scons-cache/"
+ scons-cache-limit:
+ description: The scons cache size limit.
+ # actions/cache has 10 GiB limit, and GitHub runners have a 14 GiB disk.
+ # Limit to 7 GiB to avoid having the extracted cache fill the disk.
+ default: 7168
+runs:
+ using: "composite"
+ steps:
+ - name: Scons Build
+ shell: sh
+ env:
+ SCONSFLAGS: ${{ inputs.sconsflags }}
+ SCONS_CACHE: ${{ inputs.scons-cache }}
+ SCONS_CACHE_LIMIT: ${{ inputs.scons-cache-limit }}
+ run: |
+ echo "Building with flags:" platform=${{ inputs.platform }} target=${{ inputs.target }} ${{ env.SCONSFLAGS }}
+ scons platform=${{ inputs.platform }} target=${{ inputs.target }} ${{ env.SCONSFLAGS }}
+ ls -l bin/
diff --git a/.github/actions/dataloader-cache/action.yml b/.github/actions/dataloader-cache/action.yml
new file mode 100644
index 0000000..c913216
--- /dev/null
+++ b/.github/actions/dataloader-cache/action.yml
@@ -0,0 +1,22 @@
+name: Setup OpenVic-Dataloader Build Cache
+description: Setup OpenVic-Dataloader Build Cache
+inputs:
+ cache-name:
+ description: The cache base name (job name by default).
+ default: "${{github.job}}"
+ scons-cache:
+ description: The scons cache path.
+ default: "${{github.workspace}}/.scons-cache/"
+runs:
+ using: "composite"
+ steps:
+ # Upload cache on completion and check it out now
+ - name: Load .scons_cache directory
+ uses: actions/cache@v3
+ with:
+ path: ${{inputs.scons-cache}}
+ key: ${{inputs.cache-name}}-${{env.OVDL_BASE_BRANCH}}-${{github.ref}}-${{github.sha}}
+ restore-keys: |
+ ${{inputs.cache-name}}-${{env.OVDL_BASE_BRANCH}}-${{github.ref}}-${{github.sha}}
+ ${{inputs.cache-name}}-${{env.OVDL_BASE_BRANCH}}-${{github.ref}}
+ ${{inputs.cache-name}}-${{env.OVDL_BASE_BRANCH}}
diff --git a/.github/actions/mingw-cache/action.yml b/.github/actions/mingw-cache/action.yml
new file mode 100644
index 0000000..e92962d
--- /dev/null
+++ b/.github/actions/mingw-cache/action.yml
@@ -0,0 +1,18 @@
+name: Setup MinGW Cache
+description: Setup MinGW Cache
+inputs:
+ cache-key:
+ description: Name for MinGW cache key.
+ default: "mingw-cache"
+runs:
+ using: "composite"
+ steps:
+ # Upload cache on completion and check it out now
+ - name: Load MinGW Cache
+ id: cache-mingw
+ uses: actions/cache@v3
+ with:
+ path: C:\ProgramData\chocolatey\lib\mingw
+ key: ${{inputs.cache-key}}
+ - name: Setup MinGW for build
+ uses: egor-tensin/setup-mingw@v2 \ No newline at end of file
diff --git a/.github/workflows/builds.yml b/.github/workflows/builds.yml
new file mode 100644
index 0000000..0e0bcfe
--- /dev/null
+++ b/.github/workflows/builds.yml
@@ -0,0 +1,140 @@
+name: Builds
+
+on: [push, pull_request]
+
+env:
+ OVDL_BASE_BRANCH: master
+
+concurrency:
+ group: ci-${{github.actor}}-${{github.head_ref || github.run_number}}-${{github.ref}}-macos
+ cancel-in-progress: true
+
+jobs:
+ build:
+ runs-on: ${{matrix.os}}
+ name: ${{matrix.name}}
+ permissions: write-all
+ strategy:
+ fail-fast: false
+ matrix:
+ include:
+ - identifier: windows-debug
+ os: windows-latest
+ name: 🏁 Windows Debug
+ target: template_debug
+ platform: windows
+ arch: x86_64
+ - identifier: windows-release
+ os: windows-latest
+ name: 🏁 Windows Release
+ target: template_release
+ platform: windows
+ arch: x86_64
+ - identifier: macos-debug
+ os: macos-latest
+ name: 🍎 macOS (universal) Debug
+ target: template_debug
+ platform: macos
+ arch: universal
+ - identifier: macos-release
+ os: macos-latest
+ name: 🍎 macOS (universal) Release
+ target: template_release
+ platform: macos
+ arch: universal
+ - identifier: linux-debug
+ os: ubuntu-latest
+ name: 🐧 Linux Debug
+ runner: ubuntu-20.04
+ target: template_debug
+ platform: linux
+ arch: x86_64
+ - identifier: linux-release
+ os: ubuntu-latest
+ name: 🐧 Linux Release
+ runner: ubuntu-20.04
+ target: template_release
+ platform: linux
+ arch: x86_64
+
+ steps:
+ - name: Checkout project
+ uses: actions/checkout@v3.3.0
+ with:
+ submodules: recursive
+
+ - name: Setup OpenVic-Dataloader build cache
+ uses: ./.github/actions/dataloader-cache
+ with:
+ cache-name: ${{ matrix.identifier }}
+ continue-on-error: true
+
+ - name: Set up Python
+ uses: actions/setup-python@v4
+ with:
+ python-version: "3.x"
+
+ - name: Set up SCons
+ shell: bash
+ run: |
+ python -c "import sys; print(sys.version)"
+ python -m pip install scons
+ scons --version
+
+ - name: Linux dependencies
+ if: ${{ matrix.platform == 'linux' }}
+ run: |
+ sudo apt-get update -qq
+ sudo apt-get install -qqq build-essential pkg-config
+ g++ --version
+ sudo update-alternatives --install /usr/bin/g++ g++ /usr/bin/g++-12 12
+ sudo update-alternatives --set g++ /usr/bin/g++-12
+ g++ --version
+
+ - name: Setup MinGW for Windows/MinGW build
+ if: ${{ matrix.platform == 'windows' }}
+ uses: ./.github/actions/mingw-cache
+
+ - name: Compile Dataloader
+ uses: ./.github/actions/dataloader-build
+ with:
+ platform: ${{ matrix.platform }}
+ target: ${{ matrix.target }}
+ sconsflags: arch=${{ matrix.arch }} build_ovdl_library=yes
+
+ - name: Delete compilation files
+ if: ${{ matrix.platform == 'windows' }}
+ run: |
+ Remove-Item bin/* -Include *.exp,*.pdb -Force
+
+ - name: Upload library artifact
+ uses: actions/upload-artifact@v3
+ with:
+ name: ${{ github.event.repository.name }}-library
+ path: |
+ ${{ github.workspace }}/bin/libopenvic-dataloader.*
+
+ - name: Upload executable artifact
+ uses: actions/upload-artifact@v3
+ with:
+ name: ${{ github.event.repository.name }}-executable
+ path: |
+ ${{ github.workspace }}/bin/openvic-dataloader.headless.*
+
+ - name: Archive Release
+ uses: thedoctor0/zip-release@0.7.1
+ with:
+ type: "zip"
+ filename: "../../../libopenvic-dataloader.${{ matrix.platform }}.${{ matrix.arch }}.zip"
+ directory: "${{ github.workspace }}/bin/"
+ if: github.event_name == 'push' && startsWith(github.ref, 'refs/tags')
+
+ - name: Create and upload asset
+ uses: ncipollo/release-action@v1
+ with:
+ allowUpdates: true
+ artifacts: "libopenvic-dataloader.${{ matrix.platform }}.${{ matrix.arch }}.zip"
+ omitNameDuringUpdate: true
+ omitBodyDuringUpdate: true
+ token: ${{ secrets.GITHUB_TOKEN }}
+ if: github.event_name == 'push' && startsWith(github.ref, 'refs/tags')