Key features
-
Intelligent Editor for Erlang with code completion, syntax and error highlighting and code inspections
-
Code Navigation: project and file structure views, quick jumping between files, modules, functions and usages
-
Tools and frameworks integration: support for Eunit and Rebar
-
VCS Integrations: out-of-the-box support for Subversion, Git and Mercurial
- Cross-platform: works on Windows, Mac OS X and Linux
Installation
- Download the latest IntelliJ IDEA build and install it
- Setup the latest version of Erlang plugin from Configure > Plugins > Browse Repositories... > Erlang
- Restart IntelliJ IDEA.
- Done! You can import your existing Erlang project or create the new one.
Donations
If you would like to make a donation you can use PayPal.
How-tos
User Interface
Very nice guide about IntelliJ user interface.
Erlang SDK setup
You need to specify a directory that contains bin directory with erl and erlc executables inside.
Also that directory should contains releases dir inside.
Some predefined paths:
Also that directory should contains releases dir inside.
Some predefined paths:
- /usr/lib/erlang (Linux)
- /opt/local/lib/erlang (Mac Ports on Mac OS X)
- /usr/local/Cellar/erlang/R*/lib/erlang (Homebrew on Mac OS X)
Rebar integration
First of all, you need to provide the right path to the Rebar executable (Settings > Erlang External Tools).
data:image/s3,"s3://crabby-images/b8e21/b8e21899fb4c49eaf22645efdacb3c6fdc72524a" alt=""
Note for Mac OS X users. Please, check that the PATH for IntelliJ contains rebar executable.
For further information see Stackoverflow answer and
#189 issue.
Note for Windows users. Please checkout how to install rebar for Windows.
After you have set your rebar path up you can create a new Rebar run configuration(Run > Edit run configurations...),
use a little green button on the top left corner:
use a little green button on the top left corner:
data:image/s3,"s3://crabby-images/53299/53299c93b79f3f040836bbc7d50f0f8fc3485fc1" alt=""
Or execute an existing one (Run > Run...)
data:image/s3,"s3://crabby-images/3b465/3b465c0ecc006ae3d2fa2e65082759c0c839930c" alt=""
data:image/s3,"s3://crabby-images/3b465/3b465c0ecc006ae3d2fa2e65082759c0c839930c" alt=""
You may create run configuration for every command which Rebar supports, e.g.
compile
or clean
, etc.
data:image/s3,"s3://crabby-images/52fdf/52fdf3721f0affabdabda1593a54424c4a860258" alt=""
Skip dependencies checkbox adds
skip_deps=true
command for Rebar executable.
To run eunit tests with rebar you can either create a Rebar Eunit run configuration or use a right-click context menu item 'Run ...' or 'Create ...' having clicked on a module(s), a unit test or a generator function you want to run.
data:image/s3,"s3://crabby-images/7df8c/7df8c9613a448507aa85a809841700f5847f6303" alt=""
Rebar-based Eunit test runner:
data:image/s3,"s3://crabby-images/7b78c/7b78c88da747a1c53470e5de459c53aaaea971db" alt=""
To set rebar as a default build action make sure you have checked Compile project with rebar checkbox:
data:image/s3,"s3://crabby-images/cd393/cd3936264e25ac3b5fa4eb655b701b2319af0ecb" alt=""
After that your project will be built with 'rebar compile' command when you run Build > Make Project.
Compilation result:
data:image/s3,"s3://crabby-images/c44a5/c44a52f270eba5eb8d381fdc6e2da178ff696921" alt=""
Project structure
In version 0.5 we've added additonal per-module configuration parameters(see Project Structure > Modules).
There you can setup your modules' include paths and global parse transformations.
There you can setup your modules' include paths and global parse transformations.
data:image/s3,"s3://crabby-images/0ec2f/0ec2f0ab86001c0c52cda3e89fe46215093d7664" alt=""
Debugger
Version 0.5 introduces experimental Erlang debugger support.
In order to use debugger you need to have debug_info checkbox under Settings > Compiler > Erlang Compiler checked.
You also need an Erlang Application run configuration which will be used by debugger. Such configuration can be created by right-clicking on entry point function.
data:image/s3,"s3://crabby-images/4a06f/4a06f24dbabce057e70f848c8bb061c370fbcdb0" alt=""
Then you can use this configuration to debug your program:
data:image/s3,"s3://crabby-images/9d940/9d940f151ed6907cccf1e48b4b02547569115a74" alt=""
The debugger requires Erlang Port Mapper Daemon (epmd) to be running. If it's not up, a warning will be issued. To start the daemon run any Erlang node on your machine, for example with erl -sname foo -s init stop -noshell command.
In order to use debugger you need to have debug_info checkbox under Settings > Compiler > Erlang Compiler checked.
You also need an Erlang Application run configuration which will be used by debugger. Such configuration can be created by right-clicking on entry point function.
data:image/s3,"s3://crabby-images/4a06f/4a06f24dbabce057e70f848c8bb061c370fbcdb0" alt=""
Then you can use this configuration to debug your program:
data:image/s3,"s3://crabby-images/9d940/9d940f151ed6907cccf1e48b4b02547569115a74" alt=""
The debugger requires Erlang Port Mapper Daemon (epmd) to be running. If it's not up, a warning will be issued. To start the daemon run any Erlang node on your machine, for example with erl -sname foo -s init stop -noshell command.