summaryrefslogtreecommitdiff
path: root/src/net/eathena
diff options
context:
space:
mode:
authorAndrei Karas <akaras@inbox.ru>2014-09-08 19:24:45 +0300
committerAndrei Karas <akaras@inbox.ru>2014-09-08 19:24:45 +0300
commit15e87a84d62cc0b0077b25c235824879bde66a41 (patch)
treec6cd3769b45ec2ab0b1f34e974f50ffac504d42f /src/net/eathena
parent6f7adf2485fe2da1c0b98dfc61984d14180deea8 (diff)
downloadmv-15e87a84d62cc0b0077b25c235824879bde66a41.tar.gz
mv-15e87a84d62cc0b0077b25c235824879bde66a41.tar.bz2
mv-15e87a84d62cc0b0077b25c235824879bde66a41.tar.xz
mv-15e87a84d62cc0b0077b25c235824879bde66a41.zip
Update command for sending raw packets to server.
Diffstat (limited to 'src/net/eathena')
-rw-r--r--src/net/eathena/chathandler.cpp91
1 files changed, 28 insertions, 63 deletions
diff --git a/src/net/eathena/chathandler.cpp b/src/net/eathena/chathandler.cpp
index b8973dd66..eed77a52c 100644
--- a/src/net/eathena/chathandler.cpp
+++ b/src/net/eathena/chathandler.cpp
@@ -183,75 +183,40 @@ void ChatHandler::sendRaw(const std::string &args) const
void ChatHandler::processRaw(MessageOut &restrict outMsg,
const std::string &restrict line)
{
- size_t pos = line.find(":");
- if (pos == std::string::npos)
- {
- const int i = atoi(line.c_str());
- if (line.length() <= 3)
- outMsg.writeInt8(static_cast<unsigned char>(i), "raw");
- else if (line.length() <= 5)
- outMsg.writeInt16(static_cast<int16_t>(i), "raw");
- else
- outMsg.writeInt32(i, "raw");
- }
+ if (line.size() < 2)
+ return;
+
+ char cmd = tolower(line[0]);
+ int i = 0;
+ std::string str = line.substr(1);
+ int idx = 0;
+ if (strStartWith(str, "0x"))
+ idx = 2;
+ else if (str[0] == 'h' || str[0] == 'x')
+ idx = 1;
+ if (idx > 0)
+ sscanf(str.substr(idx).c_str(), "%10x", &i);
else
+ i = atoi(str.c_str());
+ switch (cmd)
{
- const std::string header = line.substr(0, pos);
- std::string data = line.substr(pos + 1);
- if (header.length() != 1)
- return;
-
- int i = 0;
-
- switch (header[0])
+ case 'b':
+ {
+ outMsg.writeInt8(static_cast<unsigned char>(i), "raw");
+ break;
+ }
+ case 'w':
{
- case '1':
- case '2':
- case '4':
- i = atoi(data.c_str());
- break;
- default:
- break;
+ outMsg.writeInt16(static_cast<int16_t>(i), "raw");
+ break;
}
-
- switch (header[0])
+ case 'l':
{
- case '1':
- outMsg.writeInt8(static_cast<unsigned char>(i), "raw");
- break;
- case '2':
- outMsg.writeInt16(static_cast<int16_t>(i), "raw");
- break;
- case '4':
- outMsg.writeInt32(i, "raw");
- break;
- case 'c':
- {
- pos = line.find(",");
- if (pos != std::string::npos)
- {
- const uint16_t x = static_cast<uint16_t>(
- atoi(data.substr(0, pos).c_str()));
- data = data.substr(pos + 1);
- pos = line.find(",");
- if (pos == std::string::npos)
- break;
-
- const uint16_t y = static_cast<uint16_t>(
- atoi(data.substr(0, pos).c_str()));
- const int dir = atoi(data.substr(pos + 1).c_str());
- outMsg.writeCoordinates(x, y,
- static_cast<unsigned char>(dir), "raw");
- }
- break;
- }
- case 't':
- outMsg.writeString(data,
- static_cast<int>(data.length()), "raw");
- break;
- default:
- break;
+ outMsg.writeInt32(static_cast<int32_t>(i), "raw");
+ break;
}
+ default:
+ break;
}
}