From 76231ac4c997e597f17274adb086848f2e6dd91e Mon Sep 17 00:00:00 2001 From: Pavel Ivanov Date: Sun, 28 Apr 2024 23:48:06 +0200 Subject: [PATCH] new: use goreleaser for publishing --- .github/workflows/publish.yml | 35 +++++++++++++++++++++-- .goreleaser-hook.sh | 21 ++++++++++++++ .goreleaser.yaml | 54 +++++++++++++++++++++++++++++++++++ Cargo.lock | 4 +-- Cargo.toml | 2 +- build/goreleaser/stub.go | 3 ++ 6 files changed, 113 insertions(+), 6 deletions(-) create mode 100644 .goreleaser-hook.sh create mode 100644 .goreleaser.yaml create mode 100644 build/goreleaser/stub.go diff --git a/.github/workflows/publish.yml b/.github/workflows/publish.yml index 43b9bd77..2453956b 100644 --- a/.github/workflows/publish.yml +++ b/.github/workflows/publish.yml @@ -6,8 +6,8 @@ on: - 'v*.*.*' jobs: - publish: - name: Publish for ${{ matrix.name }} + build: + name: Build for ${{ matrix.name }} runs-on: ${{ matrix.os }} env: @@ -87,7 +87,7 @@ jobs: asset: hl-windows.zip steps: - - uses: actions/checkout@v3 + - uses: actions/checkout@v4 - uses: actions-rust-lang/setup-rust-toolchain@v1 with: @@ -128,9 +128,38 @@ jobs: if: matrix.archiver == 'tar.gz' && matrix.universal == true run: tar -C ./target -cz -f ${{ matrix.asset }} hl + - name: Store artifact + uses: actions/upload-artifact@v4 + with: + name: hl-${{ matrix.arch }}-${{ matrix.family }} + path: target/${{ matrix.target }}/release/hl${{ matrix.family == 'windows' && '.exe' || '' }} + retention-days: 1 + - name: Upload binaries to release + if: startsWith(github.ref, 'refs/tags/v') uses: svenstaro/upload-release-action@v2 with: repo_token: ${{ secrets.GITHUB_TOKEN }} file: ${{ matrix.asset }} tag: ${{ github.ref }} + + publish: + name: Publish + needs: [build] + runs-on: ubuntu-22.04 + steps: + - name: Checkout Git repo + uses: actions/checkout@v4 + - uses: actions/download-artifact@v4 + with: + path: artifacts + - name: Set up Go + uses: actions/setup-go@v5 + - name: Run GoReleaser + uses: goreleaser/goreleaser-action@v5 + with: + distribution: goreleaser + version: latest + args: release --clean --skip=validate + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} diff --git a/.goreleaser-hook.sh b/.goreleaser-hook.sh new file mode 100644 index 00000000..a6f152a3 --- /dev/null +++ b/.goreleaser-hook.sh @@ -0,0 +1,21 @@ +#!/usr/bin/env bash + +go_arch=$1 +go_os=$2 +project_name=$3 + +# Make Go -> Rust arch/os mapping +case $go_arch in + amd64) rust_arch='x86_64' ;; + arm64) rust_arch='aarch64' ;; + *) echo "unknown arch: $go_arch" && exit 1 ;; +esac +case $go_os in + linux) rust_os='linux' ;; + darwin) rust_os='macos' ;; + windows) rust_os='windows' ;; + *) echo "unknown os: $go_os" && exit 1 ;; +esac + +# Find artifacts and uncompress in the corresponding directory +find artifacts -type f -name "${project_name}-${rust_arch}-${rust_os}" -exec mv {} dist/${project_name}_${go_os}_${go_arch} \; diff --git a/.goreleaser.yaml b/.goreleaser.yaml new file mode 100644 index 00000000..cf1bff74 --- /dev/null +++ b/.goreleaser.yaml @@ -0,0 +1,54 @@ +project_name: hl +builds: + - main: build/goreleaser/stub.go + goos: + - linux + - darwin + - windows + goarch: + - amd64 + - arm64 + binary: hl + ignore: + - goos: windows + goarch: arm64 + hooks: + post: + - ./.goreleaser-hook.sh {{ .Arch }} {{ .Os }} {{ .ProjectName }} +checksum: + name_template: "checksums.txt" +changelog: + sort: asc + filters: + exclude: + - "^docs:" + - "^test:" +brews: + - name: hl + tap: + owner: pamburus + name: tap + url_template: "https://github.com/pamburus/tap/releases/download/{{ .Tag }}/{{ .ArtifactName }}" + commit_author: + name: Pavel Ivanov + email: mr.pavel.ivanov@gmail.com + commit_msg_template: "Brew formula update for {{ .ProjectName }} version {{ .Tag }}" + directory: Formula + homepage: "https://github.com/pamburus/hl" + description: "Log viewer for JSON and logfmt logs" + license: "MIT" + skip_upload: auto + custom_block: | + head "https://github.com/pamburus/hl.git" + test: | + system "#{bin}/hl --version" + install: | + system "cargo", "install", *std_cargo_args + generate_completions_from_executable(bin/"hl", "--shell-completions") + repository: + owner: pamburus + name: homebrew-tap + branch: main + pull_request: + enabled: true + draft: true diff --git a/Cargo.lock b/Cargo.lock index 1c38129a..819fdf90 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -600,7 +600,7 @@ checksum = "edd0f118536f44f5ccd48bcb8b111bdc3de888b58c74639dfb034a357d0f206d" [[package]] name = "encstr" -version = "0.28.0" +version = "0.28.1-beta.1" [[package]] name = "enum-map" @@ -757,7 +757,7 @@ checksum = "7f24254aa9a54b5c858eaee2f5bccdb46aaf0e486a595ed5fd8f86ba55232a70" [[package]] name = "hl" -version = "0.28.0" +version = "0.28.1-beta.1" dependencies = [ "atoi", "bincode", diff --git a/Cargo.toml b/Cargo.toml index ecc74222..7aafd78d 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -4,7 +4,7 @@ members = [".", "crate/encstr"] [workspace.package] repository = "https://github.com/pamburus/hl" authors = ["Pavel Ivanov "] -version = "0.28.0" +version = "0.28.1-beta.1" edition = "2021" license = "MIT" diff --git a/build/goreleaser/stub.go b/build/goreleaser/stub.go new file mode 100644 index 00000000..38dd16da --- /dev/null +++ b/build/goreleaser/stub.go @@ -0,0 +1,3 @@ +package main + +func main() {}