name: CD # Continuous Deployment permissions: contents: write on: push: tags: - '[v]?[0-9]+.[0-9]+.[0-9]+' workflow_dispatch: inputs: tag: description: 'Tag to deploy' required: true default: '0.0.0' jobs: create-release: name: Create a release runs-on: ubuntu-latest permissions: contents: write steps: - name: Checkout the repository uses: actions/checkout@v4 with: fetch-depth: 0 - name: Generate a changelog uses: orhun/git-cliff-action@v4 with: config: cliff.toml args: --latest --strip header env: OUTPUT: BODY.md - name: Publish on GitHub uses: ncipollo/release-action@v1 with: prerelease: false bodyFile: BODY.md publish-release: name: Publishing for ${{ matrix.os }} runs-on: ${{ matrix.os }} strategy: fail-fast: false matrix: include: - os: macos-latest os-name: macos target: x86_64-apple-darwin architecture: x86_64 binary-postfix: "" use-cross: false - os: macos-latest os-name: macos target: aarch64-apple-darwin architecture: arm64 binary-postfix: "" use-cross: false - os: ubuntu-latest os-name: linux target: x86_64-unknown-linux-gnu architecture: x86_64 binary-postfix: "" use-cross: false - os: windows-latest os-name: windows target: x86_64-pc-windows-msvc architecture: x86_64 binary-postfix: ".exe" use-cross: false - os: ubuntu-latest os-name: linux target: aarch64-unknown-linux-gnu architecture: arm64 binary-postfix: "" use-cross: true - os: ubuntu-latest os-name: linux target: i686-unknown-linux-gnu architecture: i686 binary-postfix: "" use-cross: true steps: - name: Checkout repository uses: actions/checkout@v4 - name: Install Rust toolchain uses: actions-rs/toolchain@v1 with: toolchain: stable target: ${{ matrix.target }} profile: minimal override: true - uses: Swatinem/rust-cache@v2 - name: Cargo build uses: actions-rs/cargo@v1 with: command: build use-cross: ${{ matrix.use-cross }} toolchain: stable args: --release --target ${{ matrix.target }} - name: install strip command shell: bash run: | if [[ ${{ matrix.target }} == aarch64-unknown-linux-gnu ]]; then sudo apt update sudo apt-get install -y binutils-aarch64-linux-gnu fi - name: Packaging final binary shell: bash run: | ####### reduce binary size by removing debug symbols ####### BIN=target/${{ matrix.target }}/release/tv${{ matrix.binary-postfix }} echo "BIN=$BIN" >> "$GITHUB_ENV" if [[ ${{ matrix.target }} == aarch64-unknown-linux-gnu ]]; then GCC_PREFIX="aarch64-linux-gnu-" else GCC_PREFIX="" fi "$GCC_PREFIX"strip $BIN ########## create tar.gz ########## RELEASE_NAME=tv-${GITHUB_REF/refs\/tags\//}-${{ matrix.os-name }}-${{ matrix.architecture }} echo "RELEASE_NAME=$RELEASE_NAME" >> "$GITHUB_ENV" # create the directory for the archive mkdir -p "$RELEASE_NAME"/doc cp $BIN "$RELEASE_NAME"/ cp {README.md,LICENSE} "$RELEASE_NAME"/ cp {CHANGELOG.md,docs/*,man/*} "$RELEASE_NAME"/doc/ tar czvf "$RELEASE_NAME".tar.gz "$RELEASE_NAME" ########## create sha256 ########## if [[ ${{ runner.os }} == 'Windows' ]]; then certutil -hashfile $RELEASE_NAME.tar.gz sha256 | grep -E [A-Fa-f0-9]{64} > $RELEASE_NAME.sha256 else shasum -a 256 $RELEASE_NAME.tar.gz > $RELEASE_NAME.sha256 fi - name: Packaging with zip format if: runner.os == 'Windows' run: | Compress-Archive -Path "$env:BIN" -Destination "$($env:RELEASE_NAME).zip" (Get-FileHash "$($env:RELEASE_NAME).zip" -Algorithm SHA256).Hash.ToLower() > "$($env:RELEASE_NAME).zip.sha256" - name: Releasing assets uses: softprops/action-gh-release@v2 with: files: | tv-*.tar.gz tv-*.zip tv-*.sha256 env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} publish-release-deb: name: publish-release-deb runs-on: ubuntu-latest strategy: fail-fast: false matrix: include: - target: x86_64-unknown-linux-musl os: linux arch: x86_64 - target: x86_64-unknown-linux-gnu os: linux arch: x86_64 - target: aarch64-unknown-linux-gnu os: linux arch: arm64 env: # Emit backtraces on panics. RUST_BACKTRACE: 1 # Since we're distributing the dpkg, we don't know whether the user will # have PCRE2 installed, so just do a static build. PCRE2_SYS_STATIC: 1 steps: - name: Checkout repository uses: actions/checkout@v4 - name: Install packages (Ubuntu) shell: bash run: | if ! command -V sudo; then apt-get update apt-get install -y --no-install-recommends sudo fi sudo apt-get update sudo apt-get install -y --no-install-recommends \ zsh xz-utils liblz4-tool musl-tools brotli zstd - name: Install Rust uses: dtolnay/rust-toolchain@master with: toolchain: nightly target: ${{ matrix.target }} # for some reason, the above action doesn't seem to set the target correctly - name: Add rustup target shell: bash run: | rustup target add ${{ matrix.target }} - name: Install cargo-deb shell: bash run: | cargo install cargo-deb - name: Create deployment directory shell: bash run: | dir=deployment/deb mkdir -p "$dir" echo "DEPLOY_DIR=$dir" >> $GITHUB_ENV - name: Copy man page shell: bash run: | cp man/tv.1 "$DEPLOY_DIR/" - name: Build release binary shell: bash run: | # if aarch64-unknown-linux-gnu, we need to install the cross compiler if [[ ${{ matrix.target }} == aarch64-unknown-linux-gnu ]]; then sudo apt-get install -y --no-install-recommends gcc-aarch64-linux-gnu fi version="${{ github.ref_name }}" DEB_NAME="tv-$version-${{ matrix.arch }}.deb" DEB_DIR="target/${{ matrix.target }}/debian" cargo deb --profile deb --target ${{ matrix.target }} -o "$DEB_DIR/$DEB_NAME" echo "DEB_DIR=$DEB_DIR" >> $GITHUB_ENV echo "DEB_NAME=$DEB_NAME" >> $GITHUB_ENV - name: Create sha256 sum of deb file shell: bash run: | cd "$DEB_DIR" sum="$DEB_NAME.sha256" shasum -a 256 "$DEB_NAME" > "$sum" echo "SUM=$sum" >> $GITHUB_ENV - name: Upload release archive env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} shell: bash run: | cd "$DEB_DIR" version="${{ github.ref_name }}" gh release upload "$version" "$DEB_NAME" "$SUM"