gameServer2/src/protocol/parser.rs
author Wuzzy <Wuzzy2@mail.ru>
Tue, 17 Jul 2018 19:44:29 +0200
changeset 13504 c41b16ac2e05
parent 13450 d79795acaa73
child 13486 1ee192f13456
permissions -rw-r--r--
Clarify the wording of a few checkFails messages
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
13431
6a818f9192f4 Implement parsing for rnd and add a little documentation
Marcin Mielniczuk <marmistrz.dev@zoho.eu>
parents: 13423
diff changeset
     1
/** The parsers for the chat and multiplayer protocol. The main parser is `message`.
6a818f9192f4 Implement parsing for rnd and add a little documentation
Marcin Mielniczuk <marmistrz.dev@zoho.eu>
parents: 13423
diff changeset
     2
 * # Protocol
6a818f9192f4 Implement parsing for rnd and add a little documentation
Marcin Mielniczuk <marmistrz.dev@zoho.eu>
parents: 13423
diff changeset
     3
 * All messages consist of `\n`-separated strings. The end of a message is
6a818f9192f4 Implement parsing for rnd and add a little documentation
Marcin Mielniczuk <marmistrz.dev@zoho.eu>
parents: 13423
diff changeset
     4
 * indicated by a double newline - `\n\n`.
6a818f9192f4 Implement parsing for rnd and add a little documentation
Marcin Mielniczuk <marmistrz.dev@zoho.eu>
parents: 13423
diff changeset
     5
 *
6a818f9192f4 Implement parsing for rnd and add a little documentation
Marcin Mielniczuk <marmistrz.dev@zoho.eu>
parents: 13423
diff changeset
     6
 * For example, a nullary command like PING will be actually sent as `PING\n\n`.
6a818f9192f4 Implement parsing for rnd and add a little documentation
Marcin Mielniczuk <marmistrz.dev@zoho.eu>
parents: 13423
diff changeset
     7
 * A unary command, such as `START_GAME nick` will be actually sent as `START_GAME\nnick\n\n`.
6a818f9192f4 Implement parsing for rnd and add a little documentation
Marcin Mielniczuk <marmistrz.dev@zoho.eu>
parents: 13423
diff changeset
     8
 */
6a818f9192f4 Implement parsing for rnd and add a little documentation
Marcin Mielniczuk <marmistrz.dev@zoho.eu>
parents: 13423
diff changeset
     9
12133
81df2e1f9ae9 Some parsing using nom
unc0rr
parents:
diff changeset
    10
use nom::*;
81df2e1f9ae9 Some parsing using nom
unc0rr
parents:
diff changeset
    11
13416
cdf69667593b partial room implementation
alfadur
parents: 13119
diff changeset
    12
use std::{
cdf69667593b partial room implementation
alfadur
parents: 13119
diff changeset
    13
    str, str::FromStr,
cdf69667593b partial room implementation
alfadur
parents: 13119
diff changeset
    14
    ops::Range
cdf69667593b partial room implementation
alfadur
parents: 13119
diff changeset
    15
};
cdf69667593b partial room implementation
alfadur
parents: 13119
diff changeset
    16
use super::{
cdf69667593b partial room implementation
alfadur
parents: 13119
diff changeset
    17
    messages::{HWProtocolMessage, HWProtocolMessage::*},
cdf69667593b partial room implementation
alfadur
parents: 13119
diff changeset
    18
    test::gen_proto_msg
cdf69667593b partial room implementation
alfadur
parents: 13119
diff changeset
    19
};
13419
81e0ed105f5d implementation of team related messages
alfadur
parents: 13416
diff changeset
    20
use server::coretypes::{
13450
d79795acaa73 Mostly implement voting
alfadur
parents: 13441
diff changeset
    21
    HedgehogInfo, TeamInfo, GameCfg, VoteType
13419
81e0ed105f5d implementation of team related messages
alfadur
parents: 13416
diff changeset
    22
};
13119
1e39b8749072 separated the server logic from all the async io mess.
alfadur
parents: 12142
diff changeset
    23
12133
81df2e1f9ae9 Some parsing using nom
unc0rr
parents:
diff changeset
    24
named!(end_of_message, tag!("\n\n"));
12142
4d7d41be1993 Start refactoring path from getting message from client to reacting to it
unc0rr
parents: 12140
diff changeset
    25
named!(str_line<&[u8],   &str>, map_res!(not_line_ending, str::from_utf8));
4d7d41be1993 Start refactoring path from getting message from client to reacting to it
unc0rr
parents: 12140
diff changeset
    26
named!(  a_line<&[u8], String>, map!(str_line, String::from));
4d7d41be1993 Start refactoring path from getting message from client to reacting to it
unc0rr
parents: 12140
diff changeset
    27
named!( u8_line<&[u8],     u8>, map_res!(str_line, FromStr::from_str));
4d7d41be1993 Start refactoring path from getting message from client to reacting to it
unc0rr
parents: 12140
diff changeset
    28
named!(u32_line<&[u8],    u32>, map_res!(str_line, FromStr::from_str));
13450
d79795acaa73 Mostly implement voting
alfadur
parents: 13441
diff changeset
    29
named!(yes_no_line<&[u8], bool>, alt!(
d79795acaa73 Mostly implement voting
alfadur
parents: 13441
diff changeset
    30
      do_parse!(tag_no_case!("YES") >> (true))
d79795acaa73 Mostly implement voting
alfadur
parents: 13441
diff changeset
    31
    | do_parse!(tag_no_case!("NO") >> (false))));
13438
da71e0d88a1c update nom
alfadur
parents: 13432
diff changeset
    32
named!(opt_param<&[u8], Option<String> >, alt!(
da71e0d88a1c update nom
alfadur
parents: 13432
diff changeset
    33
      do_parse!(peek!(tag!("\n\n")) >> (None))
da71e0d88a1c update nom
alfadur
parents: 13432
diff changeset
    34
    | do_parse!(tag!("\n") >> s: str_line >> (Some(s.to_string())))));
13432
ee3fa3b8809d Fix cmd parsing & update tests
alfadur
parents: 13431
diff changeset
    35
named!(spaces<&[u8], &[u8]>, preceded!(tag!(" "), eat_separator!(" ")));
13438
da71e0d88a1c update nom
alfadur
parents: 13432
diff changeset
    36
named!(opt_space_param<&[u8], Option<String> >, alt!(
da71e0d88a1c update nom
alfadur
parents: 13432
diff changeset
    37
      do_parse!(peek!(tag!("\n\n")) >> (None))
da71e0d88a1c update nom
alfadur
parents: 13432
diff changeset
    38
    | do_parse!(spaces >> s: str_line >> (Some(s.to_string())))));
13419
81e0ed105f5d implementation of team related messages
alfadur
parents: 13416
diff changeset
    39
named!(hog_line<&[u8], HedgehogInfo>,
81e0ed105f5d implementation of team related messages
alfadur
parents: 13416
diff changeset
    40
    do_parse!(name: str_line >> eol >> hat: str_line >>
81e0ed105f5d implementation of team related messages
alfadur
parents: 13416
diff changeset
    41
        (HedgehogInfo{name: name.to_string(), hat: hat.to_string()})));
81e0ed105f5d implementation of team related messages
alfadur
parents: 13416
diff changeset
    42
named!(_8_hogs<&[u8], [HedgehogInfo; 8]>,
81e0ed105f5d implementation of team related messages
alfadur
parents: 13416
diff changeset
    43
    do_parse!(h1: hog_line >> eol >> h2: hog_line >> eol >>
81e0ed105f5d implementation of team related messages
alfadur
parents: 13416
diff changeset
    44
              h3: hog_line >> eol >> h4: hog_line >> eol >>
81e0ed105f5d implementation of team related messages
alfadur
parents: 13416
diff changeset
    45
              h5: hog_line >> eol >> h6: hog_line >> eol >>
81e0ed105f5d implementation of team related messages
alfadur
parents: 13416
diff changeset
    46
              h7: hog_line >> eol >> h8: hog_line >>
81e0ed105f5d implementation of team related messages
alfadur
parents: 13416
diff changeset
    47
              ([h1, h2, h3, h4, h5, h6, h7, h8])));
13450
d79795acaa73 Mostly implement voting
alfadur
parents: 13441
diff changeset
    48
named!(voting<&[u8], VoteType>, alt!(
d79795acaa73 Mostly implement voting
alfadur
parents: 13441
diff changeset
    49
      do_parse!(tag_no_case!("KICK") >> spaces >> n: a_line >>
d79795acaa73 Mostly implement voting
alfadur
parents: 13441
diff changeset
    50
        (VoteType::Kick(n)))
d79795acaa73 Mostly implement voting
alfadur
parents: 13441
diff changeset
    51
    | do_parse!(tag_no_case!("MAP") >>
d79795acaa73 Mostly implement voting
alfadur
parents: 13441
diff changeset
    52
        n: opt!(preceded!(spaces, a_line)) >>
d79795acaa73 Mostly implement voting
alfadur
parents: 13441
diff changeset
    53
        (VoteType::Map(n)))
d79795acaa73 Mostly implement voting
alfadur
parents: 13441
diff changeset
    54
    | do_parse!(tag_no_case!("PAUSE") >>
d79795acaa73 Mostly implement voting
alfadur
parents: 13441
diff changeset
    55
        (VoteType::Pause))
d79795acaa73 Mostly implement voting
alfadur
parents: 13441
diff changeset
    56
    | do_parse!(tag_no_case!("NEWSEED") >>
d79795acaa73 Mostly implement voting
alfadur
parents: 13441
diff changeset
    57
        (VoteType::NewSeed))
d79795acaa73 Mostly implement voting
alfadur
parents: 13441
diff changeset
    58
    | do_parse!(tag_no_case!("HEDGEHOGS") >> spaces >> n: u8_line >>
d79795acaa73 Mostly implement voting
alfadur
parents: 13441
diff changeset
    59
        (VoteType::HedgehogsPerTeam(n)))));
12134
109e6765b1fc Optional parameters parsing function
unc0rr
parents: 12133
diff changeset
    60
13431
6a818f9192f4 Implement parsing for rnd and add a little documentation
Marcin Mielniczuk <marmistrz.dev@zoho.eu>
parents: 13423
diff changeset
    61
/** Recognizes messages which do not take any parameters */
12133
81df2e1f9ae9 Some parsing using nom
unc0rr
parents:
diff changeset
    62
named!(basic_message<&[u8], HWProtocolMessage>, alt!(
12135
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
    63
      do_parse!(tag!("PING") >> (Ping))
12133
81df2e1f9ae9 Some parsing using nom
unc0rr
parents:
diff changeset
    64
    | do_parse!(tag!("PONG") >> (Pong))
81df2e1f9ae9 Some parsing using nom
unc0rr
parents:
diff changeset
    65
    | do_parse!(tag!("LIST") >> (List))
12135
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
    66
    | do_parse!(tag!("BANLIST")        >> (BanList))
12133
81df2e1f9ae9 Some parsing using nom
unc0rr
parents:
diff changeset
    67
    | do_parse!(tag!("GET_SERVER_VAR") >> (GetServerVar))
12135
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
    68
    | do_parse!(tag!("TOGGLE_READY")   >> (ToggleReady))
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
    69
    | do_parse!(tag!("START_GAME")     >> (StartGame))
13423
87a6cad20c90 Implement game start & engine messages
alfadur
parents: 13422
diff changeset
    70
    | do_parse!(tag!("ROUNDFINISHED")  >> m: opt_param >> (RoundFinished))
12135
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
    71
    | do_parse!(tag!("TOGGLE_RESTRICT_JOINS")  >> (ToggleRestrictJoin))
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
    72
    | do_parse!(tag!("TOGGLE_RESTRICT_TEAMS")  >> (ToggleRestrictTeams))
12133
81df2e1f9ae9 Some parsing using nom
unc0rr
parents:
diff changeset
    73
    | do_parse!(tag!("TOGGLE_REGISTERED_ONLY") >> (ToggleRegisteredOnly))
81df2e1f9ae9 Some parsing using nom
unc0rr
parents:
diff changeset
    74
));
81df2e1f9ae9 Some parsing using nom
unc0rr
parents:
diff changeset
    75
13431
6a818f9192f4 Implement parsing for rnd and add a little documentation
Marcin Mielniczuk <marmistrz.dev@zoho.eu>
parents: 13423
diff changeset
    76
/** Recognizes messages which take exactly one parameter */
12133
81df2e1f9ae9 Some parsing using nom
unc0rr
parents:
diff changeset
    77
named!(one_param_message<&[u8], HWProtocolMessage>, alt!(
12135
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
    78
      do_parse!(tag!("NICK")    >> eol >> n: a_line >> (Nick(n)))
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
    79
    | do_parse!(tag!("INFO")    >> eol >> n: a_line >> (Info(n)))
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
    80
    | do_parse!(tag!("CHAT")    >> eol >> m: a_line >> (Chat(m)))
13416
cdf69667593b partial room implementation
alfadur
parents: 13119
diff changeset
    81
    | do_parse!(tag!("PART")    >> msg: opt_param   >> (Part(msg)))
12135
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
    82
    | do_parse!(tag!("FOLLOW")  >> eol >> n: a_line >> (Follow(n)))
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
    83
    | do_parse!(tag!("KICK")    >> eol >> n: a_line >> (Kick(n)))
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
    84
    | do_parse!(tag!("UNBAN")   >> eol >> n: a_line >> (Unban(n)))
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
    85
    | do_parse!(tag!("EM")      >> eol >> m: a_line >> (EngineMessage(m)))
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
    86
    | do_parse!(tag!("TEAMCHAT")    >> eol >> m: a_line >> (TeamChat(m)))
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
    87
    | do_parse!(tag!("ROOM_NAME")   >> eol >> n: a_line >> (RoomName(n)))
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
    88
    | do_parse!(tag!("REMOVE_TEAM") >> eol >> n: a_line >> (RemoveTeam(n)))
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
    89
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
    90
    | do_parse!(tag!("PROTO")   >> eol >> d: u32_line >> (Proto(d)))
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
    91
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
    92
    | do_parse!(tag!("QUIT")   >> msg: opt_param >> (Quit(msg)))
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
    93
));
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
    94
13431
6a818f9192f4 Implement parsing for rnd and add a little documentation
Marcin Mielniczuk <marmistrz.dev@zoho.eu>
parents: 13423
diff changeset
    95
/** Recognizes messages preceded with CMD */
12135
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
    96
named!(cmd_message<&[u8], HWProtocolMessage>, preceded!(tag!("CMD\n"), alt!(
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
    97
      do_parse!(tag_no_case!("STATS") >> (Stats))
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
    98
    | do_parse!(tag_no_case!("FIX")   >> (Fix))
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
    99
    | do_parse!(tag_no_case!("UNFIX") >> (Unfix))
13432
ee3fa3b8809d Fix cmd parsing & update tests
alfadur
parents: 13431
diff changeset
   100
    | do_parse!(tag_no_case!("RESTART_SERVER") >> spaces >> tag!("YES") >> (RestartServer))
12135
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
   101
    | do_parse!(tag_no_case!("REGISTERED_ONLY") >> (ToggleServerRegisteredOnly))
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
   102
    | do_parse!(tag_no_case!("SUPER_POWER")     >> (SuperPower))
13432
ee3fa3b8809d Fix cmd parsing & update tests
alfadur
parents: 13431
diff changeset
   103
    | do_parse!(tag_no_case!("PART")     >> m: opt_space_param >> (Part(m)))
ee3fa3b8809d Fix cmd parsing & update tests
alfadur
parents: 13431
diff changeset
   104
    | do_parse!(tag_no_case!("QUIT")     >> m: opt_space_param >> (Quit(m)))
ee3fa3b8809d Fix cmd parsing & update tests
alfadur
parents: 13431
diff changeset
   105
    | do_parse!(tag_no_case!("DELEGATE") >> spaces >> n: a_line  >> (Delegate(n)))
ee3fa3b8809d Fix cmd parsing & update tests
alfadur
parents: 13431
diff changeset
   106
    | do_parse!(tag_no_case!("SAVEROOM") >> spaces >> r: a_line  >> (SaveRoom(r)))
ee3fa3b8809d Fix cmd parsing & update tests
alfadur
parents: 13431
diff changeset
   107
    | do_parse!(tag_no_case!("LOADROOM") >> spaces >> r: a_line  >> (LoadRoom(r)))
ee3fa3b8809d Fix cmd parsing & update tests
alfadur
parents: 13431
diff changeset
   108
    | do_parse!(tag_no_case!("DELETE")   >> spaces >> r: a_line  >> (Delete(r)))
ee3fa3b8809d Fix cmd parsing & update tests
alfadur
parents: 13431
diff changeset
   109
    | do_parse!(tag_no_case!("GLOBAL")   >> spaces >> m: a_line  >> (Global(m)))
ee3fa3b8809d Fix cmd parsing & update tests
alfadur
parents: 13431
diff changeset
   110
    | do_parse!(tag_no_case!("WATCH")    >> spaces >> i: a_line  >> (Watch(i)))
ee3fa3b8809d Fix cmd parsing & update tests
alfadur
parents: 13431
diff changeset
   111
    | do_parse!(tag_no_case!("GREETING") >> spaces >> m: a_line  >> (Greeting(m)))
13450
d79795acaa73 Mostly implement voting
alfadur
parents: 13441
diff changeset
   112
    | do_parse!(tag_no_case!("VOTE")     >> spaces >> m: yes_no_line >> (Vote(m)))
d79795acaa73 Mostly implement voting
alfadur
parents: 13441
diff changeset
   113
    | do_parse!(tag_no_case!("FORCE")    >> spaces >> m: yes_no_line >> (ForceVote(m)))
13432
ee3fa3b8809d Fix cmd parsing & update tests
alfadur
parents: 13431
diff changeset
   114
    | do_parse!(tag_no_case!("INFO")     >> spaces >> n: a_line  >> (Info(n)))
ee3fa3b8809d Fix cmd parsing & update tests
alfadur
parents: 13431
diff changeset
   115
    | do_parse!(tag_no_case!("MAXTEAMS") >> spaces >> n: u8_line >> (MaxTeams(n)))
13450
d79795acaa73 Mostly implement voting
alfadur
parents: 13441
diff changeset
   116
    | do_parse!(tag_no_case!("CALLVOTE") >>
d79795acaa73 Mostly implement voting
alfadur
parents: 13441
diff changeset
   117
        v: opt!(preceded!(spaces, voting)) >> (CallVote(v)))
13431
6a818f9192f4 Implement parsing for rnd and add a little documentation
Marcin Mielniczuk <marmistrz.dev@zoho.eu>
parents: 13423
diff changeset
   118
    | do_parse!(
13432
ee3fa3b8809d Fix cmd parsing & update tests
alfadur
parents: 13431
diff changeset
   119
        tag_no_case!("RND") >> alt!(spaces | peek!(end_of_message)) >>
13431
6a818f9192f4 Implement parsing for rnd and add a little documentation
Marcin Mielniczuk <marmistrz.dev@zoho.eu>
parents: 13423
diff changeset
   120
        v: str_line >>
6a818f9192f4 Implement parsing for rnd and add a little documentation
Marcin Mielniczuk <marmistrz.dev@zoho.eu>
parents: 13423
diff changeset
   121
        (Rnd(v.split_whitespace().map(String::from).collect())))
12135
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
   122
)));
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
   123
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
   124
named!(complex_message<&[u8], HWProtocolMessage>, alt!(
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
   125
      do_parse!(tag!("PASSWORD")  >> eol >>
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
   126
                    p: a_line     >> eol >>
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
   127
                    s: a_line     >>
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
   128
                    (Password(p, s)))
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
   129
    | do_parse!(tag!("CHECKER")   >> eol >>
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
   130
                    i: u32_line   >> eol >>
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
   131
                    n: a_line     >> eol >>
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
   132
                    p: a_line     >>
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
   133
                    (Checker(i, n, p)))
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
   134
    | do_parse!(tag!("CREATE_ROOM") >> eol >>
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
   135
                    n: a_line       >>
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
   136
                    p: opt_param    >>
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
   137
                    (CreateRoom(n, p)))
13416
cdf69667593b partial room implementation
alfadur
parents: 13119
diff changeset
   138
    | do_parse!(tag!("JOIN_ROOM")   >> eol >>
12135
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
   139
                    n: a_line       >>
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
   140
                    p: opt_param    >>
13416
cdf69667593b partial room implementation
alfadur
parents: 13119
diff changeset
   141
                    (JoinRoom(n, p)))
13419
81e0ed105f5d implementation of team related messages
alfadur
parents: 13416
diff changeset
   142
    | do_parse!(tag!("ADD_TEAM")    >> eol >>
81e0ed105f5d implementation of team related messages
alfadur
parents: 13416
diff changeset
   143
                    name: a_line    >> eol >>
81e0ed105f5d implementation of team related messages
alfadur
parents: 13416
diff changeset
   144
                    color: u8_line  >> eol >>
81e0ed105f5d implementation of team related messages
alfadur
parents: 13416
diff changeset
   145
                    grave: a_line   >> eol >>
81e0ed105f5d implementation of team related messages
alfadur
parents: 13416
diff changeset
   146
                    fort: a_line    >> eol >>
81e0ed105f5d implementation of team related messages
alfadur
parents: 13416
diff changeset
   147
                    voice_pack: a_line >> eol >>
81e0ed105f5d implementation of team related messages
alfadur
parents: 13416
diff changeset
   148
                    flag: a_line    >> eol >>
81e0ed105f5d implementation of team related messages
alfadur
parents: 13416
diff changeset
   149
                    difficulty: u8_line >> eol >>
81e0ed105f5d implementation of team related messages
alfadur
parents: 13416
diff changeset
   150
                    hedgehogs: _8_hogs >>
81e0ed105f5d implementation of team related messages
alfadur
parents: 13416
diff changeset
   151
                    (AddTeam(TeamInfo{
81e0ed105f5d implementation of team related messages
alfadur
parents: 13416
diff changeset
   152
                        name, color, grave, fort,
81e0ed105f5d implementation of team related messages
alfadur
parents: 13416
diff changeset
   153
                        voice_pack, flag, difficulty,
81e0ed105f5d implementation of team related messages
alfadur
parents: 13416
diff changeset
   154
                        hedgehogs, hedgehogs_number: 0
81e0ed105f5d implementation of team related messages
alfadur
parents: 13416
diff changeset
   155
                     })))
81e0ed105f5d implementation of team related messages
alfadur
parents: 13416
diff changeset
   156
    | do_parse!(tag!("HH_NUM")    >> eol >>
81e0ed105f5d implementation of team related messages
alfadur
parents: 13416
diff changeset
   157
                    n: a_line     >> eol >>
81e0ed105f5d implementation of team related messages
alfadur
parents: 13416
diff changeset
   158
                    c: u8_line    >>
81e0ed105f5d implementation of team related messages
alfadur
parents: 13416
diff changeset
   159
                    (SetHedgehogsNumber(n, c)))
81e0ed105f5d implementation of team related messages
alfadur
parents: 13416
diff changeset
   160
    | do_parse!(tag!("TEAM_COLOR")    >> eol >>
81e0ed105f5d implementation of team related messages
alfadur
parents: 13416
diff changeset
   161
                    n: a_line     >> eol >>
81e0ed105f5d implementation of team related messages
alfadur
parents: 13416
diff changeset
   162
                    c: u8_line    >>
81e0ed105f5d implementation of team related messages
alfadur
parents: 13416
diff changeset
   163
                    (SetTeamColor(n, c)))
12135
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
   164
    | do_parse!(tag!("BAN")    >> eol >>
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
   165
                    n: a_line     >> eol >>
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
   166
                    r: a_line     >> eol >>
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
   167
                    t: u32_line   >>
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
   168
                    (Ban(n, r, t)))
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
   169
    | do_parse!(tag!("BAN_IP")    >> eol >>
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
   170
                    n: a_line     >> eol >>
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
   171
                    r: a_line     >> eol >>
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
   172
                    t: u32_line   >>
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
   173
                    (BanIP(n, r, t)))
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
   174
    | do_parse!(tag!("BAN_NICK")    >> eol >>
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
   175
                    n: a_line     >> eol >>
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
   176
                    r: a_line     >> eol >>
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
   177
                    t: u32_line   >>
23ee939ba66a Add more messages to the parser
unc0rr
parents: 12134
diff changeset
   178
                    (BanNick(n, r, t)))
12133
81df2e1f9ae9 Some parsing using nom
unc0rr
parents:
diff changeset
   179
));
81df2e1f9ae9 Some parsing using nom
unc0rr
parents:
diff changeset
   180
13422
5fb27f94fc3b Implement game config messages
alfadur
parents: 13419
diff changeset
   181
named!(cfg_message<&[u8], HWProtocolMessage>, preceded!(tag!("CFG\n"), map!(alt!(
5fb27f94fc3b Implement game config messages
alfadur
parents: 13419
diff changeset
   182
      do_parse!(tag!("THEME")    >> eol >>
5fb27f94fc3b Implement game config messages
alfadur
parents: 13419
diff changeset
   183
                name: a_line     >>
5fb27f94fc3b Implement game config messages
alfadur
parents: 13419
diff changeset
   184
                (GameCfg::Theme(name)))
5fb27f94fc3b Implement game config messages
alfadur
parents: 13419
diff changeset
   185
    | do_parse!(tag!("SCRIPT")   >> eol >>
5fb27f94fc3b Implement game config messages
alfadur
parents: 13419
diff changeset
   186
                name: a_line     >>
5fb27f94fc3b Implement game config messages
alfadur
parents: 13419
diff changeset
   187
                (GameCfg::Script(name)))
5fb27f94fc3b Implement game config messages
alfadur
parents: 13419
diff changeset
   188
    | do_parse!(tag!("AMMO")     >> eol >>
5fb27f94fc3b Implement game config messages
alfadur
parents: 13419
diff changeset
   189
                name: a_line     >>
5fb27f94fc3b Implement game config messages
alfadur
parents: 13419
diff changeset
   190
                value: opt_param >>
5fb27f94fc3b Implement game config messages
alfadur
parents: 13419
diff changeset
   191
                (GameCfg::Ammo(name, value)))
5fb27f94fc3b Implement game config messages
alfadur
parents: 13419
diff changeset
   192
    | do_parse!(tag!("SCHEME")   >> eol >>
13441
d47514fd6c6a Fix scheme config parsing
alfadur
parents: 13438
diff changeset
   193
                name: a_line     >>
d47514fd6c6a Fix scheme config parsing
alfadur
parents: 13438
diff changeset
   194
                values: opt!(preceded!(eol, separated_list!(eol, a_line))) >>
d47514fd6c6a Fix scheme config parsing
alfadur
parents: 13438
diff changeset
   195
                (GameCfg::Scheme(name, values)))
13422
5fb27f94fc3b Implement game config messages
alfadur
parents: 13419
diff changeset
   196
    | do_parse!(tag!("FEATURE_SIZE") >> eol >>
5fb27f94fc3b Implement game config messages
alfadur
parents: 13419
diff changeset
   197
                value: u32_line    >>
5fb27f94fc3b Implement game config messages
alfadur
parents: 13419
diff changeset
   198
                (GameCfg::FeatureSize(value)))
5fb27f94fc3b Implement game config messages
alfadur
parents: 13419
diff changeset
   199
    | do_parse!(tag!("MAP")      >> eol >>
5fb27f94fc3b Implement game config messages
alfadur
parents: 13419
diff changeset
   200
                value: a_line    >>
5fb27f94fc3b Implement game config messages
alfadur
parents: 13419
diff changeset
   201
                (GameCfg::MapType(value)))
5fb27f94fc3b Implement game config messages
alfadur
parents: 13419
diff changeset
   202
    | do_parse!(tag!("MAPGEN")   >> eol >>
5fb27f94fc3b Implement game config messages
alfadur
parents: 13419
diff changeset
   203
                value: u32_line  >>
5fb27f94fc3b Implement game config messages
alfadur
parents: 13419
diff changeset
   204
                (GameCfg::MapGenerator(value)))
5fb27f94fc3b Implement game config messages
alfadur
parents: 13419
diff changeset
   205
    | do_parse!(tag!("MAZE_SIZE") >> eol >>
5fb27f94fc3b Implement game config messages
alfadur
parents: 13419
diff changeset
   206
                value: u32_line   >>
5fb27f94fc3b Implement game config messages
alfadur
parents: 13419
diff changeset
   207
                (GameCfg::MazeSize(value)))
5fb27f94fc3b Implement game config messages
alfadur
parents: 13419
diff changeset
   208
    | do_parse!(tag!("SEED")     >> eol >>
5fb27f94fc3b Implement game config messages
alfadur
parents: 13419
diff changeset
   209
                value: a_line    >>
5fb27f94fc3b Implement game config messages
alfadur
parents: 13419
diff changeset
   210
                (GameCfg::Seed(value)))
5fb27f94fc3b Implement game config messages
alfadur
parents: 13419
diff changeset
   211
    | do_parse!(tag!("TEMPLATE") >> eol >>
5fb27f94fc3b Implement game config messages
alfadur
parents: 13419
diff changeset
   212
                value: u32_line  >>
5fb27f94fc3b Implement game config messages
alfadur
parents: 13419
diff changeset
   213
                (GameCfg::Template(value)))
5fb27f94fc3b Implement game config messages
alfadur
parents: 13419
diff changeset
   214
    | do_parse!(tag!("DRAWNMAP") >> eol >>
5fb27f94fc3b Implement game config messages
alfadur
parents: 13419
diff changeset
   215
                value: a_line    >>
5fb27f94fc3b Implement game config messages
alfadur
parents: 13419
diff changeset
   216
                (GameCfg::DrawnMap(value)))
5fb27f94fc3b Implement game config messages
alfadur
parents: 13419
diff changeset
   217
), Cfg)));
5fb27f94fc3b Implement game config messages
alfadur
parents: 13419
diff changeset
   218
12137
193dfdcb0620 - Use logging facilities instead of plain println!
unc0rr
parents: 12136
diff changeset
   219
named!(malformed_message<&[u8], HWProtocolMessage>,
193dfdcb0620 - Use logging facilities instead of plain println!
unc0rr
parents: 12136
diff changeset
   220
    do_parse!(separated_list!(eol, a_line) >> (Malformed)));
193dfdcb0620 - Use logging facilities instead of plain println!
unc0rr
parents: 12136
diff changeset
   221
193dfdcb0620 - Use logging facilities instead of plain println!
unc0rr
parents: 12136
diff changeset
   222
named!(empty_message<&[u8], HWProtocolMessage>,
193dfdcb0620 - Use logging facilities instead of plain println!
unc0rr
parents: 12136
diff changeset
   223
    do_parse!(alt!(end_of_message | eol) >> (Empty)));
193dfdcb0620 - Use logging facilities instead of plain println!
unc0rr
parents: 12136
diff changeset
   224
193dfdcb0620 - Use logging facilities instead of plain println!
unc0rr
parents: 12136
diff changeset
   225
named!(message<&[u8], HWProtocolMessage>, alt!(terminated!(
193dfdcb0620 - Use logging facilities instead of plain println!
unc0rr
parents: 12136
diff changeset
   226
    alt!(
193dfdcb0620 - Use logging facilities instead of plain println!
unc0rr
parents: 12136
diff changeset
   227
          basic_message
193dfdcb0620 - Use logging facilities instead of plain println!
unc0rr
parents: 12136
diff changeset
   228
        | one_param_message
193dfdcb0620 - Use logging facilities instead of plain println!
unc0rr
parents: 12136
diff changeset
   229
        | cmd_message
193dfdcb0620 - Use logging facilities instead of plain println!
unc0rr
parents: 12136
diff changeset
   230
        | complex_message
13422
5fb27f94fc3b Implement game config messages
alfadur
parents: 13419
diff changeset
   231
        | cfg_message
12137
193dfdcb0620 - Use logging facilities instead of plain println!
unc0rr
parents: 12136
diff changeset
   232
        ), end_of_message
193dfdcb0620 - Use logging facilities instead of plain println!
unc0rr
parents: 12136
diff changeset
   233
    )
12140
7e259e47eb0d Fix malformed messages parsing
unc0rr
parents: 12137
diff changeset
   234
    | terminated!(malformed_message, end_of_message)
12137
193dfdcb0620 - Use logging facilities instead of plain println!
unc0rr
parents: 12136
diff changeset
   235
    | empty_message
193dfdcb0620 - Use logging facilities instead of plain println!
unc0rr
parents: 12136
diff changeset
   236
    )
193dfdcb0620 - Use logging facilities instead of plain println!
unc0rr
parents: 12136
diff changeset
   237
);
12133
81df2e1f9ae9 Some parsing using nom
unc0rr
parents:
diff changeset
   238
12136
e25a82ce2374 - Render messages to string
unc0rr
parents: 12135
diff changeset
   239
named!(pub extract_messages<&[u8], Vec<HWProtocolMessage> >, many0!(complete!(message)));
12133
81df2e1f9ae9 Some parsing using nom
unc0rr
parents:
diff changeset
   240
13119
1e39b8749072 separated the server logic from all the async io mess.
alfadur
parents: 12142
diff changeset
   241
proptest! {
1e39b8749072 separated the server logic from all the async io mess.
alfadur
parents: 12142
diff changeset
   242
    #[test]
1e39b8749072 separated the server logic from all the async io mess.
alfadur
parents: 12142
diff changeset
   243
    fn is_parser_composition_idempotent(ref msg in gen_proto_msg()) {
1e39b8749072 separated the server logic from all the async io mess.
alfadur
parents: 12142
diff changeset
   244
        println!("!! Msg: {:?}, Bytes: {:?} !!", msg, msg.to_raw_protocol().as_bytes());
13438
da71e0d88a1c update nom
alfadur
parents: 13432
diff changeset
   245
        assert_eq!(message(msg.to_raw_protocol().as_bytes()), Ok((&b""[..], msg.clone())))
13119
1e39b8749072 separated the server logic from all the async io mess.
alfadur
parents: 12142
diff changeset
   246
    }
1e39b8749072 separated the server logic from all the async io mess.
alfadur
parents: 12142
diff changeset
   247
}
1e39b8749072 separated the server logic from all the async io mess.
alfadur
parents: 12142
diff changeset
   248
12133
81df2e1f9ae9 Some parsing using nom
unc0rr
parents:
diff changeset
   249
#[test]
81df2e1f9ae9 Some parsing using nom
unc0rr
parents:
diff changeset
   250
fn parse_test() {
13438
da71e0d88a1c update nom
alfadur
parents: 13432
diff changeset
   251
    assert_eq!(message(b"PING\n\n"),          Ok((&b""[..], Ping)));
da71e0d88a1c update nom
alfadur
parents: 13432
diff changeset
   252
    assert_eq!(message(b"START_GAME\n\n"),    Ok((&b""[..], StartGame)));
da71e0d88a1c update nom
alfadur
parents: 13432
diff changeset
   253
    assert_eq!(message(b"NICK\nit's me\n\n"), Ok((&b""[..], Nick("it's me".to_string()))));
da71e0d88a1c update nom
alfadur
parents: 13432
diff changeset
   254
    assert_eq!(message(b"PROTO\n51\n\n"),     Ok((&b""[..], Proto(51))));
da71e0d88a1c update nom
alfadur
parents: 13432
diff changeset
   255
    assert_eq!(message(b"QUIT\nbye-bye\n\n"), Ok((&b""[..], Quit(Some("bye-bye".to_string())))));
da71e0d88a1c update nom
alfadur
parents: 13432
diff changeset
   256
    assert_eq!(message(b"QUIT\n\n"),          Ok((&b""[..], Quit(None))));
da71e0d88a1c update nom
alfadur
parents: 13432
diff changeset
   257
    assert_eq!(message(b"CMD\nwatch demo\n\n"), Ok((&b""[..], Watch("demo".to_string()))));
da71e0d88a1c update nom
alfadur
parents: 13432
diff changeset
   258
    assert_eq!(message(b"BAN\nme\nbad\n77\n\n"), Ok((&b""[..], Ban("me".to_string(), "bad".to_string(), 77))));
12136
e25a82ce2374 - Render messages to string
unc0rr
parents: 12135
diff changeset
   259
13438
da71e0d88a1c update nom
alfadur
parents: 13432
diff changeset
   260
    assert_eq!(message(b"CMD\nPART\n\n"),      Ok((&b""[..], Part(None))));
da71e0d88a1c update nom
alfadur
parents: 13432
diff changeset
   261
    assert_eq!(message(b"CMD\nPART _msg_\n\n"), Ok((&b""[..], Part(Some("_msg_".to_string())))));
13119
1e39b8749072 separated the server logic from all the async io mess.
alfadur
parents: 12142
diff changeset
   262
13438
da71e0d88a1c update nom
alfadur
parents: 13432
diff changeset
   263
    assert_eq!(message(b"CMD\nRND\n\n"), Ok((&b""[..], Rnd(vec![]))));
13431
6a818f9192f4 Implement parsing for rnd and add a little documentation
Marcin Mielniczuk <marmistrz.dev@zoho.eu>
parents: 13423
diff changeset
   264
    assert_eq!(
6a818f9192f4 Implement parsing for rnd and add a little documentation
Marcin Mielniczuk <marmistrz.dev@zoho.eu>
parents: 13423
diff changeset
   265
        message(b"CMD\nRND A B\n\n"),
13438
da71e0d88a1c update nom
alfadur
parents: 13432
diff changeset
   266
        Ok((&b""[..], Rnd(vec![String::from("A"), String::from("B")])))
13431
6a818f9192f4 Implement parsing for rnd and add a little documentation
Marcin Mielniczuk <marmistrz.dev@zoho.eu>
parents: 13423
diff changeset
   267
    );
6a818f9192f4 Implement parsing for rnd and add a little documentation
Marcin Mielniczuk <marmistrz.dev@zoho.eu>
parents: 13423
diff changeset
   268
13438
da71e0d88a1c update nom
alfadur
parents: 13432
diff changeset
   269
    assert_eq!(extract_messages(b"QUIT\n1\n2\n\n"),    Ok((&b""[..], vec![Malformed])));
12140
7e259e47eb0d Fix malformed messages parsing
unc0rr
parents: 12137
diff changeset
   270
13438
da71e0d88a1c update nom
alfadur
parents: 13432
diff changeset
   271
    assert_eq!(extract_messages(b"PING\n\nPING\n\nP"), Ok((&b"P"[..], vec![Ping, Ping])));
da71e0d88a1c update nom
alfadur
parents: 13432
diff changeset
   272
    assert_eq!(extract_messages(b"SING\n\nPING\n\n"),  Ok((&b""[..],  vec![Malformed, Ping])));
da71e0d88a1c update nom
alfadur
parents: 13432
diff changeset
   273
    assert_eq!(extract_messages(b"\n\n\n\nPING\n\n"),  Ok((&b""[..],  vec![Empty, Empty, Ping])));
da71e0d88a1c update nom
alfadur
parents: 13432
diff changeset
   274
    assert_eq!(extract_messages(b"\n\n\nPING\n\n"),    Ok((&b""[..],  vec![Empty, Empty, Ping])));
13431
6a818f9192f4 Implement parsing for rnd and add a little documentation
Marcin Mielniczuk <marmistrz.dev@zoho.eu>
parents: 13423
diff changeset
   275
}