dmenv: the stupid virtualenv manager

Basic usage

Start with a setup.py like this:

python setup( name="foo", version="0.1", install_requires=[ # Your deps here "bar", "baz >= 2.0", ], extras_require = { # Your dev deps here "dev": [ "pytest", ] }, entry_points={ "console_scripts": [ "foo = foo:main" ] }, )

Run dmenv freeze: it will

Now you can add requirements.lock to your git repo, and anyone can run dmenv install to install all the deps.

As a convenience, you can use:

Specifying the python interpreter

By default, dmenv runs python -m venv to create the virtualenv. This works if python point to a Python >= 3.3, but that may not be the case for instance on certain (non arch) Linux distros or macOS.

Fear not, you can specify the binary to use in a .dmenv.toml file, like this:

toml [env.default] python = "/usr/bin/python3" # on linux

dmenv can also support multiple versions. For instance, if you add a 3.8 section in the .dmenv.toml file, like this:

toml [env.3.8] python = "/path/to/python3.8"

Then you can use all the dmenv commands by prefixing them with dmenv --env 3.8.

Cool, no?

Note: do not put the .dmenv.toml under version control, you never know what people install where :)

FAQ

Q: How do I add dependencies to build the documentation?
A: Stick them in the dev section.

Q: What if I don't want to install the dev dependencies?
A: Don't use dmenv. Run pip install without [dev] extras.

Q: How do I upgrade a dependency?
A: Just run dmenv freeze again. If something breaks, either fix your code or use more precise version specifiers

Q: How do I depend on a git specific repo/branch?
A: Edit the requirements.lock by hand like this:

foo==0.1 https://gitlab.com/foo/bar@my-branch

Q: But that sucks and it will disappear when I re-run dmenv freeze!
A: Yes that sucks. Feel free to: * Open a pull request if you've forked an upstream project * Use a local pipy mirror and a little bit of CI to publish your sources there

Why?

Why Python3 only?

Why not use virtualenv?

But I don't want to maintain a setup.py!

Too bad. Don't use dmenv, then. poetry is cool.

Why Rust?