Skip to main content

Manager for Containerized Development Environments

Project description

DEM logo

Development Environment Manager
for
Embedded Development

Manage your isolated Development Environments with ease


GitHub tag (with filter) GitHub issues Discord


:star2: Join our Community on Discord :star2:


Overview

DocumentationTutorialContribution GuideSupport

DEM is a command-line tool that provides an easy, reproducible, and scalable way to set up multi-container-based Development Environments (DevEnvs for short) for software development.

DEM is currently in alpha state, so expect major changes in the future!

Contributors and early adopters are welcome!

Key features

  • Create scalable, reliable, and reproducible containerized Development Environments where each tool is isolated in its own container.
  • Install preconfigured Development Environments from catalogs.
  • Ensure that everyone on your team works with the same toolset.

How is DEM Different?

Unlike other container-based development environments that pack all tools into a single image requiring users to enter the container via an interactive shell, DEM creates a separate container for each tool. This allows you to work on your host system with your usual setup while the development-specific tools are isolated in containers.

Prerequisites

Linux and Windows are supported.

:information_source: macOS is not yet officially supported. However, if all prerequisites are met, DEM should work on macOS as well.

DEM depends on Python and Docker. Ensure you have the following versions:

  • Python 3.10+
  • Docker Engine 24.0+

Installation

First, install Python and Docker if you haven't already:

Make sure to include pip during Python installation.

Install DEM from the PyPI repository using:

pip install axem-dem
  • The package name is 'axem-dem', but the command is dem.
  • Ensure the Docker daemon is running before using DEM.

Enable Autocompletion

Enable autocompletion for PowerShell, Bash, and Zsh shells:

dem --install-completion

If the command doesn't work, specify your shell type as an input parameter (powershell, bash, or zsh).

Note for Zsh users: compinit must be called from your .zshrc.

Quick start

We got you covered in all scenarios!

I'd like to start with a template...

DEM comes with a few templates available from the axem catalog. List them with:

dem list --cat axem

Clone the selected template:

dem clone DEV_ENV_NAME

Replace DEV_ENV_NAME with the name of the Development Environment you want to clone.

I'd like to work on a project already configured with DEM...

Enter the project's root directory and initialize the DevEnv:

dem init

I'd like to use a DevEnv someone shared with me...

Import a DevEnv descriptor JSON:

dem import PATH_TO_DEV_ENV

where PATH_TO_DEV_ENV is the path to the JSON file.

I'd like to create my own DevEnv from scratch...

Create a new DevEnv:

dem create DEV_ENV_NAME

Customize your DevEnv:

  • Add or remove tools.
  • Change the tool image for a given tool.

You can edit the DevEnv with:

dem modify DEV_ENV_NAME

Finally, if you are ready to use the Development Environment, install it with:

dem install DEV_ENV_NAME

For more detailed instructions please refer to the Documentation

The Concept in a Nutshell

A Development Environment (DevEnv) is a set of software tools used for a specific development project (e.g., build system, debugger, test framework).

The idea is to pack the tools separately into container images, which are then can be stored in registries.

Each DevEnv has a descriptor, like a blueprint, indicating which tools are required.

DevEnv descriptor

Sample descriptors can be stored in the Development Environment Catalogs. You can browse these catalogs and download a copy of the Development Environment descriptor to your local catalog.

Catalogs

A DevEnv can be installed from your local catalog.

DevEnv installation

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

axem_dem-0.8.0.tar.gz (39.6 kB view details)

Uploaded Source

Built Distribution

axem_dem-0.8.0-py3-none-any.whl (57.1 kB view details)

Uploaded Python 3

File details

Details for the file axem_dem-0.8.0.tar.gz.

File metadata

  • Download URL: axem_dem-0.8.0.tar.gz
  • Upload date:
  • Size: 39.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.4 CPython/3.10.12 Linux/6.5.0-1025-azure

File hashes

Hashes for axem_dem-0.8.0.tar.gz
Algorithm Hash digest
SHA256 367d82c4dbe8ccace4e9fb45191f48da49ff95b3026f53f5293b53fa07dad0fd
MD5 7f695e2e6bd9f72e8640ebca83ef4d3c
BLAKE2b-256 e607a221cb7c5921fd22c32163f36b29ff548e63e6d37e5f2f16dd4312f373a2

See more details on using hashes here.

File details

Details for the file axem_dem-0.8.0-py3-none-any.whl.

File metadata

  • Download URL: axem_dem-0.8.0-py3-none-any.whl
  • Upload date:
  • Size: 57.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.4 CPython/3.10.12 Linux/6.5.0-1025-azure

File hashes

Hashes for axem_dem-0.8.0-py3-none-any.whl
Algorithm Hash digest
SHA256 6d2abc5042f48b859511538a795a693bb44e04add808bb1e5dbaebf8ea8abc37
MD5 66001c6e513092724ee86f1cedb6a17e
BLAKE2b-256 9c43ca143b06f3c60f1a51e8aa7f00f7d32d889cccf6cc710eae2853c4ebe801

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page