gameServer/HWProtoInRoomState.hs
branch0.9.19
changeset 8924 13ac59499066
parent 8899 7493dde4ef51
child 8983 a25e18295959
equal deleted inserted replaced
8904:6ea838b8dcd5 8924:13ac59499066
    52         clChan <- thisClientChans
    52         clChan <- thisClientChans
    53         othChans <- roomOthersChans
    53         othChans <- roomOthersChans
    54         roomChans <- roomClientsChans
    54         roomChans <- roomClientsChans
    55         cl <- thisClient
    55         cl <- thisClient
    56         teamColor <-
    56         teamColor <-
    57             if clientProto cl < 42 then 
    57             if clientProto cl < 42 then
    58                 return color
    58                 return color
    59                 else
    59                 else
    60                 liftM (head . (L.\\) (map B.singleton ['0'..]) . map teamcolor . teams) thisRoom
    60                 liftM (head . (L.\\) (map B.singleton ['0'..]) . map teamcolor . teams) thisRoom
    61         let roomTeams = teams rm
    61         let roomTeams = teams rm
    62         let hhNum = let p = if not $ null roomTeams then hhnum $ head roomTeams else 4 in newTeamHHNum roomTeams p
    62         let hhNum = let p = if not $ null roomTeams then minimum [hhnum $ head roomTeams, canAddNumber roomTeams] else 4 in newTeamHHNum roomTeams p
    63         let newTeam = clNick `seq` TeamInfo ci clNick tName teamColor grave fort voicepack flag dif hhNum (hhsList hhsInfo)
    63         let newTeam = clNick `seq` TeamInfo ci clNick tName teamColor grave fort voicepack flag dif hhNum (hhsList hhsInfo)
    64         return $
    64         return $
    65             if not . null . drop (maxTeams rm - 1) $ roomTeams then
    65             if not . null . drop (maxTeams rm - 1) $ roomTeams then
    66                 [Warning $ loc "too many teams"]
    66                 [Warning $ loc "too many teams"]
    67             else if canAddNumber roomTeams <= 0 then
    67             else if canAddNumber roomTeams <= 0 then
    77                 SendUpdateOnThisRoom,
    77                 SendUpdateOnThisRoom,
    78                 ModifyClient (\c -> c{teamsInGame = teamsInGame c + 1, clientClan = Just teamColor}),
    78                 ModifyClient (\c -> c{teamsInGame = teamsInGame c + 1, clientClan = Just teamColor}),
    79                 AnswerClients clChan ["TEAM_ACCEPTED", tName],
    79                 AnswerClients clChan ["TEAM_ACCEPTED", tName],
    80                 AnswerClients othChans $ teamToNet $ newTeam,
    80                 AnswerClients othChans $ teamToNet $ newTeam,
    81                 AnswerClients roomChans ["TEAM_COLOR", tName, teamColor],
    81                 AnswerClients roomChans ["TEAM_COLOR", tName, teamColor],
    82                 ModifyClient $ \c -> c{actionsPending = actionsPending cl
    82                 AnswerClients roomChans ["HH_NUM", tName, showB $ hhnum newTeam]
    83                     ++ [AnswerClients clChan ["HH_NUM", tName, showB $ hhnum newTeam]]
       
    84                     },
       
    85                 AnswerClients [sendChan cl] ["PING"]
       
    86                 ]
    83                 ]
    87         where
    84         where
    88         canAddNumber rt = (48::Int) - (sum $ map hhnum rt)
    85         canAddNumber rt = (48::Int) - (sum $ map hhnum rt)
    89         findTeam = find (\t -> tName == teamname t) . teams
    86         findTeam = find (\t -> tName == teamname t) . teams
    90         dif = readInt_ difStr
    87         dif = readInt_ difStr