A version manager for all binaries.
NOTICE: This is a proof of concept and currently has no automated tests—extremely unstable. It is not recommended to use it yet as there will likely be many breaking changes.
bvm use deno path
).bvm
via cargo—cargo install bvm
.C:\Users\<user-name>\AppData\Local\bvm\bvm\shims
~/.local/share/bvm/shims
jsonc
{
"binaries": [
"https://bvm.land/deno/1.3.1.json",
"https://bvm.land/dprint/0.9.1.json"
]
}
Or specify with checksums to ensure the remote files don't change:
jsonc
{
"binaries": [
"https://bvm.land/deno/1.3.1.json@8880bc307aba44b724b7d3ed56fa89165006bf1e5c85229441e3c209880b9534",
"https://bvm.land/dprint/0.9.1.json@7fba741001eee1f02ec85faf7b0fed0244f9f1e57502f9e421220c3e4f98f98b"
]
}
bvm install
bvm install
Downloads & installs the binaries in the current configuration file and associates them on the path with bvm.
bvm install [url]
Installs a binary at the specified manifest file.
```
bvm install https://bvm.land/deno/1.3.1.json
bvm install https://bvm.land/deno/1.3.1.json@8880bc307aba44b724b7d3ed56fa89165006bf1e5c85229441e3c209880b9534 ```
bvm use [binary-name or owner-name/binary-name] [version]
Uses the specified binary name and version globally.
The binary and version must have been previously installed.
```
bvm use deno 1.3.1 bvm use denoland/deno 1.3.1 bvm use name-stealer/deno 2.0.0 ```
bvm use [binary-name or owner-name/binary-name] path
Use the version of the binary that's installed on the path if it exists.
```
bvm use deno path ```
bvm resolve [binary name]
Resolves the executable path of the specified binary based on the current working directory.
This command is used by the created shell/batch files (shims) to tell how to resolve the file.
```
bvm resolve deno
```
bvm uninstall [binary-name or owner-name/binary-name] [version]
Uninstalls the specified binary version.
```
bvm uninstall deno 1.2.0 bvm uninstall denoland/deno 1.3.1 bvm uninstall name-stealer/deno 2.0.0 ```
bvm list
Displays the installed binaries.
Example output:
denoland/deno 1.2.0
denoland/deno 1.3.1
dprint/dprint 9.0.1
The website https://bvm.land is a redirect service. If you publish a bvm.json file as a GitHub release asset (not recommended yet, due to this being a proof of concept) then you can use https://bvm.land
to redirect to your release:
https://bvm.land/<owner>/<name>/<release-tag>.json
-> https://github.com/<owner>/<name>/releases/download/<release-tag>/bvm.json
https://bvm.land/<name>/<release-tag>.json
-> https://github.com/<name>/<name>/releases/download/<release-tag>/bvm.json
Example: https://bvm.land/dprint/0.9.1.json
At the moment, it looks like this (will add architecture specific stuff later):
json
{
"schemaVersion": 1,
"name": "deno",
"owner": "denoland",
"version": "1.3.1",
"windows": {
"url": "https://github.com/denoland/deno/releases/download/v1.3.1/deno-x86_64-pc-windows-msvc.zip",
"type": "zip",
"checksum": "6ba068e517a55dd33abd60e74c38aa61ef8f45a0774578761be0107fafc3758b",
"binaryPath": "deno.exe",
"postInstall": "# this is where you can run some commands if necessary to cause additional setup"
},
"linux": {
"url": "https://github.com/denoland/deno/releases/download/v1.3.1/deno-x86_64-unknown-linux-gnu.zip",
"type": "zip",
"checksum": "ef3a8740bdceab105808c91cfb918c883a23defb6719b9c511e2be30d5bfdc01",
"binaryPath": "deno"
},
"mac": {
"url": "https://github.com/denoland/deno/releases/download/v1.3.1/deno-x86_64-apple-darwin.zip",
"type": "zip",
"checksum": "b1bc5de79b71c3f33d0151486249d088f5f5604126812dc55b1dd21b28704d8a",
"binaryPath": "deno"
}
}
Supported types: zip
, exe
(will add more later)
Low effort:
bvm clear-url-cache
- Clear the url caches, but not the binary caches.bvm resolve
(ex. bvm resolve deno 1.3.1
)--force
on bvm install <url>
if already installed.jsonc
{
"binaries": [{
"manifest": "https://bvm.land/deno/1.3.1.json",
"alias": "deno-1.3.1"
}]
}
bvm init
to create a bare configuration file in the current directory.bvm lock
to update the configuration file urls with checksums.Medium effort:
jsonc
{
"binaries": [{
"manifest": "https://bvm.land/deno/1.3.1.json",
"version": "^1.3.0"
}]
}
deno2
)
bvm exec deno 1.2.0 -V
or perhaps at the shim level deno -V --bvm-use-version 1.2.0
... or maybe this should use bvm resolve
somehow.Large effort:
bvm install [binary name] [version]
or just bvm install [binary name]
.bvm upgrade <binary name>
- Upgrade to the latest version (requires a "binary list" to be set—not implemented)Probably unnecessary complexity:
bvm use <url>
- To use a specific version of a binary globally via a url.npm run <script-name>
? Or is that out of scope?~~ Yes. I think there should be another tool people can install with bvm that does this. This tool should be very simple. There should definitely be pre and post install scripts though.bvm use <binary name> <executable file path>
for using the executable at the specified file path.