32:e528c326cf10
Anton Shestakov <engored@ya.ru>, Mon, 03 Mar 2014 15:09:55 +0900
Make rps_nickserv a gen_server.

next change 33:654a2f3e9ccf
previous change 30:efdf4524dafd

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]).
-record(state, {players=[], choices=[]}).
% 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) when is_list(Players) ->
lists:foreach(fun(Player) -> Player ! start end, Players),
room(#state{players=Players});
room(#state{players=Players, choices=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(State=#state{choices=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(State#state{choices=[{Hand, Who}|Choices]});
false ->
io:format("~w picks ~w, not allowed.~n", [Who, Hand]),
room(State)
end
end.