ManaPlus
gamerecv.cpp
Go to the documentation of this file.
1 /*
2  * The ManaPlus Client
3  * Copyright (C) 2009 The Mana World Development Team
4  * Copyright (C) 2009-2010 The Mana Developers
5  * Copyright (C) 2011-2018 The ManaPlus Developers
6  *
7  * This file is part of The ManaPlus Client.
8  *
9  * This program is free software; you can redistribute it and/or modify
10  * it under the terms of the GNU General Public License as published by
11  * the Free Software Foundation; either version 2 of the License, or
12  * any later version.
13  *
14  * This program is distributed in the hope that it will be useful,
15  * but WITHOUT ANY WARRANTY; without even the implied warranty of
16  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17  * GNU General Public License for more details.
18  *
19  * You should have received a copy of the GNU General Public License
20  * along with this program. If not, see <http://www.gnu.org/licenses/>.
21  */
22 
23 #include "net/eathena/gamerecv.h"
24 
25 #include "client.h"
26 #include "logger.h"
27 
28 #include "being/localplayer.h"
29 
30 #include "net/messagein.h"
31 
32 #include "net/eathena/network.h"
33 
34 #include "debug.h"
35 
36 namespace EAthena
37 {
38 
39 extern ServerInfo mapServer;
40 
42 {
43  // ignored, because we already know local player account id.
44  msg.readBeingId("account id");
45 }
46 
48 {
49  unsigned char direction;
50  uint16_t x;
51  uint16_t y;
52  msg.readInt32("start time");
53  msg.readCoordinates(x, y, direction, "position");
54  msg.readInt8("x size");
55  msg.readInt8("y size");
56  logger->log("Protocol: Player start position: "
57  "(%d, %d), Direction: %d",
58  x, y, direction);
59  if (msg.getVersion() >= 20080102)
60  msg.readInt16("font");
61  if (msg.getVersion() >= 20141022 && msg.getVersion() < 20160330)
62  msg.readUInt8("sex");
63 
64  mLastHost &= 0xffffff;
65 
66  Network *const network = Network::mInstance;
67  if (network != nullptr)
68  network->pauseDispatch();
69 
70  // Switch now or we'll have problems
72  if (localPlayer != nullptr)
74 }
75 
77 {
78  // ignoring
79  msg.readInt32("tick");
80 }
81 
83 {
85  msg.readUInt8("error");
86 }
87 } // namespace EAthena
unsigned char readUInt8(const char *const str)
Definition: messagein.cpp:103
BeingId readBeingId(const char *const str)
Definition: messagein.cpp:223
void setState(const StateT state)
Definition: client.h:65
void setTileCoords(const int x, const int y)
Definition: being.cpp:5010
bool msg(InputEvent &event)
Definition: chat.cpp:38
void pauseDispatch()
Definition: network.h:72
Client * client
Definition: client.cpp:117
void readCoordinates(uint16_t &x, uint16_t &y, uint8_t &direction, const char *const str)
Definition: messagein.cpp:279
signed char readInt8(const char *const str)
Definition: messagein.cpp:116
unsigned int mLastHost
Definition: client.cpp:135
Logger * logger
Definition: logger.cpp:88
int16_t readInt16(const char *const str)
Definition: messagein.cpp:130
void processServerTick(Net::MessageIn &msg)
Definition: gamerecv.cpp:76
int getVersion() const
Definition: messagein.h:133
LocalPlayer * localPlayer
void processMapAccountId(Net::MessageIn &msg)
Definition: gamerecv.cpp:41
static Network * mInstance
Definition: network.h:56
ServerInfo mapServer
void processMapLogin(Net::MessageIn &msg)
Definition: gamerecv.cpp:47
#define UNIMPLEMENTEDPACKET
Definition: logger.h:55
void processMapAuthRefuse(Net::MessageIn &msg)
Definition: gamerecv.cpp:82
void log(const char *const log_text,...)
Definition: logger.cpp:264
int32_t readInt32(const char *const str)
Definition: messagein.cpp:174