File size: 2,676 Bytes
d3dbf03 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 |
# 参与贡献 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)。
|