summaryrefslogtreecommitdiff
path: root/doc/plugins.md
diff options
context:
space:
mode:
Diffstat (limited to 'doc/plugins.md')
-rw-r--r--doc/plugins.md52
1 files changed, 32 insertions, 20 deletions
diff --git a/doc/plugins.md b/doc/plugins.md
index 11da168..572b41d 100644
--- a/doc/plugins.md
+++ b/doc/plugins.md
@@ -1,8 +1,5 @@
#### TODO ####
-- write a rebar3 template for plugin writing, make it easier on our poor souls
-- rework the tutorial to use the rebar3 template for plugins
-
# Plugins #
Rebar3's system is based on the concept of *[providers](https://github.com/tsloughter/providers)*. A provider has three callbacks:
@@ -24,14 +21,41 @@ This document contains the following elements:
## Using a Plugin ##
+To use the a plugin, add it to the rebar.config:
+
+```erlang
+{plugins, [
+ {plugin_name, ".*", {git, "git@host:user/name-of-plugin.git", {tag, "v1.0.0"}}}
+]}.
+```
+
+Then you can just call it directly:
+
+```
+→ rebar3 plugin_name
+===> Fetching plugin_name
+Cloning into '.tmp_dir539136867963'...
+===> Compiling plugin_name
+<PLUGIN OUTPUT>
+```
+
## Reference ##
+TODO
+
### Provider Interface ###
+TODO
+
### List of Possible Dependencies ###
+TODO
+
### Rebar State Manipulation ###
+TODO
+
+
## Tutorial ##
### First version ###
@@ -42,22 +66,10 @@ The first step is to create a new OTP Application that will contain the plugin:
→ git init
Initialized empty Git repository in /Users/ferd/code/self/rebar3-todo-plugin/.git/
- → mkdir src
- → touch src/provider_todo.erl src/provider_todo.app.src
-
-Let's edit the app file to make sure the description is fine:
-
-```erlang
-{application, provider_todo, [
- {description, "example rebar3 plubin"},
- {vsn, "0.1.0"},
- {registered, []},
- {applications, [kernel, stdlib]},
- {env, []}
-]}.
-```
+ → rebar3 new plugin provider_todo desc="example rebar3 plugin"
+ ...
-Open up the `provider_todo.erl` file and make sure you have the following skeleton in place:
+Open up the `src/provider_todo.erl` file and make sure you have the following skeleton in place:
```erlang
-module(provider_todo).
@@ -80,9 +92,9 @@ init(State) ->
{module, ?MODULE}, % The module implementation of the task
{bare, true}, % The task can be run by the user, always true
{deps, ?DEPS}, % The list of dependencies
- {example, "rebar $PLUGIN"}, % How to use the plugin
+ {example, "rebar provider_todo"}, % How to use the plugin
{opts, []} % list of options understood by the plugin
- {short_desc, ""},
+ {short_desc, "example rebar3 plugin"},
{desc, ""}
]),
{ok, rebar_state:add_provider(State, Provider)}.