dev
uses pkgx
and shellcode to automatically, install and activate the
packages you need for different projects as you navigate in your shell.
pkgx dev integrate
We support macOS & Linux, Bash & Zsh. PRs are very welcome for more shells.
Important
pkgx
is a required dependency.
brew install pkgxdev/made/pkgx || sh <(curl https://pkgx.sh)
Note
pkgx dev integrate
looks for and edits known shell.rc
files adding one
line:
eval "$(pkgx dev --shellcode)"
If you don’t trust us (good on you), then do a dry run first:
pkgx dev integrate --dry-run
If you like, preview the shellcode: pkgx dev --shellcode
.
$ cd my-project
my-project $ ls
package.json
my-project $ dev
+nodejs.org
# ^^ installs node to ~/.pkgx/nodejs.org/v22.12.0 if not already installed
my-project $ node --version
v22.12.0
$ which node
~/.pkgx/nodejs.org/v22.12.0/bin/node
$ cd ..
-nodejs.org
$ node
command not found: node
Tip
Modifying your shell.rc
can be… intimidating. If you just want to
temporarily try dev
out before you :wq
—we got you:
$ cd my-project
$ eval "$(pkgx dev)"
The devenv will only exist for the duration of your shell session.
- We look at the files you have and figure out the packages you need.
- Where possible we also determine the versions you need if such things can be determined by looking at configuration files.
We allow you to add YAML front matter to all files to specify versions more precisely:
# pkgx:
# openssl.org: 1.1.1n
[package]
name = "my cargo project"
# snip…
We allow more terse expressions including eg:
# pkgx: openssl.org@1.1.1n deno^2 npm
The major exception being json since it doesn’t support comments, in this case
we read a special pkgx
node:
{
"pkgx": {
"openssl.org": "1.1.1n",
"deno": "^2",
"npm": null
}
}
You can also make a pkgx.yaml
file.
You can add your own environment variables if you like:
# pkgx:
# openssl.org: 1.1.1n
# env:
# MY_VAR: my-value
Caution
The assignment of these variables are run through the shell, so you can do
stuff like $(pwd)
if you like. Obviously, be careful with that—we don’t
sanitize the input. We will accept a PR to escape this by default or something
∵ we agree this is maybe a bit insane.
Most editors if opened via the Terminal will inherit that Terminal’s
environment. We recommend Visual Studio Code, dev && code .
works great.
Warning
Unfortunately, this usually means you must open your editor via your terminal.
- uses: pkgxdev/dev@v1
Installs needed packages and sets up the environment the same as dev
does in
your terminal.
We use deno
, so either install that or—you know—type dev
.
Edit ./src/sniff.ts to add new dev types.