From 4854fd0aab602282499a94e50732236d98edd3e5 Mon Sep 17 00:00:00 2001 From: Rob Kelly Date: Fri, 10 Jan 2025 18:50:15 -0700 Subject: [PATCH] Added gitea publish action --- .gitea/workflows/publish.yaml | 56 +++++++++++++++++++++++++++++++++++ debug_build.sh | 11 ++++--- export_presets.cfg | 6 ++-- 3 files changed, 64 insertions(+), 9 deletions(-) create mode 100644 .gitea/workflows/publish.yaml diff --git a/.gitea/workflows/publish.yaml b/.gitea/workflows/publish.yaml new file mode 100644 index 0000000..8bfdae4 --- /dev/null +++ b/.gitea/workflows/publish.yaml @@ -0,0 +1,56 @@ +# Based on https://github.com/aBARICHELLO/godot-ci/blob/master/.github/workflows/godot-ci.yml +name: GFOLF - itch.io publish action +run-name: ${{ gitea.actor }} is publishing GFOLF ${{ gitea.ref_name }} to itch.io. + +on: + push: + branches: + - ci-test + tags: + - v* + +env: + GODOT_VERSION: 4.3 + EXPORT_NAME: gfolf + PROJECT_PATH: . + +jobs: + build: + runs-on: ubuntu-20.04 + container: + image: barichello/godot-ci:4.3 + strategy: + matrix: + include: + - target: linux64 + type: x86_64 + - target: osx + type: app + - target: win64 + type: exe + env: + BUILD_DIR: build/gfolf_${{ gitea.ref_name }}_${{ matrix.target }} + steps: + - name: Checkout repository + run: | + git init + git remote add origin ${{ gitea.event.repository.clone_url }} + git fetch --depth 1 origin ${{ gitea.ref }} + git checkout FETCH_HEAD + git lfs pull + - name: Reimport assets + # bruh are you fucking kidding me. bruhh + run: | + timeout 10 godot --headless --import || true + godot --headless --import + - name: Build project + run: | + echo "building to $BUILD_DIR" + mkdir -p $BUILD_DIR + godot --headless --export-debug ${{ matrix.target }} $BUILD_DIR/gfolf.${{ matrix.type }} + - name: Publish + run: | + echo "pushing $BUILD_DIR" + butler push $BUILD_DIR tetramorph/gfolf:${{ matrix.target }} --userversion ${{ gitea.ref_name }} + env: + BUTLER_API_KEY: ${{ secrets.BUTLER_API_KEY }} diff --git a/debug_build.sh b/debug_build.sh index aaf1269..21cb809 100755 --- a/debug_build.sh +++ b/debug_build.sh @@ -47,9 +47,8 @@ echo "Packaging to: $BUILD_DIR" ## Shared build logic function build_project { TARGET="$1" - TARGET_SHORT="$2" TARGET_EXT="$3" - TARGET_SUBDIR="$PROJECT_NAME""_$TARGET_SHORT" + TARGET_SUBDIR="$PROJECT_NAME""_$TARGET" TARGET_DIR="$BUILD_DIR/$TARGET_SUBDIR" TARGET_OUT="$TARGET_DIR/$PROJECT_NAME.$TARGET_EXT" @@ -61,7 +60,7 @@ function build_project { godot --headless --export-debug "$TARGET" $TARGET_OUT set +x - ZIP_OUT="$PROJECT_NAME""_$VERSION_TAG""_$TARGET_SHORT.7z" + ZIP_OUT="$PROJECT_NAME""_$VERSION_TAG""_$TARGET.7z" echo "Packaging to: $ZIP_OUT" # TODO @@ -72,10 +71,10 @@ function build_project { # Build linux -build_project "Linux" "linux64" "x86_64" +build_project "linux64" "x86_64" # Build OSX -build_project "macOS" "osx" "app" +build_project "osx" "app" # Build Michaelsoft Binbows -build_project "Windows Desktop" "win64" "exe" +build_project "win64" "exe" diff --git a/export_presets.cfg b/export_presets.cfg index 09fe2dc..91b4bbc 100644 --- a/export_presets.cfg +++ b/export_presets.cfg @@ -1,6 +1,6 @@ [preset.0] -name="Linux" +name="linux64" platform="Linux" runnable=true advanced_options=true @@ -40,7 +40,7 @@ rm -rf \"{temp_dir}\"" [preset.1] -name="Windows Desktop" +name="win64" platform="Windows Desktop" runnable=true advanced_options=true @@ -105,7 +105,7 @@ Remove-Item -Recurse -Force '{temp_dir}'" [preset.2] -name="macOS" +name="osx" platform="macOS" runnable=true advanced_options=true