diff --git a/.github/workflows/pr.yml b/.github/workflows/pr.yml index fadca52244..2600ad5068 100644 --- a/.github/workflows/pr.yml +++ b/.github/workflows/pr.yml @@ -6,6 +6,12 @@ name: Build pull request on: pull_request: workflow_dispatch: + # trigger on pushes to the default branch (main) to keep the cache up to date + push: + branches: main + +env: + JAVA_VERSION: '17.0.1' jobs: build: @@ -17,26 +23,57 @@ jobs: - uses: actions/setup-java@v4 with: distribution: temurin - java-version: "17.0.1" + java-version: ${{ env.JAVA_VERSION }} - uses: gradle/actions/setup-gradle@v3 - - - name: Clean + + - name: Build run: | chmod +x gradlew - ./gradlew clean + ./gradlew build - - name: Build - run: ./gradlew build + - name: Prepare artifacts for upload + run: | + mkdir -p dist + cp {Common,Forge,Fabric}/build/libs/*.jar dist - - name: Run Datagen - run: ./gradlew runAllDatagen + - name: Upload artifacts + uses: actions/upload-artifact@v4 + with: + name: mod-build + path: dist + retention-days: 30 + + datagen: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v4 + with: + fetch-depth: 0 + - uses: actions/setup-java@v4 + with: + distribution: temurin + java-version: ${{ env.JAVA_VERSION }} + - uses: gradle/actions/setup-gradle@v3 + + # ForgeGradle datagen asset download often fails (see #692) + # so just allow it to automatically retry a few times + - name: Run datagen + uses: nick-fields/retry@v3 + with: + timeout_minutes: 10 + max_attempts: 3 + command: | + chmod +x gradlew + ./gradlew runAllDatagen - - name: Check Datagen + - name: Check datagen run: | git add --intent-to-add . git diff --name-only --exit-code -- ":!:*/src/generated/resources/.cache/*" hexdoc: + # don't bother running the docs build when pushing to main - nothing necessary to cache here + if: github.event_name != 'push' uses: hexdoc-dev/hexdoc/.github/workflows/hexdoc.yml@main permissions: contents: write diff --git a/Common/src/main/java/at/petrak/hexcasting/common/casting/actions/eval/OpForEach.kt b/Common/src/main/java/at/petrak/hexcasting/common/casting/actions/eval/OpForEach.kt index bb5ccafa8b..bdd4f76f7a 100644 --- a/Common/src/main/java/at/petrak/hexcasting/common/casting/actions/eval/OpForEach.kt +++ b/Common/src/main/java/at/petrak/hexcasting/common/casting/actions/eval/OpForEach.kt @@ -17,8 +17,8 @@ object OpForEach : Action { if (stack.size < 2) throw MishapNotEnoughArgs(2, stack.size) - val instrs = stack.getList(stack.lastIndex - 1) - val datums = stack.getList(stack.lastIndex) + val instrs = stack.getList(stack.lastIndex - 1, stack.size) + val datums = stack.getList(stack.lastIndex, stack.size) stack.removeLastOrNull() stack.removeLastOrNull()