Project-scoped multi-environment workspace management for conda, with pixi compatibility
Project description
conda-workspaces
Project-scoped multi-environment workspaces and task runner for conda, with pixi manifest compatibility.
Define environments and tasks in your project manifest, compose environments from reusable features, and let conda handle the solving and installation. Works with existing pixi manifests -- no new package manager required.
Quick start
Create a conda.toml in your project root:
[workspace]
name = "my-project"
channels = ["conda-forge"]
platforms = ["linux-64", "osx-arm64", "win-64"]
[dependencies]
python = ">=3.10"
numpy = ">=1.24"
[feature.test.dependencies]
pytest = ">=8.0"
pytest-cov = ">=4.0"
[environments]
test = { features = ["test"] }
[tasks]
test = { cmd = "pytest tests/ -v", description = "Run the test suite" }
lint = "ruff check ."
[tasks.check]
depends-on = ["test", "lint"]
Install and manage your environments, then run tasks:
$ conda workspace install # solve + install + generate conda.lock
$ conda workspace envs # list defined environments
$ conda task run check # runs lint and test in dependency order
$ conda workspace shell -e test # spawn a shell with test env activated
$ conda workspace install --locked # reproducible install from conda.lock
Why?
Conda handles environments and packages. pixi introduced a great project model with multi-environment workspaces and a task runner, but it brings its own solver and environment management.
conda-workspaces reads pixi-compatible manifests and delegates solving and installation to conda's own infrastructure. You get workspace management and task running inside the conda CLI without switching tools.
What it does
- Reads
conda.toml,pixi.toml, andpyproject.tomlworkspace manifests - Multi-environment support with composable features
- Project-local environments in
.conda/envs/ - Lockfile generation (
conda.lock) in rattler-lock v6 format for reproducible installs - Per-platform dependency overrides via
[target.<platform>] - PyPI dependencies translated and resolved alongside conda packages via conda-pypi
- Activation scripts and environment variables per feature
- System requirements as virtual package constraints
- Per-workspace channel priority override
- Task dependencies with topological ordering (
depends-on) - Jinja2 templates in commands (
{{ conda.platform }}, conditionals) - Task arguments with defaults, input/output caching, and per-platform overrides
conda workspace/conda tasksubcommands (also available ascw/ctaliases)
Installation
conda install -c conda-forge conda-workspaces
CLI
conda-workspaces registers conda workspace and conda task subcommands,
and also provides cw and ct as shorter aliases.
Workspace commands
| Command | Description |
|---|---|
conda workspace init |
Initialize a new workspace manifest |
conda workspace install |
Create/update workspace environments |
conda workspace install --locked |
Install from lockfile (skip solving) |
conda workspace lock |
Generate/update conda.lock |
conda workspace list |
List packages in an environment |
conda workspace envs |
List defined environments |
conda workspace info [ENV] |
Show environment details |
conda workspace add SPECS... |
Add dependencies |
conda workspace remove SPECS... |
Remove dependencies |
conda workspace shell [ENV] |
Spawn a shell with an environment activated |
conda workspace activate [ENV] |
Print activation instructions |
conda workspace clean |
Remove installed environments |
Task commands
| Command | Description |
|---|---|
conda task run TASK |
Run a task (with dependency resolution) |
conda task list |
List available tasks |
conda task add NAME CMD |
Add a task to the manifest |
conda task remove NAME |
Remove a task from the manifest |
conda task export |
Export tasks to conda.toml format |
What it doesn't do
conda-workspaces is a workspace manager and task runner, not a package manager replacement. It does not bundle its own solver or bypass conda's installation machinery. If you want a fully integrated tool that handles everything including its own solver, see pixi.
Documentation
https://conda-incubator.github.io/conda-workspaces/
Demos
See demos/README.md for animated terminal recordings of workspace and task features.
Development
pixi install
pixi run test
pixi run lint
Acknowledgements
The workspace and task system in conda-workspaces is directly inspired by the work of the prefix.dev team on pixi. Their design of workspace manifests, features, environments, platform targeting, task dependencies, caching, and template variables provided the blueprint for this plugin.
License
BSD 3-Clause. See LICENSE.
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file conda_workspaces-0.4.0.tar.gz.
File metadata
- Download URL: conda_workspaces-0.4.0.tar.gz
- Upload date:
- Size: 25.8 MB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
7c86f27736e6b47725b8513d110a521bbc9cd403fefc085da357095efd85e28f
|
|
| MD5 |
1361c365014bfd7af61e51ba0e9bc765
|
|
| BLAKE2b-256 |
b32d4a2080c4c1b76adf2d89eae1b21e0c8a347734edac02dc14b621ad6a598b
|
Provenance
The following attestation bundles were made for conda_workspaces-0.4.0.tar.gz:
Publisher:
release.yml on conda-incubator/conda-workspaces
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
conda_workspaces-0.4.0.tar.gz -
Subject digest:
7c86f27736e6b47725b8513d110a521bbc9cd403fefc085da357095efd85e28f - Sigstore transparency entry: 1401861908
- Sigstore integration time:
-
Permalink:
conda-incubator/conda-workspaces@3ad5e5971cebbeceb82806e3883b604a305622d4 -
Branch / Tag:
refs/tags/0.4.0 - Owner: https://github.com/conda-incubator
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@3ad5e5971cebbeceb82806e3883b604a305622d4 -
Trigger Event:
release
-
Statement type:
File details
Details for the file conda_workspaces-0.4.0-py3-none-any.whl.
File metadata
- Download URL: conda_workspaces-0.4.0-py3-none-any.whl
- Upload date:
- Size: 104.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b7f2594f442ac56ed18beb47263de4fc5f7ef2e8d96b567c1ac71d4231ffcb4e
|
|
| MD5 |
d41dba8cc06e1ef157032e01e9ce57e9
|
|
| BLAKE2b-256 |
496d320b583eafa012a46ec3fab7dabc3429e215305346fafbbf63c3f9e9ba8e
|
Provenance
The following attestation bundles were made for conda_workspaces-0.4.0-py3-none-any.whl:
Publisher:
release.yml on conda-incubator/conda-workspaces
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
conda_workspaces-0.4.0-py3-none-any.whl -
Subject digest:
b7f2594f442ac56ed18beb47263de4fc5f7ef2e8d96b567c1ac71d4231ffcb4e - Sigstore transparency entry: 1401861977
- Sigstore integration time:
-
Permalink:
conda-incubator/conda-workspaces@3ad5e5971cebbeceb82806e3883b604a305622d4 -
Branch / Tag:
refs/tags/0.4.0 - Owner: https://github.com/conda-incubator
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@3ad5e5971cebbeceb82806e3883b604a305622d4 -
Trigger Event:
release
-
Statement type: