summaryrefslogtreecommitdiff
path: root/src/net/ea/partyhandler.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/net/ea/partyhandler.cpp')
-rw-r--r--src/net/ea/partyhandler.cpp117
1 files changed, 108 insertions, 9 deletions
diff --git a/src/net/ea/partyhandler.cpp b/src/net/ea/partyhandler.cpp
index 625f233a..8001488a 100644
--- a/src/net/ea/partyhandler.cpp
+++ b/src/net/ea/partyhandler.cpp
@@ -23,6 +23,7 @@
#include "beingmanager.h"
#include "localplayer.h"
+#include "log.h"
#include "gui/chat.h"
#include "gui/partywindow.h"
@@ -82,6 +83,8 @@ void PartyHandler::handleMessage(MessageIn &msg)
break;
case SMSG_PARTY_INFO:
{
+ partyWindow->clear();
+
int length = msg.readInt16();
std::string party = msg.readString(24);
int count = (length - 28) / 46;
@@ -96,6 +99,8 @@ void PartyHandler::handleMessage(MessageIn &msg)
partyWindow->updateMember(id, nick, leader, online);
}
+
+ partyWindow->setVisible(true);
}
break;
case SMSG_PARTY_INVITE_RESPONSE:
@@ -147,9 +152,58 @@ void PartyHandler::handleMessage(MessageIn &msg)
break;
}
case SMSG_PARTY_SETTINGS:
- // I don't see this in eAthena's source
- printf("Party settings!\n");
- break;
+ {
+ // These seem to indicate the sharing mode for exp and items
+ short exp = msg.readInt16();
+ short item = msg.readInt16();
+
+ switch (exp) {
+ case PARTY_SHARE:
+ if (mShareExp == PARTY_SHARE)
+ break;
+ mShareExp = PARTY_SHARE;
+ partyTab->chatLog(_("Experience sharing enabled."), BY_SERVER);
+ break;
+ case PARTY_SHARE_NO:
+ if (mShareExp == PARTY_SHARE_NO)
+ break;
+ mShareExp =PARTY_SHARE_NO;
+ partyTab->chatLog(_("Experience sharing disabled."), BY_SERVER);
+ break;
+ case PARTY_SHARE_NOT_POSSIBLE:
+ if (mShareExp == PARTY_SHARE_NOT_POSSIBLE)
+ break;
+ mShareExp = PARTY_SHARE_NOT_POSSIBLE;
+ partyTab->chatLog(_("Experience sharing not possible."), BY_SERVER);
+ break;
+ default:
+ logger->log("Unknown party exp option: %d\n", exp);
+ }
+
+ switch (item) {
+ case PARTY_SHARE:
+ if (mShareItems == PARTY_SHARE)
+ break;
+ mShareItems = PARTY_SHARE;
+ partyTab->chatLog(_("Item sharing enabled."), BY_SERVER);
+ break;
+ case PARTY_SHARE_NO:
+ if (mShareItems == PARTY_SHARE_NO)
+ break;
+ mShareItems =PARTY_SHARE_NO;
+ partyTab->chatLog(_("Item sharing disabled."), BY_SERVER);
+ break;
+ case PARTY_SHARE_NOT_POSSIBLE:
+ if (mShareItems == PARTY_SHARE_NOT_POSSIBLE)
+ break;
+ mShareItems = PARTY_SHARE_NOT_POSSIBLE;
+ partyTab->chatLog(_("Item sharing not possible."), BY_SERVER);
+ break;
+ default:
+ logger->log("Unknown party item option: %d\n", exp);
+ }
+ break;
+ }
case SMSG_PARTY_MOVE:
{
msg.readInt32(); // id
@@ -167,7 +221,15 @@ void PartyHandler::handleMessage(MessageIn &msg)
int id = msg.readInt32();
std::string nick = msg.readString(24);
msg.readInt8(); // fail
- partyTab->chatLog(strprintf(_("%s has left your party."),
+ if (id == player_node->getId())
+ {
+ player_node->setInParty(false);
+ partyWindow->clear();
+ partyWindow->setVisible(false);
+ partyTab->chatLog(_("You have left the party."), BY_SERVER);
+ }
+ else
+ partyTab->chatLog(strprintf(_("%s has left your party."),
nick.c_str()), BY_SERVER);
partyWindow->removeMember(id);
break;
@@ -219,6 +281,7 @@ void PartyHandler::create(const std::string &name)
void PartyHandler::join(int partyId)
{
+ // TODO?
}
void PartyHandler::invite(Player *player)
@@ -229,7 +292,7 @@ void PartyHandler::invite(Player *player)
void PartyHandler::invite(const std::string &name)
{
- // TODO
+ // TODO?
}
void PartyHandler::inviteResponse(const std::string &inviter, bool accept)
@@ -243,13 +306,28 @@ void PartyHandler::inviteResponse(const std::string &inviter, bool accept)
void PartyHandler::leave()
{
MessageOut outMsg(CMSG_PARTY_LEAVE);
- partyTab->chatLog(_("Left party."), BY_SERVER);
- player_node->setInParty(false);
}
-void PartyHandler::kick(int playerId)
+void PartyHandler::kick(Player *player)
{
- // TODO
+ MessageOut outMsg(CMSG_PARTY_KICK);
+ outMsg.writeInt32(player->getId());
+ outMsg.writeString("", 24); //Unused
+}
+
+void PartyHandler::kick(const std::string &name)
+{
+ int id = partyWindow->findMember(name);
+ if (id == -1)
+ {
+ partyTab->chatLog(strprintf(_("%s is not in your party!"), name.c_str()),
+ BY_SERVER);
+ return;
+ }
+
+ MessageOut outMsg(CMSG_PARTY_KICK);
+ outMsg.writeInt32(id);
+ outMsg.writeString(name, 24); //Unused
}
void PartyHandler::chat(const std::string &text)
@@ -262,6 +340,27 @@ void PartyHandler::chat(const std::string &text)
void PartyHandler::requestPartyMembers()
{
// Our eAthena doesn't have this message
+ // Not needed anyways
+}
+
+void PartyHandler::setShareExperience(PartyShare share)
+{
+ if (share == PARTY_SHARE_NOT_POSSIBLE)
+ return;
+
+ MessageOut outMsg(CMSG_PARTY_SETTINGS);
+ outMsg.writeInt16(share);
+ outMsg.writeInt16(mShareItems);
+}
+
+void PartyHandler::setShareItems(PartyShare share)
+{
+ if (share == PARTY_SHARE_NOT_POSSIBLE)
+ return;
+
+ MessageOut outMsg(CMSG_PARTY_SETTINGS);
+ outMsg.writeInt16(mShareExp);
+ outMsg.writeInt16(share);
}
} // namespace EAthena