Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

WIP: try out mold as the default linker #827

Draft
wants to merge 6 commits into
base: canary
Choose a base branch
from
Draft
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
@@ -1,38 +1,42 @@
name: Release engine/language_client_ruby

on:
workflow_dispatch: {}
workflow_call: {}

permissions:
contents: read
id-token: write

concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
# suffix is important to prevent a concurrency deadlock with the calling workflow
group: ${{ github.workflow }}-${{ github.ref }}-build-ruby
cancel-in-progress: true

jobs:
build:
strategy:
fail-fast: false
matrix:
platform:
- x86_64-linux
- aarch64-linux
- x86_64-darwin
- arm64-darwin
_:
- platform: x86_64-linux
# This is necessary because rb-sys-dock depends on manylinux2014,
# which is based on CentOS 7 which is EOL as of July 2024 Once
# rake-compiler-dock switches to manylinux_2_28 and rb-sys-dock
# picks that up, we can pick their updates up and then drop this.
# See https://github.com/oxidize-rb/rb-sys/issues/402 and
# https://github.com/rake-compiler/rake-compiler-dock/issues/122
# for more details.
rb-sys-dock-setup: ./x86-64_linux-setup.sh
- platform: aarch64-linux
- platform: x86_64-darwin
- platform: arm64-darwin
#- x64-mingw-ucrt

runs-on: ubuntu-latest
defaults:
run:
working-directory: engine/language_client_ruby
steps:
- uses: rubygems/configure-rubygems-credentials@main
with:
# https://rubygems.org/profile/oidc/api_key_roles/rg_oidc_akr_p6x4xz53qtk948na3bgy
role-to-assume: rg_oidc_akr_p6x4xz53qtk948na3bgy

- uses: actions/checkout@v4

- uses: oxidize-rb/actions/setup-ruby-and-rust@main
Expand Down Expand Up @@ -65,34 +69,6 @@ jobs:
echo "RB_SYS_DOCK_CACHE_DIR=$rb_sys_dock_cache_dir" >> $GITHUB_ENV
echo "rb_sys_version=$rb_sys_version" >> $GITHUB_OUTPUT

#- name: Setup caching
# uses: actions/cache@v4
# with:
# path: |
# ${{ env.RB_SYS_DOCK_CACHE_DIR }}
# tmp/rb-sys-dock/${{ inputs.platform }}/target
# key: rb-sys-dock-${{ inputs.cache-version }}-${{ inputs.platform }}-${{ hashFiles('**/Gemfile.lock', '**/Cargo.lock') }}
# save-always: ${{ inputs.cache-save-always == 'true' }}
# restore-keys: |
# rb-sys-dock-${{ inputs.cache-version }}-${{ inputs.platform }}-

#- name: Install cargo-cache
# uses: oxidize-rb/actions/cargo-binstall@v1
# id: install-cargo-cache
# if: inputs.cargo-cache-clean == 'true'
# with:
# crate: cargo-cache
# version: 0.8.3
# strategies: quick-install

#- name: Clean the cargo cache
# if: inputs.cargo-cache-clean == 'true'
# uses: oxidize-rb/actions/post-run@v1
# with:
# run: cargo-cache --autoclean
# cwd: ${{ inputs.working-directory }}
# always: ${{ inputs.cache-save-always == 'true' }}

- name: Setup rb-sys
shell: bash
run: |
Expand All @@ -108,35 +84,24 @@ jobs:
- name: Build gem
shell: bash
working-directory: engine
if: ${{ matrix.platform == 'x86_64-linux' }}
run: |
: Compile gem
echo "Docker Working Directory: $(pwd)"
set -x

# Unfortunately we can't actually parallelize the Ruby versions
# because they get bundled into the same gem
rb-sys-dock \
--platform ${{ matrix.platform }} \
--platform ${{ matrix._.platform }} \
--mount-toolchains \
--directory language_client_ruby \
--ruby-versions 3.3,3.2,3.1,3.0,2.7 \
--ruby-versions 3.3,3.2,3.1 \
--build \
-- sudo yum install -y perl-IPC-Cmd

- name: Build gem
-- ${{ matrix._.rb-sys-dock-setup }}
- name: Show built gem
shell: bash
working-directory: engine
if: ${{ matrix.platform != 'x86_64-linux' }}
run: |
: Compile gem
echo "Docker Working Directory: $(pwd)"
set -x

rb-sys-dock \
--platform ${{ matrix.platform }} \
--mount-toolchains \
--directory language_client_ruby \
--ruby-versions 3.3,3.2,3.1,3.0,2.7 \
--build
run: find pkg -name '*.gem'

#################################################################################################################
#
Expand All @@ -147,7 +112,14 @@ jobs:
#
#################################################################################################################

- run: |
for i in $(ls pkg/*.gem); do
gem push $i
done
- name: Upload Ruby artifact
uses: actions/upload-artifact@v4
with:
name: gem-${{ matrix._.platform }}
path: engine/language_client_ruby/pkg/*.gem
if-no-files-found: error

# - run: |
# for i in $(ls pkg/*.gem); do
# gem push $i
# done
6 changes: 2 additions & 4 deletions .github/workflows/primary.yml
Original file line number Diff line number Diff line change
Expand Up @@ -46,10 +46,7 @@ jobs:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: pnpm/action-setup@v3
with:
version: 9.0.6
run_install: false
- uses: jdx/mise-action@v2
- uses: actions/setup-node@v4
with:
node-version: 20
Expand Down Expand Up @@ -81,6 +78,7 @@ jobs:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: jdx/mise-action@v2
- uses: dtolnay/rust-toolchain@stable
with:
toolchain: stable
Expand Down
90 changes: 81 additions & 9 deletions .github/workflows/release.yml
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,8 @@ on:
tags:
- "test-release/*.*"
- "*.*"
branches:
- sam/build-speedup

concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
Expand All @@ -28,6 +30,7 @@ jobs:
name: Build WASM
steps:
- uses: actions/checkout@v4
- uses: jdx/mise-action@v2
- uses: dtolnay/rust-toolchain@stable
with:
toolchain: stable
Expand All @@ -38,10 +41,6 @@ jobs:
- name: Bindgen
run: cargo install -f [email protected]
working-directory: engine/baml-schema-wasm
- uses: pnpm/action-setup@v3
with:
version: 8
run_install: false
# Set up Node.js
- name: Setup Node.js
uses: actions/setup-node@v4
Expand Down Expand Up @@ -97,6 +96,9 @@ jobs:
path: typescript/vscode-ext/packages/web-panel/dist
if-no-files-found: error

build-ruby-release:
uses: ./.github/workflows/build-ruby-release.reusable.yaml

build-release:
strategy:
fail-fast: false
Expand All @@ -105,6 +107,7 @@ jobs:
- target: aarch64-apple-darwin
host: macos-14
node_build: pnpm build --target aarch64-apple-darwin
mise: true

# Disabled as python is not supported on aarch64 windows
# - target: aarch64-pc-windows-msvc
Expand All @@ -117,41 +120,58 @@ jobs:
# need a new version of manylinux to build crates on arm64-linux
container: ghcr.io/rust-cross/manylinux_2_28-cross:aarch64
node_build: pnpm build --target aarch64-unknown-linux-gnu --use-napi-cross
cargo_args: -p baml-typescript-ffi -p baml-python-ffi
baml_build_help: 'off'

- target: x86_64-apple-darwin
host: macos-latest
node_build: pnpm build --target x86_64-apple-darwin
mise: true

- target: x86_64-pc-windows-msvc
host: windows-latest
node_build: pnpm build --target x86_64-pc-windows-msvc
setup-python-architecture: x64
cargo_args: -p baml-typescript-ffi -p baml-python-ffi
baml_build_help: 'off'

- target: x86_64-unknown-linux-gnu
host: ubuntu-latest
# Using any of the manylinux containers breaks a bunch of stuff: actions/checkout here, pnpm build there - not worth it.
container: null
node_build: pnpm build --target x86_64-unknown-linux-gnu --use-napi-cross
mise: true

name: Build ${{ matrix._.target }}
runs-on: ${{ matrix._.host }}
container: ${{ matrix._.container }}
steps:
- uses: actions/checkout@v4

# Use mold as default linker
- uses: rui314/setup-mold@v1

# Install python set up
- uses: actions/setup-python@v5
with:
python-version: "3.8"
architecture: ${{ matrix._.host == 'windows-latest' && 'x64' || null }}
architecture: ${{ matrix._.setup-python-architecture }}

- uses: jdx/mise-action@v2
if: ${{ matrix._.mise }}

- uses: pnpm/action-setup@v3
with:
version: 9.0.6
run_install: false

- uses: actions/setup-node@v4
with:
node-version: 20
cache: pnpm
cache-dependency-path: |
engine/language_client_typescript/pnpm-lock.yaml

# Install rust
- uses: dtolnay/rust-toolchain@stable
with:
Expand All @@ -171,8 +191,10 @@ jobs:
cache-on-failure: true

- name: Build Rust
run: cargo build --release --target ${{ matrix._.target }}
run: cargo build --timings --release --target ${{ matrix._.target }} ${{ matrix._.cargo_args }}
working-directory: engine
env:
BAML_BUILD_HELP: ${{ matrix._.baml_build_help }}

# Build Node
- name: PNPM Build
Expand All @@ -188,6 +210,13 @@ jobs:
args: --release --out engine/language_client_python/dist --manifest-path engine/language_client_python/Cargo.toml
container: off

- name: Upload timings
uses: actions/upload-artifact@v4
with:
name: timing-${{ matrix._.target }}
path: engine/target/**/*.html
if-no-files-found: error

# Upload
- name: Upload Python
uses: actions/upload-artifact@v4
Expand All @@ -202,11 +231,21 @@ jobs:
name: bindings-${{ matrix._.target }}
path: engine/language_client_typescript/*.node
if-no-files-found: error

# placeholder fan-in step
assert-all-builds-passed:
runs-on: ubuntu-latest
needs:
- build-release
- build-ruby-release
- build-wasm
steps:
- run: true

publish-to-pypi:
environment: release
if: github.ref_type == 'tag'
needs: [build-release, build-wasm]
needs: [assert-all-builds-passed]
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
Expand All @@ -227,7 +266,7 @@ jobs:
publish-to-npm:
environment: release
if: github.ref_type == 'tag'
needs: [build-release, build-wasm]
needs: [assert-all-builds-passed]
runs-on: ubuntu-latest
env:
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}
Expand Down Expand Up @@ -274,6 +313,35 @@ jobs:
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
NPM_TOKEN: ${{ secrets.NPM_TOKEN }}

publish-to-rubygems:
environment: release
if: github.ref_type == 'tag'
needs: [assert-all-builds-passed]
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4

- uses: rubygems/configure-rubygems-credentials@main
with:
# https://rubygems.org/profile/oidc/api_key_roles/rg_oidc_akr_p6x4xz53qtk948na3bgy
role-to-assume: rg_oidc_akr_p6x4xz53qtk948na3bgy

- uses: jdx/mise-action@v2

- uses: actions/download-artifact@v4
with:
pattern: gem-*
path: engine/language_client_ruby/pkg/
merge-multiple: true

- working-directory: engine/language_client_ruby
run: |
set -euxo pipefail
find pkg
for i in $(ls pkg/*.gem); do
gem push $i
done

# publish-vscode:
# environment: release
Expand Down Expand Up @@ -331,7 +399,11 @@ jobs:
release-github:
runs-on: ubuntu-latest
if: github.ref_type == 'tag'
needs: [publish-to-pypi, publish-to-npm]
needs:
- publish-to-pypi
- publish-to-npm
- publish-to-rubygems
# - publish-vscode
steps:
- uses: actions/checkout@v4

Expand Down
3 changes: 3 additions & 0 deletions .mise.toml
Original file line number Diff line number Diff line change
@@ -1,2 +1,5 @@
[tools]
node = "latest"
ruby = "3.1"
pnpm = "latest"
poetry = "latest"
Loading
Loading