From 0428bed5a746e5a8c6fcad04ff65bfc413313deb Mon Sep 17 00:00:00 2001 From: Henner Zeller Date: Thu, 2 Jan 2025 14:27:39 +0100 Subject: [PATCH] Create compilation DB using bant from bzlmod. --- .github/bin/make-compilation-db.sh | 20 ++++++++--------- .github/workflows/verible-ci.yml | 36 +++++++++--------------------- MODULE.bazel | 3 +++ 3 files changed, 22 insertions(+), 37 deletions(-) diff --git a/.github/bin/make-compilation-db.sh b/.github/bin/make-compilation-db.sh index 4afd8fbc6..b7b030a08 100755 --- a/.github/bin/make-compilation-db.sh +++ b/.github/bin/make-compilation-db.sh @@ -19,18 +19,16 @@ set -e BANT=${BANT:-bant} if [ ! -e bazel-bin ]; then - echo "Before creating compilation DB, need to run bazel build first" + echo "Before creating compilation DB, run bazel build first to fetch deps." exit 1 fi -if command -v ${BANT} >/dev/null; then - ${BANT} compile-flags > compile_flags.txt +bazel run --cxxopt=-std=c++20 @bant//bant:bant -- \ + -C $(pwd) compile-flags 2>/dev/null > compile_flags.txt - # Bant does not see yet the flex dependency inside the toolchain - for d in bazel-out/../../../external/*flex*/src/FlexLexer.h ; do - echo "-I$(dirname $d)" >> compile_flags.txt - done -else - echo "To create compilation DB, need to have http://bant.build/ installed or provided in BANT environment variable." - exit 1 -fi +# Bant does not see yet the flex dependency inside the toolchain +for d in bazel-out/../../../external/*flex*/src/FlexLexer.h ; do + echo "-I$(dirname $d)" >> compile_flags.txt +done + +echo "Now, re-run original build to make all artifacts visible to clang-tidy" diff --git a/.github/workflows/verible-ci.yml b/.github/workflows/verible-ci.yml index 21ab15034..9f27c9391 100644 --- a/.github/workflows/verible-ci.yml +++ b/.github/workflows/verible-ci.yml @@ -80,17 +80,6 @@ jobs: source ./.github/settings.sh ./.github/bin/install-bazel.sh - - name: Get Bant - run: | - # TODO: provide this as action where we simply say with version=... - VERSION="v0.1.9" - STATIC_VERSION="bant-${VERSION}-linux-static-x86_64" - wget "https://github.com/hzeller/bant/releases/download/${VERSION}/${STATIC_VERSION}.tar.gz" - tar xvzf "${STATIC_VERSION}.tar.gz" - mkdir -p bin - ln -sf ../"${STATIC_VERSION}/bin/bant" bin/ - bin/bant -V - - name: Create Cache Timestamp id: cache_timestamp uses: nanzm/get-time-action@v2.0 @@ -106,26 +95,21 @@ jobs: key: clang-tidy2-${{ steps.cache_timestamp.outputs.time }} restore-keys: clang-tidy2- - - name: Build Project genrules - run: | - # Fetch all dependencies and run genrules for bant to see every file - # that makes it into the compile to build comile DB. - bazel build \ - //verible/common/analysis:command-file-lexer \ - //verible/verilog/parser:verilog-lex \ - //verible/verilog/parser:verilog-y \ - //verible/verilog/parser:verilog-y-final \ - //verible/common/analysis:command-file-lexer_test \ - //verible/common/lsp:lsp-text-buffer - bazel build $(bin/bant -q genrule-outputs | awk '{print $2}') \ - $(bin/bant list-targets | grep cc_proto_library | awk '{print $3}') - - name: Run clang tidy run: | + echo "::group::Trigger fetch and preparation" + bazel build -c opt :install-binaries + echo "::endgroup::" + echo "::group::Make Compilation DB" - BANT=bin/bant .github/bin/make-compilation-db.sh + .github/bin/make-compilation-db.sh cat compile_flags.txt echo "::endgroup::" + + echo "::group::Re-etablish links" + bazel build -c opt :install-binaries + echo "::endgroup::" + # For runtime references, use clang-tidy 11 that still has it, everything else: latest. CLANG_TIDY=clang-tidy-11 ./.github/bin/run-clang-tidy-cached.cc --checks="-*,google-runtime-references" \ || ( cat verible_clang-tidy.out ; exit 1) diff --git a/MODULE.bazel b/MODULE.bazel index 70ec7c50e..2bad50952 100644 --- a/MODULE.bazel +++ b/MODULE.bazel @@ -34,3 +34,6 @@ single_version_override( bazel_dep(name = "protobuf", version = "24.4") bazel_dep(name = "rules_cc", version = "0.0.9") bazel_dep(name = "rules_proto", version = "6.0.0-rc2") + +# To build compilation DB and run build-cleaning +bazel_dep(name = "bant", version = "0.1.11", dev_dependency = True)