mirror of https://github.com/PCSX2/pcsx2.git
Merge pull request #1529 from aktau/clang-tidy-parallelize
build.sh: parallelize clang-tidy
This commit is contained in:
commit
27ea9c22bb
59
build.sh
59
build.sh
|
@ -33,7 +33,7 @@ build="$root/build"
|
||||||
coverity_dir="cov-int"
|
coverity_dir="cov-int"
|
||||||
coverity_result=pcsx2-coverity.xz
|
coverity_result=pcsx2-coverity.xz
|
||||||
|
|
||||||
if command -v ninja ; then
|
if command -v ninja >/dev/null ; then
|
||||||
flags="$flags -GNinja"
|
flags="$flags -GNinja"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
@ -170,7 +170,7 @@ fi
|
||||||
############################################################
|
############################################################
|
||||||
# CPP check build
|
# CPP check build
|
||||||
############################################################
|
############################################################
|
||||||
if [ "$cppcheck" -eq 1 ] && command -v cppcheck ; then
|
if [ "$cppcheck" -eq 1 ] && command -v cppcheck >/dev/null ; then
|
||||||
summary=cpp_check_summary.log
|
summary=cpp_check_summary.log
|
||||||
rm -f $summary
|
rm -f $summary
|
||||||
touch $summary
|
touch $summary
|
||||||
|
@ -197,36 +197,39 @@ fi
|
||||||
############################################################
|
############################################################
|
||||||
# Clang tidy build
|
# Clang tidy build
|
||||||
############################################################
|
############################################################
|
||||||
if [ "$clangTidy" -eq 1 ] && command -v clang-tidy ; then
|
if [ "$clangTidy" -eq 1 ] && command -v clang-tidy >/dev/null ; then
|
||||||
compile_json=compile_commands.json
|
compile_json=compile_commands.json
|
||||||
cpp_list=cpp_file.txt
|
cpp_list=cpp_file.txt
|
||||||
summary=clang_tidy_summary.txt
|
summary=clang_tidy_summary.txt
|
||||||
rm -f $summary
|
|
||||||
touch $summary
|
|
||||||
|
|
||||||
grep '"file"' $compile_json | sed -e 's/"//g' -e 's/^\s*file\s*:\s*//' > $cpp_list
|
grep '"file"' $compile_json | sed -e 's/"//g' -e 's/^\s*file\s*:\s*//' > $cpp_list
|
||||||
|
|
||||||
while read -r cpp ; do
|
# EXAMPLE
|
||||||
# Example:
|
#
|
||||||
# clang-tidy-3.8 -p build_dev/compile_commands.json plugins/GSdx/GSTextureCache.cpp -checks='modernize-loop-convert' -fix
|
# Modernize loop syntax, fix if old style found.
|
||||||
# List of modernize check
|
# $ clang-tidy -p build_dev/compile_commands.json plugins/GSdx/GSTextureCache.cpp -checks='modernize-loop-convert' -fix
|
||||||
# modernize-loop-convert
|
# Check all, tons of output:
|
||||||
# modernize-make-unique
|
# $ clang-tidy -p $compile_json $cpp -checks='*' -header-filter='.*'
|
||||||
# modernize-pass-by-value
|
# List of modernize checks:
|
||||||
# modernize-redundant-void-arg
|
# modernize-loop-convert
|
||||||
# modernize-replace-auto-ptr
|
# modernize-make-unique
|
||||||
# modernize-shrink-to-fit
|
# modernize-pass-by-value
|
||||||
# modernize-use-auto
|
# modernize-redundant-void-arg
|
||||||
# modernize-use-default
|
# modernize-replace-auto-ptr
|
||||||
# modernize-use-nullptr
|
# modernize-shrink-to-fit
|
||||||
# modernize-use-override
|
# modernize-use-auto
|
||||||
|
# modernize-use-default
|
||||||
|
# modernize-use-nullptr
|
||||||
|
# modernize-use-override
|
||||||
|
|
||||||
# Check all, likely severals millions of log...
|
# Don't check headers, don't check google/llvm coding conventions
|
||||||
#clang-tidy -p $compile_json $cpp -checks='*' -header-filter='.*'
|
if command -v parallel >/dev/null ; then
|
||||||
|
# Run clang-tidy in parallel with as many jobs as there are CPUs.
|
||||||
# Don't check header, don't check google/llvm coding conventions
|
parallel -m "clang-tidy -p $compile_json -checks='*,-llvm-*,-google-*' {}"
|
||||||
clang-tidy -p $compile_json "$cpp" -checks='*,-llvm-*,-google-*' >> $summary
|
else
|
||||||
done < $cpp_list
|
# xargs(1) can also run jobs in parallel with -P, but will mix the
|
||||||
|
# output from the distinct processes together willy-nilly.
|
||||||
|
xargs clang-tidy -p $compile_json -checks='*,-llvm-*,-google-*'
|
||||||
|
fi < $cpp_list > $summary
|
||||||
|
|
||||||
exit 0
|
exit 0
|
||||||
fi
|
fi
|
||||||
|
@ -234,7 +237,7 @@ fi
|
||||||
############################################################
|
############################################################
|
||||||
# Coverity build
|
# Coverity build
|
||||||
############################################################
|
############################################################
|
||||||
if [ "$CoverityBuild" -eq 1 ] && command -v cov-build ; then
|
if [ "$CoverityBuild" -eq 1 ] && command -v cov-build >/dev/null ; then
|
||||||
cov-build --dir "$coverity_dir" make -j"$ncpu" 2>&1 | tee -a "$log"
|
cov-build --dir "$coverity_dir" make -j"$ncpu" 2>&1 | tee -a "$log"
|
||||||
# Warning: $coverity_dir must be the root directory
|
# Warning: $coverity_dir must be the root directory
|
||||||
(cd "$build"; tar caf $coverity_result "$coverity_dir")
|
(cd "$build"; tar caf $coverity_result "$coverity_dir")
|
||||||
|
@ -244,7 +247,7 @@ fi
|
||||||
############################################################
|
############################################################
|
||||||
# Real build
|
# Real build
|
||||||
############################################################
|
############################################################
|
||||||
if command -v ninja ; then
|
if command -v ninja >/dev/null ; then
|
||||||
ninja 2>&1 | tee -a "$log"
|
ninja 2>&1 | tee -a "$log"
|
||||||
ninja install 2>&1 | tee -a "$log"
|
ninja install 2>&1 | tee -a "$log"
|
||||||
else
|
else
|
||||||
|
|
Loading…
Reference in New Issue