summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authornsensfel <SpamShield0@noot-noot.org>2019-01-16 19:24:26 +0100
committernsensfel <SpamShield0@noot-noot.org>2019-01-16 19:24:26 +0100
commit1f8d07d0ce1573c995f4d554ce0c78218398d1ab (patch)
treef3b78b09c22702b771daf68f22e95d582dabfb65 /src/shared
parent20e83fdb119668f45fa6e24025bb07e10c581593 (diff)
...
Diffstat (limited to 'src/shared')
-rw-r--r--src/shared/struct/shr_battle_summary.erl102
1 files changed, 76 insertions, 26 deletions
diff --git a/src/shared/struct/shr_battle_summary.erl b/src/shared/struct/shr_battle_summary.erl
index 245ee87..fa1a458 100644
--- a/src/shared/struct/shr_battle_summary.erl
+++ b/src/shared/struct/shr_battle_summary.erl
@@ -12,9 +12,11 @@
{
id :: ataxia_id:type(),
mode :: mode(),
+ category :: category(),
name :: binary(),
- last_edit :: binary(),
- is_players_turn :: boolean()
+ deadline :: ataxia_time:type(),
+ is_players_turn :: boolean(),
+ is_pending :: boolean()
}
).
@@ -39,8 +41,11 @@
[
get_id/1,
get_name/1,
- get_last_edit/1,
- is_players_turn/1
+ get_deadline/1,
+ get_mode/1,
+ get_category/1,
+ is_players_turn/1,
+ is_pending/1
]
).
-export
@@ -48,8 +53,11 @@
[
set_id/2,
set_name/2,
- set_last_edit/2,
- set_is_players_turn/2
+ set_deadline/2,
+ set_mode/2,
+ set_category/2,
+ set_is_players_turn/2,
+ set_is_pending/2
]
).
@@ -58,8 +66,11 @@
[
get_id_field/0,
get_name_field/0,
- get_last_edit_field/0,
- get_is_players_turn_field/0
+ get_deadline_field/0,
+ get_mode_field/0,
+ get_category_field/0,
+ get_is_players_turn_field/0,
+ get_is_pending_field/0
]
).
@@ -78,67 +89,103 @@
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%% EXPORTED FUNCTIONS %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
--spec new (binary(), binary(), binary(), boolean()) -> type().
-new (ID, Name, Time, IsPlayersTurn) ->
+-spec new (ataxia_id:type(), binary(), mode(), category()) -> type().
+new (ID, Name, Mode, Category) ->
#battle_summary
{
id = ID,
name = Name,
- mode = none,
- last_edit = Time,
- is_players_turn = IsPlayersTurn
+ mode = Mode,
+ category = Category,
+ deadline = ataxia_time:never(),
+ is_players_turn = false,
+ is_pending = false
}.
-spec none () -> type().
none () ->
#battle_summary
{
- id = <<"">>,
+ id = ataxia_id:null(),
name = <<"">>,
mode = none,
- last_edit = <<"">>,
- is_players_turn = false
+ category = event,
+ deadline = ataxia_time:never(),
+ is_players_turn = false,
+ is_pending = false
}.
%%%% Accessors
--spec get_id (type()) -> binary().
+-spec get_id (type()) -> ataxia_id:type().
get_id (BattleSummary) -> BattleSummary#battle_summary.id.
-spec get_name (type()) -> binary().
get_name (BattleSummary) -> BattleSummary#battle_summary.name.
--spec get_last_edit (type()) -> binary().
-get_last_edit (BattleSummary) -> BattleSummary#battle_summary.last_edit.
+-spec get_deadline (type()) -> ataxia_time:type().
+get_deadline (BattleSummary) -> BattleSummary#battle_summary.deadline.
+
+-spec get_mode (type()) -> mode().
+get_mode (BattleSummary) -> BattleSummary#battle_summary.mode.
+
+-spec get_category (type()) -> category().
+get_category (BattleSummary) -> BattleSummary#battle_summary.category.
-spec is_players_turn (type()) -> boolean().
is_players_turn (BattleSummary) -> BattleSummary#battle_summary.is_players_turn.
--spec set_id (binary(), type()) -> type().
+-spec is_pending (type()) -> boolean().
+is_pending (BattleSummary) -> BattleSummary#battle_summary.is_pending.
+
+
+-spec set_id (ataxia_id:type(), type()) -> type().
set_id (Val, BattleSummary) -> BattleSummary#battle_summary{ id = Val }.
-spec set_name (binary(), type()) -> type().
set_name (Val, BattleSummary) -> BattleSummary#battle_summary{ name = Val }.
--spec set_last_edit (binary(), type()) -> type().
-set_last_edit (Val, BattleSummary) ->
- BattleSummary#battle_summary{ last_edit = Val }.
+-spec set_mode (mode(), type()) -> type().
+set_mode (Val, BattleSummary) -> BattleSummary#battle_summary{ mode = Val }.
+
+-spec set_category (category(), type()) -> type().
+set_category (Val, BattleSummary) ->
+ BattleSummary#battle_summary{ category = Val }.
+
+-spec set_deadline (ataxia_time:type(), type()) -> type().
+set_deadline (Val, BattleSummary) ->
+ BattleSummary#battle_summary{ deadline = Val }.
-spec set_is_players_turn (boolean(), type()) -> type().
set_is_players_turn (Val, BattleSummary) ->
BattleSummary#battle_summary{ is_players_turn = Val }.
+-spec set_is_pending (boolean(), type()) -> type().
+set_is_pending (Val, BattleSummary) ->
+ BattleSummary#battle_summary{ is_pending = Val }.
+
+
-spec get_id_field () -> non_neg_integer().
get_id_field () -> #battle_summary.id.
-spec get_name_field () -> non_neg_integer().
get_name_field () -> #battle_summary.name.
--spec get_last_edit_field () -> non_neg_integer().
-get_last_edit_field () -> #battle_summary.last_edit.
+-spec get_mode_field () -> non_neg_integer().
+get_mode_field () -> #battle_summary.mode.
+
+-spec get_category_field () -> non_neg_integer().
+get_category_field () -> #battle_summary.category.
+
+-spec get_deadline_field () -> non_neg_integer().
+get_deadline_field () -> #battle_summary.deadline.
-spec get_is_players_turn_field () -> non_neg_integer().
get_is_players_turn_field () -> #battle_summary.is_players_turn.
+-spec get_is_pending_field () -> non_neg_integer().
+get_is_pending_field () -> #battle_summary.is_pending.
+
+
-spec encode ({non_neg_integer(), type()}) -> {list(any())}.
encode ({IX, BattleSummary}) ->
{
@@ -146,7 +193,10 @@ encode ({IX, BattleSummary}) ->
{<<"ix">>, IX},
{<<"id">>, BattleSummary#battle_summary.id},
{<<"nme">>, BattleSummary#battle_summary.name},
- {<<"ldt">>, BattleSummary#battle_summary.last_edit},
+ {
+ <<"dln">>,
+ ataxia_time:to_string(BattleSummary#battle_summary.deadline)
+ },
{<<"ipt">>, BattleSummary#battle_summary.is_players_turn}
]
}.