Collection of rebar templates for common uses:
- library - Generates skeleton of a library OTP application (no supervision tree). rebar.config and Makefile included.
- supapp - Generates skeleton of an OTP application w/supervision tree. rebar.config and Makefile included.
- gen_server - Creates a gen_server skeleton. Can be used instead of erlang-mode's gen_server skeleton.
- mod - Creates a simple Erlang module.
All source files start with editor commands to configure Emacs and vi for proper modes and indentation. Each source file is prefixed with author and copyright annotations as well.
These templates also require using my experimental branch of rebar, available at https://github.com/kevsmith/rebar/tree/experimental. My branch has tweaks to improve the runtime performance of templates and also supports configuring global settings from the filesystem.
To get these templates working w/experimental rebar:
- Clone, build, and install experimental rebar.
- Clone rebar-templates into $HOME/.rebar/templates
- Create $HOME/.rebar/global
- Edit $HOME/.rebar/global to include the line:
{template_vars, "/Path/To/Your/HomeDir/.rebar/template_vars"}.
- Create template vars with the following entries:
{author, "Your Name"}.
{author_email, "email@yourcompany.com"}.
{copyright_holder, "Your Company Name"}.
{copyright_year, "Current Year"}
Note: Replace example values for each entry with your own data :-)
Use rebar's standard syntax for invoking these templates, e.g. rebar create template=gen_server name=example
.
An example of the gen_server template's output can be viewed at https://gist.github.com/1211350. Notice the author
and copyright tags at the top of the file and the editor configuration comments.