Commands
Bug report
We encourage you to join our open-source community. If you find any errors, inaccuracies, or have suggestions to improve our documentation or tool, please report your findings on GitHub or start a conversation in our community through Discord.
Development Environment management
dem add-task DEV_ENV_NAME TASK_NAME COMMAND
Description:
Add a new task to the Development Environment.
A task is a command that can be run in the context of the Development Environment.
The task can be run with the dem run
command.
Arguments:
Argument | Description | Required |
---|---|---|
DEV_ENV_NAME |
Name of the Development Environment. | |
TASK_NAME |
Name of the task. | |
COMMAND |
Command to run. Must be enclosed with quotes. |
Examples:
Example | Description |
---|---|
dem add-task dev_env_name list-dir "ls -la" |
Add a new command called list-dir that lists the content of the current directory. The task can be executed with dem run dev_env_name list-dir . |
dem add-task dev_env_name build "docker run --rm -v \"$(pwd)\":/work axemsolutions/make_gnu-arm:13.2 make" |
Add a new command called build that builds the project in a docker container. The task can be executed with dem run dev_env_name build . |
dem assign DEV_ENV_NAME, [PROJECT_PATH]
Description:
Assign a Development Environment to a project.
If the project already has a Development Environment assigned, the user will be asked if they want to
overwrite it or not.
Projects that have a Development Environment assigned, can be initialized with the init
command.
Arguments:
Argument | Description | Required |
---|---|---|
DEV_ENV_NAME |
Name of the Development Environment to assign. | |
[PROJECT_PATH] |
Path of the project to assign the Development Environment to. If not set, the current working directory will be used. |
dem clone DEV_ENV_NAME
Description:
Clone a Development Environment descriptor from the catalogs.
Only the Development Environment descriptor will be cloned, the required tool images won't be pulled. If a Development Environment with the same name has been already available on the host PC, the user will be asked if they want to overwrite it or not.
After cloning, the Development Environment can be installed with the install
command.
Arguments:
Argument | Description | Required |
---|---|---|
DEV_ENV_NAME |
Clone the descriptor of the Dev Env. |
dem cp DEV_ENV_NAME NEW_DEV_ENV_NAME
Description:
Create a copy of an existing local Development Environment.
Arguments:
Argument | Description | Required |
---|---|---|
DEV_ENV_NAME |
Name of the Development Environment to copy. | |
NEW_DEV_ENV_NAME |
Name of the New Development Environment. |
dem create DEV_ENV_NAME
Description:
Create a new Development Environment descriptor and save it to the local descriptor storage (catalog).
Running this command will open up the Dev Env Settings Window:
The table on the left shows the available tool types. Select the ones you want to use in the Development Environment. You can navigate with the and or and keys. Move the cursor to the tool image you would like to select or deselect and press the . On the right side, you can see the tool images that are selected.
When the Dev Env is ready, press on the save
button.
Info
After creation, the Development Environment can be installed with the install
command.
Arguments:
Argument | Description | Required |
---|---|---|
DEV_ENV_NAME |
Name of the Development Environment to create. |
dem delete DEV_ENV_NAME
Description:
Delete the Dev Env descriptor from the local descriptor storage. If the Dev Env is installed, the user will be asked whether they want to uninstall it.
Arguments:
Argument | Description | Required |
---|---|---|
DEV_ENV_NAME |
Name of the Development Environment to delete. |
dem del-task DEV_ENV_NAME TASK_NAME
Description:
Delete a task from the Development Environment.
Arguments:
Argument | Description | Required |
---|---|---|
DEV_ENV_NAME |
Name of the Development Environment. | |
TASK_NAME |
Name of the task to delete. |
dem export DEV_ENV_NAME [PATH_TO_EXPORT]
Description:
Export a Development Environment descriptor in JSON format to a text file.
This file can be imported with the import
command on another host.
The way the file gets named can be set by the PATH_TO_EXPORT
argument:
- Not set: The file gets saved to the current directory with the name of the Development Environment and without extension.
- Only a name is set: The file gets saved with that name to the current directory, optionally with the set extension.
- The argument is a directory path: The file gets saved there with the name of the Development Environment, without extension.
- The argument is a path with the file name: The exported content gets saved into that file. The extension can be set with the file name.
Note
The exported file only contains the Development Environment descriptor in JSON format. For a successful import the DEM needs access to all the registries where the required images are stored.
Arguments:
Argument | Description | Required |
---|---|---|
DEV_ENV_NAME |
The name of the Development Environment to export. | |
[PATH_TO_EXPORT] |
Where to save the exported descriptor in JSON format. If not set, the current directory will be used. |
dem import PATH_TO_DEV_ENV
Description:
Imports a Development Environment descriptor.
After the import, the Development Environment can be installed with the install
command.
Note
The file to import only contains the Development Environment descriptor. To install the Dev Env the DEM needs access to all the registries where the required images are stored.
Arguments:
Argument | Description | Required |
---|---|---|
PATH_TO_DEV_ENV |
Path of the JSON file to import. |
dem info DEV_ENV_NAME [OPTIONS] [*CATALOG_NAMES]
Description:
Get information about the specified Development Environment available locally or in the catalogs.
Options:
Options | Description |
---|---|
--cat |
DEM will search for the Dev Env in the catalogs and will print the details of the first match. You can specifiy the catalogs' name to search in after this option. If no catalog is specified, all the available catalogs will be used. If the Dev Env is not found in the catalogs, an error message will be printed. |
Autocomplete only works with the locally avialable Dev Envs.
Arguments:
Argument | Description | Required |
---|---|---|
DEV_ENV_NAME |
Name of the Development Environment to get info about. | |
[OPTIONS] |
--cat : Search in the catalogs. |
|
[*CATALOG_NAMES] |
List of catalogs to search in (separated by space). |
Examples:
Example | Description |
---|---|
dem info dev_env_name |
Get information about the locally available Development Environment. |
dem info dev_env_name --cat |
Get information about the Development Environment from the catalogs. |
dem info dev_env_name --cat catalog1 catalog2 |
Get information about the Development Environment from the catalog1 and catalog2. |
dem init [PROJECT_PATH]
Description:
Initialize a project with the assigned Development Environment.
After the initialization, the Development Environment can be installed with the install
command.
Arguments:
Argument | Description | Required |
---|---|---|
[PROJECT_PATH] |
Path of the project to initialize. If not set, the current working directory will be used. |
dem install DEV_ENV_NAME
Description:
Install the selected Development Environment. DEM pulls all the required containerized tools (which are not yet available on the host PC) from the registry and install the Development Environment locally. If the same Development Environment is already installed, but the installation is not complete, the missing tool images get obtained from the registry.
Arguments:
Argument | Description | Required |
---|---|---|
DEV_ENV_NAME |
Name of the Development Environment to install. |
dem list [OPTIONS] [*CATALOG_NAMES]
Description:
List the locally available Dev Envs.
Options:
Options | Description |
---|---|
--cat |
List the available Dev Envs from the catalogs. Specify the catalogs' name to list the Dev Envs from. More then one catalog can be specified. If no catalog is specified, all the available catalogs will be used. |
Arguments:
Argument | Description | Required |
---|---|---|
[OPTIONS] |
--cat : List the Dev Envs from the catalogs. |
|
[*CATALOG_NAMES] |
List of catalogs to list the Dev Envs from (separated by space). |
Examples:
Example | Description |
---|---|
dem list |
List the locally available Dev Envs. |
dem list --cat |
List all the Dev Envs from all the available catalogs. |
dem list --cat catalog1 catalog2 |
List all the Dev Envs from the catalog1 and catalog2. |
dem list-tools [OPTIONS] [*REGISTRY_NAMES]
Description:
List the available tools.
Options:
Options | Description |
---|---|
--reg |
List the available tools from the registries. Specify the registries' name to list the tools from. More then one registry can be specified. If no registry is specified, all the available registries will be used. |
Arguments:
Argument | Description | Required |
---|---|---|
[OPTIONS] |
--reg : List the tools from the registries. |
|
[*REGISTRY_NAMES] |
Registries to list the tools from (separated by space). |
Examples:
Example | Description |
---|---|
dem list-tools |
List the locally available tools. |
dem list-tools --reg |
List all the tools from all the available registries. |
dem list-tools --reg registry1 registry2 |
List all the tools from the registry1 and registry2. |
dem modify DEV_ENV_NAME
Description:
Modify a Development Environment descriptor available from the local descriptor storage (catalog).
Running this command will open up the Dev Env Settings Window, prefilled with the current selection:
The table on the left shows the available tool types. Select the ones you want to use in the Development Environment. You can navigate with the and or and keys. Move the cursor to the tool image you would like to select or deselect and press the . On the right side, you can see the tool images that are selected.
When the Dev Env is ready, press on the save
button.
Info
After the modification, the Development Environment can be installed with the install
command.
Arguments:
Argument | Description | Required |
---|---|---|
DEV_ENV_NAME |
Name of the Development Environment to modify. |
dem rename DEV_ENV_NAME NEW_DEV_ENV_NAME
Description:
Rename the Development Environment.
Arguments:
Argument | Description | Required |
---|---|---|
DEV_ENV_NAME |
Name of the Development Environment to rename. | |
NEW_DEV_ENV_NAME |
The new name. |
dem run [DEV_ENV_NAME] TASK_NAME
Description:
Run the task of the Development Environment. The Dev Env must be installed.
If the Dev Env is not specified, the default Dev Env will be used. If the default Dev Env is not set, an error message will be printed.
Arguments:
Argument | Description | Required |
---|---|---|
DEV_ENV_NAME |
Name of the Development Environment to run the task in. If not set, the default Dev Env will be used. | |
TASK_NAME |
The name of the task to run. |
dem set-default DEV_ENV_NAME
Description:
Set the selected Development Environment as the default one.
The default Development Environment is used when the dem run
command is run without specifying a
Development Environment.
Arguments:
Argument | Description | Required |
---|---|---|
DEV_ENV_NAME |
Name of the Development Environment to set as default. |
dem uninstall DEV_ENV_NAME
Description:
Uninstall the selected Development Environment.
Sets the installed flag to False. DEM checks whether a tool image is required or not by any of the remaining installed local Development Environments. In case the tool image is not required anymore, the DEM tries to delete it.
Arguments:
Argument | Description | Required |
---|---|---|
DEV_ENV_NAME |
Name of the Development Environment to uninstall. |
Catalog management
dem add-cat NAME URL
Description:
Add a new catalog.
You can name the catalog as you wish. The URL must point to an HTTP(S) server where the Catalog JSON file is available.
Arguments:
Argument | Description | Required |
---|---|---|
NAME |
Name of the catalog to add. | |
URL |
URL of the catalog file. |
dem del-cat NAME
Description:
Delete a catalog.
Arguments:
Argument | Description | Required |
---|---|---|
NAME |
Name of the catalog to delete. |
dem list-cat
Description:
List the available catalogs.
Registry management
dem add-reg NAME URL
Description:
Add a new registry.
The name of the registry is what you would normally use to pull an image. Examples:
Full image tag | Name |
---|---|
repository/image:tag |
repository |
192.168.1.1:5000/image:tag |
192.168.1.1:5000 |
The URL should point to the registry's API. For the Docker Hub https://registry.hub.docker.com, or it can be http://localhost:5000 for a self-hosted one.
Arguments:
Argument | Description | Required |
---|---|---|
NAME |
Name of the registry to add. | |
URL |
API URL of the registry. |
dem del-reg NAME
Description:
Delete a registry.
Arguments:
Argument | Description | Required |
---|---|---|
NAME |
Name of the registry to delete. |
dem list-reg
Description:
List the available registries.
Host management
dem add-host NAME ADDRESS
Description:
Add a new host to the configuration.
Arguments:
Argument | Description | Required |
---|---|---|
NAME |
Name of the host. | |
ADDRESS |
IP or hostname of the host. |
dem del-host NAME
Description:
Delete a host from the config file.
Arguments:
Argument | Description | Required |
---|---|---|
NAME |
Name of the host to delete. |
dem list-host
Description:
List the available hosts from the config file.