mirror of
https://git.suyu.dev/suyu/suyu
synced 2025-01-09 16:03:21 +00:00
package MSVC CI Builds differently, and include yuzu.exe
This is related to 8486 Ninja places the exe files into .\build\bin while MSBuild may place them into .\build\bin\Release upload.ps1 was originally written for use with Azure Dev Ops to cough up about 5 files and the script appears to be used for both CI and mainline builds GHA (GitHub Actions) makes available a single zip of the items uploaded by each Upload action (artifacts directory), so we want to work with that. I'm doing changes to upload.ps1 to accomplish this. The changes to the verify.yml are as follows -DGIT_BRANCH=pr-verify changes the header in yuzu, instead of saying HEAD-<hash>-dirty it'll say pr-verify-<hash> -DCLANG_FORMAT_SUFFIX=discordplzdontclang tricks the CMake stuff for discord-rpc to NOT run clang-format, as this was marking CI builds as dirty I'm also making it upload just the exe by itself, as the msvc builds are quite chunky. but maybe this is unnecessary. Currently the MSVC artifact option is a 274MB zip that contains 3 copies of the DLLs, and 4 copies of the source tarball, and zero copies of yuzu.exe This PR should have msvc artifacts of about 190MB that downloads as 81 MB zip
This commit is contained in:
parent
da066e8ed8
commit
5cda630417
2 changed files with 55 additions and 1 deletions
|
@ -47,6 +47,49 @@ Copy-Item .\CMakeModules -Recurse -Destination $MSVC_SOURCE
|
||||||
7z a -r -ttar $MSVC_SOURCE_TAR $MSVC_SOURCE
|
7z a -r -ttar $MSVC_SOURCE_TAR $MSVC_SOURCE
|
||||||
7z a -r -txz $MSVC_SOURCE_TARXZ $MSVC_SOURCE_TAR
|
7z a -r -txz $MSVC_SOURCE_TARXZ $MSVC_SOURCE_TAR
|
||||||
|
|
||||||
|
# Following section is quick hack to package artifacts differently for GitHub Actions
|
||||||
|
if ("$env:GITHUB_ACTIONS" -eq "true") {
|
||||||
|
echo "Hello GitHub Actions"
|
||||||
|
|
||||||
|
# Hopefully there is an exe in either .\build\bin or .\build\bin\Release
|
||||||
|
cp .\build\bin\yuzu*.exe .\artifacts\
|
||||||
|
Copy-Item "$BUILD_DIR\*" -Destination "artifacts" -Recurse
|
||||||
|
Remove-Item .\artifacts\tests.exe -ErrorAction ignore
|
||||||
|
|
||||||
|
# None of the other GHA builds are including source, so commenting out today
|
||||||
|
#Copy-Item $MSVC_SOURCE_TARXZ -Destination "artifacts"
|
||||||
|
|
||||||
|
# Are debug symbols important?
|
||||||
|
# cp .\build\bin\yuzu*.pdb .\pdb\
|
||||||
|
|
||||||
|
# Write out a tag BUILD_TAG to environment for the Upload step
|
||||||
|
# We're getting ${{ github.event.number }} as $env:PR_NUMBER"
|
||||||
|
echo "env:PR_NUMBER: $env:PR_NUMBER"
|
||||||
|
if (Test-Path env:PR_NUMBER) {
|
||||||
|
$PR_NUMBER = $env:PR_NUMBER.Substring(2) -as [int]
|
||||||
|
$PR_NUMBER_TAG = "pr"+([string]$PR_NUMBER).PadLeft(5,'0')
|
||||||
|
if ($PR_NUMBER -gt 1){
|
||||||
|
$BUILD_TAG="verify-$PR_NUMBER_TAG-$GITDATE-$GITREV"
|
||||||
|
} else {
|
||||||
|
$BUILD_TAG = "verify-$GITDATE-$GITREV"
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
# If env:PR_NUMBER isn't set, we should still write out a variable
|
||||||
|
$BUILD_TAG = "verify-$GITDATE-$GITREV"
|
||||||
|
}
|
||||||
|
echo "BUILD_TAG=$BUILD_TAG"
|
||||||
|
echo "BUILD_TAG=$BUILD_TAG" >> $env:GITHUB_ENV
|
||||||
|
|
||||||
|
# For extra job, just the exe
|
||||||
|
$INDIVIDUAL_EXE = "yuzu-msvc-$BUILD_TAG.exe"
|
||||||
|
echo "INDIVIDUAL_EXE=$INDIVIDUAL_EXE"
|
||||||
|
echo "INDIVIDUAL_EXE=$INDIVIDUAL_EXE" >> $env:GITHUB_ENV
|
||||||
|
echo "Just the exe: $INDIVIDUAL_EXE"
|
||||||
|
cp .\artifacts\yuzu.exe .\$INDIVIDUAL_EXE
|
||||||
|
|
||||||
|
|
||||||
|
} else {
|
||||||
|
|
||||||
# Build the final release artifacts
|
# Build the final release artifacts
|
||||||
Copy-Item $MSVC_SOURCE_TARXZ -Destination $RELEASE_DIST
|
Copy-Item $MSVC_SOURCE_TARXZ -Destination $RELEASE_DIST
|
||||||
Copy-Item "$BUILD_DIR\*" -Destination $RELEASE_DIST -Recurse
|
Copy-Item "$BUILD_DIR\*" -Destination $RELEASE_DIST -Recurse
|
||||||
|
@ -62,3 +105,7 @@ Get-ChildItem "$BUILD_DIR" -Recurse -Filter "QtWebEngineProcess*.exe" | Copy-Ite
|
||||||
Get-ChildItem . -Filter "*.zip" | Copy-Item -destination "artifacts"
|
Get-ChildItem . -Filter "*.zip" | Copy-Item -destination "artifacts"
|
||||||
Get-ChildItem . -Filter "*.7z" | Copy-Item -destination "artifacts"
|
Get-ChildItem . -Filter "*.7z" | Copy-Item -destination "artifacts"
|
||||||
Get-ChildItem . -Filter "*.tar.xz" | Copy-Item -destination "artifacts"
|
Get-ChildItem . -Filter "*.tar.xz" | Copy-Item -destination "artifacts"
|
||||||
|
}
|
||||||
|
# Extra items
|
||||||
|
git status
|
||||||
|
cp .\build\src\common\scm_rev.cpp .\artifacts
|
||||||
|
|
9
.github/workflows/verify.yml
vendored
9
.github/workflows/verify.yml
vendored
|
@ -3,6 +3,8 @@ name: 'yuzu verify'
|
||||||
on:
|
on:
|
||||||
pull_request:
|
pull_request:
|
||||||
branches: [ master ]
|
branches: [ master ]
|
||||||
|
env:
|
||||||
|
PR_NUMBER: pr${{ github.event.number }}
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
format:
|
format:
|
||||||
|
@ -99,7 +101,7 @@ jobs:
|
||||||
run: |
|
run: |
|
||||||
glslangValidator --version
|
glslangValidator --version
|
||||||
mkdir build
|
mkdir build
|
||||||
cmake . -B build -GNinja -DCMAKE_TOOLCHAIN_FILE="CMakeModules/MSVCCache.cmake" -DUSE_CCACHE=ON -DYUZU_USE_BUNDLED_QT=1 -DYUZU_USE_BUNDLED_SDL2=1 -DYUZU_USE_QT_WEB_ENGINE=ON -DENABLE_COMPATIBILITY_LIST_DOWNLOAD=ON -DYUZU_ENABLE_COMPATIBILITY_REPORTING=ON -DUSE_DISCORD_PRESENCE=ON -DENABLE_QT_TRANSLATION=ON -DCMAKE_BUILD_TYPE=Release -DYUZU_TESTS=OFF -DYUZU_USE_BUNDLED_VCPKG=ON
|
cmake . -B build -GNinja -DCMAKE_TOOLCHAIN_FILE="CMakeModules/MSVCCache.cmake" -DUSE_CCACHE=ON -DYUZU_USE_BUNDLED_QT=1 -DYUZU_USE_BUNDLED_SDL2=1 -DYUZU_USE_QT_WEB_ENGINE=ON -DENABLE_COMPATIBILITY_LIST_DOWNLOAD=ON -DYUZU_ENABLE_COMPATIBILITY_REPORTING=ON -DUSE_DISCORD_PRESENCE=ON -DENABLE_QT_TRANSLATION=ON -DCMAKE_BUILD_TYPE=Release -DGIT_BRANCH=pr-verify -DCLANG_FORMAT_SUFFIX=discordplzdontclang -DYUZU_TESTS=OFF -DYUZU_USE_BUNDLED_VCPKG=ON
|
||||||
- name: Build
|
- name: Build
|
||||||
run: cmake --build build
|
run: cmake --build build
|
||||||
- name: Cache Summary
|
- name: Cache Summary
|
||||||
|
@ -112,3 +114,8 @@ jobs:
|
||||||
with:
|
with:
|
||||||
name: msvc
|
name: msvc
|
||||||
path: artifacts/
|
path: artifacts/
|
||||||
|
- name: Upload EXE
|
||||||
|
uses: actions/upload-artifact@v3
|
||||||
|
with:
|
||||||
|
name: ${{ env.INDIVIDUAL_EXE }}
|
||||||
|
path: ${{ env.INDIVIDUAL_EXE }}
|
||||||
|
|
Loading…
Reference in a new issue