summaryrefslogtreecommitdiff
path: root/src/rebar_state.erl
diff options
context:
space:
mode:
authorSerge Aleynikov <saleyn@gmail.com>2015-12-19 12:15:03 -0500
committerSerge Aleynikov <saleyn@gmail.com>2016-02-08 19:22:52 -0500
commitce1dba7f437a5970f97076c3ec0d209b757f104e (patch)
tree77447fbc1623a3103066595fd3bba68bef955969 /src/rebar_state.erl
parent9cd788006956d384edd91868fca906d2b7be799b (diff)
Improve recursive display of dictionary values
Diffstat (limited to 'src/rebar_state.erl')
-rw-r--r--src/rebar_state.erl21
1 files changed, 14 insertions, 7 deletions
diff --git a/src/rebar_state.erl b/src/rebar_state.erl
index a97eca5..7d301ea 100644
--- a/src/rebar_state.erl
+++ b/src/rebar_state.erl
@@ -407,14 +407,21 @@ create_logic_providers(ProviderModules, State0) ->
throw({error, "Failed creating providers. Run with DEBUG=1 for stacktrace."})
end.
-to_list(#state_t{opts=O, code_paths=CP, default=D} = State) ->
- O1 = dict:to_list(O),
- CP1 = dict:to_list(CP),
- D1 = dict:to_list(D),
- State1 = State#state_t{opts=O1, code_paths=CP1, default=D1},
+to_list(#state_t{} = State) ->
Fields = record_info(fields, state_t),
- Values = tl(tuple_to_list(State1)),
- lists:zip(Fields, Values).
+ Values = tl(tuple_to_list(State)),
+ DictSz = tuple_size(dict:new()),
+ Fun = fun
+ F({K,V}) when is_list(V) ->
+ {K, [F(I) || I <- V]};
+ F(V) when is_tuple(V), element(1,V) =:= dict, tuple_size(V) =:= DictSz ->
+ [F(I) || I <- dict:to_list(V)];
+ F({K,V}) when is_tuple(V), element(1,V) =:= dict, tuple_size(V) =:= DictSz ->
+ {K, [F(I) || I <- dict:to_list(V)]};
+ F(Other) ->
+ Other
+ end,
+ lists:zip(Fields, [Fun(I) || I <- Values]).
%% ===================================================================
%% Internal functions