summaryrefslogtreecommitdiff
path: root/src/gui/chat.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/gui/chat.cpp')
-rw-r--r--src/gui/chat.cpp487
1 files changed, 247 insertions, 240 deletions
diff --git a/src/gui/chat.cpp b/src/gui/chat.cpp
index b9b1daf7..b1cec890 100644
--- a/src/gui/chat.cpp
+++ b/src/gui/chat.cpp
@@ -21,278 +21,285 @@
#include "chat.h"
-/**
- Simple ChatLog Object v0.5 (i'd say...)
-
- Bestviewd w/ Bitstream Vera Sans Mono @ 9pt and a tab-width of 2 spaces
-
- Author: kth5 aka Alexander Baldeck
- pipe your questions, suggestions and flames to: kth5@gawab.com
-*/
+/*
+ * Simple ChatLog Object v0.5 (i'd say...)
+ *
+ * Bestviewd w/ Bitstream Vera Sans Mono @ 9pt and a tab-width of 2 spaces
+ *
+ * Author: kth5 aka Alexander Baldeck
+ * pipe your questions, suggestions and flames to: kth5@gawab.com
+ */
-/**
-*/
+/*
+ */
Chat::Chat(const char * logfile, int item_num) {
- chatlog_file.open(logfile, std::ios::out | std::ios::app);
- items = 0;
- items_keep = item_num;
+ chatlog_file.open(logfile, std::ios::out | std::ios::app);
+ items = 0;
+ items_keep = item_num;
}
-/**
-*/
+/*
+ */
Chat::~Chat() {
- chatlog_file.flush();
- chatlog_file.close();
+ chatlog_file.flush();
+ chatlog_file.close();
}
-/**
-*/
+/*
+ */
void Chat::chat_dlgrsize(int) {
}
-/** adds a line of text to our message list
-
- string line -> message text
- int own -> type of message (usually the owner-type)
- ALFONT_FONT * font -> font that'll be used to draw the text later
-
- NOTE:
- to all of you who wonder why the font needs to be passed, simple.
- i already store the width in pixel in the list rather than
- calculating it again and again on every draw event. ;-)
+/*
+ * Adds a line of text to our message list. Parameters:
+ *
+ * line: message text
+ * own: type of message (usually the owner-type)
+ * font: font that'll be used to draw the text later
+ *
+ * NOTE:
+ * To all of you who wonder why the font needs to be passed, simple.
+ * i already store the width in pixel in the list rather than
+ * calculating it again and again on every draw event. ;-)
*/
void Chat::chat_log(std::string line, int own, ALFONT_FONT * font) {
- int pos;
- CHATLOG tmp;
-
- if(items<=items_keep)
- items++; // delete overhead from the end of the list
- else
- chatlog.pop_back();
-
- pos = 0;
- pos = (int)line.find(" : ", 0);
- if(pos > 0) {
- tmp.nick = line.substr(0,pos);
- switch(own) {
- case ACT_IS :
- tmp.nick += CAT_IS;
- break;
- case ACT_WHISPER :
- tmp.nick += CAT_WHISPER;
- break;
- default :
- tmp.nick += CAT_NORMAL;
- }
- tmp.width = TEXT_GETWIDTH(tmp.nick.c_str())+2;
- line.erase(0,pos+3);
- }else {
- tmp.nick = "";
- tmp.width = 1;
- }
- tmp.own = own;
- tmp.text = line;
+ int pos;
+ CHATLOG tmp;
+
+ if (items <= items_keep) {
+ items++; // delete overhead from the end of the list
+ }
+ else {
+ chatlog.pop_back();
+ }
+
+ pos = 0;
+ pos = (int)line.find(" : ", 0);
+ if (pos > 0) {
+ tmp.nick = line.substr(0,pos);
+ switch(own) {
+ case ACT_IS :
+ tmp.nick += CAT_IS;
+ break;
+ case ACT_WHISPER :
+ tmp.nick += CAT_WHISPER;
+ break;
+ default :
+ tmp.nick += CAT_NORMAL;
+ }
+ tmp.width = TEXT_GETWIDTH(tmp.nick.c_str())+2;
+ line.erase(0,pos+3);
+ } else {
+ tmp.nick = "";
+ tmp.width = 1;
+ }
+ tmp.own = own;
+ tmp.text = line;
- chatlog_file << tmp.nick << tmp.text << "\n";
- chatlog_file.flush();
+ chatlog_file << tmp.nick << tmp.text << "\n";
+ chatlog_file.flush();
- chatlog.push_front(tmp);
+ chatlog.push_front(tmp);
}
-/** function overload -> calls original chat_log()
- after processing the packet
-*/
+/*
+ * function overload -> calls original chat_log() after processing the packet
+ */
void Chat::chat_log(CHATSKILL action, ALFONT_FONT * font) {
- chat_log(const_msg(action), BY_SERVER, font);
+ chat_log(const_msg(action), BY_SERVER, font);
}
-/** draw first n lines of the list onto a Allegro type bitmap buffer
- using Alfont
-
- BITMAP * bmp -> Allegro type bitmap buffer to draw onto
- int n -> number of lines to be drawn
- ALFONT_FONT * font -> font to use
-
- NOTE:
- take great care using this, make sure the buffer passed is
- empty! ;-) anyway, line wrapping is not supported yet.
+/*
+ * Draw first n lines of the list onto a Allegro type bitmap buffer using
+ * Alfont.
+ *
+ * BITMAP * bmp: Allegro type bitmap buffer to draw onto
+ * int n: number of lines to be drawn
+ * ALFONT_FONT * font: font to use
+ *
+ * NOTE:
+ * take great care using this, make sure the buffer passed is
+ * empty! ;-) anyway, line wrapping is not supported yet.
*/
void Chat::chat_draw(BITMAP * bmp, int n, ALFONT_FONT * font) {
- int y = 600-35, i = 0;
- CHATLOG line;
- n -= 1;
-
- for(iter = chatlog.begin(); iter != chatlog.end(); iter++) {
- line = *iter;
- y -=11;
-
- switch(line.own) {
- case BY_GM :
- alfont_textprintf_aa(bmp, font, 1, y, COLOR_BLUE, "Global announcement: ");
- alfont_textprintf_aa(bmp, font, TEXT_GETWIDTH("Global announcement: "), y, COLOR_GREEN, line.text.c_str());
- break;
- case BY_PLAYER :
- alfont_textprintf_aa(bmp, font, 1, y, COLOR_YELLOW, line.nick.c_str());
- alfont_textprintf_aa(bmp, font, line.width, y, COLOR_WHITE, line.text.c_str());
- break;
- case BY_OTHER :
- alfont_textprintf_aa(bmp, font, 1, y, COLOR_GREEN, line.nick.c_str());
- alfont_textprintf_aa(bmp, font, line.width, y, COLOR_WHITE, line.text.c_str());
- break;
- default :
- alfont_textprintf_aa(bmp, font, 1, y, COLOR_LIGHTBLUE, line.text.c_str());
- }
-
- if(i>=n)
- return;
- i++;
- }
+ int y = 600-35, i = 0;
+ CHATLOG line;
+ n -= 1;
+
+ for (iter = chatlog.begin(); iter != chatlog.end(); iter++) {
+ line = *iter;
+ y -=11;
+
+ switch (line.own) {
+ case BY_GM :
+ alfont_textprintf_aa(bmp, font, 1, y, COLOR_BLUE, "Global announcement: ");
+ alfont_textprintf_aa(bmp, font, TEXT_GETWIDTH("Global announcement: "), y, COLOR_GREEN, line.text.c_str());
+ break;
+ case BY_PLAYER :
+ alfont_textprintf_aa(bmp, font, 1, y, COLOR_YELLOW, line.nick.c_str());
+ alfont_textprintf_aa(bmp, font, line.width, y, COLOR_WHITE, line.text.c_str());
+ break;
+ case BY_OTHER :
+ alfont_textprintf_aa(bmp, font, 1, y, COLOR_GREEN, line.nick.c_str());
+ alfont_textprintf_aa(bmp, font, line.width, y, COLOR_WHITE, line.text.c_str());
+ break;
+ default :
+ alfont_textprintf_aa(bmp, font, 1, y, COLOR_LIGHTBLUE, line.text.c_str());
+ }
+
+ if (i>=n) {
+ return;
+ }
+ i++;
+ }
}
-/** determines wether to send a command or an ordinary message, then
- contructs packets & sends them
-
- string nick -> the character's name to display infront
- string msg -> the message's text which is to be send.
-
- NOTE:
- the nickname is required by the server, if not specified
- the message may not be sent unless a command was intended
- which requires another packet to be constructed! you can
- achieve this by putting a slash ("/") infront of the
- message followed by the command name and the message.
- of course all slash-commands need implemented handler-
- routines. ;-)
- remember, a line starting w/ "@" is not a command that needs
- to be parsed rather is sent using the normal chat-packet.
-
- EXAMPLE:
- // for an global announcement /- command
- chatlog.chat_send("", "/announce Hello to all logged in users!");
- // for simple message by a user /- message
- chatlog.chat_send("Zaeiru", "Hello to all users on the screen!");
-*/
+/*
+ * Determines wether to send a command or an ordinary message, then
+ * contructs packets & sends them
+ *
+ * string nick -> the character's name to display infront
+ * string msg -> the message's text which is to be send.
+ *
+ * NOTE:
+ * the nickname is required by the server, if not specified
+ * the message may not be sent unless a command was intended
+ * which requires another packet to be constructed! you can
+ * achieve this by putting a slash ("/") infront of the
+ * message followed by the command name and the message.
+ * of course all slash-commands need implemented handler-
+ * routines. ;-)
+ * remember, a line starting w/ "@" is not a command that needs
+ * to be parsed rather is sent using the normal chat-packet.
+ *
+ * EXAMPLE:
+ * // for an global announcement /- command
+ * chatlog.chat_send("", "/announce Hello to all logged in users!");
+ * // for simple message by a user /- message
+ * chatlog.chat_send("Zaeiru", "Hello to all users on the screen!");
+ */
char * Chat::chat_send(std::string nick, std::string msg) {
- short packid;
-
- // prepare command
- if(msg.substr(0,1)=="/") {
- // global announcement
- if(msg.substr(0,IS_ANNOUNCE_LENGTH) == IS_ANNOUNCE) {
- msg.erase(0,IS_ANNOUNCE_LENGTH);
- packid = 0x0099;
- } else if(msg.substr(0,IS_WHERE_LENGTH) == IS_WHERE) {
+ short packid;
+
+ // prepare command
+ if(msg.substr(0,1)=="/") {
+ // global announcement
+ if(msg.substr(0,IS_ANNOUNCE_LENGTH) == IS_ANNOUNCE) {
+ msg.erase(0,IS_ANNOUNCE_LENGTH);
+ packid = 0x0099;
+ } else if(msg.substr(0,IS_WHERE_LENGTH) == IS_WHERE) {
+ } else {
+ packid = 0x008c;
+ }
+ // prepare ordinary message
} else {
- packid = 0x008c;
- }
- // prepare ordinary message
- } else {
- // temporary hack to make messed-up-keyboard-ppl able to send GM commands
- if(msg.substr(0,1)=="#")
- msg.replace(0,1,"@");
- // end temp. hack XD
- nick += " : ";
- nick += msg;
- msg = nick;
- packid = 0x008c;
- }
-
- msg += "\0";
-
- // send processed message
- WFIFOW(0) = net_w_value(packid);
- WFIFOW(2) = net_w_value((unsigned short)(msg.length()+4));
- memcpy(WFIFOP(4), msg.c_str(), msg.length());
- WFIFOSET((int)msg.length()+4);
- nick = msg = "";
- return "";
+ // temporary hack to make messed-up-keyboard-ppl able to send GM commands
+ if(msg.substr(0,1)=="#")
+ msg.replace(0,1,"@");
+ // end temp. hack XD
+ nick += " : ";
+ nick += msg;
+ msg = nick;
+ packid = 0x008c;
+ }
+
+ msg += "\0";
+
+ // send processed message
+ WFIFOW(0) = net_w_value(packid);
+ WFIFOW(2) = net_w_value((unsigned short)(msg.length()+4));
+ memcpy(WFIFOP(4), msg.c_str(), msg.length());
+ WFIFOSET((int)msg.length()+4);
+ nick = msg = "";
+ return "";
}
-/** PRIVATE :
- NOTE:
- these usually will be left undocumented coz u can't call them
- directly anyway. ;-)
-*/
+/*
+ * PRIVATE :
+ * NOTE:
+ * these usually will be left undocumented coz u can't call them
+ * directly anyway. ;-)
+ */
/** constructs failed messages for actions */
std::string Chat::const_msg(CHATSKILL action) {
- std::string msg;
- if(action.success == SKILL_FAILED && action.skill == SKILL_BASIC) {
- switch(action.bskill) {
- case BSKILL_TRADE :
- msg = "Trade failed!";
- break;
- case BSKILL_EMOTE :
- msg = "Emote failed!";
- break;
- case BSKILL_SIT :
- msg = "Sit failed!";
- break;
- case BSKILL_CREATECHAT :
- msg = "Chat creating failed!";
- break;
- case BSKILL_JOINPARTY :
- msg = "Could not join party!";
- break;
- case BSKILL_SHOUT :
- msg = "Cannot shout!";
- break;
- }
-
- switch(action.reason) {
- case RFAIL_SKILLDEP :
- msg += " You have not yet reached a high enough lvl!";
- break;
- case RFAIL_INSUFHP :
- msg += " Insufficient HP!";
- break;
- case RFAIL_INSUFSP :
- msg += " Insufficient SP!";
- break;
- case RFAIL_NOMEMO :
- msg += " You have no memos!";
- break;
- case RFAIL_SKILLDELAY :
- msg += " You cannot do that right now!";
- break;
- case RFAIL_ZENY :
- msg += " Seems you need more Zeny... ;-)";
- break;
- case RFAIL_WEAPON :
- msg += " You cannot use this skill with that kind of weapon!";
- break;
- case RFAIL_REDGEM :
- msg += " You need another red gem!";
- break;
- case RFAIL_BLUEGEM :
- msg += " You need another blue gem!";
- break;
- case RFAIL_OVERWEIGHT :
- msg += " You're carrying to much to do this!";
- break;
- default :
- msg += " Huh? What's that?";
- break;
- }
- }else{
- switch(action.skill) {
- case SKILL_WARP :
- msg = "Warp failed...";
- break;
- case SKILL_STEAL :
- msg = "Could not steal anything...";
- break;
- case SKILL_ENVENOM :
- msg = "Poison had no effect...";
- break;
- }
- }
-
- return msg;
+ std::string msg;
+ if (action.success == SKILL_FAILED && action.skill == SKILL_BASIC) {
+ switch (action.bskill) {
+ case BSKILL_TRADE :
+ msg = "Trade failed!";
+ break;
+ case BSKILL_EMOTE :
+ msg = "Emote failed!";
+ break;
+ case BSKILL_SIT :
+ msg = "Sit failed!";
+ break;
+ case BSKILL_CREATECHAT :
+ msg = "Chat creating failed!";
+ break;
+ case BSKILL_JOINPARTY :
+ msg = "Could not join party!";
+ break;
+ case BSKILL_SHOUT :
+ msg = "Cannot shout!";
+ break;
+ }
+
+ switch (action.reason) {
+ case RFAIL_SKILLDEP :
+ msg += " You have not yet reached a high enough lvl!";
+ break;
+ case RFAIL_INSUFHP :
+ msg += " Insufficient HP!";
+ break;
+ case RFAIL_INSUFSP :
+ msg += " Insufficient SP!";
+ break;
+ case RFAIL_NOMEMO :
+ msg += " You have no memos!";
+ break;
+ case RFAIL_SKILLDELAY :
+ msg += " You cannot do that right now!";
+ break;
+ case RFAIL_ZENY :
+ msg += " Seems you need more Zeny... ;-)";
+ break;
+ case RFAIL_WEAPON :
+ msg += " You cannot use this skill with that kind of weapon!";
+ break;
+ case RFAIL_REDGEM :
+ msg += " You need another red gem!";
+ break;
+ case RFAIL_BLUEGEM :
+ msg += " You need another blue gem!";
+ break;
+ case RFAIL_OVERWEIGHT :
+ msg += " You're carrying to much to do this!";
+ break;
+ default :
+ msg += " Huh? What's that?";
+ break;
+ }
+ } else {
+ switch(action.skill) {
+ case SKILL_WARP :
+ msg = "Warp failed...";
+ break;
+ case SKILL_STEAL :
+ msg = "Could not steal anything...";
+ break;
+ case SKILL_ENVENOM :
+ msg = "Poison had no effect...";
+ break;
+ }
+ }
+
+ return msg;
}
std::string const_msg(int own) {
- std::string msg;
- return msg;
+ std::string msg;
+ return msg;
}