Principally mathlib uses the fork-and-branch workflow. See https://blog.scottlowe.org/2015/01/27/using-fork-branch-git-workflow/ for a good introduction.
Here are some tips and tricks to make the process of contributing as smooth as possible.
- Use Zulip to discuss your contribution before and while you are working on it.
- Adhere to the guidelines:
- The style guide for contributors.
- The explanation of naming conventions.
- The documentation guidelines.
- The git commit conventions.
- Create a pull request from a feature branch on your personal fork, as explained in the link above, or from a branch of the main repository if you have commit access (you can ask for access on Zulip).
- If you've made a lot of changes/additions, try to make many PRs containing small, self-contained pieces. This helps you get feedback as you go along, and it is much easier to review. This is especially important for new contributors.
- If you checkout the remote branch
lean-3.5.1
you can fetch the.olean
binaries using the commandcache-olean --fetch
- You can do this by running the following commands (anywhere in the
mathlib
repository).
git fetch --all git checkout origin/lean-3.5.1 cache-olean --fetch git checkout -b my_new_feature
- Some users have reported that Lean will recompile the library even after the
.olean
files have been downloaded correctly. This happens because the timestamps of the binaries are older than the timestamps of the.lean
files. If this happens, you can run the following command to update the timestamps (in themathlib
directory):
find src/ -name '*.olean' -exec touch {} +
- You can also run
cache-olean
to save all your current.olean
files (before you checkout another branch). After returning to this branch you can restore these.olean
files by runningcache-olean --fetch
. - See Caching compilation for commands to do this automatically.
- You can do this by running the following commands (anywhere in the
Finally, https://github.com/leanprover-community/mathlib-nursery makes it possible to have early access to work in progress. See its README for more details.
In the mathlib
git repository, you can run the following in a terminal:
sudo pip3 install mathlibtools
setup-lean-git-hooks
It will install scripts including update-mathlib
and cache-olean
and setup git hooks that will call cache-olean
when making a commit
and cache-olean --fetch
and update-mathlib
when checking out a
branch. update-mathlib
will fetch a compiled version of mathlib
and cache-olean
will store and fetch the compiled binaries of the
branches you work.