publish a source tarball with version and grammars (#1875)

* publish a source tarball with version and grammars

* include_str! the release version from a VERSION file

* remove setting of .version file from tag

don't need this anymore since the file is checked into source
This commit is contained in:
Michael Davis 2022-03-29 00:34:19 -05:00 committed by GitHub
parent 6e7c287371
commit 838cfcc7cd
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 94 additions and 23 deletions

View file

@ -1,32 +1,81 @@
name: Release name: Release
on: on:
# schedule:
# - cron: '0 0 * * *' # midnight UTC
push: push:
tags: tags:
- 'v[0-9]+.[0-9]+.[0-9]+' - '[0-9]+.[0-9]+'
## - release - '[0-9]+.[0-9]+.[0-9]+'
jobs: jobs:
fetch-grammars:
name: Fetch Grammars
runs-on: ubuntu-latest
steps:
- name: Checkout sources
uses: actions/checkout@v3
- name: Install stable toolchain
uses: actions-rs/toolchain@v1
with:
profile: minimal
toolchain: stable
override: true
- name: Cache cargo registry
uses: actions/cache@v3
with:
path: ~/.cargo/registry
key: ${{ runner.os }}-v2-cargo-registry-${{ hashFiles('**/Cargo.lock') }}
restore-keys: ${{ runner.os }}-v2-cargo-registry-
- name: Cache cargo index
uses: actions/cache@v3
with:
path: ~/.cargo/git
key: ${{ runner.os }}-v2-cargo-index-${{ hashFiles('**/Cargo.lock') }}
restore-keys: ${{ runner.os }}-v2-cargo-index-
- name: Cache cargo target dir
uses: actions/cache@v3
with:
path: target
key: ${{ runner.os }}-v2-cargo-build-target-${{ hashFiles('**/Cargo.lock') }}
restore-keys: ${{ runner.os }}-v2-cargo-build-target-
- name: Fetch tree-sitter grammars
uses: actions-rs/cargo@v1
env:
HELIX_DISABLE_AUTO_GRAMMAR_BUILD: yes
with:
command: run
args: -- --grammar fetch
- name: Bundle grammars
run: tar cJf grammars.tar.xz -C runtime/grammars/sources .
- uses: actions/upload-artifact@v3
with:
name: grammars
path: grammars.tar.xz
dist: dist:
name: Dist name: Dist
needs: [fetch-grammars]
runs-on: ${{ matrix.os }} runs-on: ${{ matrix.os }}
strategy: strategy:
fail-fast: false # don't fail other jobs if one fails fail-fast: false # don't fail other jobs if one fails
matrix: matrix:
build: [x86_64-linux, aarch64-linux, x86_64-macos, x86_64-windows] #, x86_64-win-gnu, win32-msvc build: [x86_64-linux, x86_64-macos, x86_64-windows] #, x86_64-win-gnu, win32-msvc
include: include:
- build: x86_64-linux - build: x86_64-linux
os: ubuntu-20.04 os: ubuntu-20.04
rust: stable rust: stable
target: x86_64-unknown-linux-gnu target: x86_64-unknown-linux-gnu
cross: false cross: false
- build: aarch64-linux # - build: aarch64-linux
os: ubuntu-20.04 # os: ubuntu-20.04
rust: stable # rust: stable
target: aarch64-unknown-linux-gnu # target: aarch64-unknown-linux-gnu
cross: true # cross: true
- build: x86_64-macos - build: x86_64-macos
os: macos-latest os: macos-latest
rust: stable rust: stable
@ -54,6 +103,15 @@ jobs:
- name: Checkout sources - name: Checkout sources
uses: actions/checkout@v3 uses: actions/checkout@v3
- name: Download grammars
uses: actions/download-artifact@v2
- name: Move grammars under runtime
if: "!startsWith(matrix.os, 'windows')"
run: |
mkdir -p runtime/grammars/sources
tar xJf grammars/grammars.tar.xz -C runtime/grammars/sources
- name: Install ${{ matrix.rust }} toolchain - name: Install ${{ matrix.rust }} toolchain
uses: actions-rs/toolchain@v1 uses: actions-rs/toolchain@v1
with: with:
@ -98,6 +156,7 @@ jobs:
else else
cp "target/${{ matrix.target }}/release/hx" "dist/" cp "target/${{ matrix.target }}/release/hx" "dist/"
fi fi
rm -rf runtime/grammars/sources
cp -r runtime dist cp -r runtime dist
- uses: actions/upload-artifact@v3 - uses: actions/upload-artifact@v3
@ -118,7 +177,7 @@ jobs:
- name: Calculate tag name - name: Calculate tag name
run: | run: |
name=dev name=dev
if [[ $GITHUB_REF == refs/tags/v* ]]; then if [[ $GITHUB_REF == refs/tags/* ]]; then
name=${GITHUB_REF:10} name=${GITHUB_REF:10}
fi fi
echo ::set-output name=val::$name echo ::set-output name=val::$name
@ -130,8 +189,13 @@ jobs:
run: | run: |
set -ex set -ex
rm -rf tmp source="$(pwd)"
mkdir tmp mkdir -p runtime/grammars/sources
tar xJf grammars/grammars.tar.xz -C runtime/grammars/sources
rm -rf grammars
cd "$(mktemp -d)"
mv $source/bins-* .
mkdir dist mkdir dist
for dir in bins-* ; do for dir in bins-* ; do
@ -140,19 +204,22 @@ jobs:
exe=".exe" exe=".exe"
fi fi
pkgname=helix-$TAG-$platform pkgname=helix-$TAG-$platform
mkdir tmp/$pkgname mkdir $pkgname
cp LICENSE README.md tmp/$pkgname cp $source/LICENSE $source/README.md $pkgname
mv bins-$platform/runtime tmp/$pkgname/ mv bins-$platform/runtime $pkgname/
mv bins-$platform/hx$exe tmp/$pkgname mv bins-$platform/hx$exe $pkgname
chmod +x tmp/$pkgname/hx$exe chmod +x $pkgname/hx$exe
if [ "$exe" = "" ]; then if [ "$exe" = "" ]; then
tar cJf dist/$pkgname.tar.xz -C tmp $pkgname tar cJf dist/$pkgname.tar.xz $pkgname
else else
(cd tmp && 7z a -r ../dist/$pkgname.zip $pkgname) 7z a -r dist/$pkgname.zip $pkgname
fi fi
done done
tar cJf dist/helix-$TAG-source.tar.xz -C $source .
mv dist $source/
- name: Upload binaries to release - name: Upload binaries to release
uses: svenstaro/upload-release-action@v2 uses: svenstaro/upload-release-action@v2
with: with:

1
VERSION Normal file
View file

@ -0,0 +1 @@
22.03

View file

@ -2,6 +2,8 @@ use helix_loader::grammar::{build_grammars, fetch_grammars};
use std::borrow::Cow; use std::borrow::Cow;
use std::process::Command; use std::process::Command;
const VERSION: &str = include_str!("../VERSION");
fn main() { fn main() {
let git_hash = Command::new("git") let git_hash = Command::new("git")
.args(&["rev-parse", "HEAD"]) .args(&["rev-parse", "HEAD"])
@ -11,8 +13,8 @@ fn main() {
.and_then(|x| String::from_utf8(x.stdout).ok()); .and_then(|x| String::from_utf8(x.stdout).ok());
let version: Cow<_> = match git_hash { let version: Cow<_> = match git_hash {
Some(git_hash) => format!("{} ({})", env!("CARGO_PKG_VERSION"), &git_hash[..8]).into(), Some(git_hash) => format!("{} ({})", VERSION, &git_hash[..8]).into(),
None => env!("CARGO_PKG_VERSION").into(), None => VERSION.into(),
}; };
if std::env::var("HELIX_DISABLE_AUTO_GRAMMAR_BUILD").is_err() { if std::env::var("HELIX_DISABLE_AUTO_GRAMMAR_BUILD").is_err() {
@ -21,6 +23,7 @@ fn main() {
} }
println!("cargo:rerun-if-changed=../runtime/grammars/"); println!("cargo:rerun-if-changed=../runtime/grammars/");
println!("cargo:rerun-if-changed=../VERSION");
println!("cargo:rustc-env=VERSION_AND_GIT_HASH={}", version); println!("cargo:rustc-env=VERSION_AND_GIT_HASH={}", version);
} }