Thanks so much for taking the time to contribute to Disco! All contributions are welcomed and appreciated, all the way from reporting a bug or fixing a single punctuation mark in the documentation, up to implementing a complex new feature.
The following is a set of guidelines for contributing to Disco and related websites and tools, which are hosted in the disco-lang organization on GitHub. These are mostly guidelines, not rules. In particular, you don't need to worry that your contribution will be ignored or rejected in some way if you don't follow the guidelines. Use your best judgment, and also feel free to propose changes to this document in a pull request.
- Reporting Bugs
- Improving Documentation
- Suggesting Enhancements
- Your First Code Contribution
- Development Workflow
- Pull Requests
I have push access to the Disco repository, now what?
The Disco project and everyone participating in it is governed by the Contributor Covenant Code of Conduct. By participating, you are expected to uphold this code. Please report unacceptable behavior to byorgey@gmail.com.
- Bug to report or feature to request? Try the GitHub issue tracker.
- Questions? Join the
#disco-lang
IRC channel onfreenode.net
.
There are lots of ways to contribute to Disco—regardless of your background knowledge or level of mathematical or programming skill, there is probably a way you can help. For general advice on contributing to open source projects like Disco, see How to Contribute to Open Source, or Your first open source contribution: a step-by-step technical guide. The rest of this section walks through specific ways you can contribute and instructions for how to do so.
Even if you're not at the point where you would feel comfortable contributing code or documentation, playing around with the language and reporting any problems that you find is an immensely valuable way to help make the language better.
Feel free to submit a bug report for anything that seems like it's not the way it should be, such as a typo or error in the documentation, a program that yields an error even though you think it should be accepted, or a program that seems to output the wrong result. Even if the error turns out to be in your understanding rather than in the documentation or code, it's still a valuable contribution, since it may point out a way that the documentation or interface could be improved to help reduce similar confusion in the future.
Bugs are tracked as GitHub issues. Before creating a new issue, you can do a quick search to see if the problem has already been reported. If it has and the issue is still open, feel free add a comment to the existing issue instead of opening a new one.
When creating a new issue, explain the problem and include additional details to help the maintainers reproduce the problem, for example:
- Use a clear and descriptive title for the issue to identify the problem, if you can.
- Provide specific examples to demonstrate the problem. In many cases this may be in the form of some specific Disco code which causes the problem to happen. To include some Disco code in the issue, you can use Markdown code blocks.
- Describe the behavior you observed after following the steps and point out what exactly is the problem with that behavior.
- Explain which behavior you expected to see instead and why.
Not all of these are necessarily required for every single bug report (for example, to report a typo in the documentation you don't need to do much beyond point it out); use your judgment, but try to err on the side of including more information.
If you have an idea for a way Disco could be better, or a super-cool new feature you'd like to see, you can submit it on the GitHub issue tracker, the same as a bug report. Just describe your idea in as much detail as you can.
Disco has two main types of documentation:
-
Documentation hosted on
readthedocs.io
, aimed at users of Disco (students, teachers, etc.). The source for this documentation can be found in thedocs/
directory. Right now there is only a tutorial for experienced functional programmers, but more documents are planned, such as a language reference and a tutorial for beginning programmers; you may have ideas for other sorts of helpful documents! You can contribute to an existing document or even start a new one. For more information about the technical details of contributing to the documentation, see docs/README.md. -
Haddock documentation in the code, which is aimed at developers and those trying to understand the implementation of Disco. If you know Haskell, one valuable way to contribute is by reading and trying to understand the code (feel free to ask questions in the
#disco-lang
IRC channel onfreenode.net
along the way!), and adding comments to document what you learn, especially in places where the comments are inadequate.
Specific documentation that needs fixing, or specific documentation that needs to be written, can also be found on the issue tracker under the "Documentation" label (though as explained above, the issues on the issue tracker are by no means an exhaustive list of documentation improvements that would be helpful).
Disco is written in Haskell. The level of Haskell skill
needed to understand and contribute to the Disco codebase varies widely
depending on which part of the code you look at, but generally speaking you will
probably need to be comfortable with standard monads (Except
, Reader
,
State
, Maybe
) and with standard container types like Data.Set
and
Data.Map
. If you'd like to learn enough Haskell to contribute to Disco, we
recommend starting by
working through these introductory Haskell course materials.
If you'd like to contribute some code but are unsure where to begin, you can
start by looking through
issues tagged "Low-Hanging Fruit"
in the issue tracker. These are bugs and features which should be appropriate
for someone just getting started to tackle. If you want help understanding or
getting started on a particular issue, feel free to leave a comment on the issue
or ask in the
#disco-lang
IRC channel.
Never made an open source contribution before? Wondering how making a contribution actually works? Here's a quick rundown!
- Find an issue that you are interested in addressing or a feature that you would like to add.
- Fork the
disco
repository (by clicking the "Fork" button in the upper-right corner). This will make a copy of the repository in your personal GitHub account, that is, you will have your own personal copy of the repository under<your-GitHub-username>/disco
. - Clone the repository to your local machine by opening a terminal,
navigating to the directory where you would like to store the
disco
repository, and typinggit clone https://github.com/your-GitHub-username/disco.git
. (If you don't already have thegit
tool, you will have to install it first.) You should now have a subfolder nameddisco
containing an up-to-date copy of the repository. - Create a new branch for your fix using
git checkout -b BRANCH-NAME
(replaceBRANCH-NAME
by some appropriate name based on the feature or fix you plan to make). - Make the appropriate changes for the issue you are trying to address or the feature that you want to add.
- Use
git add
to add the file contents of the changed files to the "snapshot" git uses to manage the state of the project, also known as the index. - Use
git commit -m "Insert a short message of the changes made here"
to store the contents of the index with a descriptive message. - Push the changes to your fork on GitHub using
git push origin BRANCH-NAME
. - Submit a pull request
from your fork to the
disco-lang/disco
repository. - Title the pull request with a short description of the changes made and the issue or bug number associated with your change (if any). For example, you can title an issue like so "Added more log output to resolve #4352".
- In the description of the pull request, explain the changes that you made, any issues you think exist with the pull request you made, and any questions you have for the maintainer. It's OK if your pull request is not perfect (no pull request is), the reviewer will be able to help you fix any problems and improve it!
- Wait for the pull request to be reviewed by a maintainer.
- Make changes to the pull request if the reviewing maintainer recommends them.
You can simply make additional changes,
add
andcommit
them, and thenpush
to the same branch. Any additional commits added to the same branch will automatically be included in the pull request. - Celebrate your success after your pull request is merged!
- After your first pull request is merged, it is very likely that you will be
granted push access to the
disco-lang/disco
repository. This means that from now on you can create branches directly within thedisco
repository rather than working in your own fork. For more information, see I have push access to the Disco repository, now what?.
Inspired by Edward Kmett, Disco uses The Pull Request Hack: anyone who submits a pull request to Disco is likely to be granted push access in short order.
One benefit is that when working on a new feature, you can create a branch in
the disco
repository itself (instead of in your own fork) and then open a pull
request from the feature branch to master
. This is actually preferred since
it makes several things smoother (for example, the restyled.io
bot works much
better on pulls from local branches than from forks).
Although being given push access does not imply any particular responsibility, you are welcome to do things such as help review and merge other pull requests, and help triage, label, and update issues in the issue tracker.
Having push access also means, of course, that you can push directly to
master
. You are welcome to do so for typos, small fixes, documentation
improvements, and the like; for larger fixes, new features, etc. opening a
pull request from a feature branch is still preferred, to give a chance for
others to offer suggestions for improvement.