mirror of
https://github.com/libexpat/libexpat.git
synced 2025-04-04 21:04:57 +00:00
Merge pull request #987 from libexpat/clang-static-analyzer
Make GitHub Actions apply Clang Static Analyzer
This commit is contained in:
commit
453c150541
2 changed files with 91 additions and 0 deletions
90
.github/workflows/clang-static-analyzer.yml
vendored
Normal file
90
.github/workflows/clang-static-analyzer.yml
vendored
Normal file
|
@ -0,0 +1,90 @@
|
|||
# __ __ _
|
||||
# ___\ \/ /_ __ __ _| |_
|
||||
# / _ \\ /| '_ \ / _` | __|
|
||||
# | __// \| |_) | (_| | |_
|
||||
# \___/_/\_\ .__/ \__,_|\__|
|
||||
# |_| XML parser
|
||||
#
|
||||
# Copyright (c) 2025 Sebastian Pipping <sebastian@pipping.org>
|
||||
# Licensed under the MIT license:
|
||||
#
|
||||
# Permission is hereby granted, free of charge, to any person obtaining
|
||||
# a copy of this software and associated documentation files (the
|
||||
# "Software"), to deal in the Software without restriction, including
|
||||
# without limitation the rights to use, copy, modify, merge, publish,
|
||||
# distribute, sublicense, and/or sell copies of the Software, and to permit
|
||||
# persons to whom the Software is furnished to do so, subject to the
|
||||
# following conditions:
|
||||
#
|
||||
# The above copyright notice and this permission notice shall be included
|
||||
# in all copies or substantial portions of the Software.
|
||||
#
|
||||
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||
# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||||
# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
|
||||
# NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
|
||||
# DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
|
||||
# OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
|
||||
# USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||
|
||||
name: Enforce Clang Static Analyzer (scan-build) clean code
|
||||
|
||||
on:
|
||||
pull_request:
|
||||
push:
|
||||
schedule:
|
||||
- cron: '0 2 * * 5' # Every Friday at 2am
|
||||
workflow_dispatch:
|
||||
|
||||
permissions:
|
||||
contents: read
|
||||
|
||||
jobs:
|
||||
clang_static_analyzer:
|
||||
name: Enforce Clang Static Analyzer (scan-build) clean code
|
||||
runs-on: ubuntu-22.04
|
||||
steps:
|
||||
- uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
|
||||
|
||||
- name: Install Clang 19 (including scan-build)
|
||||
run: |-
|
||||
set -x
|
||||
source /etc/os-release
|
||||
wget -O - https://apt.llvm.org/llvm-snapshot.gpg.key | sudo apt-key add -
|
||||
sudo add-apt-repository "deb https://apt.llvm.org/${UBUNTU_CODENAME}/ llvm-toolchain-${UBUNTU_CODENAME}-19 main"
|
||||
sudo apt-get update # due to new repository
|
||||
sudo apt-get install --yes --no-install-recommends -V \
|
||||
clang-19 \
|
||||
clang-tools-19
|
||||
echo /usr/lib/llvm-19/bin >>"${GITHUB_PATH}"
|
||||
|
||||
- name: Build using scan-build
|
||||
run: |
|
||||
set -x
|
||||
|
||||
clang --version | head -n1
|
||||
clang++ --version | head -n1
|
||||
|
||||
available_checkers="$(scan-build --help | grep -o '^ [+ ] [^. ]\+\.[^ ]\+' | sed 's,^.\{3\},,' | sort)"
|
||||
[[ "$(wc -l <<<"${available_checkers}")" -ge 103 ]] # self-test
|
||||
|
||||
enabled_checkers="$(grep -v \
|
||||
-e '^optin\.performance\.Padding$' \
|
||||
-e '^security\.insecureAPI\.strcpy$' \
|
||||
<<<"${available_checkers}")"
|
||||
[[ "$(wc -l <<<"${enabled_checkers}")" -ge 101 ]] # self-test
|
||||
|
||||
scan-build \
|
||||
-o html/ \
|
||||
$(sed 's,^,-enable-checker ,' <<<"${enabled_checkers}") \
|
||||
sh -c 'cmake -S expat/ -B build/ && make -C build -j$(nproc) VERBOSE=1'
|
||||
|
||||
rmdir html || false 'The report directory is non-empty, i.e. Clang Static Analyzer found an issue! Please download and inspect the zip file artifact attached to this CI run. Thanks!'
|
||||
|
||||
- name: Store scan-build report
|
||||
if: always()
|
||||
uses: actions/upload-artifact@4cec3d8aa04e39d1a68397de0c4cd6fb9dce8ec1 # v4.6.1
|
||||
with:
|
||||
name: expat_scan_build_report_${{ github.sha }}
|
||||
path: html/
|
||||
if-no-files-found: ignore
|
|
@ -45,6 +45,7 @@ Release 2.7.1 ??? ????? ?? ????
|
|||
#986 Address compiler warnings
|
||||
|
||||
Infrastructure:
|
||||
#987 CI: Enforce Clang Static Analyzer clean code
|
||||
#981 CI: Cover compilation with musl
|
||||
#983 #984 CI: Cover compilation with 32bit Emscripten
|
||||
#976 #977 CI: Protect against fuzzer files missing from future
|
||||
|
|
Loading…
Add table
Reference in a new issue