[llvm] [ci] Add ids workflow for checking llvm apis have been annotated with LLVM_ABI (PR #128370)

via llvm-commits llvm-commits at lists.llvm.org
Sat Feb 22 12:45:05 PST 2025


https://github.com/mcbarton updated https://github.com/llvm/llvm-project/pull/128370

>From ed3d5c09c06bbf437bc0aef1367046f9d7ad0471 Mon Sep 17 00:00:00 2001
From: mcbarton <150042563+mcbarton at users.noreply.github.com>
Date: Tue, 7 Jan 2025 09:06:17 +0000
Subject: [PATCH 1/3] Add ids workflow

---
 .github/workflows/ids-check.yml | 72 +++++++++++++++++++++++++++++++++
 1 file changed, 72 insertions(+)
 create mode 100644 .github/workflows/ids-check.yml

diff --git a/.github/workflows/ids-check.yml b/.github/workflows/ids-check.yml
new file mode 100644
index 0000000000000..8ed12140d4bbc
--- /dev/null
+++ b/.github/workflows/ids-check.yml
@@ -0,0 +1,72 @@
+name: ids-check
+on:
+  pull_request:
+    branches: [main]
+  push:
+    branches: [main]
+
+concurrency:
+  group: ${{ github.workflow }}-${{ github.event.pull_request.number }}
+  cancel-in-progress: true
+
+jobs:
+  build:
+    name: ${{ matrix.name }}
+    runs-on: ${{ matrix.os }}
+    strategy:
+      fail-fast: false
+      matrix:
+        include:
+          - name: ids-check
+            os: macos-15
+
+    steps:
+    - uses: actions/checkout at v4
+      with:
+        repository: compnerd/ids
+        path: ${{ github.workspace }}/ids
+        fetch-depth: 0
+
+    - uses: actions/checkout at v4
+      with:
+        path: ${{ github.workspace }}/llvm-project
+        fetch-depth: 0
+
+    - name: Configure and build minimal LLVM for use by ids
+      run: |
+        cmake -B ${{ github.workspace }}/llvm-project/build/ \
+              -D CMAKE_BUILD_TYPE=Release \
+              -S ${{ github.workspace }}/llvm-project/llvm/ \
+              -D LLVM_ENABLE_PROJECTS=clang \
+              -D LLVM_TARGETS_TO_BUILD="host" \
+              -G Ninja
+        cd {{ github.workspace }}/llvm-project/build/
+        ninja -t targets all | grep "CommonTableGen: phony$" | grep -v "/" | sed 's/:.*//'
+
+    - name: install llvm and lit to build ids against
+      run: |
+        brew install llvm at 18
+        brew install lit at 18
+
+    - name: Configure ids
+      run: |
+        cmake -B ${{ github.workspace }}/ids/build/ \
+              -S ${{ github.workspace }}/ids/ \
+               -D CMAKE_BUILD_TYPE=Release \
+               -D CMAKE_C_COMPILER=$(brew --prefix llvm at 18)/bin/clang \
+               -D CMAKE_CXX_COMPILER=$(brew --prefix llvm at 18)/bin/clang++ \
+               -D CMAKE_EXE_LINKER_FLAGS=-fuse-ld=lld \
+               -D LLVM_DIR=$(brew --prefix llvm at 18)lib/cmake/llvm \
+               -D Clang_DIR=$(brew --prefix llvm at 18)/lib/cmake/clang \
+               -D FILECHECK_EXECUTABLE=$(brew --prefix llvm at 18)/bin/FileCheck \
+               -D LIT_EXECUTABLE=$(brew --prefix lit at 18)/bin/lit
+
+    - name: Build ids
+      run: |
+        cmake --build ${{ github.workspace }}/ids/build \
+              --config Release \
+              --parallel $(nproc --all)
+
+    - name: Run ids over compilation database
+      run: |
+        ${{ github.workspace }}/ids/build/bin/ids -export-macro LLVM_ABI -p ${{ github.workspace }}/llvm-project/build/compile_commands.json

>From f0d13b387cb02e234967e0d74203cbbcc9f6833b Mon Sep 17 00:00:00 2001
From: mcbarton <matthew.c.barton at hotmail.co.uk>
Date: Sat, 22 Feb 2025 20:40:02 +0000
Subject: [PATCH 2/3] Install ninja as part of ids-check.yml

---
 .github/workflows/ids-check.yml | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)

diff --git a/.github/workflows/ids-check.yml b/.github/workflows/ids-check.yml
index 8ed12140d4bbc..c4efc1fdc6636 100644
--- a/.github/workflows/ids-check.yml
+++ b/.github/workflows/ids-check.yml
@@ -43,10 +43,11 @@ jobs:
         cd {{ github.workspace }}/llvm-project/build/
         ninja -t targets all | grep "CommonTableGen: phony$" | grep -v "/" | sed 's/:.*//'
 
-    - name: install llvm and lit to build ids against
+    - name: install dependencies needed to build ids
       run: |
         brew install llvm at 18
         brew install lit at 18
+        brew install ninja
 
     - name: Configure ids
       run: |

>From 63bb05b912fad3607506fa6d1c617d116434accc Mon Sep 17 00:00:00 2001
From: mcbarton <matthew.c.barton at hotmail.co.uk>
Date: Sat, 22 Feb 2025 20:44:55 +0000
Subject: [PATCH 3/3] Update ids-check.yml

---
 .github/workflows/ids-check.yml | 12 ++++++------
 1 file changed, 6 insertions(+), 6 deletions(-)

diff --git a/.github/workflows/ids-check.yml b/.github/workflows/ids-check.yml
index c4efc1fdc6636..a45f4ce7b0d28 100644
--- a/.github/workflows/ids-check.yml
+++ b/.github/workflows/ids-check.yml
@@ -32,6 +32,12 @@ jobs:
         path: ${{ github.workspace }}/llvm-project
         fetch-depth: 0
 
+    - name: install dependencies needed to build ids
+      run: |
+        brew install llvm at 18
+        brew install lit at 18
+        brew install ninja
+
     - name: Configure and build minimal LLVM for use by ids
       run: |
         cmake -B ${{ github.workspace }}/llvm-project/build/ \
@@ -43,12 +49,6 @@ jobs:
         cd {{ github.workspace }}/llvm-project/build/
         ninja -t targets all | grep "CommonTableGen: phony$" | grep -v "/" | sed 's/:.*//'
 
-    - name: install dependencies needed to build ids
-      run: |
-        brew install llvm at 18
-        brew install lit at 18
-        brew install ninja
-
     - name: Configure ids
       run: |
         cmake -B ${{ github.workspace }}/ids/build/ \



More information about the llvm-commits mailing list