Skip to content

Commit

Permalink
docs(readme): Added CONTRIBUTORS.md
Browse files Browse the repository at this point in the history
  • Loading branch information
tingerrr committed Jul 25, 2024
1 parent d3c038a commit 318bdc1
Showing 1 changed file with 97 additions and 0 deletions.
97 changes: 97 additions & 0 deletions CONTRIBUTING.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,97 @@
# Contributing
Thank you for considering to contribute to `typst-test`.
Any contributions are welcome, from implementing large features to fixing small typos.

**If you're contributing for the first time to `typst-test`, please familiarize yourself with the workflow below.**

1. When you open a PR as a draft, it can be as messy as you want.
1. Once you request review, make sure you have cleaned up the PR:
- It should have a linear history, rebase on main to update your branch instead of merging main into it.
- Each commit should be atomic, they should compile and pass tests on their own.
- Each commit should have a clear commit message with a short and long description (if applicable).
- It should not contain any `fix` or `review` commits, each commit should be a meaningful change to the code base.

Each commit is reviewed in isolation, which is why clear commit messages and atomic commits are important.
1. When a change is requested, address this change by rewriting the commits and force pushing the branch, od not add `fix` or `review` commits.
1. Once reviewed it is either squashed and merged, or rebased on main.

## Commit Messages
Each of the final commits should have a clear commit message starting with `a(b):`, where `a` is a general term like:
- `fix` for fixing bugs
- `docs` for changing, fixing or adding new documentation
- `feat` for a new feature of any kind
- `chore` for anything else like cleanups or refactors, these shold not have any externally observerable change in behavior (other than speed ups)

`b` is optional, but may be a term like:
- `cli` for change to the cli crate
- `lib` for changes to the library crate
- `book` for changes to the book
- `ci` for changes to ci workflows
- `vcs` for changes to features regarding VCS
- a path to a file for various other changes concerning specific things like scripts (rarely used)
- a path to module or type in the code base (`lib::test::Test`/`lib::Test`) for very specific refactors

This is generally optional, but helps developers filter out commits when bug hunting.
After this should follow a short summary of what the commit changes followed by a more elaborate description.
This can be left out for very small commits, no need to make something up.
Commit messages are is documentation for developers to understand reasoning behind changes, so don't be afraid to write an essay here, the more complicated a refactor or bug fix, the more elaborate the commit message should likely be.
Here's a commit message from the code base:

```
docs(book): Add installation chapter
Adds an installation chapter to the quick start part of the book, this section
outlines methods of installation, as well as system dependencies such as
openssl.
```

The short message (first line) is seen most often and clearly communicates what this does, a developer looking for bugs in the library code can ignore this commit entirely.
The long message (after the empty line) more closely describes the change, but since it is simple it's not very long.

## Atomic Commits
Each commit in a PR should be
- self contained,
- compilable,
- and able to pass all tests.

None of these restrictions can easily be enforced by CI, it is up to you as the contributor to uphold that.
A good way to ensure this is to think about the changes before writing them and rewriting your commit history by amending, splitting or reordering.

Here are some general guidelines:
- Keep refactors required for a feature separate to the feature itself.
- Code documentation, test adjustments or new test cases and features all belong in the same commit, do not split these up.
- If you find a bug while adding a new feature, add a bug fix in a separate commit.

## Linear History
`typst-test` imposes a linear history on its main branch, this means that PR's are not merged, but either squashed or rebased on top of main.
This means that the commits landing on main must likewise be a linear history, at least once added to main.

There are two was to add PRs to main:
1. The squash workflow: Squash all commits and add them to main.
It's fairly easy to get a single commit on main which is atomic, but such commits may get unecessarily large.
This is avoided where possible.
1. The rebase workflow: All commits are added individually on main.
This is done most often and the main reaons your commits should all individually be valid states of the repository.

## Adressing Reivew
Say you created a PR with this history:

```txt
◆ A fix(vcs): Avoid panic on UNC paths within escape check
◆ B feat(vcs): Add mercurial support
◆ C docs(book): Add mercurial chapter to cli reference
```

You open the PR and on review you agree to rename one of the Types introduced in `B`.
Instead of adding a new commit which does nothing substantial other than renaming a type, you amend the changes to the commit `B` and force push the branch.
It is up to you how you accomplish this, but one way to do it is to add a new commit and use `git rebae --interactive` to squash it into `B`.

I personally use [jj] for all my repos, which makes history rewriting and commit-fu very easy.
I can recommend it especially for this type of workflow.
If you prefer a GUI or TUI, there's also [gg] and [lazyjj].

[jj]: https://github.com/martinvonz/jj
[gg]: https://github.com/gulbanana/gg
[lazyjj]: https://github.com/Cretezy/lazyjj

0 comments on commit 318bdc1

Please sign in to comment.