Skip to content

Latest commit

 

History

History
105 lines (75 loc) · 3.22 KB

DEV.md

File metadata and controls

105 lines (75 loc) · 3.22 KB

Basic development workflow

Creating an initial framework of your future service:

$ mkdir {service_name}
$ cd {service_name}
$ rebar create template=service name={service_name} description="Describe your service here."
$ ./run.me.first.sh

See also README.md.

Cloning and running a fresh repo:

$ git clone {url-to-the-repo}
$ cd {service_name}
$ make run

Changing code

$ make run
$ vim deps/{your_app}/src/{your_module}.erl

All changed modules will be automatically compiled and loaded into Erlang VM using sync. Note that before changing the code for real in deps directory, you should checkout a branch:

$ cd deps/{your_app}
$ git checkout master

It is needed because sometimes rebar leaves the deps repositories in detached state ("Not currently at any branch").

Creating appup files

$ cd deps/{your_app}
$ vim src/*.erl # meaning you change your code in some way
$ OLD_REV=`git rev-parse HEAD` # meaning your just know the current rev
$ git commit
$ genappup $OLD_REV

or

$ cd deps/{your_app}
$ git co -b {your-branch}
$ vim src/*.erl # meaning you change your code in some way
$ git commit
$ genappup master

After genappup is run there will be a new file src/{your_app}.appup.src. You should revise it, change manually if needed and commit. At compile time, this file will be automatically copied to ebin/{your_app}.app (Erlang/OTP releases require the appup file to be there).

Sometimes you will need the appup file for a third-party application. If the owners do not use Erlang/OTP releases, most likely there will not be an appup file in the repo. In this case, you can still run genappup against the foreign repo and move the generated {foreign_app}.appup.src file to your root project src directory. Your root src dir can look like this:

ebin/
deps/
src/
    {foreign_app1}.appup.src
    {foreign_app2}.appup.src
priv/

Those files, at compile time, will be placed to corresponding applications ebin directories.

See also genappup and Appup Cookbook.

Adding a new dependency

$ cd {project_root}
$ vim rebar.config # meaning you add a new app record to deps section
$ make update-lock apps={your_new_app}
$ git commit rebar.config rebar.config.lock

If you want to include a new application into a release as well, you should edit rel/reltool.config.in by adding the following line to the list of applications:

{app,your_new_app,[{mod_cond,app},{incl_cond,include}]},

And if you also want your applciation to be automatically started, change "rel" section:

{rel,"{{name}}","RELVSN",
    [kernel,sasl,stdlib,lager,corman,your_new_app]},

Checking how target system build (release) works:

$ make target

Checking how upgrade works:

$ git checkout {an_older_rev} # checking out a specific past git revision
$ make clean
$ make run-no-sync # no-sync as we do not want modules to be auto-loaded
$ git checkout master # checking out the current revision
$ make upgrade

See also:

Makefile targets