dmenv: the stupid virtualenv manager

Basic usage

dmenv only needs one config file: the .dmenv.toml.

The config must contain a default config, like this:

[env.default] python = /path/to/python

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

Then, make sure to have setup.py file looking 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 then anyone can run dmenv install to install all the deps and get exactly the same versions you got when you ran dmenv freeze. Hooray reproducible builds!

As a convenience, you can use:

Using an other python version

To use a different Python, version add a new section in .dmenv with the name and the path to the binary, 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?

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?