| # 参与贡献 MMACTION2 | |
| 欢迎各种形式的贡献,包括但不限于以下内容。 | |
| - 修改拼写错误或代码错误 | |
| - 新功能和组件 | |
| - 添加文档或将文档翻译成其他语言 | |
| - 添加关于视频理解算法的新项目(推荐),具体细节请参考[这里](../projectzoo.md) | |
| ## 工作流程 | |
| 1. Fork 并拉取最新的 mmaction2 | |
| 2. 创建一个有意义的新分支(不要使用主分支进行 PR) | |
| 3. 提交你的更改 | |
| 4. 创建一个 PR | |
| ```{note} | |
| - 如果你计划添加一些涉及大规模更改的新功能,请首先打开一个 issue 进行讨论。 | |
| - 如果你是论文的作者,并希望将你的方法包含在 mmaction2 中,请与我们联系。我们将非常感谢您的贡献。 | |
| ``` | |
| ## 代码风格 | |
| ### Python | |
| 我们采用 [PEP8](https://www.python.org/dev/peps/pep-0008/) 作为首选代码风格。 | |
| 我们使用以下工具进行代码检查和格式化: | |
| - [flake8](http://flake8.pycqa.org/en/latest/):检查器 | |
| - [yapf](https://github.com/google/yapf):格式化器 | |
| - [isort](https://github.com/timothycrosley/isort):排序导入 | |
| - [codespell](https://github.com/codespell-project/codespell):一个用于修复文本文件中常见拼写错误的 Python 工具。 | |
| - [mdformat](https://github.com/executablebooks/mdformat):Mdformat 是一个自由裁量的 Markdown 格式化工具,可用于强制执行一致的 Markdown 文件样式。 | |
| - [docformatter](https://github.com/myint/docformatter):一个格式化工具,用于格式化文档字符串。 | |
| yapf 和 isort 的样式配置可以在 [setup.cfg](https://github.com/open-mmlab/mmaction2/blob/main/setup.cfg) 中找到。 | |
| 我们使用 [pre-commit hook](https://pre-commit.com/) 来保证每次提交时自动进行代码检查和格式化,启用的功能包括 `flake8`, `yapf`, `isort`, `trailing whitespaces`, `markdown files`, 修复 `end-of-files`, `double-quoted-strings`, `python-encoding-pragma`, `mixed-line-ending`, 对 `requirments.txt`的排序等。 | |
| 预提交钩子的配置存储在 [.pre-commit-config](https://github.com/open-mmlab/mmaction2/blob/main/.pre-commit-config.yaml) 中。 | |
| 在克隆仓库后,你需要安装初始化的预提交钩子。 | |
| ```shell | |
| pip install -U pre-commit | |
| ``` | |
| 从仓库文件夹中 | |
| ```shell | |
| pre-commit install | |
| ``` | |
| 在此之后,每次提交,代码规范检查和格式化工具都将被强制执行。 | |
| ```{note} | |
| 在创建 PR 之前,请确保你的代码通过了 lint 检查并由 yapf 进行了格式化。 | |
| ``` | |
| ### C++ 和 CUDA | |
| 我们遵循 [Google C++ Style Guide](https://google.github.io/styleguide/cppguide.html)。 | |