gh-131895: fix $PATH
for clang on Darwin runners for tail-calling interpreter
#395
Workflow file for this run
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Tail calling interpreter | |
on: | |
pull_request: | |
paths: | |
- '.github/workflows/tail-call.yml' | |
- 'Python/bytecodes.c' | |
- 'Python/ceval.c' | |
- 'Python/ceval_macros.h' | |
- 'Python/generated_cases.c.h' | |
push: | |
paths: | |
- '.github/workflows/tail-call.yml' | |
- 'Python/bytecodes.c' | |
- 'Python/ceval.c' | |
- 'Python/ceval_macros.h' | |
- 'Python/generated_cases.c.h' | |
workflow_dispatch: | |
permissions: | |
contents: read | |
concurrency: | |
group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }} | |
cancel-in-progress: true | |
env: | |
FORCE_COLOR: 1 | |
jobs: | |
tail-call: | |
name: ${{ matrix.target }} | |
runs-on: ${{ matrix.runner }} | |
timeout-minutes: 90 | |
strategy: | |
fail-fast: false | |
matrix: | |
target: | |
# Un-comment as we add support for more platforms for tail-calling interpreters. | |
# - i686-pc-windows-msvc/msvc | |
- x86_64-pc-windows-msvc/msvc | |
# - aarch64-pc-windows-msvc/msvc | |
- x86_64-apple-darwin/clang | |
- aarch64-apple-darwin/clang | |
- x86_64-unknown-linux-gnu/gcc | |
- aarch64-unknown-linux-gnu/gcc | |
- free-threading | |
llvm: | |
- 19 | |
include: | |
# - target: i686-pc-windows-msvc/msvc | |
# architecture: Win32 | |
# runner: windows-latest | |
- target: x86_64-pc-windows-msvc/msvc | |
architecture: x64 | |
runner: windows-latest | |
# - target: aarch64-pc-windows-msvc/msvc | |
# architecture: ARM64 | |
# runner: windows-latest | |
- target: x86_64-apple-darwin/clang | |
architecture: x86_64 | |
runner: macos-13 | |
- target: aarch64-apple-darwin/clang | |
architecture: aarch64 | |
runner: macos-14 | |
- target: x86_64-unknown-linux-gnu/gcc | |
architecture: x86_64 | |
runner: ubuntu-24.04 | |
- target: aarch64-unknown-linux-gnu/gcc | |
architecture: aarch64 | |
runner: ubuntu-24.04-arm | |
- target: free-threading | |
architecture: x86_64 | |
runner: ubuntu-24.04 | |
steps: | |
- uses: actions/checkout@v4 | |
with: | |
persist-credentials: false | |
- uses: actions/setup-python@v5 | |
with: | |
python-version: '3.11' | |
- name: Native Windows (debug) | |
if: runner.os == 'Windows' && matrix.architecture != 'ARM64' | |
shell: cmd | |
run: | | |
choco install llvm --allow-downgrade --no-progress --version ${{ matrix.llvm }}.1.5 | |
set PlatformToolset=clangcl | |
set LLVMToolsVersion=${{ matrix.llvm }}.1.5 | |
set LLVMInstallDir=C:\Program Files\LLVM | |
call ./PCbuild/build.bat --tail-call-interp -d -p ${{ matrix.architecture }} | |
call ./PCbuild/rt.bat -d -p ${{ matrix.architecture }} -q --multiprocess 0 --timeout 4500 --verbose2 --verbose3 | |
# No tests (yet): | |
- name: Emulated Windows (release) | |
if: runner.os == 'Windows' && matrix.architecture == 'ARM64' | |
shell: cmd | |
run: | | |
choco install llvm --allow-downgrade --no-progress --version ${{ matrix.llvm }}.1.5 | |
set PlatformToolset=clangcl | |
set LLVMToolsVersion=${{ matrix.llvm }}.1.5 | |
set LLVMInstallDir=C:\Program Files\LLVM | |
./PCbuild/build.bat --tail-call-interp -p ${{ matrix.architecture }} | |
# The `find` line is required as a result of https://github.com/actions/runner-images/issues/9966. | |
# This is a bug in the macOS runner image where the pre-installed Python is installed in the same | |
# directory as the Homebrew Python, which causes the build to fail for macos-13. This line removes | |
# the symlink to the pre-installed Python so that the Homebrew Python is used instead. | |
- name: Native macOS (release) | |
if: runner.os == 'macOS' | |
run: | | |
brew update | |
find /usr/local/bin -lname '*/Library/Frameworks/Python.framework/*' -delete | |
brew install jq llvm@${{ matrix.llvm }} | |
export SDKROOT="$(xcrun --show-sdk-path)" | |
export PATH="/opt/homebrew/opt/llvm/bin:$PATH" | |
export PATH="/usr/local/opt/llvm@{{ matrix.llvm }}/bin:$PATH" | |
export PATH="/usr/local/opt/llvm/bin:$PATH" | |
export TMP_LLVM_VERSION="$(curl -s https://formulae.brew.sh/api/formula/llvm@{{ matrix.llvm }}.json | jq -r .versions.stable)" | |
export PATH="/usr/local/Cellar/llvm@{{ matrix.llvm }}/${TMP_LLVM_VERSION}/bin:$PATH" | |
unset TMP_LLVM_VERSION | |
CC=clang-19 ./configure --with-tail-call-interp | |
make all --jobs 4 | |
./python.exe -m test --multiprocess 0 --timeout 4500 --verbose2 --verbose3 | |
- name: Native Linux (debug) | |
if: runner.os == 'Linux' && matrix.target != 'free-threading' | |
run: | | |
sudo bash -c "$(wget -O - https://apt.llvm.org/llvm.sh)" ./llvm.sh ${{ matrix.llvm }} | |
export PATH="$(llvm-config-${{ matrix.llvm }} --bindir):$PATH" | |
CC=clang-19 ./configure --with-tail-call-interp --with-pydebug | |
make all --jobs 4 | |
./python -m test --multiprocess 0 --timeout 4500 --verbose2 --verbose3 | |
- name: Native Linux with free-threading (release) | |
if: matrix.target == 'free-threading' | |
run: | | |
sudo bash -c "$(wget -O - https://apt.llvm.org/llvm.sh)" ./llvm.sh ${{ matrix.llvm }} | |
export PATH="$(llvm-config-${{ matrix.llvm }} --bindir):$PATH" | |
CC=clang-19 ./configure --with-tail-call-interp --disable-gil | |
make all --jobs 4 | |
./python -m test --multiprocess 0 --timeout 4500 --verbose2 --verbose3 | |