From 255bf0164899a89c0d541cab0e7ca298a3b100b5 Mon Sep 17 00:00:00 2001 From: Jim Huang Date: Thu, 18 Jul 2024 12:20:38 +0800 Subject: [PATCH] Add preliminary CI scripts Indent all C source files with clang-format-12. At present, "make" is the only way to validate the build. --- .ci/check-format.sh | 14 ++++++++++ .ci/check-newline.sh | 19 ++++++++++++++ .github/workflows/main.yml | 53 ++++++++++++++++++++++++++++++++++++++ 3 files changed, 86 insertions(+) create mode 100755 .ci/check-format.sh create mode 100755 .ci/check-newline.sh create mode 100644 .github/workflows/main.yml diff --git a/.ci/check-format.sh b/.ci/check-format.sh new file mode 100755 index 0000000..ee3000b --- /dev/null +++ b/.ci/check-format.sh @@ -0,0 +1,14 @@ +#!/usr/bin/env bash + +set -e -u -o pipefail + +SOURCES=$(find $(git rev-parse --show-toplevel) | egrep "\.(c|cxx|cpp|h|hpp)\$") + +set -x + +for file in ${SOURCES}; +do + clang-format-12 ${file} > expected-format + diff -u -p --label="${file}" --label="expected coding style" ${file} expected-format +done +exit $(clang-format-12 --output-replacements-xml ${SOURCES} | egrep -c "") diff --git a/.ci/check-newline.sh b/.ci/check-newline.sh new file mode 100755 index 0000000..2e23cb5 --- /dev/null +++ b/.ci/check-newline.sh @@ -0,0 +1,19 @@ +#!/usr/bin/env bash + +set -e -u -o pipefail + +ret=0 +show=0 +# Reference: https://medium.com/@alexey.inkin/how-to-force-newline-at-end-of-files-and-why-you-should-do-it-fdf76d1d090e +while IFS= read -rd '' f; do + if file --mime-encoding "$f" | grep -qv binary; then + tail -c1 < "$f" | read -r _ || show=1 + if [ $show -eq 1 ]; then + echo "Warning: No newline at end of file $f" + ret=1 + show=0 + fi + fi +done < <(git ls-files -z src tests/arch-test-target) + +exit $ret diff --git a/.github/workflows/main.yml b/.github/workflows/main.yml new file mode 100644 index 0000000..ba92e9f --- /dev/null +++ b/.github/workflows/main.yml @@ -0,0 +1,53 @@ +name: CI + +on: [push, pull_request] + +jobs: + detect-code-related-file-changes: + runs-on: ubuntu-22.04 + outputs: + has_code_related_changes: ${{ steps.set_has_code_related_changes.outputs.has_code_related_changes }} + steps: + - name: Check out the repo + uses: actions/checkout@v4 + - name: Test changed files + id: changed-files + uses: tj-actions/changed-files@v44 + with: + files: | + .ci/** + mk/** + src/** + target/** + .clang-format + Makefile + - name: Set has_code_related_changes + id: set_has_code_related_changes + run: | + if [[ ${{ steps.changed-files.outputs.any_changed }} == true ]]; then + echo "has_code_related_changes=true" >> $GITHUB_OUTPUT + else + echo "has_code_related_changes=false" >> $GITHUB_OUTPUT + fi + + host-x64: + needs: [detect-code-related-file-changes] + if: needs.detect-code-related-file-changes.outputs.has_code_related_changes == 'true' + runs-on: ubuntu-22.04 + steps: + - uses: actions/checkout@v4 + - name: default build + run: make + + coding-style: + needs: [detect-code-related-file-changes] + if: needs.detect-code-related-file-changes.outputs.has_code_related_changes == 'true' + runs-on: ubuntu-22.04 + steps: + - uses: actions/checkout@v4 + - name: coding convention + run: | + sudo apt-get install -q -y clang-format-12 + .ci/check-newline.sh + .ci/check-format.sh + shell: bash