You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

68 lines
2.6 KiB

10 years ago
10 years ago
10 years ago
  1. %% -*- erlang-indent-level: 4;indent-tabs-mode: nil -*-
  2. %% ex: ts=4 sw=4 et
  3. -module(rebar_prv_help).
  4. -behaviour(provider).
  5. -export([init/1,
  6. do/1,
  7. format_error/1]).
  8. -include("rebar.hrl").
  9. -define(PROVIDER, help).
  10. -define(DEPS, []).
  11. %% ===================================================================
  12. %% Public API
  13. %% ===================================================================
  14. -spec init(rebar_state:t()) -> {ok, rebar_state:t()}.
  15. init(State) ->
  16. State1 = rebar_state:add_provider(State, providers:create([{name, ?PROVIDER},
  17. {module, ?MODULE},
  18. {bare, false},
  19. {deps, ?DEPS},
  20. {example, "rebar help <task>"},
  21. {short_desc, "Display a list of tasks or help for a given task or subtask."},
  22. {desc, "Display a list of tasks or help for a given task or subtask."},
  23. {opts, [
  24. {help_task, undefined, undefined, string, "Task to print help for."}
  25. ]}])),
  26. {ok, State1}.
  27. -spec do(rebar_state:t()) -> {ok, rebar_state:t()} | {error, string()}.
  28. do(State) ->
  29. {Args, _} = rebar_state:command_parsed_args(State),
  30. case proplists:get_value(help_task, Args, undefined) of
  31. undefined ->
  32. help(State),
  33. {ok, State};
  34. Name ->
  35. Providers = rebar_state:providers(State),
  36. case providers:get_provider(list_to_atom(Name), Providers) of
  37. not_found ->
  38. {error, io_lib:format("Unknown task ~s", [Name])};
  39. Provider ->
  40. providers:help(Provider),
  41. {ok, State}
  42. end
  43. end.
  44. -spec format_error(any()) -> iolist().
  45. format_error(Reason) ->
  46. io_lib:format("~p", [Reason]).
  47. %%
  48. %% print help/usage string
  49. %%
  50. help(State) ->
  51. ?CONSOLE("Rebar is a tool for working with Erlang projects.~n~n", []),
  52. OptSpecList = rebar3:global_option_spec_list(),
  53. getopt:usage(OptSpecList, "rebar", "", []),
  54. ?CONSOLE("~nSeveral tasks are available:~n", []),
  55. providers:help(rebar_state:providers(State)),
  56. ?CONSOLE("~nRun 'rebar help <TASK>' for details.~n~n", []).