Closed ErikSchierboom closed 1 year ago
⚠ The spec for Practice Exercises has changed. Besides having a prerequisites
field, each Practice Exercise should now also have a practices
field, which should list the slugs of Concepts that this Practice Exercise actively allows a student to practice. See the spec for more information.
The issue's text has been updated to reflect the updated spec.
We don't yet have concept exercises, so I think it's fine to ignore this for now.
This issue is part of the migration to v3. You can read full details about the various changes here.
Exercism v3 introduces a new type of exercise: Concept Exercises. All existing (V2) exercises will become Practice Exercises.
Concept Exercises and Practice Exercises are linked to each other via Concepts. Concepts are taught by Concept Exercises and practiced in Practice Exercises. Each Exercise (Concept or Practice) has prerequisites, which must be met to unlock an Exercise - once all the prerequisite Concepts have been "taught" by a Concept Exercise, the exercise itself becomes unlocked.
For example, in some languages completing the Concept Exercises that teach the "String Interpolation" and "Optional Parameters" concepts might then unlock the
two-fer
Practice Exercise.Each Practice Exercise has two fields containing concepts: a
practices
field and aprerequisites
field.Practices
The
practices
key should list the slugs of Concepts that this Practice Exercise actively allows a student to practice.strings
). In those cases we recommend choosing a few good exercises that make people think about those Concepts in interesting ways. For example, exercises that require UTF-8, string concatenation, char enumeration, etc, would all be good examples.Prerequisites
The
prerequisites
key lists the Concept Exercises that a student must have completed in order to access this Practice Exercise.strings
,optional-params
,implicit-return
.loops
orrecursion
), the maintainer should choose the one approach that they would like to unlock the Exercise, considering the student's journey through the track. For example, the loops/recursion example, they might think this exercise is a good early practice ofloops
or that they might like to leave it later to teach recursion. They can also make use of an analyzer to prompt the student to try an alternative approach: "Nice work on solving this via loops. You might also like to try solving this using Recursion."Although ideally all Concepts should be taught by Concept Exercises, we recognise that it will take time for tracks to achieve that. Any Practice Exercises that have prerequisites which are not taught by Concept Exercises, will become unlocked once the final Concept Exercise has been completed.
Goal
Practices
The
"practices"
field of each element in the"exercises.practice"
field in theconfig.json
file should be updated to contain the practice concepts. See the spec.To help with identifying the practice concepts, the
"topics"
field can be used (if it has any contents). Once prerequisites have been defined for a Practice Exercise, the"topics"
field should be removed.Each practice concept should have its own entry in the top-level
"concepts"
array. See the spec.Prerequisites
The
"prerequisites"
field of each element in the"exercises.practice"
field in theconfig.json
file should be updated to contain the prerequisite concepts. See the spec.To help with identifying the prerequisites, the
"topics"
field can be used (if it has any contents). Once prerequisites have been defined for a Practice Exercise, the"topics"
field should be removed.Each prerequisite concept should have its own entry in the top-level
"concepts"
array. See the spec.Example
Tracking
https://github.com/exercism/v3-launch/issues/6