asdf/README.md

239 lines
13 KiB
Markdown
Raw Normal View History

2017-01-19 10:30:45 -07:00
# asdf [![Build Status](https://travis-ci.org/asdf-vm/asdf.svg?branch=master)](https://travis-ci.org/asdf-vm/asdf)
2014-12-18 12:08:02 -07:00
### _extendable version manager_
2014-09-29 09:51:09 -07:00
2016-03-15 21:22:07 -07:00
Supported languages include Ruby, Node.js, Elixir and more. Supporting a new language is as simple as [this plugin API](https://github.com/asdf-vm/asdf/blob/master/docs/creating-plugins.md).
2014-11-30 06:46:11 -07:00
2015-05-11 10:36:25 -07:00
## SETUP
2014-11-30 06:46:11 -07:00
2014-11-30 20:32:14 -07:00
Copy-paste the following into command line:
2014-11-30 06:46:11 -07:00
2015-05-11 10:33:05 -07:00
```bash
git clone https://github.com/asdf-vm/asdf.git ~/.asdf --branch v0.3.0
2015-05-11 10:33:05 -07:00
```
Depending on your OS, run the following
```bash
2015-05-10 09:51:33 -07:00
# For Ubuntu or other linux distros
echo -e '\n. $HOME/.asdf/asdf.sh' >> ~/.bashrc
echo -e '\n. $HOME/.asdf/completions/asdf.bash' >> ~/.bashrc
2015-05-10 09:51:33 -07:00
2016-09-12 14:01:45 -07:00
# OR for Mac OSX
echo -e '\n. $HOME/.asdf/asdf.sh' >> ~/.bash_profile
echo -e '\n. $HOME/.asdf/completions/asdf.bash' >> ~/.bash_profile
2014-11-30 06:46:11 -07:00
```
If you use zsh or any other shell, replace `.bashrc` with the config file for the respective shell.
2016-04-18 00:33:14 -07:00
For fish, you can use the following:
```
echo 'source ~/.asdf/asdf.fish' >> ~/.config/fish/config.fish
mkdir -p ~/.config/fish/completions; and cp ~/.asdf/completions/asdf.fish ~/.config/fish/completions
```
2016-10-08 12:00:03 -07:00
> For most plugins, it is good if you have installed the following packages OR their equivalent on your OS
> * **OS X**: Install these via homebrew `coreutils automake autoconf openssl libyaml readline libxslt libtool unixodbc`
> * **Ubuntu**: `automake autoconf libreadline-dev libncurses-dev libssl-dev libyaml-dev libxslt-dev libffi-dev libtool unixodbc-dev`
> * **Fedora**: `automake autoconf readline-devel ncurses-devel openssl-devel libyaml-devel libxslt-devel libffi-devel libtool unixODBC-devel`
2014-11-30 06:46:11 -07:00
2015-05-10 09:51:33 -07:00
**That's all ~! You are ready to use asdf**
2014-11-30 20:32:14 -07:00
2015-05-11 10:36:25 -07:00
-----------------------
2014-11-30 20:32:14 -07:00
2015-05-11 10:36:25 -07:00
## USAGE
### Manage plugins
2014-11-30 20:32:14 -07:00
2016-03-15 21:28:04 -07:00
Plugins are how asdf understands how to handle different packages. Below is a list of plugins for languages. There is a [super-simple API](https://github.com/asdf-vm/asdf/blob/master/docs/creating-plugins.md) for supporting more languages.
2016-06-12 01:10:59 -07:00
| Language | Repository | CI Status
|-----------|-------------|----------
| Clojure | [vic/asdf-clojure](https://github.com/vic/asdf-clojure) | [![Build Status](https://travis-ci.org/vic/asdf-clojure.svg?branch=master)](https://travis-ci.org/vic/asdf-clojure)
2017-01-21 06:48:45 -07:00
| Crystal | [marciogm/asdf-crystal](https://github.com/marciogm/asdf-crystal) | [![Build Status](https://travis-ci.org/marciogm/asdf-crystal.svg?branch=master)](https://travis-ci.org/marciogm/asdf-crystal)
2016-12-15 01:04:27 -07:00
| D (DMD) | [sylph01/asdf-dmd](https://github.com/sylph01/asdf-dmd) | [![Build Status](https://travis-ci.org/sylph01/asdf-dmd.svg?branch=master)](https://travis-ci.org/sylph01/asdf-dmd)
2016-06-12 01:10:59 -07:00
| Elixir | [asdf-vm/asdf-elixir](https://github.com/asdf-vm/asdf-elixir) | [![Build Status](https://travis-ci.org/asdf-vm/asdf-elixir.svg?branch=master)](https://travis-ci.org/asdf-vm/asdf-elixir)
| Elm | [vic/asdf-elm](https://github.com/vic/asdf-elm) | [![Build Status](https://travis-ci.org/vic/asdf-elm.svg?branch=master)](https://travis-ci.org/vic/asdf-elm)
2016-06-12 01:10:59 -07:00
| Erlang | [asdf-vm/asdf-erlang](https://github.com/asdf-vm/asdf-erlang) | [![Build Status](https://travis-ci.org/asdf-vm/asdf-erlang.svg?branch=master)](https://travis-ci.org/asdf-vm/asdf-erlang)
| Go | [kennyp/asdf-golang](https://github.com/kennyp/asdf-golang) | [![Build Status](https://travis-ci.org/kennyp/asdf-golang.svg?branch=master)](https://travis-ci.org/kennyp/asdf-golang)
| Gradle | [rfrancis/asdf-gradle](https://github.com/rfrancis/asdf-gradle) | [![Build Status](https://travis-ci.org/rfrancis/asdf-gradle.svg?branch=master)](https://travis-ci.org/rfrancis/asdf-gradle)
| Haskell | [vic/asdf-haskell](https://github.com/vic/asdf-haskell) | [![Build Status](https://travis-ci.org/vic/asdf-haskell.svg?branch=master)](https://travis-ci.org/vic/asdf-haskell)
| Idris | [vic/asdf-idris](https://github.com/vic/asdf-idris) | [![Build Status](https://travis-ci.org/vic/asdf-idris.svg?branch=master)](https://travis-ci.org/vic/asdf-idris)
2016-11-26 11:57:49 -07:00
| Julia | [rkyleg/asdf-julia](https://github.com/rkyleg/asdf-julia) | [![Build Status](https://travis-ci.org/rkyleg/asdf-julia.svg?branch=master)](https://travis-ci.org/rkyleg/asdf-julia)
| LFE | [vic/asdf-lfe](https://github.com/vic/asdf-lfe) | [![Build Status](https://travis-ci.org/vic/asdf-lfe.svg?branch=master)](https://travis-ci.org/vic/asdf-lfe)
| Link (system tools) | [vic/asdf-link](https://github.com/vic/asdf-link) | [![Build Status](https://travis-ci.org/vic/asdf-link.svg?branch=master)](https://travis-ci.org/vic/asdf-link)
2016-06-12 01:10:59 -07:00
| Lua | [Stratus3D/asdf-lua](https://github.com/Stratus3D/asdf-lua) | [![Build Status](https://travis-ci.org/Stratus3D/asdf-lua.svg?branch=master)](https://travis-ci.org/Stratus3D/asdf-lua)
| LuaJIT | [smashedtoatoms/asdf-luaJIT](https://github.com/smashedtoatoms/asdf-luaJIT) | [![Build Status](https://travis-ci.org/smashedtoatoms/asdf-luaJIT.svg?branch=master)](https://travis-ci.org/smashedtoatoms/asdf-luaJIT)
2016-11-04 09:06:25 -07:00
| MongoDB | [sylph01/asdf-mongodb](https://github.com/sylph01/asdf-mongodb) | [![Build Status](https://travis-ci.org/sylph01/asdf-mongodb.svg?branch=master)](https://travis-ci.org/sylph01/asdf-mongodb)
| Nim | [rfrancis/asdf-nim](https://github.com/rfrancis/asdf-nim) | [![Build Status](https://travis-ci.org/rfrancis/asdf-nim.svg?branch=master)](https://travis-ci.org/rfrancis/asdf-nim)
2016-06-12 01:10:59 -07:00
| Node.js | [asdf-vm/asdf-nodejs](https://github.com/asdf-vm/asdf-nodejs) | [![Build Status](https://travis-ci.org/asdf-vm/asdf-nodejs.svg?branch=master)](https://travis-ci.org/asdf-vm/asdf-nodejs)
2017-06-06 00:17:47 -07:00
| OCaml | [vic/asdf-ocaml](https://github.com/vic/asdf-ocaml) | [![Build Status](https://travis-ci.org/vic/asdf-ocaml.svg?branch=master)](https://travis-ci.org/vic/asdf-ocaml)
| OpenResty | [smashedtoatoms/asdf-openresty](https://github.com/smashedtoatoms/asdf-openresty) | [![Build Status](https://travis-ci.org/smashedtoatoms/asdf-openresty.svg?branch=master)](https://travis-ci.org/smashedtoatoms/asdf-openresty)
| Packer | [gozer/asdf-packer](https://github.com/gozer/asdf-packer) | [![Build Status](https://travis-ci.org/gozer/asdf-packer.svg?branch=master)](https://travis-ci.org/gozer/asdf-packer)
2016-10-16 22:56:11 -07:00
| PHP | [odarriba/asdf-php](https://github.com/odarriba/asdf-php) | [![Build Status](https://travis-ci.org/odarriba/asdf-php.svg?branch=master)](https://travis-ci.org/odarriba/asdf-php)
2016-06-12 01:10:59 -07:00
| Postgres | [smashedtoatoms/asdf-postgres](https://github.com/smashedtoatoms/asdf-postgres) | [![Build Status](https://travis-ci.org/smashedtoatoms/asdf-postgres.svg?branch=master)](https://travis-ci.org/smashedtoatoms/asdf-postgres)
| Python | [tuvistavie/asdf-python](https://github.com/tuvistavie/asdf-python) | [![Build Status](https://travis-ci.org/tuvistavie/asdf-python.svg?branch=master)](https://travis-ci.org/tuvistavie/asdf-python)
2017-06-28 23:39:42 -07:00
| Racket | [vic/asdf-racket](https://github.com/vic/asdf-racket) | [![Build Status](https://travis-ci.org/vic/asdf-racket.svg?branch=master)](https://travis-ci.org/vic/asdf-racket)
2017-05-26 11:44:57 -07:00
| Rebar | [Stratus3D/asdf-rebar](https://github.com/Stratus3D/asdf-rebar) | [![Build Status](https://travis-ci.org/Stratus3D/asdf-rebar.svg?branch=master)](https://travis-ci.org/Stratus3D/asdf-rebar)
2016-06-12 01:10:59 -07:00
| Redis | [smashedtoatoms/asdf-redis](https://github.com/smashedtoatoms/asdf-redis) | [![Build Status](https://travis-ci.org/smashedtoatoms/asdf-redis.svg?branch=master)](https://travis-ci.org/smashedtoatoms/asdf-redis)
| Riak | [smashedtoatoms/asdf-riak](https://github.com/smashedtoatoms/asdf-riak) | [![Build Status](https://travis-ci.org/smashedtoatoms/asdf-riak.svg?branch=master)](https://travis-ci.org/smashedtoatoms/asdf-riak)
| Ruby | [asdf-vm/asdf-ruby](https://github.com/asdf-vm/asdf-ruby) | [![Build Status](https://travis-ci.org/asdf-vm/asdf-ruby.svg?branch=master)](https://travis-ci.org/asdf-vm/asdf-ruby)
2016-11-10 20:15:16 -07:00
| Rust | [code-lever/asdf-rust](https://github.com/code-lever/asdf-rust) | [![Build Status](https://travis-ci.org/code-lever/asdf-rust.svg?branch=master)](https://travis-ci.org/code-lever/asdf-rust)
2017-01-19 02:38:30 -07:00
| SBT | [lerencao/asdf-sbt](https://github.com/lerencao/asdf-sbt) | [![Build Status](https://travis-ci.org/lerencao/asdf-sbt.svg?branch=master)](https://travis-ci.org/lerencao/asdf-sbt)
2016-12-12 19:25:49 -07:00
| Scala | [mtatheonly/asdf-scala](https://github.com/mtatheonly/asdf-scala)| [![Build Status](https://travis-ci.org/mtatheonly/asdf-scala.svg?branch=master)](https://travis-ci.org/mtatheonly/asdf-scala)
| Swift | [fcrespo82/asdf-swift](https://github.com/fcrespo82/asdf-swift)| [![Build Status](https://travis-ci.org/fcrespo82/asdf-swift.svg?branch=master)](https://travis-ci.org/fcrespo82/asdf-swift)
2016-11-04 15:07:45 -07:00
| Terraform | [neerfri/asdf-terraform](https://github.com/neerfri/asdf-terraform) | [![Build Status](https://travis-ci.org/neerfri/asdf-terraform.svg?branch=master)](https://travis-ci.org/neerfri/asdf-terraform)
2014-11-30 06:46:11 -07:00
##### Add a plugin
2014-11-30 20:32:14 -07:00
```bash
asdf plugin-add <name> <git-url>
2016-03-15 21:22:07 -07:00
# asdf plugin-add erlang https://github.com/asdf-vm/asdf-erlang.git
2014-11-30 06:46:11 -07:00
```
2014-11-30 20:32:14 -07:00
##### List installed plugins
```bash
asdf plugin-list
# asdf plugin-list
```
##### Remove a plugin
2014-11-30 20:32:14 -07:00
```bash
asdf plugin-remove <name>
# asdf plugin-remove erlang
2014-11-30 06:46:11 -07:00
```
##### Update plugins
2014-11-30 06:46:11 -07:00
2014-11-30 20:32:14 -07:00
```bash
asdf plugin-update --all
2014-11-30 06:46:11 -07:00
```
If you want to update a specific package, just say so.
2014-11-30 20:32:14 -07:00
```bash
asdf plugin-update <name>
# asdf plugin-update erlang
2014-11-30 06:46:11 -07:00
```
### Manage versions
2014-11-30 06:46:11 -07:00
2014-11-30 20:32:14 -07:00
```bash
2015-05-11 10:33:05 -07:00
asdf install <name> <version>
# asdf install erlang 17.3
2014-11-30 06:46:11 -07:00
asdf current <name>
# asdf current erlang
# 17.3 (set by /Users/kim/.tool-versions)
2015-05-27 00:20:23 -07:00
2015-05-11 10:33:05 -07:00
asdf uninstall <name> <version>
# asdf uninstall erlang 17.3
2014-11-30 06:46:11 -07:00
```
*If a plugin supports downloading & compiling from source, you can also do this `ref:foo` (replace `foo` with the branch/tag/commit).* You'll have to use the same name when uninstalling too.
2015-05-11 10:36:25 -07:00
##### Lists installed versions
2014-11-30 06:46:11 -07:00
2014-11-30 20:32:14 -07:00
```bash
2015-05-11 10:33:05 -07:00
asdf list <name>
# asdf list erlang
2014-11-30 06:46:11 -07:00
```
2015-05-11 10:36:25 -07:00
##### List all available versions
2014-11-30 06:46:11 -07:00
2014-11-30 20:32:14 -07:00
```bash
2015-05-11 10:33:05 -07:00
asdf list-all <name>
# asdf list-all erlang
2014-11-30 06:46:11 -07:00
```
#### View current version
```bash
asdf current <name>
# asdf current erlang
# 17.3 (set by /Users/kim/.tool-versions)
```
#### Set current version
```bash
asdf global <name> <version>
asdf local <name> <version>
# asdf global elixir 1.2.4
```
`global` writes the version to `$HOME/.tool-versions`.
`local` writes the version to `$PWD/.tool-versions`, creating it if needed.
Alternatively, if you want to set a version only for the current shell session
or for executing just a command under a particular tool version, you
can set an environment variable like `ASDF_${TOOL}_VERSION`.
The following example runs tests on an Elixir project with version `1.4.0`.
The version format is the same supported by the `.tool-versions` file.
```shell
ASDF_ELIXIR_VERSION=1.4.0 mix test
```
## The `.tool-versions` file
2014-11-30 06:46:11 -07:00
Add a `.tool-versions` file to your project dir and versions of those tools will be used.
2015-05-21 21:34:41 -07:00
**Global defaults can be set in the file `$HOME/.tool-versions`**
2015-05-21 21:36:45 -07:00
This is what a `.tool-versions` file looks like:
2014-10-19 09:18:48 -07:00
```
2015-05-21 21:34:41 -07:00
ruby 2.2.0
nodejs 0.12.3
2014-10-19 09:18:48 -07:00
```
2015-05-21 21:34:41 -07:00
The versions can be in the following format:
* `0.12.3` - an actual version. Plugins that support downloading binaries, will download binaries.
* `ref:v1.0.2-a` or `ref:39cb398vb39` - tag/commit/branch to download from github and compile
* `path:/src/elixir` - a path to custom compiled version of a tool to use. For use by language developers and such.
* `system` - this keyword causes asdf to passthrough to the version of the tool on the system that is not managed by asdf.
To install all the tools defined in a `.tool-versions` file run the `asdf install` command with no other arguments in the directory containing the `.tool-versions` file.
You can view/modify the file by hand or use `asdf local` and `asdf global` to manage it.
## The `$HOME/.asdfrc` config file
Add a `.asdfrc` file to your home directory and asdf will use the settings specified in the file. The file should be formatted like this:
```
legacy_version_file = yes
```
**Settings**
* `legacy_version_file` - defaults to `no`. If set to yes it will cause plugins that support this feature to read the version files used by other version managers (e.g. `.ruby-version` in the case of Ruby's rbenv).
2017-07-23 00:24:40 -07:00
## Docker images
2017-07-23 01:50:16 -07:00
The [asdf-alpine](https://github.com/vic/asdf-alpine) and [asdf-ubuntu](https://github.com/vic/asdf-ubuntu) projects are an ongoing effort to provide Dockerized images of some asdf tools. You can use these docker images as base for your development servers, or for running your production apps.
2017-07-23 00:24:40 -07:00
2014-11-30 06:46:11 -07:00
## Credits
2014-10-19 09:18:48 -07:00
Me ([@HashNuke](https://github.com/HashNuke)), High-fever, cold, cough.
2014-10-19 09:18:48 -07:00
2016-03-15 21:59:50 -07:00
Copyright 2014 to the end of time ([MIT License](https://github.com/asdf-vm/asdf/blob/master/LICENSE))
2014-12-20 07:05:56 -07:00
2016-05-12 21:06:14 -07:00
### Maintainers
- [@HashNuke](https://github.com/HashNuke)
- [@tuvistavie](https://github.com/tuvistavie)
- [@Stratus3D](https://github.com/Stratus3D)
2017-01-19 11:00:23 -07:00
- [@vic](https://github.com/vic)
2016-05-12 21:06:14 -07:00
2014-12-20 07:05:56 -07:00
-------
2016-03-15 21:22:07 -07:00
Read the [ballad](https://github.com/asdf-vm/asdf/blob/master/ballad-of-asdf.md).