Fix many #14
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: Check style | |
on: | |
push: | |
branches-ignore: | |
- master | |
- staging.tmp | |
- trying.tmp | |
- staging-squash-merge.tmp | |
pull_request: | |
jobs: | |
check-style: | |
runs-on: ubuntu-20.04 | |
steps: | |
- uses: actions/checkout@v3 | |
with: | |
submodules: true | |
- name: Prepare | |
run: | | |
sudo apt-get update -y | |
sudo apt-get install clang-format imagemagick ddnet-tools shellcheck pkg-config cmake ninja-build libfreetype6-dev libnotify-dev libsdl2-dev libsqlite3-dev libavcodec-dev libavformat-dev libavutil-dev libswresample-dev libswscale-dev libx264-dev python3-clang libvulkan-dev glslang-tools spirv-tools rustc cargo -y | |
pip3 install pylint | |
git clone https://gitlab.com/Patiga/twmap | |
cd twmap/twmap-tools | |
cargo install --path=. | |
cd ../.. | |
rm -rf twmap | |
mkdir release | |
cd release | |
cmake -G Ninja -DCMAKE_BUILD_TYPE=Release -DDOWNLOAD_GTEST=OFF -DCMAKE_RUNTIME_OUTPUT_DIRECTORY_RELEASE=. .. | |
cmake --build . --config Release --target dilate | |
- name: Check clang-format | |
run: clang-format -version | |
- name: Check fix_style | |
run: scripts/fix_style.py --dry-run | |
- name: Check header guards | |
run: scripts/check_header_guards.py | |
- name: Check languages | |
run: scripts/languages/update_all.py | |
- name: Check dilated images | |
run: scripts/check_dilate.sh release data | |
# TODO: Enable on release branches | |
#- name: Out-of-date translations | |
# run: | | |
# cp -a data/languages data/languages.orig | |
# scripts/languages/update_all.py | |
# diff_lang=$(diff data/languages.orig data/languages) | |
# if [ -n "$diff_lang" ]; then | |
# echo "Update translations:\n$diff_lang" | |
# exit 1 | |
# fi | |
- name: Shellcheck | |
run: find . -type f -name '*.sh' -print0 | xargs -0 shellcheck | |
- name: Check log error case | |
run: | | |
if grep -Eqr '(msg|Print).*\(.*"[Ee]rror:' src/; | |
then | |
echo "Expected log errors to be in this format 'ERROR: error message'" | |
echo "Found these non uppercased log errors:" | |
grep -Er '(msg|Print).*\(.*"[Ee]rror:' src/ | |
exit 1 | |
fi | |
- name: Pylint | |
run: | | |
pylint --version | |
find . -type f -name "*.py" -not -path './ddnet-libs/*' -not -path './googletest-src/*' -print0 | xargs -0 pylint | |
- name: Unused headers | |
run: | | |
find src -name '*.h' | while read -r i; do grep -r -q "$(basename "$i")" || (echo "Header file $i is unused" && exit 1); done | |
- name: Check maps | |
run: | | |
findings=$(find data -type f -name '*.map' -print0 | xargs -0 ~/.cargo/bin/twmap-check-ddnet 2>&1 | \ | |
grep -v -E "\"data/maps/(ctf|dm).*\.map\": Time cps are missing on the map" | \ | |
grep -v -E "\"data/themes/.*\.map\": Time cps are missing on the map" | \ | |
grep -v -E "\"data/maps/ctf4\.map\": Map - Image error at index 3 : 'jungle_doodads_old' is not a valid external image in version DDNet06" | \ | |
grep -v -E "\"data/themes/autumn_night\.map\": Map - Image error at index 3 : 'generic_lamps' is not a valid external image in version DDNet06" | \ | |
grep -v -E "\"data/maps7?/Tutorial\.map\": Map setting - Unusual: 'sv_show_others_default'" || true) | |
if [ -n "$findings" ]; then | |
echo "$findings" | |
exit 1 | |
fi |