Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

CI: Run clang-format faster using a different action that runs in parallel #3284

Closed
wants to merge 23 commits into from
Closed
Changes from all commits
Commits
Show all changes
23 commits
Select commit Hold shift + click to select a range
5b5d6d8
Use DoozyX/clang-format-lint-action to run clang-format faster
echoix Dec 3, 2023
59003cb
Merge branch 'OSGeo:main' into parallel-clang-format
echoix Feb 28, 2024
1e1e586
CI(clang-format): Run on all pull requests
echoix Mar 6, 2024
086192f
CI(clang-format): Always run upload of changed files artifacts
echoix Mar 6, 2024
f366a7c
CI(clang-format): Update verify-changed-files action
echoix Mar 6, 2024
764274c
CI(clang-format): Add a job summary with the list files changed by cl…
echoix Mar 6, 2024
7fe15e7
CI(clang-format): Suggest changes as code comments in PR
echoix Mar 6, 2024
2176ab2
CI(clang-format): Clear default permissions for GITHUB_TOKEN
echoix Mar 6, 2024
4b02f17
CI(clang-format): Simplify concurrency group
echoix Mar 6, 2024
86afbbe
Merge branch 'main' into parallel-clang-format
echoix Mar 6, 2024
7fa228e
CI(clang-format): Add a job summary when there are no files changed
echoix Mar 6, 2024
5add8da
CI(clang-format): Update DoozyX/clang-format-lint-action action
echoix Mar 6, 2024
0bff5d6
CI(clang-format): Add a job summary when there are no files changed
echoix Mar 6, 2024
db5e54e
CI(clang-format): Debug outputs of verify-changed-files
echoix Mar 6, 2024
4d09b7c
CI(clang-format): Fix step's conditions to when files are changed or not
echoix Mar 6, 2024
af72158
Add a formatting error in db.copy
echoix Mar 6, 2024
450c6bc
CI(clang-format): Add `pull-requests: write` permission to post comme…
echoix Mar 6, 2024
dc63a82
CI(clang-format): Temporarily set all permissions to write-all
echoix Mar 6, 2024
5e8aa9e
CI(clang-format): Use reviewdog/action-suggester to add code suggestions
echoix Mar 6, 2024
d6f33f4
CI(clang-format): Use git ls-files to get the list of files changed, …
echoix Mar 6, 2024
e070803
CI(clang-format): Add extra explanations in the job summary on how to…
echoix Mar 6, 2024
3bb94a5
Revert: Add a formatting error in db.copy
echoix Mar 6, 2024
acce7f4
CI(clang-format): Add workflow_dispatch to allow running manually
echoix Mar 6, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
75 changes: 68 additions & 7 deletions .github/workflows/clang-format-check.yml
Original file line number Diff line number Diff line change
Expand Up @@ -9,17 +9,78 @@ on:
branches:
- main
- releasebranch_*
- "*"
workflow_dispatch:
concurrency:
group: ${{ github.workflow }}-${{ github.event_name == 'pull_request' && github.head_ref || github.sha }}
cancel-in-progress: true
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: ${{ github.ref_protected != true }}
permissions: {}
jobs:
formatting-check:
name: Formatting Check
runs-on: ubuntu-latest
permissions:
contents: read
checks: write
issues: write
pull-requests: write
steps:
- uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4
- name: Run clang-format style check for C/C++/Protobuf programs.
uses: jidicula/[email protected]
- uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1
- uses: DoozyX/clang-format-lint-action@11b773b1598aa4ae3b32f023701bca5201c3817d # v0.17
with:
clang-format-version: '15'
check-path: .
source: "."
clangFormatVersion: 15
inplace: True
- name: Verify Changed files
uses: tj-actions/verify-changed-files@d774a4c7ebe335445d79c7b44138f56a76058ba0 # v19.0.0
id: verify-changed-files
- id: git-changed-files
run: |
{
echo 'CHANGED_FILES<<EOF'
git ls-files --other --modified --exclude-standard
echo EOF
} >> "$GITHUB_OUTPUT"
- name: List all changed files tracked and untracked files
run: |
echo "Changed files: ${{ steps.git-changed-files.outputs.CHANGED_FILES }}"
- name: Add job summary without changed files
if: ${{ steps.verify-changed-files.outputs.files_changed == 'false' }}
run: |
{
echo "### Changed files:"
echo "No files were changed by clang-format"
} >> "$GITHUB_STEP_SUMMARY"
- name: Add job summary with changed files
if: ${{ steps.verify-changed-files.outputs.files_changed == 'true' }}
run: |
{
echo '### Changed files:'
echo '```'
echo "${CHANGED_FILES}"
echo '```'
} >> "$GITHUB_STEP_SUMMARY"
env:
CHANGED_FILES: ${{ steps.git-changed-files.outputs.CHANGED_FILES }}
- name: Add code suggestions
uses: reviewdog/action-suggester@3d7fde6859623ad6174df5fd662677a0eb63310a # v1.11.0
with:
tool_name: clang-format
fail_on_error: true
cleanup: false
- name: Explain that more files need to be fixed
if: ${{ steps.verify-changed-files.outputs.files_changed == 'true' }}
run: |
{
echo ''
echo 'Suggestions can only be added near to lines changed in this PR.'
echo 'All these fixed files are included in the artifact. The artifact can be downloaded and copied to the the repository to replace unformatted files with the formatted files.'
} >> "$GITHUB_STEP_SUMMARY"
exit 1
- uses: actions/upload-artifact@5d5d22a31266ced268874388b861e4b58bb5c2f3 # v4.3.1
if: always()
with:
name: my-artifact
path: |
.clang-format
${{ steps.git-changed-files.outputs.CHANGED_FILES }}
Loading