cmta Command Reference
Command Summary
cmta takes a command as the first parameters and it operates on a CMT main [git] repository.
The available commands and their function is as follows:
- studentify: generate a studentified artifact
- linearize: generate a linearized artifact
- delinearize: reflect the changes made in a linearized artifact back into the corresponding main repository
- renumber-exercises: renumber exercises in a main repository
- duplicate-insert-before: duplicate a selected exercise in a main repository and insert it before that exercise
- new: create a new main repository from a Github template
The remainder of this section describes these commands in further detail.
Note that all
cmtacommands require the CMT main repository to be clean from a git repository perspective which means that there should be no files in the repository's git workspace or index.
cmta studentify
Synopsys
cmta studentify [-fgh] -m <Main repo> -d <studentified repo parent folder> [-c <config-file>]
Description
Generate a studentified artifact from a CMT main respository. The former is a self-contained artifact
that contains all exercise materials and a code folder that holds the complete state for the first
exercise. It can be distributed to users, in general people following a course, who can use cmtc to
navigate between exercises, "pull" an exercise solution, save the current state of their work for a given
exercise with the possibility to restore it at a later time.
Note:
cmta studentifywill generate an error is the CMT main repository's git workspace isn't clean. So, commit any unsaved work before trying to studentify a repository.
The following options are available:
-f: Force-delete a pre-existing studentified artifact.
-g: Initialise the studentified artifact as a git repository.
          This option can be useful in some use cases. For example, students may
          commit specific exercise state in git, then move to the next exercise
          and then use `git diff` to explore any changed test code.
-c: Specify an alternative CMT configuration file.
-h: Print command-specific help.
cmta linearize
Synopsys
cmta linearize [-fh] -m <Main repo> -d <linearized repo parent folder> [-c <config-file>]
Description
Generate a linearized artifact from a CMT main repository. The former is a git repository in which each commit corresponds to the state of an exercise of the main repository. The first (oldest) commit in the repo corresponds to the first exercise in the main repository. The commit message for each commit is a single line with the name of the exercise in it.
The linearized repository can be used for different purposes, but the most important one is to assist in editing the content of exercise code: this can be done using interactive rebasing on a linearized repository. The changes applied on the latter via such process, can be applied by delinearizing the linearized repository into the main repository.
The following options are available:
-f: Force-delete a pre-existing studentified artifact.
-c: Specify an alternative CMT configuration file.
-h: Print command-specific help.
Note:
cmta linearizewill generate an error is the CMT main repository's git workspace isn't clean. So, commit any unsaved work before trying to linearize a repository.
Warning: It is important to leave the commit messages in the linearized repository as-is. Also never delete or insert commits. Not adhering to these rules will make it impossible to delinearize the repository.
cmta delinearize
Synopsys
cmta delinearize [-h] -m <Main repo> -d <linearized repo folder> [-c <config-file>]
Description
Apply the state of a linearized repository to its corresponding main repository. Before performing its task, the delinearization command will check that the linearized repository and the main repository "match", i.e. they should have the same number of exercises, with matching exercise names.
The following options are available:
-c: Specify an alternative CMT configuration file.
-h: Print command-specific help.
cmta duplicate-insert-before
Synopsys
cmta duplicate-insert-before [-h] -n <exercise number N> -m <Main repo> [-c <config-file>]
Description
The exercise number (N), passed in via the -n parameter, will be duplicated and inserted as a new exercise before the exercise with that number.
It there is a gap before the original exercise in the exercise series, the duplicated exercise will have sequence number N - 1. Otherwise, room will be made for the duplicated exercise by shifting exercises around. Note that if the exercises after the insertion point have one or more gaps in the numbering, those gaps will be removed and the exercises will be renumbered as a continuous series.
In general, the description of the new, duplicated exercise will be what it was followed by _copy.
The following option are available:
-c: Specify an alternative CMT configuration file.
-h: Print command-specific help.
cmta renumber-exercises
Synopsys
cmta renumber-exercises [-f <value>,-t <value>, -s <value>, -h] -m <Main repo> [-c <config-file>]
Description
By default, this command will renumber all exercises to a series starting at exercise number 1, with the consecutive exercises number being incremented by one.
The different available command options allow to start the renumbering starting from a specific exercise, move exercises to a different starting offset, and to specify by how much the exercise numbers are incremented between consecutive exercises.
The following options are available:
-f: number of the exercise at which the renumbering needs to be started.
          This option enables partial renumbering of the exercise set. The value passed as an
          argument to this option is the number of the exercise at which the renumbering should
          start. All subsequent exercises, if any, will be renumbered.
-t: move the exercise pointed-to by --from to this --to offset.
          This option allows moving a subset of the exercises to a new point (offset). As such, it
          can created gaps in the exercise numbering.
-s: defines the increment between subsequent, renumbered exercises.
.
          By default, this value is 1, so renumbered exercises will have numbers that are contiguous.
          Using a value different than 1 will introduce gaps in the numbering between consecutive
          exercises
-c: Specify an alternative CMT configuration file.
-h: Print command-specific help.
cmta new
Synopsys
cmta new [-h] -t <template repository reference>
Description
Create a main CMT repository from a given template repository on Github. The template repository can be any regular main CMT repository on Github.
The template repository reference is composed of the name of the repository and the Github organisation.
Following is an example of an invocation of the cmta new command that is creating a new CMT main repo
based on the lunatech-scala-2-to-scala3-course Github repository:
$ cmta new -t lunatech-labs/lunatech-scala-2-to-scala3-course
Cloning into 'lunatech-scala-2-to-scala3-course'...
Project:
   lunatech-labs/lunatech-scala-2-to-scala3-course/3.0.0-v1
successfully installed to:
   /Users/ericloots/Library/Caches/com.lunatech.cmt/Courses/lunatech-scala-2-to-scala3-course
It is also possible to create a new repo from a specific, existing release:
$ cmta new -t lunatech-labs/lunatech-scala-2-to-scala3-course/0.27.0-RC1-v0
Cloning into 'lunatech-scala-2-to-scala3-course'...
Project:
   lunatech-labs/lunatech-scala-2-to-scala3-course/0.27.0-RC1-v0
successfully installed to:
   /Users/ericloots/Library/Caches/com.lunatech.cmt/Courses/lunatech-scala-2-to-scala3-course-2
When a project is passed without specifying a Github organisation, the project name will be prepended with cmt-template- and the most recent version of the project will be fetched from the lunatech-labs github organisation. To illustrate this, the following example launches the cmta new command passing scala as the template name. As a result the newest version (1.0.0) of the lunatech-labs/cmt-template-scala repo will be used to create a new course.
$ cmta new -t scala
Cloning into 'cmt-template-scala'...
Project:
   lunatech-labs/cmt-template-scala/1.0.0
successfully installed to:
   /Users/ericloots/Library/Caches/com.lunatech.cmt/Courses/scala
The following options are available:
-h: Print command-specific help.