-
Notifications
You must be signed in to change notification settings - Fork 89
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
7 changed files
with
503 additions
and
246 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 |
---|---|---|
@@ -1,16 +1,16 @@ | ||
# Code of Conduct | ||
|
||
## Our Pledge | ||
|
||
## Our Pledge | ||
In the interest of fostering an open and welcoming environment, we as | ||
contributors and maintainers pledge to make participation in our project and | ||
our community a harassment-free experience for everyone, regardless of age, body | ||
size, disability, ethnicity, sex characteristics, gender identity and expression, | ||
level of experience, education, socio-economic status, nationality, personal | ||
appearance, race, religion, or sexual identity and orientation. | ||
|
||
## Our Standards | ||
|
||
## Our Standards | ||
Examples of behavior that contributes to creating a positive environment | ||
include: | ||
|
||
|
@@ -31,8 +31,8 @@ address, without explicit permission | |
* Other conduct which could reasonably be considered inappropriate in a | ||
professional setting | ||
|
||
## Our Responsibilities | ||
|
||
## Our Responsibilities | ||
Project maintainers are responsible for clarifying the standards of acceptable | ||
behavior and are expected to take appropriate and fair corrective action in | ||
response to any instances of unacceptable behavior. | ||
|
@@ -43,8 +43,8 @@ that are not aligned to this Code of Conduct, or to ban temporarily or | |
permanently any contributor for other behaviors that they deem inappropriate, | ||
threatening, offensive, or harmful. | ||
|
||
## Scope | ||
|
||
## Scope | ||
This Code of Conduct applies within all project spaces, and it also applies when | ||
an individual is representing the project or its community in public spaces. | ||
Examples of representing a project or community include using an official | ||
|
@@ -56,8 +56,8 @@ This Code of Conduct also applies outside the project spaces when there is a | |
reasonable belief that an individual's behavior may have a negative impact on | ||
the project or its community. | ||
|
||
## Enforcement | ||
|
||
## Enforcement | ||
Instances of abusive, harassing, or otherwise unacceptable behavior may be | ||
reported by contacting the project team at <[email protected]>. All | ||
complaints will be reviewed and investigated and will result in a response that | ||
|
@@ -69,8 +69,8 @@ Project maintainers who do not follow or enforce the Code of Conduct in good | |
faith may face temporary or permanent repercussions as determined by other | ||
members of the project's leadership. | ||
|
||
## Attribution | ||
|
||
## Attribution | ||
This Code of Conduct is adapted from the [Contributor Covenant][homepage], version 1.4, | ||
available at https://www.contributor-covenant.org/version/1/4/code-of-conduct.html | ||
|
||
|
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 |
---|---|---|
@@ -1,29 +1,165 @@ | ||
# Contributing to fairseq2 | ||
We want to make contributing to this project as easy and transparent as | ||
possible. | ||
We want to make contributing to fairseq2 as easy and transparent as possible. | ||
Please make sure to read this guideline carefully. | ||
|
||
## Pull Requests | ||
We actively welcome your pull requests. | ||
|
||
## Setting up Development Environment | ||
fairseq2 consists of two packages; the user-facing fairseq2 package implemented | ||
in pure Python, and the fairseq2n package that contains the C++ and CUDA | ||
portions of the library. If fairseq2n is available as a pre-built package for | ||
your system (check installation instructions for your operating system in | ||
[README](.)), and if you are interested in only modifying Python portions of | ||
fairseq2, you can use an editable pip installation as described below. | ||
Otherwise, if you are planning to work on C++/CUDA, or if fairseq2n is not | ||
available as a pre-built package for your system, please follow the install | ||
instructions [here](INSTALL_FROM_SOURCE.md). | ||
|
||
For an editable installation, first, clone the fairseq2 repository to your | ||
machine. | ||
|
||
```sh | ||
git clone https://github.com/facebookresearch/fairseq2.git | ||
|
||
cd fairseq2 | ||
``` | ||
|
||
Then, install the fairseq2 package in editable mode. | ||
|
||
```sh | ||
pip install -e . | ||
``` | ||
|
||
Finally, make sure to install the development tools (e.g. linters and | ||
formatters). | ||
|
||
```sh | ||
pip install -r requirements-devel.txt | ||
``` | ||
|
||
|
||
## Testing Your Work | ||
|
||
### Python and C++/CUDA | ||
Any work that you plan to contribute should ideally be covered by a unit or | ||
integration test. Once you have all your tests in place, ensure the full test | ||
suite passes. | ||
|
||
```sh | ||
pytest | ||
``` | ||
|
||
By default, the tests will be run on CPU; pass the `--device` (short form `-d`) | ||
option to run them on a specific device (e.g. GPU). | ||
|
||
```sh | ||
pytest --device cuda:0 | ||
``` | ||
|
||
### C++/CUDA | ||
If you have changes in C++ or CUDA, in addition to `pytest`, also run the native | ||
tests. | ||
|
||
```sh | ||
fairseq2n/build/tests/run-tests | ||
``` | ||
|
||
|
||
## Documenting Your Work | ||
Any new or revised user-facing feature included in your work should have an | ||
accompanying documentation. Depending on the scope of the work, the | ||
documentation can be just docstrings in Python code, or, for larger features, | ||
one or more Sphinx RST files. For docstrings, make sure to follow our formatting | ||
conventions. You can check out any Python file in our code base to study how we | ||
format our docstrings. | ||
|
||
To build and test out the library documentation, run the following commands. | ||
|
||
```sh | ||
cd doc | ||
|
||
pip install -r requirements.txt | ||
|
||
make html | ||
|
||
cd build/html | ||
|
||
python -m http.server 8084 | ||
``` | ||
|
||
and, visit http://localhost:8084 in your browser. | ||
|
||
|
||
## Linting Your Work | ||
|
||
### Python | ||
If you have made changes to the Python code, run the following commands and | ||
address any issues reported. | ||
|
||
```sh | ||
mypy . && flake8 . | ||
``` | ||
|
||
### C++/CUDA | ||
If you have touched C++ or CUDA files, lint your code with an up-to-date version | ||
of the clang toolkit and address any issues reported. | ||
|
||
```sh | ||
cd fairseq2n | ||
|
||
CC=clang CXX=clang++ cmake -GNinja -DFAIRSEQ2N_RUN_CLANG_TIDY=ON -B build | ||
|
||
cmake --build build | ||
``` | ||
|
||
Alternatively: | ||
|
||
```sh | ||
cd fairseq2n | ||
|
||
CC=clang CXX=clang++ cmake -GNinja -B build | ||
|
||
run-clang-tidy -p build | ||
``` | ||
|
||
|
||
## Formatting Your Work | ||
|
||
### Python | ||
For Python code, run the following commands. | ||
|
||
```sh | ||
isort . && black . | ||
``` | ||
|
||
### C++/CUDA | ||
For C++, we do not enforce our coding conventions via a tool (e.g. | ||
clang-format), but we expect you to follow them. You can check out any C++ file | ||
in our code base to study our conventions. Since C++ syntax can become pretty | ||
complex at times, refrain from being too pedantic and prioritize readability | ||
over convention. | ||
|
||
|
||
## Check List For Pull Requests | ||
1. Fork the repository and create your branch from `main`. | ||
2. If you've added code that should be tested, add tests. | ||
3. If you've changed the API, update the documentation. | ||
4. Ensure the test suite passes `pytest`. | ||
5. Make sure your code is formatted: `isort . && black .` | ||
6. Make sure your code lints: `mypy . && flake8 .` | ||
7. If you haven't already, complete the Contributor License Agreement ("CLA"). | ||
2. If you've added code that should be tested, add tests, and ensure the entire | ||
test suite passes. | ||
3. If you've added or revised a user-facing feature, update the documentation. | ||
4. Lint and format your code. | ||
5. If you haven't already, complete the Contributor License Agreement ("CLA"). | ||
|
||
|
||
## Contributor License Agreement ("CLA") | ||
In order to accept your pull request, we need you to submit a CLA. You only need | ||
to do this once to work on any of Facebook's open source projects. | ||
|
||
Complete your CLA here: <https://code.facebook.com/cla> | ||
|
||
|
||
## Issues | ||
We use GitHub issues to track public bugs. Please ensure your description is | ||
clear and has sufficient instructions to be able to reproduce the issue. | ||
|
||
|
||
## License | ||
By contributing to FAIR Sequence Modeling Toolkit v2 (fairseq2), you agree that your | ||
contributions will be licensed under the LICENSE file in the root directory of | ||
this source tree. | ||
By contributing to fairseq2, you agree that your contributions will be licensed | ||
under the LICENSE file in the root directory of this source tree. |
Oops, something went wrong.