Bump the ssh-agent version for actions to 0.9.0 #384
This file contains 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: clang-doc | |
on: | |
push: | |
branches: [main] | |
jobs: | |
docs: | |
name: Generate documentation with clang-doc | |
# Is disabled. | |
if: false && (github.repository == 'chromium/subspace') | |
runs-on: ubuntu-latest | |
env: | |
clang_version: 16 | |
installed_clang_version: 16 | |
steps: | |
- uses: actions/checkout@v4 | |
with: | |
submodules: 'true' | |
- uses: webfactory/ssh-agent@v0.7.0 | |
with: | |
ssh-private-key: ${{ secrets.DOCS_SSH_PRIVATE_KEY }} | |
- name: Install LLVM+Clang | |
if: env.clang_version != env.installed_clang_version | |
run: | | |
wget https://apt.llvm.org/llvm.sh | |
chmod +x llvm.sh | |
sudo ./llvm.sh ${clang_version} all | |
- name: Install System LLVM+Clang | |
if: env.clang_version == env.installed_clang_version | |
run: | | |
sudo apt-get install clang-${{env.installed_clang_version}} \ | |
lldb-${{env.installed_clang_version}} \ | |
lld-${{env.installed_clang_version}} \ | |
clangd-${{env.installed_clang_version}} \ | |
clang-tidy-${{env.installed_clang_version}} \ | |
clang-format-${{env.installed_clang_version}} \ | |
clang-tools-${{env.installed_clang_version}} \ | |
llvm-${{env.installed_clang_version}}-dev \ | |
lld-${{env.installed_clang_version}} \ | |
lldb-${{env.installed_clang_version}} \ | |
llvm-${{env.installed_clang_version}}-tools \ | |
libomp-${{env.installed_clang_version}}-dev \ | |
libc++-${{env.installed_clang_version}}-dev \ | |
libc++abi-${{env.installed_clang_version}}-dev \ | |
libclang-common-${{env.installed_clang_version}}-dev \ | |
libclang-${{env.installed_clang_version}}-dev \ | |
libclang-cpp${{env.installed_clang_version}}-dev \ | |
libunwind-${{env.installed_clang_version}}-dev | |
- name: Configure | |
run: | | |
# Path to LLVM+Clang nightly that we have installed. | |
export LLVM_DIR="/usr/lib/llvm-${clang_version}/lib/cmake/llvm" | |
export Clang_DIR="/usr/lib/llvm-${clang_version}/lib/cmake/clang" | |
sudo apt install build-essential cmake ninja-build | |
cmake -G Ninja -B out -DCMAKE_EXPORT_COMPILE_COMMANDS=1 -DSUBSPACE_BUILD_SUBDOC=OFF | |
- name: Checkout docs | |
run: | | |
git clone git@github.com:danakj/subspace-docs.git docs | |
- name: Generate | |
run: | | |
# Work around https://github.com/llvm/llvm-project/issues/59815 as the | |
# default stylesheet and index.js are not included in the debian | |
# package, which leads to an error when running the tool. | |
sudo mkdir -p /usr/lib/llvm-${clang_version}/share/clang/ | |
sudo cp tools/clang-doc/clang-doc-default-stylesheet.css /usr/lib/llvm-${clang_version}/share/clang/ | |
sudo cp tools/clang-doc/index.js /usr/lib/llvm-${clang_version}/share/clang/ | |
# For crash dumps. | |
export LLVM_SYMBOLIZER_PATH="/usr/lib/llvm-${clang_version}/bin/llvm-symbolizer" | |
clang-doc-${clang_version} \ | |
--executor=all-TUs \ | |
--format=html \ | |
--public \ | |
--extra-arg=-Wno-error \ | |
--project-name=Subspace \ | |
--repository=https://github.com/chromium/subspace/blob/main \ | |
--output=docs \ | |
-p out compile_commands.json | |
- name: Deploy | |
run: | | |
SHA=`git rev-parse HEAD` | |
cd docs | |
git config user.email "noreply@chromium.org" | |
git config user.name "Subspace clang-doc generator" | |
git add . | |
git commit -m "Update docs: $SHA" | |
git push origin | |