-
Notifications
You must be signed in to change notification settings - Fork 260
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #209 from aaronfranke/format-ci
Add file formatting checks to CI
- Loading branch information
Showing
6 changed files
with
77 additions
and
6 deletions.
There are no files selected for viewing
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
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,24 @@ | ||
# Copyright (c) 2020 The Khronos Group Inc. | ||
# SPDX-License-Identifier: Apache-2.0 | ||
jobs: | ||
- job: check_file_format | ||
displayName: 'Check file formatting' | ||
pool: | ||
vmImage: 'ubuntu-20.04' | ||
container: khronosgroup/docker-images:openxr-sdk | ||
steps: | ||
- script: sudo apt-get install -qq dos2unix recode | ||
displayName: Install dependencies | ||
- script: ./file_format.sh | ||
displayName: File formatting checks (file_format.sh) | ||
|
||
- script: git diff --patch --exit-code > file_format.patch | ||
displayName: Save changes as diff | ||
- script: echo "The following files need file formatting:"; sed -n -e "s/^diff.* b\///p" file_format.patch | ||
condition: failed() | ||
- task: PublishPipelineArtifact@1 | ||
displayName: Publish diff | ||
condition: failed() | ||
inputs: | ||
path: $(System.DefaultWorkingDirectory)/file_format.patch | ||
artifact: file_format_changes |
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,47 @@ | ||
#!/usr/bin/env bash | ||
# Copyright (c) 2020 The Khronos Group Inc. | ||
# SPDX-License-Identifier: Apache-2.0 | ||
|
||
# This script ensures proper POSIX text file formatting and a few other things. | ||
# This is supplementary to clang-format. | ||
|
||
# We need dos2unix and recode. | ||
if [ ! -x "$(command -v dos2unix)" -o ! -x "$(command -v recode)" ]; then | ||
printf "Install 'dos2unix' and 'recode' to use this script.\n" | ||
fi | ||
|
||
set -e -uo pipefail | ||
IFS=$'\n\t' | ||
|
||
# Loops through all text files tracked by Git. | ||
git grep -zIl '' | | ||
while IFS= read -rd '' f; do | ||
# Exclude some files. | ||
if [[ "$f" == "external"* ]]; then | ||
continue | ||
elif [[ "$f" == "src/external"* ]]; then | ||
continue | ||
fi | ||
# Ensure that files are UTF-8 formatted. | ||
recode UTF-8 "$f" 2> /dev/null | ||
# Ensure that files have LF line endings and do not contain a BOM. | ||
dos2unix "$f" 2> /dev/null | ||
# Remove trailing space characters and ensures that files end | ||
# with newline characters. -l option handles newlines conveniently. | ||
perl -i -ple 's/\s*$//g' "$f" | ||
done | ||
|
||
# If no patch has been generated all is OK, clean up, and exit. | ||
if git diff --exit-code > patch.patch; then | ||
printf "Files in this commit comply with the formatting rules.\n" | ||
rm -f patch.patch | ||
exit 0 | ||
fi | ||
|
||
# A patch has been created, notify the user, clean up, and exit. | ||
printf "\n*** The following differences were found between the code " | ||
printf "and the formatting rules:\n\n" | ||
cat patch.patch | ||
printf "\n*** Aborting, please fix your commit(s) with 'git commit --amend' or 'git rebase -i <hash>'\n" | ||
rm -f patch.patch | ||
exit 1 |
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
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
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