50:3f31a4eec418
Anton Shestakov <engored@ya.ru>, Sat, 08 Mar 2014 23:36:15 +0900
Slightly more consistent naming of variables in rps_rules:parse/2.

next change 51:24ba56a575b1
previous change 41:f32e096c5433

src/rps_rules.erl

Permissions: -rw-r--r--

Other formats: Feeds:
-module(rps_rules).
-export([parse/1, winning_hand/2]).
-include("rps_rules.hrl").
add_unique(Elem, List) ->
case lists:member(Elem, List) of
true -> List;
false -> [Elem|List]
end.
parse(Text) ->
Tokens = lists:map(fun list_to_atom/1, string:tokens(Text, " ")),
parse(Tokens, #ruleinfo{}).
parse([H1,Label,H2|T], #ruleinfo{hands=Hands, beats=Beats, loses=Loses, why=Why}) ->
Acc = #ruleinfo{
hands=add_unique(H1, Hands),
beats=dict:append(H1, H2, Beats),
loses=dict:append(H2, H1, Loses),
why=dict:store({H1, H2}, Label, Why)},
parse([H2|T], Acc);
parse([_H2], Acc) ->
Acc.
% winner for 3 hands is:
% rock, rock, rock -> rock
% rock, paper, scissors -> undefined
% rock, paper, paper -> paper
% rock, rock, paper -> paper
winning_hand(Hands, State=#ruleinfo{}) ->
HSet = sets:from_list(Hands),
sets:fold(
fun(Hand, Acc) ->
Loses = dict:fetch(Hand, State#ruleinfo.loses),
case sets:is_disjoint(sets:from_list(Loses), HSet) of
false -> Acc;
true -> Hand
end
end, undefined, HSet).