forked from FAForever/fa
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Update CONTRIBUTING.md (FAForever#6453)
- Loading branch information
Showing
1 changed file
with
95 additions
and
16 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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,23 +1,102 @@ | ||
Contributing | ||
------------ | ||
|
||
To contribute, please fork this repository and make pull requests to the | ||
`deploy/fafdevelop` branch. | ||
## When making a PR: | ||
|
||
Use the normal git conventions for commit messages, with the following rules: | ||
- Subject line shorter than 80 characters | ||
- No trailing period | ||
- For non-trivial commits, always include a commit message body, describing the change in detail | ||
- If there are related issues, reference them in the commit message footer | ||
If you plan a bigger change, make an issue first to discuss the feature. This way you can avoid spending time on something that would ultimately be denied integration. | ||
|
||
We use [git flow](http://nvie.com/posts/a-successful-git-branching-model/) for our branch conventions. | ||
- Target the `develop` branch. | ||
- Start your PR as draft. | ||
- Don't forget to add appropriate tags. | ||
|
||
When making _backwards incompatible API changes_, do so with a stub function and put in a logging statement including traceback. This gives time for mod authors to change their code, as well as for us to catch any incompatibilities introduced by the change. | ||
Each PR needs a [snippet](https://faforever.github.io/fa/development/changelog) for the changelog file of the release. | ||
When you have made all the changes you intended to do and have added the snippet, you can mark the PR as ready for review by removing the draft status from the PR. | ||
Now the PR should be milestoned to the next release. | ||
You can request reviews from people that a knowledgable in the domains of the code you changed (See below). | ||
|
||
Code convention | ||
--------------- | ||
|
||
Please follow the [Lua Style Guide](http://lua-users.org/wiki/LuaStyleGuide) as | ||
much as possible. | ||
## How to do a review: | ||
|
||
For file encoding, use UTF-8 and unix-style file endings (Set core.autocrlf). | ||
1. Do we want this feature? | ||
If it's just a bugfix this can generally be answered as yes. | ||
If it's a new feature or changes gameplay in a more meaningful way there is ideally a linked issue where the discussion already happened and it was concluded that we want this feature. | ||
Sanity check: Should this rather be a sim/ui mod? | ||
|
||
2. Functionality | ||
Start the game with these changes and see if the described changes work as intended. | ||
Test if related functionality still works and didn't inadvertantly break. | ||
There is no hard rule how much testing is needed, especially as we can't automate this. You don't have to go overboard with testing as we still have the duration between the merge and the next release to notice bugs during actual gameplay. | ||
|
||
3. Technical code review | ||
Is the code style correct? Please follow the [Lua Style Guide](http://lua-users.org/wiki/LuaStyleGuide). | ||
Is the code readable and doing things the way things should be done? | ||
This step should be done by people that have knowledge of the affected domains of the code base (See below). | ||
|
||
4. Balance implications (only for PRs labeled as balance) | ||
Changes touching balance need a green light from the balance team. | ||
|
||
It's totally possible to review not all steps if you don't have the knowledge or motivation to do them all. Someone else can pick up the other steps. | ||
If you don't review all steps, don't formally approve the PR, but state your approval of the steps you did in a review comment. Only PRs that passed all review steps should be formally approved. | ||
|
||
|
||
## When to merge: | ||
|
||
After all the necessary reviews have passed and the PR has been approved it can be merged. We suggest to wait 24 hours after approval, so the owner of the PR can interject if there was some sort of miscommunication and the owner still intends to do some changes. The PR owner can also merge the PR if they want. | ||
|
||
Merge by using the squash option. | ||
Use the normal git conventions for the commit message, with the following rules: | ||
|
||
- Subject line shorter than 80 characters | ||
- Pull request number at the end | ||
- No trailing period | ||
- For non-trivial commits, always include a commit message body, describing the change in detail | ||
|
||
If the branch was in the FAForever repository, delete it after the merge, so it doesn't clutter the repo. | ||
|
||
## Reviewers | ||
|
||
These are people knowledgeable of the indicated areas, that are good candidates to request a review from. | ||
|
||
**lua (ui)** | ||
@4z0t | ||
@Basilisk3 | ||
@lL1l1 | ||
@Garanas | ||
@Hdt80bro | ||
@clyfordv | ||
@speed2CZ | ||
|
||
**lua (sim)** | ||
@lL1l1 | ||
@4z0t | ||
@Basilisk3 | ||
@Garanas | ||
@Hdt80bro | ||
@clyfordv | ||
@speed2CZ | ||
@The-Balthazar | ||
|
||
**AI** | ||
@relent0r | ||
@Garanas | ||
|
||
**blueprints** | ||
@Basilisk3 | ||
@Garanas | ||
@Hdt80bro | ||
@lL1l1 | ||
@The-Balthazar | ||
|
||
**mapping** | ||
@speed2CZ | ||
|
||
**modeling** | ||
@MadMaxFAF | ||
@The-Balthazar | ||
@lL1l1 | ||
|
||
**graphics** | ||
@BlackYps | ||
@Garanas | ||
|
||
**binary patches** | ||
@4z0t | ||
@Hdt80bro |