From 884d298291e64fad99f096ee82018b568e0985f2 Mon Sep 17 00:00:00 2001 From: Tristan Sloughter Date: Tue, 16 Sep 2014 19:36:04 -0500 Subject: update templating --- src/rebar.erl | 16 ++++++---------- src/rebar_templater.erl | 27 ++++++++++++++------------- 2 files changed, 20 insertions(+), 23 deletions(-) (limited to 'src') diff --git a/src/rebar.erl b/src/rebar.erl index 3560772..8ad61cc 100644 --- a/src/rebar.erl +++ b/src/rebar.erl @@ -156,12 +156,8 @@ init_config({Options, _NonOptArgs}) -> init_config1(BaseConfig) -> %% Determine the location of the rebar executable; important for pulling %% resources out of the escript - %ScriptName = filename:absname(escript:script_name()), - %BaseConfig1 = rebar_state:set(BaseConfig, escript, ScriptName), - %?DEBUG("Rebar location: ~p\n", [ScriptName]), - %% Note the top-level directory for reference - AbsCwd = filename:absname(rebar_utils:get_cwd()), - rebar_state:set(BaseConfig, base_dir, AbsCwd). + ScriptName = filename:absname(escript:script_name()), + rebar_state:set(BaseConfig, escript, ScriptName). run_aux(BaseConfig, Commands) -> %% Make sure crypto is running @@ -176,13 +172,13 @@ run_aux(BaseConfig, Commands) -> [Command | Args] = Commands, CommandAtom = list_to_atom(Command), - %BaseConfig1 = init_config1(BaseConfig), + BaseConfig1 = init_config1(BaseConfig), %% Process each command, resetting any state between each one - BaseConfig1 = rebar_state:set(BaseConfig, base_dir, filename:absname(rebar_state:dir(BaseConfig))), + BaseConfig2 = rebar_state:set(BaseConfig1, base_dir, filename:absname(rebar_state:dir(BaseConfig1))), {ok, Providers} = application:get_env(rebar, providers), - BaseConfig2 = rebar_state:create_logic_providers(Providers, BaseConfig1), - rebar_core:process_command(rebar_state:command_args(BaseConfig2, Args), CommandAtom), + BaseConfig3 = rebar_state:create_logic_providers(Providers, BaseConfig2), + rebar_core:process_command(rebar_state:command_args(BaseConfig3, Args), CommandAtom), ok. %% diff --git a/src/rebar_templater.erl b/src/rebar_templater.erl index a71bae2..c035ec3 100644 --- a/src/rebar_templater.erl +++ b/src/rebar_templater.erl @@ -43,11 +43,11 @@ %% =================================================================== new(app, DirName, State) -> - create1(State, DirName, "otpapp"); + create1(State, DirName, "otp_app"); new(lib, DirName, State) -> - create1(State, DirName, "otplib"); + create1(State, DirName, "otp_lib"); new(rel, DirName, State) -> - create1(State, DirName, "otpapp"). + create1(State, DirName, "otp_rel"). list_templates(State) -> {AvailTemplates, Files} = find_templates(State), @@ -113,29 +113,30 @@ create1(State, AppDir, TemplateId) -> %% Load the template definition as is and get the list of variables the %% template requires. + Context0 = dict:from_list([{appid, AppDir}]), TemplateTerms = consult(load_file(Files, Type, Template)), case lists:keyfind(variables, 1, TemplateTerms) of {variables, Vars} -> - case parse_vars(Vars, dict:new()) of + case parse_vars(Vars, Context0) of {error, Entry} -> - Context0 = undefined, + Context1 = undefined, ?ABORT("Failed while processing variables from template ~p." "Variable definitions must follow form of " "[{atom(), term()}]. Failed at: ~p\n", [TemplateId, Entry]); - Context0 -> + Context1 -> ok end; false -> ?WARN("No variables section found in template ~p; " "using empty context.\n", [TemplateId]), - Context0 = dict:new() + Context1 = Context0 end, %% Load variables from disk file, if provided - Context1 = case rebar_state:get(State, template_vars, undefined) of + Context2 = case rebar_state:get(State, template_vars, undefined) of undefined -> - Context0; + Context1; File -> case consult(load_file([], file, File)) of {error, Reason} -> @@ -144,18 +145,18 @@ create1(State, AppDir, TemplateId) -> Terms -> %% TODO: Cleanup/merge with similar code in rebar_reltool M = fun(_Key, _Base, Override) -> Override end, - dict:merge(M, Context0, dict:from_list(Terms)) + dict:merge(M, Context1, dict:from_list(Terms)) end end, %% For each variable, see if it's defined in global vars -- if it is, %% prefer that value over the defaults - Context2 = update_vars(State, dict:fetch_keys(Context1), Context1), - ?DEBUG("Template ~p context: ~p\n", [TemplateId, dict:to_list(Context1)]), + Context3 = update_vars(State, dict:fetch_keys(Context2), Context1), + ?DEBUG("Template ~p context: ~p\n", [TemplateId, dict:to_list(Context2)]), %% Handle variables that possibly include other variables in their %% definition - Context = resolve_variables(dict:to_list(Context2), Context2), + Context = resolve_variables(dict:to_list(Context3), Context3), ?DEBUG("Resolved Template ~p context: ~p\n", [TemplateId, dict:to_list(Context)]), -- cgit v1.1