We want to make contributing to this project as easy and transparent as possible.
Minor changes and improvements will be released on an ongoing basis. Larger changes (e.g., changesets implementing a new paper) will be released on a more periodic basis.
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
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.
Facebook has a bounty program for the safe disclosure of security bugs. In those cases, please go through the process outlined on that page and do not file a public issue.
We actively welcome your pull requests.
However, if you're adding anything significant (e.g. > 50 lines), please open up an issue before sending a PR to involve and discuss with maintainers if the change is required and will be accepted.
We take the following factors into consideration before accepting features and PRs:
- If the feature can be achieved without modifying MMF. MMF is designed so that you can implement extensions from the outside, e.g. Hateful Memes ConcatVL example.
- If something is not extensible, please open up an issue so we can improve MMF together.
- Whether the feature is potentially useful to a large audience (e.g. an impactful paper, a popular dataset, a significant speedup or a widely useful utility).
- Whether the proposed solution has a good design/interface. This can be discussed in the issues prior to the PRs, or in the form of a draft PR and we will help you make it better.
- Whether the proposed solution adds extra overhead to users who don't need such feature.
- Whether the proposed solution breaks existing APIs.
- Read the PR guidelines if you haven't.
- Fork the repo and create your branch from
master
. - If your PR contains multiple orthogonal changes, split it to several PRs. Keep one PR focused on a single change while keeping it small.
- If you've added code that should be tested, add tests.
- Follow the coding style guidelines mentioned below.
- If you've changed APIs:
- Update the documentation. We use the Google style docstrings in python.
- Ensure backwards compatibility.
- Ensure the test suite passes.
- If the PR involves adding (i) a new dataset: update the dataset zoo to enable automatic downloads (ii) a new model: you don't need to update the model zoo, but make sure to describe your results and experiments in PR description. Also, update the list of the models and the datasets in the documentation accordingly.
- Follow commit guidelines to ensure your commit message follows MMF style.
- If you haven't already, complete the Contributor License Agreement ("CLA").
- In your editor, install the editorconfig extension which should ensure that you are following the same standards as us.
- MMF uses pre-commit hooks to ensure style consistency and prevent common mistakes. Enable it by:
pip install pre-commit && pre-commit install
After this pre-commit hooks will be run before every commit.
-
Read the editorconfig file to understand the exact coding style preferences.
-
Ideally, black and isort should be run via pre-commit hooks. But if for some reason you want to run black and isort separately follow this:
pip install black==19.3b0 isort==4.3.21
black ./(mmf|tests|tools)/**/*.py
isort -rc (mmf|tests|tools)
We follow the same guidelines as AngularJS. Each commit message consists of a header, a body and a footer. The header has a special format that includes a type, and a subject:
[<type>] <subject>
<BLANK LINE>
<body>
<BLANK LINE>
<footer>
Any line of the commit message cannot be longer 100 characters! This allows the message to be easier to read on github as well as in various git tools.
Must be one of the following:
- feat: A new feature
- fix: A bug fix
- cleanup: Changes that do not affect the meaning of the code (white-space, formatting, missing semi-colons, dead code removal etc.)
- refactor: A code change that neither fixes a bug or adds a feature
- perf: A code change that improves performance
- test: Adding missing tests or fixing them
- chore: Changes to the build process or auxiliary tools and libraries such as documentation generation
- docs: Documentation only changes
By contributing to MMF, you agree that your contributions will be licensed under the LICENSE file in the root directory of this source tree.