Skip to content

Commit efadcc8

Browse files
committed
Merge branch 'main' into update/2.7.12
2 parents 51d4e4c + 969a3c6 commit efadcc8

File tree

3 files changed

+261
-212
lines changed

3 files changed

+261
-212
lines changed

.github/workflows/preview.yml

Lines changed: 130 additions & 94 deletions
Original file line numberDiff line numberDiff line change
@@ -1,12 +1,16 @@
1-
name: Deploy preview modpack
1+
name: Deploy Preview Modpack
22

33
permissions:
4-
contents: write
4+
contents: read
55
deployments: write
66

77
on:
88
workflow_dispatch:
99
inputs:
10+
target_branch:
11+
description: 'Target branch for the preview'
12+
type: string
13+
required: true
1014
version:
1115
description: 'Modpack version'
1216
required: true
@@ -15,23 +19,31 @@ on:
1519
required: true
1620

1721
env:
22+
NAME: "GTExpert2"
1823
VERSION_NORMAL: "v${{ github.event.inputs.version }}-pr-${{ github.event.inputs.preview_version }}"
1924
VERSION_LWJGL3: "v${{ github.event.inputs.version }}-lwjgl3-${{ github.event.inputs.preview_version }}"
20-
NAME: "GTExpert2"
2125

2226
jobs:
23-
deploy:
27+
build:
2428
runs-on: ubuntu-latest
2529
strategy:
2630
matrix:
27-
version: [ "NORMAL", "LWJGL3" ]
31+
buildType: [standard, lwjgl3]
2832

2933
steps:
30-
- name: Checkout
34+
- name: Checkout repository
3135
uses: actions/checkout@v4
36+
with:
37+
ref: ${{ github.event.inputs.target_branch || github.ref }}
38+
fetch-depth: 0
3239

33-
- name: Setup Build
34-
uses: ./.github/actions/build_setup
40+
- name: Cache dependencies
41+
uses: actions/cache@v4
42+
with:
43+
path: |
44+
~/.m2/repository
45+
~/.cache/pip
46+
key: ${{ runner.os }}-deps-${{ matrix.buildType }}-${{ hashFiles('**/pom.xml') }}
3547

3648
- name: Download Resource Packs zip
3749
run: |
@@ -40,112 +52,136 @@ jobs:
4052
ASSET_NAME=$(echo $ASSET_URL | awk -F'/' '{print $NF}')
4153
wget -O ./overrides/resourcepacks/$ASSET_NAME $ASSET_URL
4254
43-
- if: matrix.version == 'LWJGL3'
44-
name: Set the version (LWJGL3)
45-
run: |
46-
echo "[CleanroomMMC] GregTech Expert 2 ${{ env.VERSION_LWJGL3 }}" > ./overrides/config/txloader/load/custommainmenu/version.txt
47-
sed -i -e "s/MODPACKVERSION/${{ env.VERSION_LWJGL3 }}/g" ./manifest.json
48-
sed -i -e "s/MODPACKVERSION/${{ env.VERSION_LWJGL3 }}/g" ./instance.cfg
49-
sed -i -e "s/MODPACKVERSION/${{ env.VERSION_LWJGL3 }}/g" ./overrides/config/craftpresence.json
55+
- name: Setup Build Environment
56+
uses: ./.github/actions/build_setup
5057

51-
- if: matrix.version == 'NORMAL'
52-
name: Set the version (NORMAL)
53-
run: |
54-
echo "GregTech Expert 2 ${{ env.VERSION_NORMAL }}" > ./overrides/config/txloader/load/custommainmenu/version.txt
55-
sed -i -e "s/MODPACKVERSION/${{ env.VERSION_NORMAL }}/g" ./manifest.json
56-
sed -i -e "s/MODPACKVERSION/${{ env.VERSION_NORMAL }}/g" ./instance.cfg
57-
sed -i -e "s/MODPACKVERSION/${{ env.VERSION_NORMAL }}/g" ./overrides/config/craftpresence.json
58+
- name: Create artifacts directory
59+
run: mkdir -p artifacts
5860

59-
- if: matrix.version == 'LWJGL3'
60-
name: Remove lwjgl3 not supported mods
61+
- name: Set Modpack Version
62+
run: |
63+
if [[ "${{ matrix.buildType }}" == "lwjgl3" ]]; then
64+
VER="${{ env.VERSION_LWJGL3 }}"
65+
echo "[CleanroomMMC] GregTech Expert 2 $VER" > overrides/config/txloader/load/custommainmenu/version.txt
66+
else
67+
VER="${{ env.VERSION_NORMAL }}"
68+
echo "GregTech Expert 2 $VER" > overrides/config/txloader/load/custommainmenu/version.txt
69+
fi
70+
sed -i "s/MODPACKVERSION/$VER/g" manifest.json instance.cfg overrides/config/craftpresence.json
71+
72+
- name: Adjust for LWJGL3
73+
if: matrix.buildType == 'lwjgl3'
6174
run: |
6275
python buildtools/gen-lwjgl3-manifest.py
63-
cp -vf ./cmmc/manifest.json ./manifest.json
76+
cp -vf cmmc/manifest.json manifest.json
6477
65-
- name: Run Python
78+
- name: Install Mods
6679
env:
6780
CF_API_TOKEN: ${{ secrets.CF_API_TOKEN }}
6881
run: python buildtools/mod-install.py
6982

70-
- name: Remaove .gitkeep files
71-
run: find . -name ".gitkeep" -type f -delete
83+
- name: Clean up placeholder files
84+
run: find . -name ".gitkeep" -delete
7285

73-
- if: matrix.version == 'NORMAL'
74-
name: Archive Release CF (NORMAL)
75-
run: zip -r ./${{ env.NAME }}-${{ env.VERSION_NORMAL }}-cf.zip ./manifest.json ./modlist.html ./overrides/bansoukou/ ./overrides/config/ ./overrides/local/ ./overrides/resourcepacks/ ./overrides/scripts/
76-
77-
- if: matrix.version == 'LWJGL3'
78-
name: Archive Release MMC (LWJGL3)
79-
run: |
80-
sed -i -e "s/B:EnableCustomGameTitle=false/B:EnableCustomGameTitle=true/g" ./overrides/config/stellar_core.cfg
81-
cp -rvf ./cmmc/bansoukou/ ./overrides/
82-
rm -Rf ./cmmc/bansoukou/
83-
mv -vf ./overrides/ .minecraft/
84-
cp -vf ./icon.png .minecraft/
85-
cp -rvf ./cmmc/* ./
86-
zip -r ./${{ env.NAME }}-${{ env.VERSION_LWJGL3 }}-cmmc.zip ./libraries/ ./patches/ ./mmc-pack.json ./instance.cfg .minecraft/
87-
88-
- if: matrix.version == 'NORMAL'
89-
name: Archive Release MMC (NORMAL)
86+
- name: Package Artifacts
9087
run: |
91-
mv -vf ./overrides/ .minecraft/
92-
cp -vf ./icon.png .minecraft/
93-
zip -r ./${{ env.NAME }}-${{ env.VERSION_NORMAL }}-mmc.zip ./mmc-pack.json ./instance.cfg .minecraft/
88+
if [[ "${{ matrix.buildType }}" == "lwjgl3" ]]; then
89+
sed -i "s/B:EnableCustomGameTitle=false/B:EnableCustomGameTitle=true/" overrides/config/stellar_core.cfg
90+
cp -rvf cmmc/bansoukou/ ./overrides/
91+
rm -Rf cmmc/bansoukou/
92+
mv -vf overrides/ .minecraft/
93+
cp -vf icon.png .minecraft/
94+
cp -rvf cmmc/* ./
95+
zip -r artifacts/${{ env.NAME }}-${{ env.VERSION_LWJGL3 }}-mmc.zip libraries/ patches/ mmc-pack.json instance.cfg .minecraft/
96+
else
97+
zip -r artifacts/${{ env.NAME }}-${{ env.VERSION_NORMAL }}-cf.zip manifest.json modlist.html overrides/bansoukou/ overrides/config/ overrides/local/ overrides/resourcepacks/icons/ overrides/resourcepacks/GTExpert2-* overrides/scripts/
98+
mv overrides/ .minecraft/
99+
cp icon.png .minecraft/
100+
zip -r artifacts/${{ env.NAME }}-${{ env.VERSION_NORMAL }}-mmc.zip mmc-pack.json instance.cfg .minecraft/
101+
mv serverfiles/* ./
102+
rm -vf .minecraft/mods/!Red-Core-*
103+
rm -vf .minecraft/mods/Alfheim-*
104+
rm -vf .minecraft/mods/Valkyrie-*
105+
rm -vf .minecraft/mods/CraftPresence-*
106+
rm -vf .minecraft/mods/Controlling-*
107+
rm -vf .minecraft/mods/UniLib-*
108+
rm -vf .minecraft/mods/CustomMainMenu-*
109+
rm -vf .minecraft/mods/Fixeroo-*
110+
rm -vf .minecraft/mods/FpsReducer-*
111+
rm -vf .minecraft/mods/modernsplash-*
112+
rm -vf .minecraft/mods/RenderLib-*
113+
rm -vf .minecraft/mods/particleculling-*
114+
rm -vf .minecraft/mods/EntityCulling-*
115+
rm -vf .minecraft/mods/SmoothFont-*
116+
rm -vf .minecraft/mods/InGameInfoXML-*
117+
rm -vf .minecraft/mods/oauth-*
118+
rm -vf .minecraft/mods/UntranslatedItems-*
119+
rm -vf .minecraft/mods/vintagefix-*
120+
mv -vf .minecraft/* ./
121+
zip -r artifacts/${{ env.NAME }}-${{ env.VERSION_NORMAL }}-server.zip docker-compose.yml PleaseRead.txt log4j2_112-116.xml Install.* ServerStart.* settings.* TmuxServer.sh bansoukou/ config/ local/ mods/ resources/ scripts/
122+
fi
123+
124+
- name: Upload Artifacts
125+
uses: actions/upload-artifact@v4
126+
with:
127+
name: ${{ matrix.buildType }}-artifacts
128+
path: artifacts/
129+
retention-days: 1
94130

95-
- if: matrix.version == 'NORMAL'
96-
name: Move Server Files (NORMAL)
97-
run: |
98-
mv -vf ./serverfiles/* ./
131+
release:
132+
needs: build
133+
runs-on: ubuntu-latest
134+
permissions:
135+
contents: write
99136

100-
- name: Remove Client Only Mods
137+
steps:
138+
- name: Checkout repository
139+
uses: actions/checkout@v4
140+
with:
141+
ref: ${{ github.event.inputs.target_branch || github.ref }}
142+
fetch-depth: 0
143+
144+
- name: Download All Artifacts
145+
uses: actions/download-artifact@v4
146+
with:
147+
path: downloads
148+
149+
- name: Aggregate Artifacts
101150
run: |
102-
rm -vf .minecraft/mods/!Red-Core-*
103-
rm -vf .minecraft/mods/Alfheim-*
104-
rm -vf .minecraft/mods/Valkyrie-*
105-
rm -vf .minecraft/mods/CraftPresence-*
106-
rm -vf .minecraft/mods/Controlling-*
107-
rm -vf .minecraft/mods/UniLib-*
108-
rm -vf .minecraft/mods/CustomMainMenu-*
109-
rm -vf .minecraft/mods/Fixeroo-*
110-
rm -vf .minecraft/mods/FpsReducer-*
111-
rm -vf .minecraft/mods/modernsplash-*
112-
rm -vf .minecraft/mods/RenderLib-*
113-
rm -vf .minecraft/mods/particleculling-*
114-
rm -vf .minecraft/mods/EntityCulling-*
115-
rm -vf .minecraft/mods/SmoothFont-*
116-
rm -vf .minecraft/mods/InGameInfoXML-*
117-
rm -vf .minecraft/mods/oauth-*
118-
rm -vf .minecraft/mods/UntranslatedItems-*
119-
rm -vf .minecraft/mods/vintagefix-*
120-
121-
- if: matrix.version == 'NORMAL'
122-
name: Archive Release Server (NORMAL)
151+
mkdir -p artifacts
152+
for d in downloads/*; do
153+
if [ -d "$d" ]; then
154+
cp -r "$d"/* artifacts/ || true
155+
fi
156+
done
157+
158+
- name: Ensure Tag Exists
159+
if: "!startsWith(github.ref, 'refs/tags/')"
123160
run: |
124-
mv -vf .minecraft/* ./
125-
zip -r ./${{ env.NAME }}-${{ env.VERSION_NORMAL }}-server.zip ./docker-compose.yml ./PleaseRead.txt ./log4j2_112-116.xml ./Install.bat ./Install.sh ./ServerStart.bat ./ServerStart.sh ./settings.bat ./settings.sh ./TmuxServer.sh ./bansoukou/ ./config/ ./local/ ./mods/ ./resources/ ./scripts/
161+
git config --global user.name "github-actions"
162+
git config --global user.email "[email protected]"
163+
git tag ${{ env.VERSION_NORMAL }}
164+
git push origin ${{ env.VERSION_NORMAL }}
126165
127-
- if: matrix.version == 'NORMAL'
128-
name: Create GitHub Release (NORMAL)
166+
- name: Create or Update GitHub Release
129167
uses: softprops/action-gh-release@v2
130168
with:
131169
tag_name: ${{ env.VERSION_NORMAL }}
132-
prerelease: true
133-
generate_release_notes: true
134-
files: |
135-
./${{ env.NAME }}-${{ env.VERSION_NORMAL }}-cf.zip
136-
./${{ env.NAME }}-${{ env.VERSION_NORMAL }}-mmc.zip
137-
./${{ env.NAME }}-${{ env.VERSION_NORMAL }}-server.zip
170+
name: "Preview ${{ env.VERSION_NORMAL }}"
171+
body: |
172+
## GregTech Expert 2 - Preview Release
138173
139-
- if: matrix.version == 'LWJGL3'
140-
name: Create GitHub Release (LWJGL3)
141-
uses: softprops/action-gh-release@v2
142-
with:
143-
tag_name: ${{ env.VERSION_LWJGL3 }}
174+
This preview includes:
175+
- **Standard** (CurseForge / MultiMC / PrismLauncher / Server)
176+
- **LWJGL3** (MultiMC / PrismLauncher only)
177+
178+
See installation guide for LWJGL3 [here](https://github.com/GTModpackTeam/GregTech-Expert-2/blob/main/cmmc/README.md).
144179
prerelease: true
145-
body: |
146-
Note - This is LWJGL3 build and only available for MMC / PrismLauncher.
147-
FOLLOW THE INSTALLATION GUIDE [HERE](https://github.com/GTModpackTeam/GregTech-Expert-2/blob/main/cmmc/README.md).
148-
---
149180
generate_release_notes: true
150181
files: |
151-
./${{ env.NAME }}-${{ env.VERSION_LWJGL3 }}-cmmc.zip
182+
artifacts/${{ env.NAME }}-${{ env.VERSION_NORMAL }}-cf.zip
183+
artifacts/${{ env.NAME }}-${{ env.VERSION_NORMAL }}-mmc.zip
184+
artifacts/${{ env.NAME }}-${{ env.VERSION_NORMAL }}-server.zip
185+
artifacts/${{ env.NAME }}-${{ env.VERSION_LWJGL3 }}-mmc.zip
186+
env:
187+
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}

0 commit comments

Comments
 (0)