/*
* The ManaPlus Client
* Copyright (C) 2011-2015 The ManaPlus Developers
*
* This file is part of The ManaPlus Client.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
*/
#include "net/eathena/homunculushandler.h"
#include "being/playerinfo.h"
#include "net/serverfeatures.h"
#include "net/eathena/homunculusrecv.h"
#include "net/eathena/messageout.h"
#include "net/eathena/protocol.h"
#include "debug.h"
extern Net::HomunculusHandler *homunculusHandler;
namespace EAthena
{
HomunculusHandler::HomunculusHandler() :
MessageHandler()
{
static const uint16_t _messages[] =
{
SMSG_HOMUNCULUS_SKILLS,
SMSG_HOMUNCULUS_DATA,
SMSG_HOMUNCULUS_INFO,
SMSG_HOMUNCULUS_SKILL_UP,
SMSG_HOMUNCULUS_FOOD,
0
};
handledMessages = _messages;
homunculusHandler = this;
}
void HomunculusHandler::handleMessage(Net::MessageIn &msg)
{
switch (msg.getId())
{
case SMSG_HOMUNCULUS_SKILLS:
HomunculusRecv::processHomunculusSkills(msg);
break;
case SMSG_HOMUNCULUS_DATA:
HomunculusRecv::processHomunculusData(msg);
break;
case SMSG_HOMUNCULUS_INFO:
HomunculusRecv::processHomunculusInfo(msg);
break;
case SMSG_HOMUNCULUS_SKILL_UP:
HomunculusRecv::processHomunculusSkillUp(msg);
break;
case SMSG_HOMUNCULUS_FOOD:
HomunculusRecv::processHomunculusFood(msg);
break;
default:
break;
}
}
void HomunculusHandler::setName(const std::string &name) const
{
createOutPacket(CMSG_HOMUNCULUS_SET_NAME);
outMsg.writeString(name, 24, "name");
}
void HomunculusHandler::moveToMaster() const
{
const BeingId id = PlayerInfo::getHomunculusId();
if (id == BeingId_zero)
return;
createOutPacket(CMSG_HOMMERC_MOVE_TO_MASTER);
outMsg.writeBeingId(id, "homunculus id");
}
void HomunculusHandler::move(const int x, const int y) const
{
const BeingId id = PlayerInfo::getHomunculusId();
if (id == BeingId_zero)
return;
createOutPacket(CMSG_HOMMERC_MOVE_TO);
outMsg.writeBeingId(id, "homunculus id");
outMsg.writeCoordinates(static_cast(x),
static_cast(y),
0U, "position");
}
void HomunculusHandler::attack(const BeingId targetId,
const Keep keep) const
{
const BeingId id = PlayerInfo::getHomunculusId();
if (id == BeingId_zero)
return;
createOutPacket(CMSG_HOMMERC_ATTACK);
outMsg.writeBeingId(id, "homunculus id");
outMsg.writeBeingId(targetId, "target id");
outMsg.writeInt8(static_cast(keep == Keep_true ? 1 : 0), "keep");
}
void HomunculusHandler::feed() const
{
createOutPacket(CMSG_HOMUNCULUS_MENU);
outMsg.writeInt16(0, "type");
outMsg.writeInt8(1, "command"); // feed
}
void HomunculusHandler::fire() const
{
createOutPacket(CMSG_HOMUNCULUS_MENU);
outMsg.writeInt16(0, "type");
outMsg.writeInt8(2, "command"); // delete
}
void HomunculusHandler::talk(const std::string &restrict text) const
{
if (!serverFeatures->haveMovePet())
return;
if (text.empty())
return;
std::string msg = text;
if (msg.size() > 500)
msg = msg.substr(0, 500);
const size_t sz = msg.size();
createOutPacket(CMSG_HOMMERC_TALK);
outMsg.writeInt16(static_cast(sz + 4 + 1), "len");
outMsg.writeString(msg, static_cast(sz), "message");
outMsg.writeInt8(0, "zero byte");
}
void HomunculusHandler::emote(const uint8_t emoteId) const
{
if (!serverFeatures->haveMovePet())
return;
createOutPacket(CMSG_HOMMERC_EMOTE);
outMsg.writeInt8(emoteId, "emote id");
}
void HomunculusHandler::setDirection(const unsigned char type) const
{
if (!serverFeatures->haveMovePet())
return;
createOutPacket(CMSG_HOMMERC_DIRECTION);
outMsg.writeInt32(0, "pet id");
outMsg.writeInt8(0, "head direction");
outMsg.writeInt8(0, "unused");
outMsg.writeInt8(MessageOut::toServerDirection(type),
"pet direction");
}
} // namespace EAthena