summaryrefslogtreecommitdiff |
diff options
Diffstat (limited to 'src/roster/struct')
-rw-r--r-- | src/roster/struct/rst_character.erl | 239 | ||||
-rw-r--r-- | src/roster/struct/rst_roster.erl | 75 |
2 files changed, 68 insertions, 246 deletions
diff --git a/src/roster/struct/rst_character.erl b/src/roster/struct/rst_character.erl deleted file mode 100644 index 61d7b7e..0000000 --- a/src/roster/struct/rst_character.erl +++ /dev/null @@ -1,239 +0,0 @@ --module(rst_character). - -%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% -%% TYPES %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% -%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% --record -( - rst_char, - { - name :: binary(), - portrait_id :: shr_portrait:id(), - weapon_ids :: {shr_weapon:id(), shr_weapon:id()}, - armor_id :: shr_armor:id(), - glyph_ids :: list(shr_glyph:id()), - glyph_board_id :: shr_glyph_board:id() - } -). - --opaque type() :: #rst_char{}. - --export_type([type/0]). -%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% -%% EXPORTS %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% -%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% -%%%% Accessors --export -( - [ - get_name/1, - get_portrait_id/1, - get_weapon_ids/1, - get_armor_id/1, - get_glyph_ids/1, - get_glyph_board_id/1, - - set_name/2, - set_portrait_id/2, - set_weapon_ids/2, - set_armor_id/2, - set_glyph_ids/2, - set_glyph_board_id/2, - - get_name_field/0, - get_portrait_id_field/0, - get_weapon_ids_field/0, - get_armor_id_field/0, - get_glyph_ids_field/0, - get_glyph_board_id_field/0 - ] -). - --export -( - [ - decode/1, - new/0 - ] -). - --export -( - [ - validate/2 - ] -). - -%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% -%% LOCAL FUNCTIONS %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% -%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% --spec validate_name (binary()) -> ok. -validate_name (_Name) -> - % TODO [SECURITY][LOW]: unimplemented - ok. - --spec validate_portrait_id (shr_inventory:type(), shr_portrait:id()) -> ok. -validate_portrait_id (_Inventory, _Portrait) -> - % TODO [SECURITY][LOW]: unimplemented - ok. - --spec validate_weapons - ( - shr_inventory:type(), - {shr_weapon:id(), shr_weapon:id()} - ) - -> ok. -validate_weapons (_Inventory, {_ActiveWeapon, _SecondaryWeapon}) -> - % TODO [SECURITY][LOW]: unimplemented - ok. - --spec validate_armor (shr_inventory:type(), shr_armor:id()) -> ok. -validate_armor (_Inventory, _Armor) -> - % TODO [SECURITY][LOW]: unimplemented - ok. - --spec validate_glyphs (shr_inventory:type(), list(shr_glyph:id())) -> ok. -validate_glyphs (_Inventory, _Glyphs) -> - % TODO [SECURITY][LOW]: unimplemented - ok. - --spec validate_glyph_board (shr_inventory:type(), shr_glyph_board:id()) -> ok. -validate_glyph_board (_Inventory, _GlyphBoard) -> - % TODO [SECURITY][LOW]: unimplemented - ok. - --spec validate_glyphs_on_board - ( - list(shr_glyph:id()), - shr_glyph_board:id() - ) - -> ok. -validate_glyphs_on_board (_Glyphs, _GlyphBoard) -> - % TODO [SECURITY][LOW]: unimplemented - ok. - -%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% -%% EXPORTED FUNCTIONS %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% -%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% -%%%% Accessors --spec get_name (type()) -> binary(). -get_name (Char) -> Char#rst_char.name. - --spec get_portrait_id (type()) -> shr_portrait:id(). -get_portrait_id (Char) -> Char#rst_char.portrait_id. - --spec get_weapon_ids (type()) -> {shr_weapon:id(), shr_weapon:id()}. -get_weapon_ids (Char) -> Char#rst_char.weapon_ids. - --spec get_armor_id (type()) -> shr_armor:id(). -get_armor_id (Char) -> Char#rst_char.armor_id. - --spec get_glyph_ids (type()) -> list(shr_glyph:id()). -get_glyph_ids (Char) -> Char#rst_char.glyph_ids. - --spec get_glyph_board_id (type()) -> shr_glyph_board:id(). -get_glyph_board_id (Char) -> Char#rst_char.glyph_board_id. - - --spec set_name (binary(), type()) -> type(). -set_name (Name, Char) -> - Char#rst_char - { - name = Name - }. - --spec set_portrait_id (shr_portrait:id(), type()) -> type(). -set_portrait_id (PortraitID, Char) -> - Char#rst_char - { - portrait_id = PortraitID - }. - --spec set_armor_id (shr_armor:id(), type()) -> type(). -set_armor_id (ArmorID, Char) -> - Char#rst_char - { - armor_id = ArmorID - }. - --spec set_weapon_ids ({shr_weapon:id(), shr_weapon:id()}, type()) -> type(). -set_weapon_ids (WeaponIDs, Char) -> - Char#rst_char - { - weapon_ids = WeaponIDs - }. - --spec set_glyph_ids (list(shr_glyph:id()), type()) -> type(). -set_glyph_ids (GlyphIDs, Char) -> - Char#rst_char - { - glyph_ids = GlyphIDs - }. - --spec set_glyph_board_id (shr_glyph_board:id(), type()) -> type(). -set_glyph_board_id (GlyphBoardID, Char) -> - Char#rst_char - { - glyph_board_id = GlyphBoardID - }. - --spec new () -> type(). -new () -> - UnarmedID = shr_weapon:get_id(shr_weapon:none()), - #rst_char - { - name = <<"Nameless">>, - portrait_id = shr_portrait:get_id(shr_portrait:default()), - weapon_ids = {UnarmedID, UnarmedID}, - armor_id = shr_armor:get_id(shr_armor:none()), - glyph_ids = [], - glyph_board_id = shr_glyph_board:get_id(shr_glyph_board:none()) - }. - --spec get_name_field () -> non_neg_integer(). -get_name_field () -> #rst_char.name. --spec get_portrait_id_field () -> non_neg_integer(). -get_portrait_id_field () -> #rst_char.portrait_id. --spec get_armor_id_field () -> non_neg_integer(). -get_armor_id_field () -> #rst_char.armor_id. --spec get_weapon_ids_field () -> non_neg_integer(). -get_weapon_ids_field () -> #rst_char.weapon_ids. --spec get_glyph_ids_field () -> non_neg_integer(). -get_glyph_ids_field () -> #rst_char.glyph_ids. --spec get_glyph_board_id_field () -> non_neg_integer(). -get_glyph_board_id_field () -> #rst_char.glyph_board_id. - --spec decode (map()) -> type(). -decode (JSONReqMap) -> - Name = maps:get(<<"nam">>, JSONReqMap), - Portrait = maps:get(<<"prt">>, JSONReqMap), - ActiveWeapon = maps:get(<<"awp">>, JSONReqMap), - SecondaryWeapon = maps:get(<<"swp">>, JSONReqMap), - Armor = maps:get(<<"ar">>, JSONReqMap), - GlyphsList = maps:get(<<"gls">>, JSONReqMap), - GlyphBoard = maps:get(<<"gb">>, JSONReqMap), - - #rst_char - { - name = Name, - portrait_id = Portrait, - weapon_ids = {ActiveWeapon, SecondaryWeapon}, - armor_id = Armor, - glyph_ids = GlyphsList, - glyph_board_id = GlyphBoard - }. - --spec validate (shr_inventory:type(), type()) -> ok. -validate (Inventory, Character) -> - Glyphs = Character#rst_char.glyph_ids, - GlyphBoard = Character#rst_char.glyph_board_id, - - validate_name(Character#rst_char.name), - validate_portrait_id(Inventory, Character#rst_char.portrait_id), - validate_weapons(Inventory, Character#rst_char.weapon_ids), - validate_armor(Inventory, Character#rst_char.armor_id), - validate_glyphs(Inventory, Glyphs), - validate_glyph_board(Inventory, GlyphBoard), - validate_glyphs_on_board(Glyphs, GlyphBoard), - - ok. diff --git a/src/roster/struct/rst_roster.erl b/src/roster/struct/rst_roster.erl index 90b2f98..ec28db0 100644 --- a/src/roster/struct/rst_roster.erl +++ b/src/roster/struct/rst_roster.erl @@ -10,7 +10,8 @@ roster, { owner :: binary(), - characters :: orddict:orddict(non_neg_integer(), rst_character:type()) + characters :: + orddict:orddict(non_neg_integer(), shr_character:unresolved()) } ). @@ -30,7 +31,13 @@ get_character/2, set_characters/2, - set_character/3 + set_character/3, + + ataxia_set_characters/2, + ataxia_set_characters/3, + + ataxia_set_character/3, + ataxia_set_character/4 ] ). @@ -63,24 +70,50 @@ get_owner (Roster) -> Roster#roster.owner. ( type() ) - -> orddict:orddict(non_neg_integer(), rst_character:type()). + -> orddict:orddict(non_neg_integer(), shr_character:unresolved()). get_characters (Roster) -> Roster#roster.characters. --spec get_character (non_neg_integer(), type()) -> rst_character:type(). +-spec get_character (non_neg_integer(), type()) -> shr_character:unresolved(). get_character (IX, Roster) -> orddict:fetch(IX, Roster#roster.characters). -spec set_characters ( - orddict:orddict(non_neg_integer(), rst_character:type()), + orddict:orddict(non_neg_integer(), shr_character:unresolved()), type() ) -> type(). set_characters (Characters, Roster) -> Roster#roster{ characters = Characters }. +-spec ataxia_set_characters + ( + orddict:orddict(non_neg_integer(), shr_character:unresolved()), + type() + ) + -> {type(), ataxic:basic()}. +ataxia_set_characters (Characters, Roster) -> + ataxia_set_characters(Characters, ataxic:constant(Characters), Roster). + +-spec ataxia_set_characters + ( + orddict:orddict(non_neg_integer(), shr_character:unresolved()), + ataxic:basic(), + type() + ) + -> {type(), ataxic:basic()}. +ataxia_set_characters (Characters, CharactersAtaxiaUpdate, Roster) -> + { + set_characters(Characters, Roster), + ataxic:update_field + ( + get_characters_field(), + CharactersAtaxiaUpdate + ) + }. + -spec set_character ( non_neg_integer(), - rst_character:type(), + shr_character:unresolved(), type() ) -> type(). @@ -90,12 +123,40 @@ set_character (IX, Character, Roster) -> characters = orddict:store(IX, Character, Roster#roster.characters) }. +-spec ataxia_set_character + ( + non_neg_integer(), + shr_character:unresolved(), + type() + ) + -> {type(), ataxic:basic()}. +ataxia_set_character (IX, Character, Roster) -> + ataxia_set_character(IX, Character, ataxic:constant(Character), Roster). + +-spec ataxia_set_character + ( + non_neg_integer(), + shr_character:unresolved(), + ataxic:basic(), + type() + ) + -> {type(), ataxic:basic()}. +ataxia_set_character (IX, Character, CharacterAtaxiaUpdate, Roster) -> + { + ataxia_set_character(IX, Character, Roster), + ataxic:update_field + ( + get_characters_field(), + ataxic_sugar:update_orddict_element(IX, CharacterAtaxiaUpdate) + ) + }. + -spec get_characters_field () -> non_neg_integer(). get_characters_field () -> #roster.characters. -spec new (binary()) -> type(). new (Owner) -> - NewChar = rst_character:new(), + NewChar = shr_character:new(), #roster { owner = Owner, |