riichi/include/riichi.hrl

93 lines
2.8 KiB
Erlang
Raw Normal View History

2013-06-15 03:43:46 +00:00
-define(DRAGONS, [green, red, white]).
-define(WINDS, [east, south, west, north]).
-define(T_SIMPLES, [#tile{suit=S, value=V} || S <- [pin, man, sou], V <- lists:seq(2,8)]).
-define(T_TERMINALS, [#tile{suit=S, value=V} || S <- [pin, man, sou], V <- [1,9]]).
-define(T_DRAGONS, [#tile{suit=dragon, value=V} || V <- ?DRAGONS]).
-define(T_WINDS, [#tile{suit=wind, value=V} || V <- ?WINDS]).
-define(T_HONOURS, ?T_DRAGONS ++ ?T_WINDS).
-define(TILES, ?T_SIMPLES ++ ?T_TERMINALS ++ ?T_HONOURS).
2012-08-01 04:11:36 +00:00
%% @type wind() = east | south | west | north
2012-07-21 04:09:27 +00:00
-type wind() :: east | south | west | north.
2012-08-01 04:11:36 +00:00
%% @type dragon() = green | red | white
2012-07-21 04:09:27 +00:00
-type dragon() :: green | red | white.
2013-06-15 03:43:46 +00:00
%% @type suit() = wind | dragon | pin | man | sou
-type suit() :: wind | dragon | pin | man | sou.
2012-08-01 04:11:36 +00:00
%% @type tile() = {tile, Suit, Value, From}
2013-06-15 03:43:46 +00:00
%% Suit = suit()
2012-08-01 04:11:36 +00:00
%% Value = integer() | wind() | dragon()
%% From = draw | wind()
2012-07-21 04:09:27 +00:00
-record(tile, {
2013-06-15 03:43:46 +00:00
suit :: suit(),
2012-07-21 04:09:27 +00:00
value :: integer() | wind() | dragon(),
from=draw :: draw | wind()
}).
2012-07-21 04:09:27 +00:00
-type tile() :: #tile{}.
2012-08-01 04:11:36 +00:00
%% @type meld() = {meld, Type, Tiles}
%% Type = pair | chii | pon | kan
%% Tiels = [tile()]
2012-07-21 04:09:27 +00:00
-record(meld, {
type :: pair | chii | pon | kan,
tiles :: [tile()]
}).
2012-07-21 04:09:27 +00:00
-type meld() :: #meld{}.
2012-07-03 02:05:05 +00:00
2012-08-01 04:11:36 +00:00
%% @type hand() = {hand, Tiles, Melds}
%% Tiles = [tile()]
%% Melds = [meld()]
2012-07-21 04:09:27 +00:00
-record(hand, {
tiles=[] :: [tile()],
melds=[] :: [meld()]
2012-07-03 02:05:05 +00:00
}).
2012-07-21 04:09:27 +00:00
-type hand() :: #hand{}.
2012-08-01 04:11:36 +00:00
%% @type player() = {player, Name, Seat, Hand, Discards, Drawn}
%% Name = string()
%% Seat = wind()
%% Hand = hand()
%% Discards = [tile()]
%% Drawn = none | {tsumo | ron, tile()}
-record(player, {
name :: string(),
2013-06-15 03:43:46 +00:00
pid :: none | pid(),
seat :: wind(),
hand=#hand{} :: hand(),
discards=[] :: [tile()],
drawn=none :: none | {tsumo | ron, tile()}
}).
-type player() :: #player{}.
2012-08-01 04:11:36 +00:00
%% @type phase() = Phase
%% Phase = draw | discard
2013-06-15 03:43:46 +00:00
-type phase() :: start | draw | discard.
2012-08-01 04:11:36 +00:00
%% @type game() = {game, Rounds, Timeout, Round, Turn, Phase, Wall, Rinshan, Dora, Uradora, Players}
%% Rounds = integer()
%% Timeout = integer() | infinity
%% Round = wind()
%% Turn = wind()
%% Phase = phase()
%% Wall = [tile()]
%% Rinshan = [tile()]
%% Dora = [tile()]
%% Uradora = [tile()]
%% Players = [player()]
-record(game, {
rounds=2 :: integer(),
timeout=infinity :: integer() | infinity,
round=east :: wind(),
turn=east :: wind(),
2013-06-15 03:43:46 +00:00
phase=start :: phase(),
wall=[] :: [tile()],
rinshan=[] :: [tile()],
dora=[] :: [tile()],
uradora=[] :: [tile()],
players=[] :: [player()]
}).
-type game() :: #game{}.