Skip to content

Commit

Permalink
Build compilation DB in a different way.
Browse files Browse the repository at this point in the history
The rules_compdb approach is not maintained anymore and does
not work for newer bazel or modules bazel.
The hedronvision way of creating a compilation DB was not
working (chipsalliance#2261), so using `bant` now in this approach.
  • Loading branch information
hzeller committed Dec 16, 2024
1 parent a3485a2 commit 8c554d2
Show file tree
Hide file tree
Showing 4 changed files with 43 additions and 80 deletions.
22 changes: 15 additions & 7 deletions .github/bin/make-compilation-db.sh
Original file line number Diff line number Diff line change
Expand Up @@ -16,13 +16,21 @@
set -u
set -e

readonly OUTPUT_BASE="$(bazel info output_base)"
BANT=${BANT:-bant}

readonly COMPDB_SCRIPT="${OUTPUT_BASE}/external/rules_compdb/generate.py"
[ -r "${COMPDB_SCRIPT}" ] || bazel fetch ...
if [ ! -e bazel-bin ]; then
echo "Before creating compilation DB, need to run bazel build first"
exit 1
fi

python3 "${COMPDB_SCRIPT}"
if command -v ${BANT} >/dev/null; then
${BANT} compile-flags > compile_flags.txt

# Remove a flags observed in the wild that clang-tidy doesn't understand.
sed -i -e 's/-fno-canonical-system-headers//g; s/DEBUG_PREFIX_MAP_PWD=.//g' \
compile_commands.json
# 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
70 changes: 28 additions & 42 deletions .github/workflows/verible-ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -80,6 +80,17 @@ 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
Expand All @@ -95,11 +106,25 @@ jobs:
key: clang-tidy-${{ steps.cache_timestamp.outputs.time }}
restore-keys: clang-tidy-

- 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.f
bazel fetch ...
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
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::Make Compilation DB"
.github/bin/make-compilation-db.sh
wc -l compile_commands.json
BANT=bin/bant .github/bin/make-compilation-db.sh
cat compile_flags.txt
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" \
Expand Down Expand Up @@ -127,7 +152,7 @@ jobs:
- name: Get Bant
run: |
# TODO: provide this as action where we simply say with version=...
VERSION="v0.1.7"
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"
Expand Down Expand Up @@ -348,45 +373,6 @@ jobs:
with:
path: kythe_output/*.kzip

MacOsBuildDevTools:
runs-on: macos-latest
steps:

- name: Install Dependencies
run: |
brew install llvm
echo "CLANG_TIDY=$(brew --prefix llvm)/bin/clang-tidy" >> $GITHUB_ENV
echo "USE_BAZEL_VERSION=6.5.0" >> $GITHUB_ENV
- name: Checkout code
uses: actions/checkout@v3
with:
fetch-depth: 0

- name: Create Cache Timestamp
id: cache_timestamp
uses: nanzm/get-time-action@v2.0
with:
format: 'YYYY-MM-DD-HH-mm-ss'

- name: Mount bazel cache
uses: actions/cache@v3
with:
path: |
/private/var/tmp/_bazel_runner
/Users/runner/.cache/clang-tidy
key: clangtidy_macos_${{ steps.cache_timestamp.outputs.time }}
restore-keys: clangtidy_macos_

- name: Test Developer tooling scripts
run: |
# Just a smoke test to make sure developer scripts run on Mac
echo "::group::Make Compilation DB"
.github/bin/make-compilation-db.sh
echo "::endgroup::"
# Quick with no checks to be fast (full tidy run in ClangTidy action)
.github/bin/run-clang-tidy-cached.cc --checks="-*"
MacOsBuild:
runs-on: macos-latest
steps:
Expand Down
12 changes: 0 additions & 12 deletions WORKSPACE
Original file line number Diff line number Diff line change
Expand Up @@ -155,15 +155,3 @@ http_archive(
"https://github.com/nlohmann/json/archive/refs/tags/v3.11.3.tar.gz",
],
)

# 2024-02-06
http_archive(
name = "rules_compdb",
sha256 = "70232adda61e89a4192be43b4719d35316ed7159466d0ab4f3da0ecb1fbf00b2",
strip_prefix = "bazel-compilation-database-fa872dd80742b3dccd79a711f52f286cbde33676",
urls = ["https://github.com/grailbio/bazel-compilation-database/archive/fa872dd80742b3dccd79a711f52f286cbde33676.tar.gz"],
)

load("@rules_compdb//:deps.bzl", "rules_compdb_deps")

rules_compdb_deps()
19 changes: 0 additions & 19 deletions WORKSPACE.bzlmod
Original file line number Diff line number Diff line change
@@ -1,19 +0,0 @@
workspace(name = "com_google_verible")

load("@bazel_tools//tools/build_defs/repo:http.bzl", "http_archive")

#
# External tools needed
#

# 2024-02-06
http_archive(
name = "rules_compdb",
sha256 = "70232adda61e89a4192be43b4719d35316ed7159466d0ab4f3da0ecb1fbf00b2",
strip_prefix = "bazel-compilation-database-fa872dd80742b3dccd79a711f52f286cbde33676",
urls = ["https://github.com/grailbio/bazel-compilation-database/archive/fa872dd80742b3dccd79a711f52f286cbde33676.tar.gz"],
)

load("@rules_compdb//:deps.bzl", "rules_compdb_deps")

rules_compdb_deps()

0 comments on commit 8c554d2

Please sign in to comment.