v3's main goal is to improve the learning experience for students, so that when they complete a track they will be able to program in that language in an idiomatic way.
Exercism v2 currently focuses heavily on discovering lots of various information from a relatively complex exercise - something which can be challenging and confusing both for students and those trying to mentor them. In contrast, in v3, we are explicitly designing exercises to teach these Concepts. These new exercises are called Concept Exercises. Their goal is to teach one just Concept, providing enough challenge to familiarse the student with the idea of the Concept and enough mental scaffolding for them to know where to discover more information. Concept Exercises are therefore designed with a specific purpose in mind, whereas in v2 the learning experience was more incidental.
v3 also adds new features and changes to the user experience, such as In-browser coding, Approaches, better automated-feedback, and an improved mentoring system.
For a more in-depth explanation on v3, please check the following links:
- Introduction to v3: An introduction to v3.
- The features of v3: A deeper dive into the changes we're making to v3.
- Rationale for v3. An explanation about the rationale behind some of our our design decisions for v3.
The key role for maintainers is in designing and managing their tracks. We don't expect maintainers to do all the work of creating everything. We want to crowd-source work as much as possible. Maintainers' key role is in working out how their track can best teach a student, and designing and reviewing exercises. We hope that maintainers will also enjoy creating some of the actual exercise themselves, but the load of this should be spread amongst the wider community.
For more information, see the maintainers README.
A Concept Exercise is an exercise that is designed to teach one Concept, and nothing more. Concept Exercises are thus designed with a specific purpose in mind, whereas in v2 the learning experience was more incidental.
As opposed to the v2 exercises, Concept Exercises are not based on shared data anymore. The reason for that is that we don't want any cross-track dependency issues, where changing the shared data makes sense for some tracks, but not for other tracks. The Concept Exercises can thus be tailored completely to best fit their track.
For more information, see the concept exercises document.
A Concept describes a feature of a programming language. Examples are "Encapsulation", "Conditionals", and "Functions." In other words, Concepts are what one would need to learn if one was to learn a new (programming) language.
Although there will obviously be cross-over between languages, Concepts are indented to be language-specific. What is it about your language that a junior programmer would need to learn, unlearn and remap to be able to successfully transition to it.
Each track will compile a list of Concepts for their track's language, for which Concept Exercises will be created.
Determining a language's Concepts will be a collective effort. Each track will start with maintainers selecting a couple of existing v2 exercises and analyze them to determine which Concepts one needs to know to get to an optimal solution. The concepts gathered thus are compared against each other and used to compile a list of Concepts. The end result is a list of the Concepts for that track's language.
For more information, see the determining concepts documentation.
The only Concept Exercises a student can start are ones that have no prerequisite Concepts (very, very few will be like this) or where the prerequisites are fulfilled already.
Therefore, the order/hierarchy of the Concepts themselves doesn't matter, other than as an organisation tool for you. What matters is just designing lots of exercises that teach lots of Concepts, and then thinking through what each of those exercises has as it's own prerequisites. Out of that a tree (or many parallel trees) will form, which is how things will be presented to the student.
Each Concept Exercise will in principle be designed from scratch. The basis will be formed by a single Concept. When designing the Concept Exercise, there are lots of things to consider:
- What should be taught?
- What shouldn't be taught?
- What are the prerequisite Concepts?
- ...
It can be very helpful to look at existing Concept Exercises, and see how they were designed.
Once you have a firm idea on what precisely the Concept Exercise will be teaching, the next step is to write a GitHub issue for the Concept Exercise. This issue should contain very detailed, actionable steps an outside contributor could work with. This will allow us to crowd-source the actual implementation of the Concept Exercises.
Not all Concept Exercises have to designed from scratch, it is perfectly reasonable for tracks to adapt Concept Exercises that were created for other tracks. The important part here is that when adapting existing Concept Exercises, they should be modified to best fit the track that is adapting them.
For some basic Concept Exercises, it might make sense to design them to teach two Concepts. The additional Concept must be one that is very simple and can be taught well in the context of the primary Concept. As an example, a basic "Integers" exercise could decide to also teach the basic "Conditionals" Concept. Note though that have more than one Concept should be the exception, not the rule.
A Concept Exercise has two types of files. The first are the general, language-agnostic files, which are required for all tracks. You can find a description of these files in the generic how to implement a concept exercise section. The second type of files are language-specific, and as such are different for each track. A description of these language-specific files will be added to each track. Here are the C# track's language-specific instructions.
Implementing a Concept Exercise should in principle be a case of following the detailed instructions in the Concept Exercise's corresponding GitHub issue.
If your track has already implemented one or more Concept Exercises, we highly recommend you taking a look at them too, to see how they were implemented.
We're aiming for about 50 Concept Exercises, although that does depend on the language and how many concepts it has (some languages are more complex than others). There is no fixed number here, it all depends on the language and how many Concepts it has. For the more complex languages with lots of concepts, the number could easily go to 100 Concept Exercises.
As each Concept Exercise will have detailed instructions in the form of a GitHub issue, we're hoping to crowd-source the actual implementation of the Concept Exercises. Designing the Concept Exercises and creating the corresponding GitHub issues is a responsibility of the maintainers though.
In general: yes. However, for very complex Concepts, it can make sense to have multiple smaller Concept Exercises instead of one huge Concept Exercise.
We highly recommend reading this thread for a nice discussion on this topic.
There will be no mentoring on Concept Exercises in v3. The process will be fully automated, and will work as follows:
- The student submits a solution for a Concept Exercise which prerequisites have been met (i.e. the student has completed Concept Exercises teaching the prerequisite Concepts).
- The solution is tested automatically to verify it passes all tests. This is done by the test runner. If a test fails, details of the failing test are shown to the student. The student must submit again (step 1) in order to continue.
- The representer creates a representation of the solution. If there are any comments linked to that representation, those comments are presented to the student. The student must submit submit again (step 1) in order to continue.
- The analyzer analyzes the solution. If there are comments, those comments are presented to the student. If one of the comments indicates that the student should not be allowed to proceed, the student must submit submit again (step 1) in order to continue.
- The student's solution is approved and the student can work on another Concept Exercise which prerequisites have been met.
At first: nothing. We're currently focusing on creating the Concept Exercises. At a later stage, we'll turn out attention to Practice Exercises, which is what the existing v2 exercises will be converted to.
Practice Exercises will be far less structured than Concept Exercises and not have a particular goal assigned to them. This makes them perfect for exploring different options. We'll add features to highlight different approaches.
Students will have the option to request mentoring for Practice Exercises.
For more information, see the practice exercises section.
Concept Exercises are obviously our main focus. However, v3 also requires the following, track-specific tooling:
- Test runner: verify a solution passes all the tests.
- Representer: takes a solution and returns a normalized representation of it.
- Analyzer: provide automated feedback on solutions.
The first two tools are must haves for v3, whilst the last one is in essence optional (although extremely useful).
Some tracks already have a working implementation of one or more of these tools. You can check this in your track's README file.
The problem-specifications repository will remain a very valuable resource to create/generate Practice Exercises from. That said, there are some issues we had with the problem-specifications repository, in particular the fact that we had some cross-track conflicts of interest. We have several ideas on how to fix these, which we'll be discussing and implementing at a later time. For now, the problem-specifications repository will remain locked and will only accept bugfixes.
Short answer: no. For the moment, we have all the v3 tracks in this single monorepo for one reason: to make it easier for tracks to borrow/be inspired by what other tracks are doing. Once a track has transitioned to v3, we'll be moving the track's data back over to the track's repository.
The basic communication channel for maintainers is Slack, and in particular the maintainer-only #maintaining-<track>
channel. For communication with everyone else, GitHub issues should be used, for obvious reasons (discoverability, familiarity, etc.). We've also enabled the GitHub Projects feature on the v3 repo, so you can organize your track's v3 transition there too.
Yes! Please use citations in any reference documentation (files under **/reference/**
). We are using the Science of Computer Programming citation style. This means that when citing website, please use this format:
$TITLE, $SOURCE. ($PUBLISHED_DATE). $URL (accessed $ACCESSED_DATE).
For example:
[1] Actor model, Wikipedia. (2020). https://en.wikipedia.org/w/index.php?title=Actor_model&oldid=939106706 (accessed February 29, 2020).
To include a citation in reference documentation, add the citation reference to the bottom of the page. Then add a line with the ---
separator above the citation. The final step is to append a superscript to the cited text. This superscript should refer to the citation reference's number (usually <sup>1</sup>
). See the actor model reference documentation for an example.
Note that if the cited text is copied literally, please put it in blockquotes.
To help generate these citations, ZoteroBib can be used. On that website, first set the citation style to "Science of Computer Programming" in the "Bibliography" section. Then, paste the URL you want to cite in the input field at the top of the page, click on the "Cite" button and the citation will be generated for you.
Do you have more questions or feel that something is missing? Please let us know by opening a GitHub issue.