Skip to content

Latest commit

 

History

History
168 lines (109 loc) · 6.36 KB

CONTRIBUTING.md

File metadata and controls

168 lines (109 loc) · 6.36 KB

Contributing

Formatting

  • Android: IntelliJ or Android Studio.
  • Dart: dart format.
  • Python: Black.
  • Swift: swiftformat.

Git Branch/Merge rules

When you are working on a repository you don't own, or when you are planning on creating a significant change, you should create a new feature branch and open a Pull Request to merge against the main branch.

  • If you have any questions regarding the content, please ask immediately.
  • Editors have buttons for each of the commands below. Feel free to use them as long as you know what you are doing and they work.

Please follow the steps below.

Create a new feature branch

Make should you are already on the latest main:

git switch main
git pull

Name your new feature branch what it does. For example, when writing this document about Git rules, I name it specify-git-rules:

git switch -c specify-git-rules

The above command "branches off" main, creates a new branch specify-git-rules, and "switches" to it.

Push your branch to GitHub:

git push -u origin specify-git-rules

This will create a new branch on GitHub called specify-git-rules based on main and set the upstream of your local branch to it.

Find out if the branch name is taken

You need to avoid using a name that is already taken. To find out if a branch name is taken:

git branch

The above command shows all the branch names that are taken.

Make the changes you need to make

  • Every time before you make a commit, review the diff and go over every line that you just changed. Also, be sure to spot unwanted files that are going to be committed by mistake.

  • In your commit messages, specify what the commit does. For example, when I commit the change for this document, I use the commit message add branch/merge rules.

    • Ideally, you should also comment on the reason for the commit. For example, I should modify the commit message to add branch/merge rules for collaboration instruction.
    • If you have no idea what you should be saying in commits, please look at Conventional Commits.
  • After you make a commit, immediately push to GitHub.

    git push
  • Do not commit to feature branches other people created! If you wish to modify them, branch off them to a new feature branch.

Clean up mistakes in commits

  • If you have a serious typo in the commit message, or a coding mistake in your previous commit, and you don't want to create another commit, you can modify your last commit and force push it.

    git add .
    git commit --amend

    An editor (by default Vi) would pops up. Edit the commit message if you need to, and close the editor.

    Force push the overriding change you just made to GitHub:

    git push -f

Make a Pull Request

Go on GitHub and create a Pull Request from your branch (specify-git-rules) to main.

  • Name your Pull Request what it does.
  • Further explain what the Pull Request does if needed.
  • Explain why you are making this Pull Request.

Review your own Pull Request, especially the file changes. If you spot any problems, you can still fix them by making a local commit on your branch and doing a Git push.

If you are making a Pull Request in someone else's repository, it is best to ask them to review and merge it.

Review and merge the Pull Request

Ideally, a second person should review the Pull Request.

  • Fully review every line of the Pull Request.
  • For any questions, reference the line and ask the person making the Pull Request.
  • All questions should be answered, all problems should be fixed, before merging the Pull Request.
  • If the Pull Request has any conflict with main, merge main back into the feature branch first. (Technically, a rebase is better than a merge here, but it is harder).

When the Pull Request is ready and accepted, merge it by creating a merge commit. The commit message should still describe what the commit does, followed by the Pull Request number.

If the Pull Request is especially messy—for example, it added many files and removed them later, prefer doing a squash merge instead.

It is okay to just copy the name of the Pull Request and append the Pull Request number. For example, Specify Git branch/merge rules for collaboration instruction #1.

Merge conflict

When there is a conflict in the Pull Request, merge main into to the feature branch to make them compatible.

  • If you are confused at any stage, don't try to solve it yourself, ask for help.

  • Make sure you are already on your feature branch. If not, switch to it:

    git switch specify-git-rules
  • Start to merge main into the feature branch:

    git merge main

    You should see an error saying that the merge cannot be done automatically.

  • Open up your editor and solve all the conflicts manually. What conflicts look like. Editors usually have features that make the process easier.

  • Review the diff just as you would for a regular commit.

  • Make a merge commit just like a regular commit, and push.

Git Large File Storage usage

We use Git LFS to store assets.

To clone our repositories with assets included, simply install Git LFS.

To add assets:

  1. Ensure you have Git LFS installed.

  2. Remove the type of files you want to add from .gitignore if it is included there.

  3. Tell Git LFS to track the type of files you want to add if it is not already tracked:

    git lfs track '**.replace_with_your_file_extension'
  4. Continue with ordinary Git workflow.

Code Style

  • Code style is not for style. It is for maintainability. Do not nitpick code with identical functionality.
  • Shorter code is usually better, unless it takes longer to read asymptotically.
  • Code that hide important facts or create non-obvious control flows are bad.

Code Style Suggestions

  • Prefer immutable values and pure functions.
  • Reduce the amount of mutable states floating around (e.g. globals, classes).