diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index 1ec6dfa1d728..8a44f5bd7fa5 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -431,6 +431,20 @@ check_doc_links: - cd docs - make linkcheck +check_line_endings: + stage: deploy + image: $CI_DOCKER_REGISTRY/esp32-ci-env$BOT_DOCKER_IMAGE_TAG + tags: + - build + except: + - master + - /^release\/v/ + - /^v\d+\.\d+(\.\d+)?($|-)/ + dependencies: [] + before_script: *do_nothing_before + script: + - tools/ci/check-line-endings.sh ${IDF_PATH} + check_commit_msg: stage: deploy image: $CI_DOCKER_REGISTRY/esp32-ci-env$BOT_DOCKER_IMAGE_TAG diff --git a/docs/en/contribute/style-guide.rst b/docs/en/contribute/style-guide.rst index 6564bd083297..9eb10e892107 100644 --- a/docs/en/contribute/style-guide.rst +++ b/docs/en/contribute/style-guide.rst @@ -158,6 +158,21 @@ Although not directly related to formatting, here are a few notes about using co } +Line Endings +^^^^^^^^^^^^ + +Commits should only contain files with LF (Unix style) endings. + +Windows users can configure git to check out CRLF (Windows style) endings locally and commit LF endings by setting the ``core.autocrlf`` setting. `Github has a document about setting this option `. However because MSYS2 uses Unix-style line endings, it is often easier to configure your text editor to use LF (Unix style) endings when editing ESP-IDF source files. + +If you accidentally have some commits in your branch that add LF endings, you can convert them to Unix by running this command in an MSYS2 or Unix terminal (change directory to the IDF working directory and check the correct branch is currently checked out, beforehand):: + + git rebase --exec 'git diff-tree --no-commit-id --name-only -r HEAD | xargs dos2unix && git commit -a --amend --no-edit --allow-empty' master + +(Note that this line rebases on master, change the branch name at the end to rebase on another branch.) + +For updating a single commit, it's possible to run ``dos2unix FILENAME`` and then run ``git commit --amend`` + Formatting your code ^^^^^^^^^^^^^^^^^^^^ diff --git a/tools/ci/check-line-endings.sh b/tools/ci/check-line-endings.sh new file mode 100755 index 000000000000..b813aa6b34a7 --- /dev/null +++ b/tools/ci/check-line-endings.sh @@ -0,0 +1,14 @@ +#!/bin/sh + +if ! [ -z "$1" ]; then + cd "$1" +fi + +echo "Checking for Windows line endings in `pwd`" + +if git ls-tree --name-only -r HEAD | xargs file -N | grep CRLF; then + echo "Some files have CRLF (Windows-style) line endings. Please convert to LF (Unix-style). git can be configured to do this automatically." + exit 1 +fi + +exit 0 diff --git a/tools/ci/executable-list.txt b/tools/ci/executable-list.txt index 989c31b17c54..74ff88c10d0e 100644 --- a/tools/ci/executable-list.txt +++ b/tools/ci/executable-list.txt @@ -14,6 +14,7 @@ docs/gen-kconfig-doc.py tools/ci/apply_bot_filter.py tools/ci/build_examples.sh tools/ci/check-executable.sh +tools/ci/check-line-endings.sh tools/ci/checkout_project_ref.py tools/ci/get-full-sources.sh tools/ci/mirror-submodule-update.sh