esp-idf/docs/en/contribute/install-pre-commit-hook.rst

51 lines
1.8 KiB
ReStructuredText
Raw Normal View History

Install Pre-commit Hook for ESP-IDF Project
2020-10-30 07:31:55 -04:00
===========================================
:link_to_translation:`zh_CN:[中文]`
Install ``pre-commit``
----------------------
2020-10-30 07:31:55 -04:00
Run ``pip install pre-commit``.
2020-10-30 07:31:55 -04:00
Install ``pre-commit`` Hook
---------------------------
2020-10-30 07:31:55 -04:00
1. Go to the ESP-IDF project directory.
2020-10-30 07:31:55 -04:00
2. Run ``pre-commit install --allow-missing-config -t pre-commit -t commit-msg``. Install hook by this approach will let you commit successfully even in branches without the ``.pre-commit-config.yaml``
2020-10-30 07:31:55 -04:00
3. pre-commit hook will run automatically when you are running ``git commit`` command
2020-10-30 07:31:55 -04:00
Uninstall ``pre-commit`` Hook
-----------------------------
Run ``pre-commit uninstall``.
Related Documents
-------------------
2020-10-30 07:31:55 -04:00
For detailed usage, please refer to the documentation of pre-commit_.
2020-10-30 07:31:55 -04:00
2022-04-28 02:34:20 -04:00
.. _pre-commit: https://pre-commit.com/
2020-10-30 07:31:55 -04:00
Common Problems For Windows Users
---------------------------------
``/usr/bin/env: python: Permission denied.``
2020-10-30 07:31:55 -04:00
If you are in Git Bash, please check the python executable location by run ``which python``.
2020-10-30 07:31:55 -04:00
If the executable is under ``~/AppData/Local/Microsoft/WindowsApps/``, then it is a link to Windows AppStore, not a real one.
2020-10-30 07:31:55 -04:00
Please install Python manually and update this in your ``PATH`` environment variable.
Your ``USERPROFILE`` contains non-ASCII characters
``pre-commit`` may fail when initializing an environment for a particular hook when the path of ``pre-commit``'s cache contains non-ASCII characters. The solution is to set ``PRE_COMMIT_HOME`` to a path containing only standard characters before running pre-commit.
- CMD: ``set PRE_COMMIT_HOME=C:\somepath\pre-commit``
- PowerShell: ``$Env:PRE_COMMIT_HOME = "C:\somepath\pre-commit"``
- git bash: ``export PRE_COMMIT_HOME="/c/somepath/pre-commit"``