Request a new Exercism language track
Does Exercism already support the language?
Please search our repositories, to see both active and inactive tracks on the site.
If you find the language, check the
config.json file to see if it has an
active key, which will be true or false. If you'd like to help out, please open an issue on that repository to say hello.
Has someone else asked for it?
Do a search in the issues in this repository for the name of the language. Remember to check both open and closed issues.
It doesn't exist - I want to create it!
Awesome!! Please open a new issue, filling out the template. We'll take a look!
How to improve the process for the next new maintainer
It's crucial that we improve the documentation and instructions for launching a track. The best people to discover issues with our current process are new maintainers, launching a track for the first time. Unfortunately, that's the worst possible time for them to fix the documentation, because they've got the least amount of knowledge about how Exercism is put together.
The files in this repository serve as a template for a new track. Some files get edited and added to the track, others are used to create new issues in the track, but are not added to the new repository. If new maintainers have questions, it will often be because these files are confusing or missing information.
When that happens we should tweak the documentation for clarity in a new pull request to the request-new-language-track repository (not their repository) and tag the maintainer to review it. If it's still confusing, they'll know, and figuring out how to explain it will help us fix it.
In some cases, we might discover that we're missing high-level documentation that should live in the docs repo, in which case we should open an issue or pull request there, proposing the new documentation. Tag the new maintainer there, as well, to get their input on the new docs.
Notes for Org Owners
How to bootstrap a new track
Only owners of the organization can create new repositories.
- Install hub.
- Clone the request-new-language-track repository.
- Clone the tools repository.
- Follow the instructions in the tools README to clone all the existing tracks.
- Create a saved reply with the following checklist:
- [ ] Run bootstrap script `TRACK_ID=<id> LANGUAGE=<language> bin/bootstrap` Add it as a Linux project, then switch it to OS X in _Project Settings -> Build Environment_ - [ ] Add as a submodule to [trackler] `TRACK_ID=<id>; git submodule add https://github.com/exercism/$TRACK_ID tracks/$TRACK_ID` - [ ] Create [new team][new-team] for language - [ ] Add bootstrapped repository to team **with write access** - [ ] Invite maintainer to team [trackler]: https://github.com/exercism/trackler/tree/main/tracks [new-team]: https://github.com/orgs/exercism/new-team
Bootstrap a Track
Add the "new track" label.
- If the requestor is volunteering, that's fine.
- If the requestor is volunteering someone else for the job, confirm with that person.
- If there is no maintainer, label with "needs maintainer"
Once a maintainer is confirmed, add the "new track" checklist as a reply.
Once the checklist is complete, let the requestor/maintainer know that the repo is ready for them, and point them to the launch checklist issue.