Skip to content
Permalink
main
Switch branches/tags
Go to file
 
 
Cannot retrieve contributors at this time
87 lines (61 sloc) 4.04 KB

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.

One-time setup

  1. Install hub.
  2. Clone the request-new-language-track repository.
  3. Clone the tools repository.
  4. Follow the instructions in the tools README to clone all the existing tracks.
  5. 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

  1. Add the "new track" label.

  2. Confirm maintainer

    • 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"
  3. Once a maintainer is confirmed, add the "new track" checklist as a reply.

  4. 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.