summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/net/beinghandler.cpp31
-rw-r--r--src/net/gameserver/player.cpp11
-rw-r--r--src/net/gameserver/player.h10
-rw-r--r--src/net/protocol.h1
4 files changed, 52 insertions, 1 deletions
diff --git a/src/net/beinghandler.cpp b/src/net/beinghandler.cpp
index 38299b8d..28791975 100644
--- a/src/net/beinghandler.cpp
+++ b/src/net/beinghandler.cpp
@@ -37,6 +37,12 @@
#include "../particle.h"
#include "../sound.h"
+#include "../gui/ok_dialog.h"
+
+#include "../utils/gettext.h"
+
+#include "gameserver/player.h"
+
const int EMOTION_TIME = 150; /**< Duration of emotion icon */
BeingHandler::BeingHandler()
@@ -592,9 +598,32 @@ void BeingHandler::handleBeingsDamageMessage(MessageIn &msg)
void BeingHandler::handleBeingActionChangeMessage(MessageIn &msg)
{
Being* being = beingManager->findBeing(msg.readInt16());
+ Being::Action action = (Being::Action) msg.readInt8();
if (!being) return;
- being->setAction((Being::Action) msg.readInt8());
+ being->setAction(action);
+
+ if (action == Being::DEAD && being==player_node)
+ {
+ static char const *const deadMsg[] =
+ {
+ _("You are dead."),
+ _("We regret to inform you that your character was killed in battle."),
+ _("You are not that alive anymore."),
+ _("The cold hands of the grim reaper are grabbing for your soul."),
+ _("Game Over!"),
+ _("No, kids. Your character did not really die. It... err... went to a better place."),
+ _("Your plan of breaking your enemies weapon by bashing it with your throat failed."),
+ _("I guess this did not run too well."),
+ _("Do you want your possessions identified?"), // Nethack reference
+ _("Sadly, no trace of you was ever found..."), // Secret of Mana reference
+
+ };
+ std::string message(deadMsg[rand()%10]);
+ message.append(" Press OK to respawn");
+ OkDialog *dlg = new OkDialog(_("You died"), message);
+ dlg->addActionListener(&(Net::GameServer::Player::respawnListener));
+ }
}
void BeingHandler::handleBeingLooksChangeMessage(MessageIn &msg)
diff --git a/src/net/gameserver/player.cpp b/src/net/gameserver/player.cpp
index 67edc7ad..d8050d2b 100644
--- a/src/net/gameserver/player.cpp
+++ b/src/net/gameserver/player.cpp
@@ -29,6 +29,11 @@
#include "../messageout.h"
#include "../protocol.h"
+void RespawnRequestListener::action(const gcn::ActionEvent &event)
+{
+ Net::GameServer::Player::respawn();
+}
+
void Net::GameServer::Player::say(const std::string &text)
{
MessageOut msg(PGMSG_SAY);
@@ -168,3 +173,9 @@ void Net::GameServer::Player::lowerAttribute(int attribute)
msg.writeInt8(attribute);
Net::GameServer::connection->send(msg);
}
+
+void Net::GameServer::Player::respawn()
+{
+ MessageOut msg(PGMSG_RESPAWN);
+ Net::GameServer::connection->send(msg);
+}
diff --git a/src/net/gameserver/player.h b/src/net/gameserver/player.h
index 7ebb2830..eea15c2b 100644
--- a/src/net/gameserver/player.h
+++ b/src/net/gameserver/player.h
@@ -26,8 +26,16 @@
#include "../../being.h"
+#include <guichan/actionlistener.hpp>
+
#include <iosfwd>
+
+struct RespawnRequestListener : public gcn::ActionListener
+{
+ void action(const gcn::ActionEvent &event);
+};
+
namespace Net
{
namespace GameServer
@@ -53,6 +61,8 @@ namespace Net
void tradeWithNPC(int item, int amount);
void raiseAttribute(int attribute);
void lowerAttribute(int attribute);
+ void respawn();
+ static RespawnRequestListener respawnListener;
}
}
}
diff --git a/src/net/protocol.h b/src/net/protocol.h
index e6f5869b..eb65febe 100644
--- a/src/net/protocol.h
+++ b/src/net/protocol.h
@@ -90,6 +90,7 @@ enum {
GPMSG_RAISE_ATTRIBUTE_RESPONSE = 0x0161, // B error, B attribute
PGMSG_LOWER_ATTRIBUTE = 0x0170, // B attribute
GPMSG_LOWER_ATTRIBUTE_RESPONSE = 0x0171, // B error, B attribute
+ PGMSG_RESPAWN = 0x0180, // -
GPMSG_BEING_ENTER = 0x0200, // B type, W being id, B action, W*2 position
// player: S name, B hair style, B hair color, B gender, B item bitmask, { W item id }*
// monster: W type id