CI: add a script and job to run cmakelint
A number of checks don't match our style or are buggy and so are disabled. Co-authored-by: Viktor Szakats <vszakats@users.noreply.github.com> Fixes #14580 Closes #14665
This commit is contained in:
parent
fa37248d0e
commit
59b419f1a5
12
.github/workflows/checksrc.yml
vendored
12
.github/workflows/checksrc.yml
vendored
@ -13,11 +13,9 @@ name: Source
|
|||||||
- '*/ci'
|
- '*/ci'
|
||||||
paths-ignore:
|
paths-ignore:
|
||||||
- '**/*.md'
|
- '**/*.md'
|
||||||
- '**/CMakeLists.txt'
|
|
||||||
- '.azure-pipelines.yml'
|
- '.azure-pipelines.yml'
|
||||||
- '.circleci/**'
|
- '.circleci/**'
|
||||||
- 'appveyor.*'
|
- 'appveyor.*'
|
||||||
- 'CMake/**'
|
|
||||||
- 'plan9/**'
|
- 'plan9/**'
|
||||||
- 'tests/data/**'
|
- 'tests/data/**'
|
||||||
- 'winbuild/**'
|
- 'winbuild/**'
|
||||||
@ -26,11 +24,9 @@ name: Source
|
|||||||
- master
|
- master
|
||||||
paths-ignore:
|
paths-ignore:
|
||||||
- '**/*.md'
|
- '**/*.md'
|
||||||
- '**/CMakeLists.txt'
|
|
||||||
- '.azure-pipelines.yml'
|
- '.azure-pipelines.yml'
|
||||||
- '.circleci/**'
|
- '.circleci/**'
|
||||||
- 'appveyor.*'
|
- 'appveyor.*'
|
||||||
- 'CMake/**'
|
|
||||||
- 'plan9/**'
|
- 'plan9/**'
|
||||||
- 'tests/data/**'
|
- 'tests/data/**'
|
||||||
- 'winbuild/**'
|
- 'winbuild/**'
|
||||||
@ -47,7 +43,7 @@ jobs:
|
|||||||
- name: check
|
- name: check
|
||||||
run: git ls-files -z "*.[ch]" | xargs -0 -n1 ./scripts/checksrc.pl
|
run: git ls-files -z "*.[ch]" | xargs -0 -n1 ./scripts/checksrc.pl
|
||||||
|
|
||||||
codespell:
|
codespell-cmakelint:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4
|
- uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4
|
||||||
@ -57,11 +53,15 @@ jobs:
|
|||||||
run: |
|
run: |
|
||||||
sudo rm -f /etc/apt/sources.list.d/microsoft-prod.list
|
sudo rm -f /etc/apt/sources.list.d/microsoft-prod.list
|
||||||
sudo apt-get update
|
sudo apt-get update
|
||||||
sudo apt-get install codespell
|
sudo apt-get install codespell python3-pip
|
||||||
|
python3 -m pip install cmakelint==1.4.3
|
||||||
|
|
||||||
- name: spellcheck
|
- name: spellcheck
|
||||||
run: codespell --skip src/tool_hugehelp.c -I .github/scripts/codespell-ignore.txt include src lib
|
run: codespell --skip src/tool_hugehelp.c -I .github/scripts/codespell-ignore.txt include src lib
|
||||||
|
|
||||||
|
- name: cmakelint
|
||||||
|
run: scripts/cmakelint.sh
|
||||||
|
|
||||||
reuse:
|
reuse:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
|
|||||||
@ -24,7 +24,7 @@
|
|||||||
|
|
||||||
EXTRA_DIST = coverage.sh completion.pl firefox-db2pem.sh checksrc.pl \
|
EXTRA_DIST = coverage.sh completion.pl firefox-db2pem.sh checksrc.pl \
|
||||||
mk-ca-bundle.pl schemetable.c cd2nroff nroff2cd cdall cd2cd managen \
|
mk-ca-bundle.pl schemetable.c cd2nroff nroff2cd cdall cd2cd managen \
|
||||||
dmaketgz release-tools.sh verify-release
|
dmaketgz release-tools.sh verify-release cmakelint.sh
|
||||||
|
|
||||||
ZSH_FUNCTIONS_DIR = @ZSH_FUNCTIONS_DIR@
|
ZSH_FUNCTIONS_DIR = @ZSH_FUNCTIONS_DIR@
|
||||||
FISH_FUNCTIONS_DIR = @FISH_FUNCTIONS_DIR@
|
FISH_FUNCTIONS_DIR = @FISH_FUNCTIONS_DIR@
|
||||||
|
|||||||
50
scripts/cmakelint.sh
Executable file
50
scripts/cmakelint.sh
Executable file
@ -0,0 +1,50 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
#***************************************************************************
|
||||||
|
# _ _ ____ _
|
||||||
|
# Project ___| | | | _ \| |
|
||||||
|
# / __| | | | |_) | |
|
||||||
|
# | (__| |_| | _ <| |___
|
||||||
|
# \___|\___/|_| \_\_____|
|
||||||
|
#
|
||||||
|
# Copyright (C) Dan Fandrich, <dan@coneharvesters.com>, et al.
|
||||||
|
#
|
||||||
|
# This software is licensed as described in the file COPYING, which
|
||||||
|
# you should have received as part of this distribution. The terms
|
||||||
|
# are also available at https://curl.se/docs/copyright.html.
|
||||||
|
#
|
||||||
|
# You may opt to use, copy, modify, merge, publish, distribute and/or sell
|
||||||
|
# copies of the Software, and permit persons to whom the Software is
|
||||||
|
# furnished to do so, under the terms of the COPYING file.
|
||||||
|
#
|
||||||
|
# This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
||||||
|
# KIND, either express or implied.
|
||||||
|
#
|
||||||
|
# SPDX-License-Identifier: curl
|
||||||
|
#
|
||||||
|
###########################################################################
|
||||||
|
|
||||||
|
# Run cmakelint on the curl source code. It will check all files given on the
|
||||||
|
# command-line, or else all relevant files in git, or if not in a git
|
||||||
|
# repository, all files starting in the tree rooted in the current directory.
|
||||||
|
#
|
||||||
|
# cmakelint can be installed from PyPi with the command "python3 -m pip install
|
||||||
|
# cmakelint".
|
||||||
|
#
|
||||||
|
# The xargs invocation is portable, but does not preserve spaces in file names.
|
||||||
|
# If such a file is ever added, then this can be portably fixed by switching to
|
||||||
|
# "xargs -I{}" and appending {} to the end of the xargs arguments (which will
|
||||||
|
# call cmakelint once per file) or by using the GNU extension "xargs -d'\n'".
|
||||||
|
{
|
||||||
|
if [ -n "$1" ]; then
|
||||||
|
for A in "$@"; do printf "%s\n" "$A"; done
|
||||||
|
elif git rev-parse --is-inside-work-tree >/dev/null 2>&1; then
|
||||||
|
git ls-files
|
||||||
|
else
|
||||||
|
# strip off the leading ./ to make the grep regexes work properly
|
||||||
|
find . -type f | sed 's@^\./@@'
|
||||||
|
fi
|
||||||
|
} | grep -E '(/CMake|\.cmake$)' | grep -v -E '(\.h\.cmake|\.in)$' \
|
||||||
|
| xargs \
|
||||||
|
cmakelint \
|
||||||
|
--spaces=2 --linelength=132 \
|
||||||
|
--filter=-whitespace/indent,-convention/filename,-package/stdargs
|
||||||
Loading…
Reference in New Issue
Block a user