Skip to content

docs: Add usage section #139

docs: Add usage section

docs: Add usage section #139

Workflow file for this run

name: hydrun CI
on:
push:
pull_request:
schedule:
- cron: "0 0 * * 0"
jobs:
build-linux:
runs-on: ubuntu-latest
strategy:
matrix:
target:
- id: flatpak
src: .
os: fedora:36
flags: "-e '--privileged'"
cmd: ./Hydrunfile flatpak
dst: out/*
- id: windows
src: .
os: fedora:36
flags: "-e '--privileged'"
cmd: ./Hydrunfile windows
dst: out/*
steps:
- name: Maximize build space
run: |
sudo rm -rf /usr/share/dotnet
sudo rm -rf /usr/local/lib/android
sudo rm -rf /opt/ghc
- name: Checkout
uses: actions/checkout@v2
- name: Set up QEMU
uses: docker/setup-qemu-action@v1
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v1
- name: Set up hydrun
run: |
curl -L -o /tmp/hydrun "https://github.com/pojntfx/hydrun/releases/latest/download/hydrun.linux-$(uname -m)"
sudo install /tmp/hydrun /usr/local/bin
- name: Build with hydrun
working-directory: ${{ matrix.target.src }}
env:
GPG_KEY_CONTENT: ${{ secrets.GPG_KEY_CONTENT }} # GPG_KEY_CONTENT must be a unarmored PGP private key which is base64 encoded with -w0
GPG_KEY_PASSWORD: ${{ secrets.GPG_KEY_PASSWORD }} # GPG_KEY_PASSWORD must be base64 encoded with -w0
GPG_KEY_ID: ${{ secrets.GPG_KEY_ID }}
run: hydrun -o ${{ matrix.target.os }} ${{ matrix.target.flags }} "GPG_KEY_CONTENT=\"${GPG_KEY_CONTENT}\" GPG_KEY_PASSWORD=\"${GPG_KEY_PASSWORD}\" GPG_KEY_ID=\"${GPG_KEY_ID}\" ${{ matrix.target.cmd }}"
- name: Fix permissions for output
run: sudo chown -R $USER .
- name: Upload output
uses: actions/upload-artifact@v2
with:
name: ${{ matrix.target.id }}
path: ${{ matrix.target.dst }}
publish-linux:
runs-on: ubuntu-latest
needs: build-linux
steps:
- name: Checkout
uses: actions/checkout@v2
- name: Download output
uses: actions/download-artifact@v2
with:
path: /tmp/out
- name: Isolate the unstable repositories
if: ${{ github.ref == 'refs/heads/main' }}
run: |
mkdir -p /tmp/out/github-pages/flatpak
cp -r /tmp/out/flatpak/repositories/unstable /tmp/out/github-pages/flatpak/unstable
- name: Isolate the stable repositories
if: startsWith(github.ref, 'refs/tags/v')
run: |
mkdir -p /tmp/out/github-pages/flatpak
cp -r /tmp/out/flatpak/repositories/stable /tmp/out/github-pages/flatpak/stable
- name: Publish pre-release to GitHub releases
if: ${{ github.ref == 'refs/heads/main' }}
uses: marvinpinto/action-automatic-releases@latest
with:
repo_token: "${{ secrets.GITHUB_TOKEN }}"
automatic_release_tag: unstable
prerelease: true
files: |
/tmp/out/*/*
- name: Publish release to GitHub releases
if: startsWith(github.ref, 'refs/tags/v')
uses: marvinpinto/action-automatic-releases@latest
with:
repo_token: "${{ secrets.GITHUB_TOKEN }}"
prerelease: false
files: |
/tmp/out/*/*
- name: Publish release to GitHub pages
if: ${{ github.ref == 'refs/heads/main' || startsWith(github.ref, 'refs/tags/v') }}
uses: JamesIves/[email protected]
with:
branch: gh-pages
folder: /tmp/out/github-pages
git-config-name: GitHub Pages Bot
git-config-email: [email protected]