Revert workflow logic

This commit is contained in:
ReenigneArcher
2022-04-30 12:38:08 -04:00
parent 31f7faa6a5
commit 2a69385aed

View File

@@ -32,12 +32,14 @@ jobs:
check_versions: check_versions:
name: Check Versions name: Check Versions
runs-on: ubuntu-latest runs-on: ubuntu-latest
needs: check_changelog
if: ${{ github.ref == 'refs/heads/master' || github.base_ref == 'master' }}
# base_ref for pull request check, ref for push
steps: steps:
- name: Checkout - name: Checkout
uses: actions/checkout@v3 uses: actions/checkout@v3
- name: Check CMakeLists.txt Version - name: Check CMakeLists.txt Version
if: ${{ github.ref == 'refs/heads/master' || github.base_ref == 'master' }}
run: | run: |
version=$(grep -o -E '^project\(Sunshine VERSION [0-9]+\.[0-9]+\.[0-9]+\)' CMakeLists.txt | grep -o -E '[0-9]+\.[0-9]+\.[0-9]+') version=$(grep -o -E '^project\(Sunshine VERSION [0-9]+\.[0-9]+\.[0-9]+\)' CMakeLists.txt | grep -o -E '[0-9]+\.[0-9]+\.[0-9]+')
echo "cmakelists_version=${version}" >> $GITHUB_ENV echo "cmakelists_version=${version}" >> $GITHUB_ENV
@@ -53,17 +55,15 @@ jobs:
build_appimage: build_appimage:
name: AppImage name: AppImage
runs-on: ubuntu-20.04 runs-on: ubuntu-20.04
needs: [ check_versions, check_changelog ] needs: check_changelog
steps: steps:
- name: Checkout - name: Checkout
uses: actions/checkout@v3 uses: actions/checkout@v3
with: with:
submodules: recursive submodules: recursive
- name: Setup Dependencies - name: Setup Dependencies AppImage
run: | run: |
mkdir -p artifacts
sudo apt-get update -y && \ sudo apt-get update -y && \
sudo apt-get --reinstall install -y \ sudo apt-get --reinstall install -y \
git wget gcc-10 g++-10 build-essential cmake libssl-dev libavdevice-dev libboost-thread-dev libboost-filesystem-dev libboost-log-dev libpulse-dev libopus-dev libxtst-dev libx11-dev libxrandr-dev libxfixes-dev libevdev-dev libxcb1-dev libxcb-shm0-dev libxcb-xfixes0-dev libdrm-dev libcap-dev libwayland-dev git wget gcc-10 g++-10 build-essential cmake libssl-dev libavdevice-dev libboost-thread-dev libboost-filesystem-dev libboost-log-dev libpulse-dev libopus-dev libxtst-dev libx11-dev libxrandr-dev libxfixes-dev libevdev-dev libxcb1-dev libxcb-shm0-dev libxcb-xfixes0-dev libdrm-dev libcap-dev libwayland-dev
@@ -82,11 +82,14 @@ jobs:
CMAKE_BUILD_TYPE="${CMAKE_BUILD_TYPE:-Release}" CMAKE_BUILD_TYPE="${CMAKE_BUILD_TYPE:-Release}"
SUNSHINE_EXECUTABLE_PATH="${SUNSHINE_EXECUTABLE_PATH:-/usr/bin/sunshine}" SUNSHINE_EXECUTABLE_PATH="${SUNSHINE_EXECUTABLE_PATH:-/usr/bin/sunshine}"
SUNSHINE_ASSETS_DIR="${SUNSHINE_ASSETS_DIR:-sunshine.AppImage.config}" SUNSHINE_ASSETS_DIR="${SUNSHINE_ASSETS_DIR:-sunshine.AppImage.config}"
SUNSHINE_ENABLE_WAYLAND=${SUNSHINE_ENABLE_WAYLAND:-ON} SUNSHINE_ENABLE_WAYLAND=${SUNSHINE_ENABLE_WAYLAND:-ON}
SUNSHINE_ENABLE_X11=${SUNSHINE_ENABLE_X11:-ON} SUNSHINE_ENABLE_X11=${SUNSHINE_ENABLE_X11:-ON}
SUNSHINE_ENABLE_DRM=${SUNSHINE_ENABLE_DRM:-ON} SUNSHINE_ENABLE_DRM=${SUNSHINE_ENABLE_DRM:-ON}
SUNSHINE_ENABLE_CUDA=${SUNSHINE_ENABLE_CUDA:-ON} SUNSHINE_ENABLE_CUDA=${SUNSHINE_ENABLE_CUDA:-ON}
mkdir -p appimage-build && cd appimage-build mkdir -p appimage-build && cd appimage-build
cmake "-DCMAKE_BUILD_TYPE=$CMAKE_BUILD_TYPE" "-DSUNSHINE_EXECUTABLE_PATH=$SUNSHINE_EXECUTABLE_PATH" "-DSUNSHINE_ASSETS_DIR=$SUNSHINE_ASSETS_DIR" "-DSUNSHINE_ENABLE_WAYLAND=$SUNSHINE_ENABLE_WAYLAND" "-DSUNSHINE_ENABLE_X11=$SUNSHINE_ENABLE_X11" "-DSUNSHINE_ENABLE_DRM=$SUNSHINE_ENABLE_DRM" "-DSUNSHINE_ENABLE_CUDA=$SUNSHINE_ENABLE_CUDA" "../" -DCMAKE_INSTALL_PREFIX=/usr cmake "-DCMAKE_BUILD_TYPE=$CMAKE_BUILD_TYPE" "-DSUNSHINE_EXECUTABLE_PATH=$SUNSHINE_EXECUTABLE_PATH" "-DSUNSHINE_ASSETS_DIR=$SUNSHINE_ASSETS_DIR" "-DSUNSHINE_ENABLE_WAYLAND=$SUNSHINE_ENABLE_WAYLAND" "-DSUNSHINE_ENABLE_X11=$SUNSHINE_ENABLE_X11" "-DSUNSHINE_ENABLE_DRM=$SUNSHINE_ENABLE_DRM" "-DSUNSHINE_ENABLE_CUDA=$SUNSHINE_ENABLE_CUDA" "../" -DCMAKE_INSTALL_PREFIX=/usr
make -j ${nproc} DESTDIR=AppDir make -j ${nproc} DESTDIR=AppDir
@@ -95,16 +98,21 @@ jobs:
run: | run: |
version=${{ needs.check_changelog.outputs.next_version_bare }} version=${{ needs.check_changelog.outputs.next_version_bare }}
echo "VERSION=${version}" >> $GITHUB_ENV echo "VERSION=${version}" >> $GITHUB_ENV
- name: Package AppImage - name: Package AppImage
# https://docs.appimage.org/packaging-guide/index.html # https://docs.appimage.org/packaging-guide/index.html
run: | run: |
mkdir -p appimage_temp && cd appimage_temp mkdir -p appimage_temp && cd appimage_temp
DESKTOP_FILE="${DESKTOP_FILE:-sunshine.desktop}" DESKTOP_FILE="${DESKTOP_FILE:-sunshine.desktop}"
ICON_FILE="${ICON_FILE:-sunshine.png}" ICON_FILE="${ICON_FILE:-sunshine.png}"
CONFIG_DIR="${CONFIG_DIR:-sunshine/sunshine.AppImage.config/}" CONFIG_DIR="${CONFIG_DIR:-sunshine/sunshine.AppImage.config/}"
HOME_DIR="${HOME_DIR:-sunshine/sunshine.AppImage.home/}" HOME_DIR="${HOME_DIR:-sunshine/sunshine.AppImage.home/}"
wget https://github.com/linuxdeploy/linuxdeploy/releases/download/continuous/linuxdeploy-x86_64.AppImage && chmod +x linuxdeploy-x86_64.AppImage wget https://github.com/linuxdeploy/linuxdeploy/releases/download/continuous/linuxdeploy-x86_64.AppImage && chmod +x linuxdeploy-x86_64.AppImage
./linuxdeploy-x86_64.AppImage --appdir ../AppDir -e ../appimage-build/sunshine -i "../$ICON_FILE" -d "../appimage-build/$DESKTOP_FILE" --output appimage ./linuxdeploy-x86_64.AppImage --appdir ../AppDir -e ../appimage-build/sunshine -i "../$ICON_FILE" -d "../appimage-build/$DESKTOP_FILE" --output appimage
mv sunshine*.AppImage sunshine.AppImage mv sunshine*.AppImage sunshine.AppImage
mkdir sunshine && mv sunshine.AppImage sunshine/ mkdir sunshine && mv sunshine.AppImage sunshine/
./sunshine/sunshine.AppImage --appimage-portable-config ./sunshine/sunshine.AppImage --appimage-portable-config
@@ -114,6 +122,8 @@ jobs:
mkdir -p ./"$HOME_DIR"/.config/"$CONFIG_DIR" mkdir -p ./"$HOME_DIR"/.config/"$CONFIG_DIR"
cp ./"$CONFIG_DIR"/apps_linux.json ./"$HOME_DIR"/.config/"$CONFIG_DIR" cp ./"$CONFIG_DIR"/apps_linux.json ./"$HOME_DIR"/.config/"$CONFIG_DIR"
zip -r ./sunshine-appimage.zip ./sunshine/* zip -r ./sunshine-appimage.zip ./sunshine/*
mkdir -p artifacts
mv sunshine-appimage.zip ../artifacts/ mv sunshine-appimage.zip ../artifacts/
- name: Verify AppImage - name: Verify AppImage
@@ -128,17 +138,25 @@ jobs:
name: sunshine-appimage name: sunshine-appimage
path: artifacts/ path: artifacts/
- name: Create Release
if: ${{ github.event_name == 'push' && github.ref == 'refs/heads/master' }}
uses: SunshineStream/actions/create_release@master
with:
token: ${{ secrets.GITHUB_TOKEN }}
next_version: ${{ needs.check_changelog.outputs.next_version }}
last_version: ${{ needs.check_changelog.outputs.last_version }}
release_body: ${{ needs.check_changelog.outputs.release_body }}
build_linux: build_linux:
name: Linux name: Linux
runs-on: ubuntu-20.04 runs-on: ubuntu-20.04
needs: [ check_versions, check_changelog ] needs: check_changelog
steps: steps:
- name: Checkout - name: Checkout
uses: actions/checkout@v3 uses: actions/checkout@v3
with: with:
submodules: recursive submodules: recursive
- name: Setup Dependencies Linux
- name: Setup Dependencies
run: | run: |
mkdir -p artifacts mkdir -p artifacts
sudo apt-get update -y && \ sudo apt-get update -y && \
@@ -154,7 +172,7 @@ jobs:
sudo apt-get upgrade -y && sudo apt-get dist-upgrade -y sudo apt-get upgrade -y && sudo apt-get dist-upgrade -y
sudo apt-get install ffmpeg -y sudo apt-get install ffmpeg -y
- name: Build Sunshine - name: Build Linux
run: | run: |
CMAKE_BUILD_TYPE="${CMAKE_BUILD_TYPE:-Release}" CMAKE_BUILD_TYPE="${CMAKE_BUILD_TYPE:-Release}"
SUNSHINE_EXECUTABLE_PATH="${SUNSHINE_EXECUTABLE_PATH:-/usr/bin/sunshine}" SUNSHINE_EXECUTABLE_PATH="${SUNSHINE_EXECUTABLE_PATH:-/usr/bin/sunshine}"
@@ -170,105 +188,92 @@ jobs:
cd build cd build
cmake "-DCMAKE_BUILD_TYPE=$CMAKE_BUILD_TYPE" "-DSUNSHINE_CONFIG_DIR=$SUNSHINE_CONFIG_DIR" "-DSUNSHINE_EXECUTABLE_PATH=$SUNSHINE_EXECUTABLE_PATH" "-DSUNSHINE_ASSETS_DIR=$SUNSHINE_ASSETS_DIR" "-DSUNSHINE_ENABLE_WAYLAND=$SUNSHINE_ENABLE_WAYLAND" "-DSUNSHINE_ENABLE_X11=$SUNSHINE_ENABLE_X11" "-DSUNSHINE_ENABLE_DRM=$SUNSHINE_ENABLE_DRM" "-DSUNSHINE_ENABLE_CUDA=$SUNSHINE_ENABLE_CUDA" "../" -DCMAKE_INSTALL_PREFIX=/usr cmake "-DCMAKE_BUILD_TYPE=$CMAKE_BUILD_TYPE" "-DSUNSHINE_CONFIG_DIR=$SUNSHINE_CONFIG_DIR" "-DSUNSHINE_EXECUTABLE_PATH=$SUNSHINE_EXECUTABLE_PATH" "-DSUNSHINE_ASSETS_DIR=$SUNSHINE_ASSETS_DIR" "-DSUNSHINE_ENABLE_WAYLAND=$SUNSHINE_ENABLE_WAYLAND" "-DSUNSHINE_ENABLE_X11=$SUNSHINE_ENABLE_X11" "-DSUNSHINE_ENABLE_DRM=$SUNSHINE_ENABLE_DRM" "-DSUNSHINE_ENABLE_CUDA=$SUNSHINE_ENABLE_CUDA" "../" -DCMAKE_INSTALL_PREFIX=/usr
- name: Build DEB - name: Package Linux
run: | run: |
cd build cd build
cpack -G DEB
mv Sunshine__.deb ../artifacts/sunshine.deb
- name: Build RPM # package
run: | cpack -G DEB
cd build
cpack -G RPM cpack -G RPM
# move
mv Sunshine__.deb ../artifacts/sunshine.deb
mv Sunshine__.rpm ../artifacts/sunshine.rpm mv Sunshine__.rpm ../artifacts/sunshine.rpm
- name: Upload Sunshine DEB - name: Upload Artifacts
if: ${{ github.event_name == 'pull_request' || github.event_name == 'workflow_dispatch' }} if: ${{ github.event_name == 'pull_request' || github.event_name == 'workflow_dispatch' }}
uses: actions/upload-artifact@v3 uses: actions/upload-artifact@v3
with: with:
name: sunshine.deb name: sunshine-linux
path: artifacts/sunshine.deb path: artifacts/
- name: Create Release
- name: Upload Sunshine RPM if: ${{ github.event_name == 'push' && github.ref == 'refs/heads/master' }}
if: ${{ github.event_name == 'pull_request' || github.event_name == 'workflow_dispatch' }} uses: SunshineStream/actions/create_release@master
uses: actions/upload-artifact@v3 with:
with: token: ${{ secrets.GITHUB_TOKEN }}
name: sunshine.rpm next_version: ${{ needs.check_changelog.outputs.next_version }}
path: artifacts/sunshine.rpm last_version: ${{ needs.check_changelog.outputs.last_version }}
release_body: ${{ needs.check_changelog.outputs.release_body }}
build_win:
name: Windows build_win:
runs-on: windows-2019 name: Windows
needs: [ check_versions, check_changelog ] runs-on: windows-2019
needs: check_changelog
steps:
- name: Checkout steps:
uses: actions/checkout@v3 - name: Checkout
with: uses: actions/checkout@v3
submodules: recursive with:
submodules: recursive
- name: MSYS2 Setup
uses: msys2/setup-msys2@v2 - name: Setup Dependencies Windows
with: uses: msys2/setup-msys2@v2
update: true with:
install: >- update: true
base-devel install: >-
git base-devel
mingw-w64-x86_64-binutils diffutils
mingw-w64-x86_64-openssl git
mingw-w64-x86_64-cmake make
mingw-w64-x86_64-toolchain mingw-w64-x86_64-binutils
mingw-w64-x86_64-opus mingw-w64-x86_64-boost
mingw-w64-x86_64-x265 mingw-w64-x86_64-cmake
mingw-w64-x86_64-boost mingw-w64-x86_64-nsis
mingw-w64-x86_64-nsis mingw-w64-x86_64-openssl
git mingw-w64-x86_64-opus
yasm mingw-w64-x86_64-toolchain
nasm mingw-w64-x86_64-x265
diffutils nasm
make yasm
- name: Build Windows - name: Build Windows
shell: msys2 {0} shell: msys2 {0}
run: | run: |
mkdir sunshine-windows-build mkdir build
cd sunshine-windows-build cd build
cmake -DCMAKE_BUILD_TYPE=Release -DSUNSHINE_ASSETS_DIR=assets -G "MinGW Makefiles" .. cmake -DCMAKE_BUILD_TYPE=Release -DSUNSHINE_ASSETS_DIR=assets -G "MinGW Makefiles" ..
mingw32-make -j2 mingw32-make -j2
- name: Package Windows
- name: Create packages shell: msys2 {0}
shell: msys2 {0} run: |
run: | mkdir -p artifacts
cd sunshine-windows-build cd build
cpack -G NSIS # package
cpack -G ZIP cpack -G NSIS
cpack -G ZIP
mkdir -p ../artifacts
# move
# Installers mv Sunshine__.exe ../artifacts/sunshine-windows-installer.exe
mv Sunshine__.exe ../artifacts/sunshine-windows-installer.exe mv Sunshine__.zip ../artifacts/sunshine-windows-standalone.zip
mv Sunshine__.zip ../artifacts/sunshine-windows-standalone.zip
- name: Upload Artifacts
- name: Upload Sunshine Windows Installer if: ${{ github.event_name == 'pull_request' || github.event_name == 'workflow_dispatch' }}
if: ${{ github.event_name == 'pull_request' || github.event_name == 'workflow_dispatch' }} uses: actions/upload-artifact@v3
uses: actions/upload-artifact@v3 with:
with: name: sunshine-windows
name: sunshine-windows-installer path: artifacts/
path: artifacts/sunshine-windows-installer.exe
- name: Upload Sunshine Windows Standalone
if: ${{ github.event_name == 'pull_request' || github.event_name == 'workflow_dispatch' }}
uses: actions/upload-artifact@v3
with:
name: sunshine-windows-standalone
path: artifacts/sunshine-windows-standalone.zip
release:
name: Create Release
runs-on: ubuntu-20.04
needs: [ "build_win", "build_linux", "build_appimage" ]
steps:
- name: Create Release - name: Create Release
if: ${{ github.event_name == 'push' && github.ref == 'refs/heads/master' }} if: ${{ github.event_name == 'push' && github.ref == 'refs/heads/master' }}
uses: SunshineStream/actions/create_release@master uses: SunshineStream/actions/create_release@master