diff options
author | Andrei Karas <akaras@inbox.ru> | 2016-07-27 20:49:31 +0300 |
---|---|---|
committer | Andrei Karas <akaras@inbox.ru> | 2016-07-27 20:49:31 +0300 |
commit | 4b02d01243eeb6b31c57e5220914b9e5e7c7bfe8 (patch) | |
tree | 371dac23117eb986c841b424afe5870b18604a7b | |
parent | 19125da4c29f4475aafa4bf9bf2d9400bceff657 (diff) | |
download | manaplus-4b02d01243eeb6b31c57e5220914b9e5e7c7bfe8.tar.gz manaplus-4b02d01243eeb6b31c57e5220914b9e5e7c7bfe8.tar.bz2 manaplus-4b02d01243eeb6b31c57e5220914b9e5e7c7bfe8.tar.xz manaplus-4b02d01243eeb6b31c57e5220914b9e5e7c7bfe8.zip |
Impliment packet SMSG_HOMUNCULUS_EXP 0x0b22.
For now it show homunculus exp over player ovner.
But probably need show it over homunculus.
-rw-r--r-- | src/being/localplayer.cpp | 13 | ||||
-rw-r--r-- | src/being/localplayer.h | 2 | ||||
-rw-r--r-- | src/net/eathena/homunculusrecv.cpp | 9 | ||||
-rw-r--r-- | src/net/eathena/homunculusrecv.h | 1 | ||||
-rw-r--r-- | src/net/eathena/packetsin.inc | 1 |
5 files changed, 26 insertions, 0 deletions
diff --git a/src/being/localplayer.cpp b/src/being/localplayer.cpp index 3ae1cd90b..abecee8de 100644 --- a/src/being/localplayer.cpp +++ b/src/being/localplayer.cpp @@ -1144,6 +1144,19 @@ void LocalPlayer::addXpMessage(const int change) } } +void LocalPlayer::addHomunXpMessage(const int change) +{ + if (change != 0 && mMessages.size() < 20) + { + addMessageToQueue(strprintf("%s %d %s", + // TRANSLATORS: get homunculus xp message + _("Homun"), + change, + // TRANSLATORS: get xp message + _("xp"))); + } +} + void LocalPlayer::addHpMessage(const int change) { if (change != 0 && mMessages.size() < 20) diff --git a/src/being/localplayer.h b/src/being/localplayer.h index 5fa17b7f8..50ef31052 100644 --- a/src/being/localplayer.h +++ b/src/being/localplayer.h @@ -376,6 +376,8 @@ class LocalPlayer final : public Being, void addXpMessage(const int change); + void addHomunXpMessage(const int change); + void addJobMessage(const int change); void addHpMessage(const int change); diff --git a/src/net/eathena/homunculusrecv.cpp b/src/net/eathena/homunculusrecv.cpp index 2366b639b..4511d89b1 100644 --- a/src/net/eathena/homunculusrecv.cpp +++ b/src/net/eathena/homunculusrecv.cpp @@ -25,6 +25,7 @@ #include "being/homunculusinfo.h" #include "being/playerinfo.h" +#include "being/localplayer.h" #include "enums/resources/notifytypes.h" @@ -205,4 +206,12 @@ void HomunculusRecv::processHomunculusFood(Net::MessageIn &msg) } } +void HomunculusRecv::processHomunculusExp(Net::MessageIn &msg) +{ + const int exp = msg.readInt32("exp"); + msg.readInt32("unused"); + if (localPlayer) + localPlayer->addHomunXpMessage(exp); +} + } // namespace EAthena diff --git a/src/net/eathena/homunculusrecv.h b/src/net/eathena/homunculusrecv.h index a7b9c4ea6..76ddcf544 100644 --- a/src/net/eathena/homunculusrecv.h +++ b/src/net/eathena/homunculusrecv.h @@ -37,6 +37,7 @@ namespace EAthena void processHomunculusInfo(Net::MessageIn &msg); void processHomunculusSkillUp(Net::MessageIn &msg); void processHomunculusFood(Net::MessageIn &msg); + void processHomunculusExp(Net::MessageIn &msg); } // namespace HomunculusRecv } // namespace EAthena diff --git a/src/net/eathena/packetsin.inc b/src/net/eathena/packetsin.inc index 49d5a3e5d..8439ea6c7 100644 --- a/src/net/eathena/packetsin.inc +++ b/src/net/eathena/packetsin.inc @@ -809,6 +809,7 @@ if (serverVersion > 0) packet(SMSG_PLAYER_ADD_SKILL2, 0x0b1f, -1, &SkillRecv::processSkillAdd2, 0); packet(SMSG_PLAYER_UPDATE_SKILL2, 0x0b20, -1, &SkillRecv::processSkillUpdate2, 0); packet(SMSG_WALK_ERROR, 0x0b21, 10, &PlayerRecv::processWalkError, 0); + packet(SMSG_HOMUNCULUS_EXP, 0x0b22, 10, &HomunculusRecv::processHomunculusExp, 0); // char server packet(SMSG_CHAR_PASSWORD_RESPONSE, 0x0062, 3, &LoginRecv::processCharPasswordResponse, 0); |