9 Development & Deployment
9.1 Creating Projects with Rebar
In this section we'll be exploring how rebar can be used to manage LFE projects.
9.1.1 Dependencies
You're going to need to have an Erlang. We recommend using kerl, as deponstrated in the next section. However, you may already have one set up, in which case you're good for the next step.
9.1.2 Installation
$ curl -L -O https://raw.github.com/wiki/rebar/rebar/rebar
$ mv rebar /usr/local/bin/
$ chmod a+x /usr/local/bin/rebar
Make sure everything's working as expected:
$ rebar -h
This will give you output like the following:
Usage: rebar [-h] [-c] [-v <verbose>] [-V] [-f] [-D <defines>] [-j <jobs>]
[-C <config>] [-p] [var=value,...] <command,...>
-h, --help Show the program options
-c, --commands Show available commands
-v, --verbose Verbosity level (-v, -vv, -vvv, --verbose 3). Default: 0
-V, --version Show version information
-f, --force Force
-D Define compiler macro
-j, --jobs Num concurrent workers a command may use. Default: 3
-C, --config Rebar config file to use
-p, --profile Profile this run of rebar
var=value rebar global variables (e.g. force=1)
command Command to run (e.g. compile)
9.1.2 What is a Project?
The first question we should probably address is this: How are we defining a project?
An LFE project is a set of modules developed and distributed to accomplish a
particular goal. The project should have a rebar configuration file, a source
directory with .lfe
files in it, possibly an include directory, and (ideally)
unit tests in a test
directory.
9.1.2 Project Structure
Let's expand upon the project definition given above, focusing on the directory structure of a prototypical project and some of the files one might find in an LFE project.
├── ebin
│ └── libexample.app
├── src
│ └── libexample.lfe
├── Makefile
├── README.md
└── rebar.config
This is from a sample project whose purpose is to provide a library for use by other LFE (or Erlang!) projects. More on that below.
Rebar supports LFE files. All that it needs is the standard rebar.config
and
an .app
file in the ebin
directory. With these, Rebar will be able to
download the project dependencies and compile the *.lfe
files in src
to the
ebin
directory as *.beam
files.
9.1.3 Project Dependencies
Dependencies are handled very nicely with Rebar: just add a git repo in your
rebar.config
file like so:
{deps, [
{lfe, ".*", {git, "git://github.com/rvirding/lfe.git", "develop"}}
]}.
Any dependencies listed here will be downloaded with the rebar get-deps
command. Once downloaded, issuing the rebar compile
command will not only
compile your project's src/*
files into its ebin
directory, but will compile
all dependency project source code as well.