diff options
-rw-r--r-- | src/gui/chat.cpp | 148 | ||||
-rw-r--r-- | src/gui/chat.h | 40 |
2 files changed, 97 insertions, 91 deletions
diff --git a/src/gui/chat.cpp b/src/gui/chat.cpp index c97f4b65..04a0cdfc 100644 --- a/src/gui/chat.cpp +++ b/src/gui/chat.cpp @@ -54,8 +54,12 @@ ChatWindow::ChatWindow(const char *logfile, int item_num): chatInput->setWidth(600 - 2 * chatInput->getBorderSize()); chatInput->setEventId("chatinput"); chatInput->addActionListener(this); + add(scrollArea); add(chatInput); + + // Add key listener to chat input to be able to respond to up/down + chatInput->addKeyListener(this); } ChatWindow::~ChatWindow() @@ -72,7 +76,7 @@ void ChatWindow::chat_log(std::string line, int own) CHATLOG tmp; // Delete overhead from the end of the list - while (chatlog.size() > items_keep) { + while ((int)chatlog.size() > items_keep) { chatlog.pop_back(); } @@ -102,7 +106,7 @@ void ChatWindow::chat_log(std::string line, int own) // A try to get text sentences no too long... bool finished = false; - unsigned int maxLength = 98; + unsigned int maxLength = 97; while (!finished) { @@ -111,7 +115,7 @@ void ChatWindow::chat_log(std::string line, int own) if (line.length() > maxLength) { if (line.length() > maxLength) { - line = cut_string(tempText, maxLength); + line = cutString(tempText, maxLength); } //tmp.text = tempText; @@ -247,10 +251,6 @@ char *ChatWindow::chat_send(std::string nick, std::string msg) return ""; } 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; @@ -345,23 +345,23 @@ std::string ChatWindow::const_msg(CHATSKILL action) return msg; } -std::string ChatWindow::cut_string(std::string& value, unsigned int maximumLength) +std::string ChatWindow::cutString(std::string& value, unsigned int maximumLength) { // If the string exceeds the maximum length - if(value.length() > maximumLength) + if (value.length() > maximumLength) { unsigned int index = 0; unsigned int lastSpace = 0; std::string cutOff = ""; - for(index = 0; index < maximumLength; index++) { - if(value.at(index) == ' ') { + for (index = 0; index < maximumLength; index++) { + if (value.at(index) == ' ') { lastSpace = index; } } // If the last space is at the beginning of the string - if(lastSpace == 0) { + if (lastSpace == 0) { // Just cut it right off from the end cutOff = value.substr(maximumLength); value = value.substr(0, maximumLength); @@ -377,75 +377,79 @@ std::string ChatWindow::cut_string(std::string& value, unsigned int maximumLengt return std::string(""); } -void ChatWindow::update_history(const char *ptr) +void ChatWindow::updateHistory(const char *ptr) { - f = t; - if(*ptr == 0) return; - - // prevent duplicates - if(f != s && strcmp(ptr, buf[(f + HIST_LEN -1) % HIST_LEN]) == 0) return; - - buf[f] = strdup(ptr); - f = ( f + 1) % HIST_LEN; - - if(f == s) { - free(buf[f]); - buf[s] = 0; - s = (s + 1) % HIST_LEN; - } - - t = f; + f = t; + if(*ptr == 0) return; + + // prevent duplicates + if(f != s && strcmp(ptr, buf[(f + HIST_LEN -1) % HIST_LEN]) == 0) return; + + buf[f] = strdup(ptr); + f = ( f + 1) % HIST_LEN; + + if(f == s) { + free(buf[f]); + buf[s] = 0; + s = (s + 1) % HIST_LEN; + } + + t = f; } -void ChatWindow::arrow_up(void) +void ChatWindow::arrowUp(void) { - const char *ptr; - - ptr = chatInput->getText().c_str(); - - if(*ptr) { - if(t == f || strcmp(ptr, buf[t]) != 0) { - update_history(ptr); - t = (f + HIST_LEN -1) % HIST_LEN; - } - } - - if(t != s) - t = (t + HIST_LEN -1) % HIST_LEN; - if(buf[t]) - update_history(buf[t]); - else - update_history(""); + printf("arrowUp\n"); + const char *ptr; + + ptr = chatInput->getText().c_str(); + + if (*ptr) { + if(t == f || strcmp(ptr, buf[t]) != 0) { + updateHistory(ptr); + t = (f + HIST_LEN - 1) % HIST_LEN; + } + } + + if (t != s) + t = (t + HIST_LEN -1) % HIST_LEN; + if (buf[t]) + updateHistory(buf[t]); + else + updateHistory(""); } -void ChatWindow::arrow_down(void) +void ChatWindow::arrowDown(void) { - const char *ptr; - - ptr = chatInput->getText().c_str(); - - if(*ptr) { - if(t == f || strcmp(ptr, buf[t]) != 0) { - update_history(ptr); - t = (f + HIST_LEN -1) % HIST_LEN; - } - } - - if(t != f) - t = (t + 1) % HIST_LEN; - - if(buf[t]) - update_history(buf[t]); - else - update_history(""); + printf("arrowDown\n"); + const char *ptr; + + ptr = chatInput->getText().c_str(); + + if (*ptr) { + if(t == f || strcmp(ptr, buf[t]) != 0) { + updateHistory(ptr); + t = (f + HIST_LEN - 1) % HIST_LEN; + } + } + + if (t != f) + t = (t + 1) % HIST_LEN; + + if (buf[t]) + updateHistory(buf[t]); + else + updateHistory(""); } -void ChatWindow::keyPress(const gcn::Key& key) +void ChatWindow::keyPress(const gcn::Key &key) { - if(key.getValue() == key.DOWN) - arrow_down(); - else if(key.getValue() == key.UP) - arrow_up(); + if (key.getValue() == key.DOWN) + arrowDown(); + else if (key.getValue() == key.UP) + arrowUp(); - chatInput->setText(std::string(buf[t])); + if (buf[t]) { + chatInput->setText(std::string(buf[t])); + } } diff --git a/src/gui/chat.h b/src/gui/chat.h index 574accab..b078e952 100644 --- a/src/gui/chat.h +++ b/src/gui/chat.h @@ -88,7 +88,8 @@ /** should always be zero if failed */ #define SKILL_FAILED 0x00 -struct CHATSKILL { +struct CHATSKILL +{ short skill; short bskill; short unused; @@ -99,7 +100,9 @@ struct CHATSKILL { /** * Simple chatlog object. */ -class ChatWindow : public Window, public gcn::ActionListener { +class ChatWindow : public Window, public gcn::ActionListener, + public gcn::KeyListener +{ public: /** * Constructor. @@ -170,14 +173,14 @@ class ChatWindow : public Window, public gcn::ActionListener { */ char *chat_send(std::string nick, std::string msg); - /** History */ - void update_history(const char *ptr); - void arrow_up(void); - void arrow_down(void); + /** History */ + void updateHistory(const char *ptr); + void arrowUp(void); + void arrowDown(void); + + /** Called when key is pressed */ + void keyPress(const gcn::Key& key); - /** Called when key is pressed */ - void keyPress(const gcn::Key& key); - private : std::ofstream chatlog_file; @@ -197,20 +200,19 @@ class ChatWindow : public Window, public gcn::ActionListener { std::string const_msg(CHATSKILL); /** - * Cuts a string into two on a per word basis - * @param value The string to be cut, it may be modified - * in the function. + * Cuts a string into two on a per word basis. + * + * @param value The string to be cut, it may be modified + * in the function. * @param maximumLength The length after which the string - * should be cut. + * should be cut. * @return The cut off section of the string */ - std::string cut_string(std::string& value, unsigned int maximumLength); - - /** Input box for chat messages */ - gcn::TextField *chatInput; - gcn::TextBox *textOutput; - ScrollArea *scrollArea; + std::string cutString(std::string& value, unsigned int maximumLength); + gcn::TextField *chatInput; /**< Input box for typing chat messages */ + gcn::TextBox *textOutput; /**< Text box for displaying chat history */ + ScrollArea *scrollArea; /**< Scroll area around text output */ }; #endif |