ManaPlus
messagein.cpp
Go to the documentation of this file.
1 /*
2  * The ManaPlus Client
3  * Copyright (C) 2004-2009 The Mana World Development Team
4  * Copyright (C) 2009-2010 The Mana Developers
5  * Copyright (C) 2011-2019 The ManaPlus Developers
6  * Copyright (C) 2019-2021 Andrei Karas
7  *
8  * This file is part of The ManaPlus Client.
9  *
10  * This program is free software; you can redistribute it and/or modify
11  * it under the terms of the GNU General Public License as published by
12  * the Free Software Foundation; either version 2 of the License, or
13  * any later version.
14  *
15  * This program is distributed in the hope that it will be useful,
16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18  * GNU General Public License for more details.
19  *
20  * You should have received a copy of the GNU General Public License
21  * along with this program. If not, see <http://www.gnu.org/licenses/>.
22  */
23 
24 #include "net/eathena/messagein.h"
25 
26 #include "logger.h"
27 
28 #include "net/net.h"
29 
30 #include "utils/stringutils.h"
31 
32 #include "debug.h"
33 
34 namespace EAthena
35 {
36 
37 MessageIn::MessageIn(const char *const data,
38  const unsigned int length) :
39  Net::MessageIn(data, length)
40 {
41 }
42 
43 void MessageIn::postInit(const char *const str,
44  const unsigned int version)
45 {
46  // Read the message ID
47  mId = readId();
48  mVersion = version;
50  DEBUGLOG2("Receive packet", 0, "MessageIn");
51 #ifdef ENABLEDEBUGLOG
52  if (mVersion > 0)
53  {
54  const std::string verStr = toString(mVersion);
55  DEBUGLOG2("Version", 0, verStr.c_str());
56  }
57 #endif // ENABLEDEBUGLOG
58 
59  readInt16(str);
60 }
61 
62 } // namespace EAthena
void postInit(const char *const str, const unsigned int version)
Definition: messagein.cpp:43
MessageIn(const char *const data, const unsigned int length)
Definition: messagein.cpp:37
uint16_t mId
Definition: messagein.h:161
int16_t readInt16(const char *const str)
Definition: messagein.cpp:131
uint16_t readId() const
Definition: messagein.cpp:87
#define IGNOREDEBUGLOG
Definition: logger.h:48
#define DEBUGLOG2(str, pos, comment)
Definition: logger.h:42
uint32_t data
std::string toString(T const &value)
converts any type to a string
Definition: catch.hpp:1774