Thank you for your interest in contributing to the Agda standard library. Hopefully this guide should make it easy to do so! Feel free to ask any questions on the Agda mailing list. Before you start please read the style-guide.
-
Create a fork by clicking
Fork
button at the top right of the repository. -
If you are on a Mac, make sure that your git options has
autocrlf
set toinput
. This can be done by executinggit config --global core.autocrlf input
If you are on Windows, make sure that your editor can deal with Unix format files.
-
On the command line, and in a suitable folder, download your fork by running the command
git clone https://github.com/USER_NAME/agda-stdlib agda-stdlib-fork
where
USER_NAME
is your Git username. The folderagda-stdlib-fork
should now contain a copy of the standard library. -
Enter the folder
agda-stdlib-fork
and choose the correct branch of the library to make your changes on by running the commandgit checkout X
where
X
should bemaster
if your changes are compatible with the current released version of Agda, andexperimental
if your changes require the development version of Agda.
-
Make your proposed changes. Please try to obey existing conventions in the library. See
agda-stdlib-fork/notes/style-guide.md
for a selection of the most important ones. -
Document your changes in
agda-stdlib-fork/CHANGELOG.md
. -
Ensure your changes are compatible with the rest of the library by running the commands
make clean make test
inside the
agda-stdlib-fork
folder. Continue to correct any bugs thrown up until the tests are passed.Your proposed changes MUST pass these tests. Note that the tests require the use of a tool called
fix-whitespace
. See the instructions at the end of this file for how to install this.If you are creating new modules, please make sure you are having a proper header, and a brief description of what the module is for, e.g.
------------------------------------------------------------------------ -- The Agda standard library -- -- {PLACE YOUR BRIEF DESCRIPTION HERE} ------------------------------------------------------------------------
If possible, each module should use the options
--safe
and--without-K
. You can achieve this by placing the following pragma under the header and before any other line of code (including the module name):{-# OPTIONS --without-K --safe #-}
If a module cannot be made safe or needs the
--with-K
option then it should be split into a module which is compatible with these options and an auxiliary one which will:- Either be called
SOME/PATH/Unsafe.agda
orSOME/PATH/WithK.agda
- Or explicitly declared as either unsafe or needing K in
GenerateEverything.hs
- Either be called
-
Use the
git add X
command to add changes to fileX
to the commit, orgit add .
to add all the changed files. -
Run the command:
git commit
and enter a meaningful description for your changes.
-
Upload your changes to your fork by running the command:
git push
-
Go to your fork on Github at
https://github.com/USER_NAME/agda-stdlib
and follow the official Git instructions to open a pull request to the main standard library repository. -
The library maintainers will then be made aware of your requested changes and should be in touch soon.
This tool is kept in the main agda organization. It can be installed by following these instructions:
git clone https://github.com/agda/fix-whitespace --depth 1
cd fix-whitespace/
cabal install
You can add the following code to the file .git/hooks/pre-commit
to
get git to run fix-whitespace before each git commit
and ensure
you are never committing anything with a whitespace violation:
#!/bin/sh
fix-whitespace --check
-
By default the README directory is not exported in the
standard-library.agda-lib
file in order to avoid clashing with other people's README files. This means that by default type-checking a file in the README directory fails. -
If you wish to type-check a README file, then you will need to change the line:
include: src
to
include: src .
in the
standard-library.agda-lib
file. -
Please do not include this change in your pull request.