summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDavid Athay <ko2fan@gmail.com>2008-10-21 13:15:29 +0000
committerDavid Athay <ko2fan@gmail.com>2008-10-21 13:15:29 +0000
commit01511ddb3a81eec835073bc4f30a6707ae552002 (patch)
tree48fda9cef5600b708941f54b4940102a3e496d2b
parent7eb4f31b82976d222336132586dd31ff07bf3d1e (diff)
downloadmana-01511ddb3a81eec835073bc4f30a6707ae552002.tar.gz
mana-01511ddb3a81eec835073bc4f30a6707ae552002.tar.bz2
mana-01511ddb3a81eec835073bc4f30a6707ae552002.tar.xz
mana-01511ddb3a81eec835073bc4f30a6707ae552002.zip
Fixed up some of the postal system stuff for testing it.
-rw-r--r--ChangeLog6
-rw-r--r--src/commandhandler.cpp13
-rw-r--r--src/game.cpp3
-rw-r--r--src/game.h1
-rw-r--r--src/net/posthandler.cpp80
-rw-r--r--src/net/posthandler.h37
-rw-r--r--src/net/protocol.h2
7 files changed, 141 insertions, 1 deletions
diff --git a/ChangeLog b/ChangeLog
index 5d2417f3..686f8983 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,9 @@
+2008-10-21 David Athay <ko2fan@gmail.com>
+
+ * src/game.cpp, src/commandhandler.cpp, src/net/posthandler.h,
+ src/net/posthandler.cpp, src/net/protocol.h, src/game.h: Fixed some of
+ the test stuff for the postal system.
+
2008-10-15 David Athay <ko2fan@gmail.com>
* src/localplayer.cpp, src/net/beinghandler.cpp, src/net/protocol.h,
diff --git a/src/commandhandler.cpp b/src/commandhandler.cpp
index 58b8905d..66f746f3 100644
--- a/src/commandhandler.cpp
+++ b/src/commandhandler.cpp
@@ -96,8 +96,21 @@ void CommandHandler::handleCommand(const std::string &command)
else if (type == "post")
{
std::string::size_type pos = args.find(' ');
+ if (pos == std::string::npos)
+ {
+ chatWindow->chatLog("Please include the user and message");
+ return;
+ }
std::string recipient(args, 0, pos);
+ if (recipient == "")
+ {
+ chatWindow->chatLog("Invalid user");
+ }
std::string text(args, pos+1);
+ if (text == "")
+ {
+ chatWindow->chatLog("Invalid message");
+ }
Net::GameServer::Player::sendLetter(recipient, text);
}
else if (type == "check")
diff --git a/src/game.cpp b/src/game.cpp
index fb434be2..fc16e1ea 100644
--- a/src/game.cpp
+++ b/src/game.cpp
@@ -82,6 +82,7 @@
#include "net/network.h"
#include "net/npchandler.h"
#include "net/partyhandler.h"
+#include "net/posthandler.h"
#include "net/playerhandler.h"
#include "net/tradehandler.h"
@@ -272,6 +273,7 @@ Game::Game():
mNpcHandler(new NPCHandler()),
mPartyHandler(new PartyHandler()),
mPlayerHandler(new PlayerHandler()),
+ mPostHandler(new PostHandler()),
mTradeHandler(new TradeHandler()),
mLogicCounterId(0), mSecondsCounterId(0)
{
@@ -317,6 +319,7 @@ Game::Game():
Net::registerHandler(mNpcHandler.get());
Net::registerHandler(mPartyHandler.get());
Net::registerHandler(mPlayerHandler.get());
+ Net::registerHandler(mPostHandler.get());
Net::registerHandler(mTradeHandler.get());
}
diff --git a/src/game.h b/src/game.h
index cdfe025b..78c5dc80 100644
--- a/src/game.h
+++ b/src/game.h
@@ -69,6 +69,7 @@ class Game : public ConfigListener
MessageHandlerPtr mNpcHandler;
MessageHandlerPtr mPartyHandler;
MessageHandlerPtr mPlayerHandler;
+ MessageHandlerPtr mPostHandler;
MessageHandlerPtr mTradeHandler;
SDL_TimerID mLogicCounterId;
diff --git a/src/net/posthandler.cpp b/src/net/posthandler.cpp
new file mode 100644
index 00000000..673d8611
--- /dev/null
+++ b/src/net/posthandler.cpp
@@ -0,0 +1,80 @@
+/*
+ * The Mana World
+ * Copyright 2009 The Mana World Development Team
+ *
+ * This file is part of The Mana World.
+ *
+ * The Mana World 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.
+ *
+ * The Mana World 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 The Mana World; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+ *
+ * $Id$
+ */
+
+#include "posthandler.h"
+
+#include <string>
+#include <sstream>
+
+#include "messagein.h"
+#include "protocol.h"
+
+#include "../gui/chat.h"
+
+PostHandler::PostHandler()
+{
+ static const Uint16 _messages[] = {
+ GPMSG_SEND_POST_RESPONSE,
+ GPMSG_GET_POST_RESPONSE,
+ 0
+ };
+ handledMessages = _messages;
+}
+
+void PostHandler::handleMessage(MessageIn &msg)
+{
+ switch (msg.getId())
+ {
+ case GPMSG_SEND_POST_RESPONSE:
+ {
+ if (msg.readInt8() == ERRMSG_OK)
+ {
+ chatWindow->chatLog("Post sent successfully");
+ }
+ else
+ {
+ chatWindow->chatLog("Unable to send post");
+ }
+ } break;
+
+ case GPMSG_GET_POST_RESPONSE:
+ {
+ std::stringstream str;
+ // get the name of the sender
+ std::string sender = msg.readString();
+
+ if (sender == "")
+ {
+ chatWindow->chatLog("No post found");
+ break;
+ }
+
+ // get the message
+ std::string letter = msg.readString();
+
+ // put message together
+ str << "Message from " << sender << " says: " << letter;
+ chatWindow->chatLog(str.str());
+ } break;
+ }
+}
diff --git a/src/net/posthandler.h b/src/net/posthandler.h
new file mode 100644
index 00000000..d46b8bce
--- /dev/null
+++ b/src/net/posthandler.h
@@ -0,0 +1,37 @@
+/*
+ * The Mana World
+ * Copyright 2009 The Mana World Development Team
+ *
+ * This file is part of The Mana World.
+ *
+ * The Mana World 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.
+ *
+ * The Mana World 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 The Mana World; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+ *
+ * $Id$
+ */
+
+#ifndef _TMW_NET_POSTHANDLER_H
+#define _TMW_NET_POSTHANDLER_H
+
+#include "messagehandler.h"
+
+class PostHandler : public MessageHandler
+{
+public:
+ PostHandler();
+
+ void handleMessage(MessageIn &msg);
+};
+
+#endif
diff --git a/src/net/protocol.h b/src/net/protocol.h
index f766d2da..ad1eebdb 100644
--- a/src/net/protocol.h
+++ b/src/net/protocol.h
@@ -186,7 +186,7 @@ enum {
PGMSG_SEND_POST = 0x04A0, // S player, S letter, { W attachment id }
GPMSG_SEND_POST_RESPONSE = 0x04A1, // B error
PGMSG_GET_POST = 0x04A2, //
- GPMSG_GET_POST_RESPONSE = 0x04A3, // { L sender id, S letter, { W attachment id } }
+ GPMSG_GET_POST_RESPONSE = 0x04A3, // { S sender name, S letter, { W attachment id } }
XXMSG_INVALID = 0x7FFF
};