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, y;
51  msg.readInt32("start time");
52  msg.readCoordinates(x, y, direction, "position");
53  msg.readInt8("x size");
54  msg.readInt8("y size");
55  logger->log("Protocol: Player start position: "
56  "(%d, %d), Direction: %d",
57  x, y, direction);
58  if (msg.getVersion() >= 20080102)
59  msg.readInt16("font");
60  if (msg.getVersion() >= 20141022 && msg.getVersion() < 20160330)
61  msg.readUInt8("sex");
62 
63  mLastHost &= 0xffffff;
64 
65  Network *const network = Network::mInstance;
66  if (network != nullptr)
67  network->pauseDispatch();
68 
69  // Switch now or we'll have problems
71  if (localPlayer != nullptr)
73 }
74 
76 {
77  // ignoring
78  msg.readInt32("tick");
79 }
80 
82 {
84  msg.readUInt8("error");
85 }
86 } // namespace EAthena
virtual unsigned char readUInt8(const char *const str)
Definition: messagein.cpp:74
void setState(const StateT state)
Definition: client.h:65
virtual BeingId readBeingId(const char *const str)=0
void setTileCoords(const int x, const int y)
Definition: being.cpp:4980
virtual int16_t readInt16(const char *const str)=0
bool msg(InputEvent &event)
Definition: chat.cpp:38
void pauseDispatch()
Definition: network.h:72
Client * client
Definition: client.cpp:113
virtual void readCoordinates(uint16_t &x, uint16_t &y, uint8_t &direction, const char *const str)
Definition: messagein.cpp:131
virtual signed char readInt8(const char *const str)
Definition: messagein.cpp:87
unsigned int mLastHost
Definition: client.cpp:127
Logger * logger
Definition: logger.cpp:95
void processServerTick(Net::MessageIn &msg)
Definition: gamerecv.cpp:75
LocalPlayer * localPlayer
void processMapAccountId(Net::MessageIn &msg)
Definition: gamerecv.cpp:41
unsigned int getVersion() const
Definition: messagein.h:127
static Network * mInstance
Definition: network.h:56
ServerInfo mapServer
void processMapLogin(Net::MessageIn &msg)
Definition: gamerecv.cpp:47
virtual int32_t readInt32(const char *const str)=0
#define UNIMPLEMENTEDPACKET
Definition: logger.h:55
void processMapAuthRefuse(Net::MessageIn &msg)
Definition: gamerecv.cpp:81
void log(const char *const log_text,...)
Definition: logger.cpp:243