24:19a7ba960f8e
Anton Shestakov <engored@ya.ru>, Sun, 02 Mar 2014 00:02:23 +0900
Tests.

next change 26:6b3a3b22ea78
previous change 22:8a7719ddce58

src/rps_room.erl

Permissions: -rw-r--r--

Other formats: Feeds:
-module(rps_room).
-import(rps3, [get_rules/0, winning_hand/1]).
-export([room/1]).
% winner for 3 players is:
% rock, rock, rock -> undefined
% rock, paper, scissors -> undefined
% rock, paper, paper -> undefined
% rock, rock, paper -> {paper, Who}
winner(Choices) when length(Choices) > 1 ->
PlayersByHand = lists:foldl(
fun({Hand, Who}, Acc) ->
dict:append(Hand, Who, Acc)
end, dict:new(), Choices),
WHand = winning_hand([Hand || {Hand, _} <- Choices]),
Players = if
WHand =:= undefined -> [];
WHand =/= undefined -> dict:fetch(WHand, PlayersByHand)
end,
case length(Players) of
1 -> {WHand, hd(Players)};
_ -> undefined
end.
room(Players) ->
lists:foreach(fun(Player) -> Player ! start end, Players),
room(Players, []).
room(Players, Choices) when length(Players) =:= length(Choices) ->
Winner = winner(Choices),
Msg = if
Winner =:= undefined ->
{draw, Choices};
true ->
{winner, Winner}
end,
counter ! Msg,
lists:foreach(fun(Player) -> Player ! Msg end, Players),
room(Players);
room(Players, Choices) ->
receive
{Hand, Who} ->
ObjectIsOk = lists:any(fun(X) -> X =:= Hand end, get_rules()),
ChoiceMade = lists:keymember(Who, 2, Choices),
case ObjectIsOk andalso not ChoiceMade of
true ->
room(Players, [{Hand, Who}|Choices]);
false ->
io:format("~w picks ~w, not allowed.~n", [Who, Hand]),
room(Players, Choices)
end
end.