diff options
author | Michael Sterrett <mr_bones_@gentoo.org> | 2007-10-21 05:54:10 +0000 |
---|---|---|
committer | Michael Sterrett <mr_bones_@gentoo.org> | 2007-10-21 05:54:10 +0000 |
commit | 87f490eaf6c333714401ecacd1d6c3168ce58cc2 (patch) | |
tree | 87ef72a5f72a4936d611767cbed0696bcdef80d7 /games-mud/mcl | |
parent | Adding ~amd64 and ~ppc for seaview. (diff) | |
download | historical-87f490eaf6c333714401ecacd1d6c3168ce58cc2.tar.gz historical-87f490eaf6c333714401ecacd1d6c3168ce58cc2.tar.bz2 historical-87f490eaf6c333714401ecacd1d6c3168ce58cc2.zip |
add patch from Jose Quinteiro to send whole lines to embedded interpreter (bug #196216)
Package-Manager: portage-2.1.3.9
Diffstat (limited to 'games-mud/mcl')
-rw-r--r-- | games-mud/mcl/ChangeLog | 9 | ||||
-rw-r--r-- | games-mud/mcl/Manifest | 30 | ||||
-rw-r--r-- | games-mud/mcl/files/mcl-0.53.00-inputlines.patch | 648 | ||||
-rw-r--r-- | games-mud/mcl/mcl-0.53.00.ebuild | 11 |
4 files changed, 676 insertions, 22 deletions
diff --git a/games-mud/mcl/ChangeLog b/games-mud/mcl/ChangeLog index 7d89f91f99b2..4a247d5f337a 100644 --- a/games-mud/mcl/ChangeLog +++ b/games-mud/mcl/ChangeLog @@ -1,6 +1,11 @@ # ChangeLog for games-mud/mcl -# Copyright 2002-2006 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/games-mud/mcl/ChangeLog,v 1.15 2006/11/28 20:29:04 nyhm Exp $ +# Copyright 2002-2007 Gentoo Foundation; Distributed under the GPL v2 +# $Header: /var/cvsroot/gentoo-x86/games-mud/mcl/ChangeLog,v 1.16 2007/10/21 05:54:09 mr_bones_ Exp $ + + 21 Oct 2007; Michael Sterrett <mr_bones_@gentoo.org> + +files/mcl-0.53.00-inputlines.patch, mcl-0.53.00.ebuild: + add patch from Jose Quinteiro to send whole lines to embedded interpreter (bug + #196216) 28 Nov 2006; Tristan Heaven <nyhm@gentoo.org> +files/mcl-0.53.00-libdir.patch, mcl-0.53.00.ebuild: diff --git a/games-mud/mcl/Manifest b/games-mud/mcl/Manifest index 28e88e45af34..a117a6708a57 100644 --- a/games-mud/mcl/Manifest +++ b/games-mud/mcl/Manifest @@ -1,6 +1,3 @@ ------BEGIN PGP SIGNED MESSAGE----- -Hash: SHA1 - AUX 0.53.00-dynacomplete.patch 424 RMD160 e23684b1c954273654f22e49be2482a7fc8d0abb SHA1 00faa0e5a17284d44051e6fcb74e6aa91ff5f9f0 SHA256 73bb64b77abc92715182f19e53ff3ff806d7b27c952668da43cd7a7df11a75e4 MD5 c53c29552ecc41d90850d4bd845a7e95 files/0.53.00-dynacomplete.patch 424 RMD160 e23684b1c954273654f22e49be2482a7fc8d0abb files/0.53.00-dynacomplete.patch 424 @@ -17,19 +14,23 @@ AUX mcl-0.53.00-gcc34.patch 476 RMD160 64827d3bd25993962520cb2a4f3b37f9b9441da8 MD5 d5532610f9217f91f3d097748060fc9d files/mcl-0.53.00-gcc34.patch 476 RMD160 64827d3bd25993962520cb2a4f3b37f9b9441da8 files/mcl-0.53.00-gcc34.patch 476 SHA256 0be999b66bc629eb6c6617b361c0484e216723387d54a4b3ea65d5e17f1c5171 files/mcl-0.53.00-gcc34.patch 476 +AUX mcl-0.53.00-inputlines.patch 22381 RMD160 ee542661cc4e8fbf8b9ae8ecacc3e25369a69629 SHA1 fface2323bb631678c5cce0cb017152eb9176a0b SHA256 80e30138ae8a74f615f400ab58400d3574301f677b64d6027579bcbee05e34b7 +MD5 caa7771710422bd57fe71353f54d129e files/mcl-0.53.00-inputlines.patch 22381 +RMD160 ee542661cc4e8fbf8b9ae8ecacc3e25369a69629 files/mcl-0.53.00-inputlines.patch 22381 +SHA256 80e30138ae8a74f615f400ab58400d3574301f677b64d6027579bcbee05e34b7 files/mcl-0.53.00-inputlines.patch 22381 AUX mcl-0.53.00-libdir.patch 1213 RMD160 d6021616f794df59467d6f9c6a36ffba13c00e5e SHA1 a7f1bb5e14e4b23537f857294aecec58ee4ab86e SHA256 2ae675268d606fe57956eeaa9087463e711ff562cd9f81ca05649c38e5ba0007 MD5 1f7bd812cef8d0fe4531eda0796eabfd files/mcl-0.53.00-libdir.patch 1213 RMD160 d6021616f794df59467d6f9c6a36ffba13c00e5e files/mcl-0.53.00-libdir.patch 1213 SHA256 2ae675268d606fe57956eeaa9087463e711ff562cd9f81ca05649c38e5ba0007 files/mcl-0.53.00-libdir.patch 1213 DIST mcl-0.53.00-src.tar.gz 225100 RMD160 207f6494c579acbd814a2f70550833003a4729cd SHA1 1cd3df0301f4739a759ec968a931987be15277bb SHA256 39416133970e9b17e1e2aafc0eb6e1eb95f367c9882efba1439546b1702f43e2 -EBUILD mcl-0.53.00.ebuild 1247 RMD160 fd43a1c997987cc23084b4abfcdabec584771bb7 SHA1 b6ae1f7fb7a6ecb9af983f95487c6cb62e06ab30 SHA256 e5228c20bb874f49a7e81c6f4f934b565f787f44ae023e36837a92139a7f8f05 -MD5 c277d9cbec105c2abb2f721251fcd64e mcl-0.53.00.ebuild 1247 -RMD160 fd43a1c997987cc23084b4abfcdabec584771bb7 mcl-0.53.00.ebuild 1247 -SHA256 e5228c20bb874f49a7e81c6f4f934b565f787f44ae023e36837a92139a7f8f05 mcl-0.53.00.ebuild 1247 -MISC ChangeLog 2065 RMD160 5b66f8bc5af3d9f25450da59006f80e24c1e623e SHA1 d2b222b4824e81cfebc6fe439001bbfc28936b08 SHA256 bbb167e350beb0c69a4a6d243795e405ae15ce718aa5653509fedbf4872bc2e1 -MD5 107cf59e7b1be856cb919d6ac5e1366b ChangeLog 2065 -RMD160 5b66f8bc5af3d9f25450da59006f80e24c1e623e ChangeLog 2065 -SHA256 bbb167e350beb0c69a4a6d243795e405ae15ce718aa5653509fedbf4872bc2e1 ChangeLog 2065 +EBUILD mcl-0.53.00.ebuild 1389 RMD160 93048f268becf62d234a04a48601dbcea5d5e6fb SHA1 79abbac1be92b15cd33fdf99c986529a8b16f568 SHA256 d239f4379b8c6abc58390785fda626c169400b65db5835234c7eab5f9f0a7e7f +MD5 da569011074b696d19b5863467cbf777 mcl-0.53.00.ebuild 1389 +RMD160 93048f268becf62d234a04a48601dbcea5d5e6fb mcl-0.53.00.ebuild 1389 +SHA256 d239f4379b8c6abc58390785fda626c169400b65db5835234c7eab5f9f0a7e7f mcl-0.53.00.ebuild 1389 +MISC ChangeLog 2277 RMD160 55ba566e966e2cee691c9ba2a92ac6091ba620d0 SHA1 4fd06f8cc09b8ebc28506d76f527fbc2586dacf4 SHA256 dbb1c4132e272176dce70fa3a29768267f5cc50b6068cae151b469d36387e6b8 +MD5 16721c03457a2339b7dcc8876b5cc84e ChangeLog 2277 +RMD160 55ba566e966e2cee691c9ba2a92ac6091ba620d0 ChangeLog 2277 +SHA256 dbb1c4132e272176dce70fa3a29768267f5cc50b6068cae151b469d36387e6b8 ChangeLog 2277 MISC metadata.xml 158 RMD160 cbd9984bb6b426c8c9cee5022fe0a26261612fea SHA1 be5251fa1dacef5c41b74761bb1c8c54fb633b9e SHA256 1423a4fdd4a79b1728a2056d9e300f7e1074253095d82726218d9e9b953888a3 MD5 f17b9b8fa07a38914fe1c03268f51678 metadata.xml 158 RMD160 cbd9984bb6b426c8c9cee5022fe0a26261612fea metadata.xml 158 @@ -37,10 +38,3 @@ SHA256 1423a4fdd4a79b1728a2056d9e300f7e1074253095d82726218d9e9b953888a3 metadata MD5 084706359e2237d8f829984957e19ae5 files/digest-mcl-0.53.00 247 RMD160 591c0953f64063d2b92a29ca34a85465630021f9 files/digest-mcl-0.53.00 247 SHA256 9d230f731272f4045c25034dfecb8e9276f3e04630cfd745643a33665156967c files/digest-mcl-0.53.00 247 ------BEGIN PGP SIGNATURE----- -Version: GnuPG v2.0.3 (GNU/Linux) - -iD8DBQFGGoc/dz7hIScOURERAjCbAKDjSVbMGestV4jnxgawmvqX9YmLOQCgg/Gb -pLQW/rs87j6UAMRL2jgxjj8= -=84/w ------END PGP SIGNATURE----- diff --git a/games-mud/mcl/files/mcl-0.53.00-inputlines.patch b/games-mud/mcl/files/mcl-0.53.00-inputlines.patch new file mode 100644 index 000000000000..37d1fc64c68c --- /dev/null +++ b/games-mud/mcl/files/mcl-0.53.00-inputlines.patch @@ -0,0 +1,648 @@ +Patch from Jose Quinteiro +via http://bugs.gentoo.org/show_bug.cgi?id=196216 + +Index: StatusLine.cc +=================================================================== +--- StatusLine.cc (revision 1) ++++ StatusLine.cc (revision 3) +@@ -27,5 +27,5 @@ + + // Set the status line (using a formatted string) +-void StatusLine::setf(const char *fmt ...) ++void StatusLine::setf(const char *fmt, ...) + { + char buf[256]; +Index: misc.cc +=================================================================== +--- misc.cc (revision 1) ++++ misc.cc (revision 3) +@@ -135,5 +135,4 @@ + } + +-#define MAX_COLOR_BUF 256 + int ColorConverter::convert (const unsigned char *s, int size) { + char buf[MAX_COLOR_BUF]; +Index: Session.cc +=================================================================== +--- Session.cc (revision 1) ++++ Session.cc (revision 3) +@@ -18,4 +18,5 @@ + #include "Curses.h" + #include "Chat.h" ++#include "StatusLine.h" + + const int connectTimeout = 30; +@@ -235,9 +236,12 @@ + } + +-Session::Session(MUD& _mud, Window *_window, int _fd) : Socket(_fd), state(disconnected),mud(_mud), window(_window), pos(0), +-nsw(NULL), timer(NULL), statWindow(NULL), last_nsw_update(0) ++Session::Session(MUD& _mud, Window *_window, int _fd) : Socket(_fd), state(disconnected),mud(_mud), ++ window(_window), nsw(NULL), timer(NULL), statWindow(NULL), last_nsw_update(0), m_input_state(text) + { +- input_buffer[0] = NUL; +- prompt[0] = NUL; ++ m_ansi_buf[0] = NUL; ++ m_ansi_pos = m_ansi_buf; ++ m_output_buf[0] = NUL; ++ m_output_pos = m_output_buf; ++ m_last_line = m_output_buf; + memset(&stats,0,sizeof(stats)); + +@@ -391,21 +395,17 @@ + + // Data from the MUD has arrived +-void Session::inputReady() { +- char out_buf[MAX_MUD_BUF]; +- char temp_buf[MAX_MUD_BUF]; +- char *out; +- int code_pos; +- char *prompt_begin; +- +- int count; +- int i; +- +- count = read(temp_buf, MAX_MUD_BUF-1); +- +- globalStats.bytes_read += count; +- stats.bytes_read += count; ++void Session::inputReady() ++{ ++ unsigned char l_cur_buf[MAX_MUD_BUF]; ++ char l_temp_buf[MAX_MUD_BUF]; ++ int l_count; ++ ++ l_count = read(l_temp_buf, MAX_MUD_BUF-1); ++ ++ globalStats.bytes_read += l_count; ++ stats.bytes_read += l_count; + + // Filter through mudcompress +- mudcompress_receive(mcinfo, temp_buf, count); ++ mudcompress_receive(mcinfo, l_temp_buf, l_count); + + // Error? +@@ -423,186 +423,204 @@ + } + +- while (mudcompress_pending(mcinfo) && pos < MAX_MUD_BUF-1) { ++ while (mudcompress_pending(mcinfo)) ++ { + // Get some data +- count = mudcompress_get(mcinfo, (char*) input_buffer + pos, MAX_MUD_BUF - pos - 1); +- +- if (count > 0 && chatServerSocket) +- chatServerSocket->handleSnooping((char*)(input_buffer+pos), count); +- +- prompt_begin = NULL; +- out = out_buf; +- +- /* If we have data from last call, this means we got some incomplete ansi */ +- if (pos) +- code_pos = 0; +- else +- code_pos = -1; +- +- /* Process the buffer */ +- for (i = 0; i < count + pos; i++) +- { +- /* Lose patience of code does not terminate within 16 characters */ +- if (code_pos >= 0 && i - code_pos > 16) +- code_pos = -1; +- +- +- /* IAC: next character is a telnet command */ +- if (input_buffer[i] == IAC) +- { +- if (++i < count + pos) /* just forget it if it appears at the end of a buffer */ +- { +- /* spec: handle prompts that split across reads */ +- if (input_buffer[i] == GA || input_buffer[i] == EOR) /* this is a prompt */ +- { +- /* if we have a prompt_begin, that's the start of +- * the prompt. If we don't, then the contents +- * of the 'prompt' buffer, plus any output we +- * have, is the prompt. +- */ +- if(!config->getOption(opt_snarf_prompt)) { +- if(prompt_begin) { +- int len = out - prompt_begin; +- char *buf = new char[len + 1]; +- memcpy(buf, prompt_begin+1, len); +- buf[len] = '\0'; +- embed_interp->run_quietly("sys/prompt", buf, buf); +- } ++ l_count = mudcompress_get(mcinfo, (char*) l_cur_buf, MAX_MUD_BUF - 1); ++ ++ if (l_count > 0 && chatServerSocket) ++ chatServerSocket->handleSnooping((char*)(l_cur_buf), l_count); ++ ++ for(int i = 0; i < l_count; i++) ++ { ++ if( (m_output_pos - m_output_buf) == MAX_MUD_BUF ) { ++ //We've buffered as much as we can, let's write it out ++ //TODO: Trigger scripts here? Looks like a corner case ++ //log.warn("Buffer exhausted, flushing\n"); ++ *m_output_pos = NUL; ++ print( m_output_buf ); ++ m_output_pos = m_output_buf; ++ m_last_line = m_output_buf; ++ } ++ if( (m_ansi_pos - m_ansi_buf) == MAX_COLOR_BUF ) { ++ *m_ansi_pos = NUL; ++ //log.warn("ANSI sequence %s too long, ignoring\n", m_ansi_buf); ++ m_ansi_pos = m_ansi_buf; ++ } ++ ++ switch(m_input_state) ++ { ++ case text: ++ if( l_cur_buf[i] == IAC ) { ++ m_state_stack.push_back(m_input_state); ++ m_input_state = found_iac; ++ continue; ++ } ++ if( l_cur_buf[i] == '\e' ) { ++ m_state_stack.push_back(m_input_state); ++ m_input_state = found_esc; ++ continue; ++ } ++ if (l_cur_buf[i] == '\a' && config->getOption(opt_mudbeep)) { ++ ::write(STDOUT_FILENO, "\a", 1); // use screen->flash() here? ++ continue; ++ } ++ if (l_cur_buf[i] == '\r') { ++ //log.debug("Discarded carriage return"); ++ continue; ++ } ++ if (l_cur_buf[i] == '\n') ++ { ++ triggerCheck(m_last_line, m_output_pos - m_last_line, &m_output_pos); ++ m_last_line = m_output_pos + 1; ++ } ++ ++ *m_output_pos++ = l_cur_buf[i]; ++ continue; ++ ++ case found_iac: ++ if( l_cur_buf[i] >= WILL && l_cur_buf[i] <= DONT ) { ++ m_input_state = telnet_option; ++ continue; ++ } ++ if( l_cur_buf[i] == EOR || l_cur_buf[i] == GA ) ++ { ++ *m_output_pos = NUL; ++ if( config->getOption(opt_snarf_prompt) ) { ++ set_prompt( m_last_line, (int)strlen(m_last_line) ); ++ } else { ++ embed_interp->run_quietly("sys/prompt", m_last_line, m_last_line); ++ } ++ ++ if( config->getOption(opt_showprompt) ) { ++ *m_output_pos++ = '\n'; ++ *m_output_pos = NUL; ++ print( m_output_buf ); ++ } else { ++ *m_last_line = NUL; ++ print( m_output_buf ); ++ } ++ m_output_pos = m_output_buf; ++ m_last_line = m_output_buf; ++ m_input_state = m_state_stack.back(); ++ m_state_stack.pop_back(); ++ continue; ++ } ++ //log.warn("Ignoring telnet command %d\n", l_cur_buf[i]); ++ m_input_state = m_state_stack.back(); ++ m_state_stack.pop_back(); ++ continue; ++ ++ case telnet_option: ++ if( l_cur_buf[i] == TELOPT_EOR) { ++ //TODO: use telnet.h defines here ++ write ("\377\375\31", 3); ++ } else { ++ //log.warn("Ignoring telnet option %c\n", l_cur_buf[i]); ++ } ++ m_input_state = m_state_stack.back(); ++ m_state_stack.pop_back(); ++ continue; ++ ++ case found_esc: ++ if( l_cur_buf[i] == IAC ) { ++ m_state_stack.push_back(m_input_state); ++ m_input_state = found_iac; ++ continue; ++ } ++ if( l_cur_buf[i] ='[' ) { ++ if( m_ansi_pos != m_ansi_buf ) { ++ //log.warn("New ANSI escape sequence started before the last one was finished"); ++ m_ansi_pos = m_ansi_buf; ++ } ++ *m_ansi_pos++ = '\e'; ++ *m_ansi_pos++ = l_cur_buf[i]; ++ m_input_state = ansi_sequence; ++ continue; ++ } ++ //log.warn("Ignoring escape sequence ESC%c\n", l_cur_buf[i]); ++ m_input_state = m_state_stack.back(); ++ m_state_stack.pop_back(); ++ continue; ++ ++ case ansi_sequence: ++ if( l_cur_buf[i] == IAC ) { ++ m_state_stack.push_back(m_input_state); ++ m_input_state = found_iac; ++ continue; ++ } ++ if( isdigit(l_cur_buf[i]) || l_cur_buf[i] == ';' ){ ++ *m_ansi_pos++ = l_cur_buf[i]; ++ continue; ++ } ++ if(l_cur_buf[i] == '"') { ++ *m_ansi_pos++ = l_cur_buf[i]; ++ m_state_stack.push_back(m_input_state); ++ m_input_state = ansi_found_quot; ++ continue; ++ } ++ if( isalpha(l_cur_buf[i]) ) ++ { ++ if( l_cur_buf[i] == 'm' || l_cur_buf[i] == 'R' ) ++ { ++ /* Conver this color code to internal representation */ ++ int l_color; ++ if( (l_color = m_colorConverter.convert((const byte*)m_ansi_buf, m_ansi_pos - m_ansi_buf)) > 0 ) ++ { ++ *m_output_pos++ = SET_COLOR; ++ *m_output_pos++ = l_color; + } +- else if (prompt_begin) +- { +- set_prompt (prompt_begin + 1, out - prompt_begin - 1); +- if (!config->getOption(opt_showprompt)) +- out = prompt_begin + 1; ++ if (m_colorConverter.checkReportStatus()) { /* suggested by Chris Litchfield */ ++ output->printf("\n(Sending location code\n"); ++ writeMUD("\e[40;13R\n"); + } +- else +- { +- if (prompt[0] || out[0]) +- { +- unsigned char *temp = prompt + strlen ((char*)prompt); +- +- *out = NUL; +- strcat ((char*)prompt, out_buf); +- set_prompt ((char*)prompt, (int)strlen ((char*)prompt)); +- *temp = NUL; +- } +- if (!config->getOption(opt_showprompt)) +- out = out_buf; +- } +- // Insert a clear color code here +- // It'd be better to interpret color codes in the prompt properly, +- // but that is surprisingly hard to do +- *out++ = SET_COLOR; +- *out++ = bg_black|fg_white; // Is that really the *default* color? +- +- prompt[0] = NUL; +- prompt_begin = out; +- } +- // React to IAC WILL EOR and send back IAC DO EOR +- else if (input_buffer[i] == WILL && (i+1) < count+pos && input_buffer[i+1] == TELOPT_EOR) +- { +- i++; +- +- // @@ use telnet.h defines here +- write ("\377\375\31", 3); +- } +- /* Skip the next character if this is an option */ +- else if (input_buffer[i] >= WILL && input_buffer[i] <= DONT) +- i++; +- } +- ++ } else { ++ *m_ansi_pos = NUL; ++ //log.warn("Ignoring ANSI sequence %s%c\n", m_ansi_buf, l_cur_buf[i]); ++ } ++ m_ansi_pos = m_ansi_buf; ++ m_input_state = m_state_stack.back(); ++ m_state_stack.pop_back(); ++ continue; ++ } ++ *m_ansi_pos = NUL; ++ //log.warn("Ignoring ANSI sequence %s%c\n", m_ansi_buf, l_cur_buf[i]); ++ m_ansi_pos = m_ansi_buf; ++ m_input_state = m_state_stack.back(); ++ m_state_stack.pop_back(); + continue; +- } +- +- // Escape sequence +- else if (input_buffer[i] == '\e') +- code_pos = i; +- +- // Attention +- else if (input_buffer[i] == '\a' && config->getOption(opt_mudbeep)) +- ::write(STDOUT_FILENO, "\a", 1); // use screen->flash() here? +- +- else if (code_pos == -1) { // not inside a color code, real text +- if (input_buffer[i] == '\n') { +- // Do regexp trigger magic +- bool cancel_line = triggerCheck(prompt_begin ? prompt_begin+1 : (char*) out_buf, +- prompt_begin ? out-prompt_begin-1: out-out_buf, &out); +- prompt_begin = out; +- if (cancel_line) { +- // We just gagged that line, so the \n which otherwise would be the beginning of the prompt +- // is eaten up. +- if (out > out_buf) +- prompt_begin = out-1; +- else +- prompt_begin = NULL; +- continue; +- } +- } +- +- if (input_buffer[i] != '\r') /* discard those */ +- *out++ = input_buffer[i]; /* Add to output buffer */ +- } +- +- /* Check if the code should terminate here */ +- if (code_pos >= 0 && isalpha (input_buffer[i])) +- { +- int color; +- +- /* Conver this color code to internal representation */ +- if ((color = colorConverter.convert (input_buffer + code_pos, i - code_pos + 1)) > 0) +- { +- *out++ = SET_COLOR; +- *out++ = color; +- } +- if (colorConverter.checkReportStatus()) { /* suggested by Chris Litchfield */ +- output->printf("\n(Sending location code\n"); +- writeMUD("\e[40;13R\n"); +- } +- +- code_pos = -1; +- } +- } +- +- *out = NUL; +- +- // Run triggers on incompletely received lines +- bool cancel_line = triggerCheck(prompt_begin ? prompt_begin+1 : (char*) out_buf, +- prompt_begin ? out-prompt_begin-1: out-out_buf, &out); +- prompt_begin = out; +- if (cancel_line) { +- // We just gagged that line, so the \n which otherwise would be the beginning of the prompt +- // is eaten up. +- if (out > out_buf) +- prompt_begin = out-1; +- else +- prompt_begin = NULL; +- } +- +- print (out_buf); +- +- /* Do we have some leftover data, an incomplete ANSI sequence? */ +- if (code_pos >= 0) +- { +- /* Copy so that the buffer is at the beginning of that code */ +- memcpy (input_buffer, input_buffer + code_pos, count + pos - code_pos); +- +- /* Next incoming data will be put there */ +- pos = count + pos - code_pos; +- } +- else +- pos = 0; +- +- +- +- /* spec: fix up partial lines for subsequent prompts */ +- if (prompt_begin) +- strcpy ((char*)prompt, prompt_begin); +- else if (strlen((char*)prompt) < MAX_MUD_BUF/4 && strlen(out_buf) < MAX_MUD_BUF/4) { +- // guard against too long lines +- strcat((char*)prompt, out_buf); +- } +- +- +- } // end while +-} ++ //case ansi_sequence ++ ++ case ansi_found_quot: ++ if( l_cur_buf[i] == IAC ) { ++ m_state_stack.push_back(m_input_state); ++ m_input_state = found_iac; ++ continue; ++ } ++ //Is literally anything allowed between quotes in an ANSI key redefinition sequence? ++ //I think so ++ *m_ansi_pos++ = l_cur_buf[i]; ++ if(l_cur_buf[i] == '"') { ++ //Should always fall back to ansi_sequence ++ m_input_state = m_state_stack.back(); ++ m_state_stack.pop_back(); ++ } ++ continue; ++ ++ }//switch(m_input_state) ++ ++ }//for(int i = 0; i < l_count; i++) ++ } // end while (mudcompress_pending(mcinfo)) ++ ++ //We got a complete line, flush it out ++ //TODO: is newline (\n) a valid character in any mode besides text? ++ //i.e., should I check for m_input_state == text here? ++ if( m_output_pos > m_output_buf && *(m_output_pos - 1) == '\n' ) ++ { ++ *m_output_pos = NUL; ++ print( m_output_buf ); ++ m_output_pos = m_output_buf; ++ m_last_line = m_output_buf; ++ } ++} //inputReady() + + void Session::show_timer() { +Index: h/StatusLine.h +=================================================================== +--- h/StatusLine.h (revision 1) ++++ h/StatusLine.h (revision 3) +@@ -11,5 +11,5 @@ + virtual void idle(); // Check if it is time to remove the text + void set(const char *s); // Set status lien to this message +- void setf(const char *fmt ...); // As above ,but formatted string ++ void setf(const char *fmt, ...); // As above ,but formatted string + + virtual void redraw(); +Index: h/Session.h +=================================================================== +--- h/Session.h (revision 1) ++++ h/Session.h (revision 3) +@@ -4,6 +4,9 @@ + #include "mccpDecompress.h" + #include "Socket.h" ++#include <vector> + +-typedef enum {disconnected, connecting, connected} state_t; ++typedef enum { ++ disconnected, connecting, connected ++} state_t; + + class NetworkStateWindow; +@@ -11,61 +14,80 @@ + class StatWindow; + class Window; ++class MUD; ++class ColorConverter; ++class Action; + + class Session : public Socket { +- public: +- Session(MUD& _mud, Window *_window, int _fd = -1); // Initialize a new session to this mud +- ~Session(); +- bool open(); // Connect +- bool close(); // Disconnect +- void idle(); // Do time-based updates +- +- void show_nsw(); // Show the NSW +- void show_timer(); // Show the Timer Window +- bool expand_macros(int key); // Expand this macro key +- void writeMUD (const char *s); // Send this +- +- state_t state; // Are offline, connecting or connected? +- MUD& mud; +- ++public: ++ Session(MUD& _mud, Window *_window, int _fd = -1); // Initialize a new session to this mud ++ ~Session(); ++ bool open(); // Connect ++ bool close(); // Disconnect ++ void idle(); // Do time-based updates ++ ++ void show_nsw(); // Show the NSW ++ void show_timer(); // Show the Timer Window ++ bool expand_macros(int key); // Expand this macro key ++ void writeMUD (const char *s); // Send this ++ ++ state_t state; // Are offline, connecting or connected? ++ MUD& mud; ++ enum input_state_t { ++ text, found_iac, telnet_option, found_esc, ansi_sequence, ansi_found_quot ++ }; ++ ++ + private: +- Window *window; // Window we are writing to +- +- // Incomplete ANSI codes should be left in this buffer +- unsigned char input_buffer[MAX_MUD_BUF]; +- +- // and this one, partial lines (for prompts) +- unsigned char prompt[MAX_MUD_BUF]; +- int pos; +- +- NetworkStateWindow *nsw; // if non-NULL, we display stats there when idle'ing +- TimerWindow *timer; // Timer window +- StatWindow *statWindow; // Input/Output statitstics here +- +- // Some statistics +- struct { +- int bytes_written, bytes_read; // # of bytes read/written +- time_t connect_time; // When did we connect? +- time_t dial_time; +- } stats; +- +- time_t last_nsw_update; +- mc_state *mcinfo; +- ColorConverter colorConverter; ++ Window *window; // Window we are writing to + +- friend class NetworkStateWindow; +- friend class StatWindow; +- friend class TimerWindow; ++ NetworkStateWindow *nsw; // if non-NULL, we display stats there when idle'ing ++ TimerWindow *timer; // Timer window ++ StatWindow *statWindow; // Input/Output statitstics here + +- void print(const char *s); // Write to our output/log ++ // Some statistics ++ struct { ++ int bytes_written, bytes_read; // # of bytes read/written ++ time_t connect_time; // When did we connect? ++ time_t dial_time; ++ } stats; + +- void set_prompt (const char *s, int len); +- bool triggerCheck (char *line, int len, char **out); +- void runTrigger(Action *a, char *buf, char *line, int& len, char **out); +- void establishConnection(bool quick_restore); // run on connect, qr = true if 'hot' boot +- int convert_color (const unsigned char *s, int size); ++ time_t last_nsw_update; ++ mc_state *mcinfo; ++ ColorConverter m_colorConverter; + +- virtual void connectionEstablished(); +- virtual void inputReady(); +- virtual void errorEncountered(int); ++ //Current input parser state ++ input_state_t m_input_state; ++ //State history. We need to know which state we should ++ //return to after processing escape sequences and/or ++ //telnet commands ++ std::vector<input_state_t> m_state_stack; ++ ++ // Incomplete ANSI codes should be left in this buffer ++ char m_ansi_buf[MAX_COLOR_BUF]; ++ //points to the last char ++ char *m_ansi_pos; ++ ++ //Incomplete lines ++ char m_output_buf[MAX_MUD_BUF]; ++ //points to the last char ++ char *m_output_pos; ++ //points to the beginning of the last line ++ char *m_last_line; ++ ++ friend class NetworkStateWindow; ++ friend class StatWindow; ++ friend class TimerWindow; ++ ++ void print(const char *s); // Write to our output/log ++ ++ void set_prompt (const char *s, int len); ++ bool triggerCheck (char *line, int len, char **out); ++ void runTrigger(Action *a, char *buf, char *line, int& len, char **out); ++ void establishConnection(bool quick_restore); // run on connect, qr = true if 'hot' boot ++ int convert_color (const unsigned char *s, int size); ++ ++ virtual void connectionEstablished(); ++ virtual void inputReady(); ++ virtual void errorEncountered(int); + + }; +Index: h/Socket.h +=================================================================== +--- h/Socket.h (revision 1) ++++ h/Socket.h (revision 3) +@@ -4,4 +4,8 @@ + + #include <netinet/in.h> ++#include "defs.h" ++#include "Buffer.h" ++ ++class Selectable; + + class Socket : public Selectable { +Index: h/defs.h +=================================================================== +--- h/defs.h (revision 1) ++++ h/defs.h (revision 3) +@@ -4,4 +4,6 @@ + #define MAX_MUD_BUF 4096 + #define MAX_INPUT_BUF 1024 ++#define MAX_COLOR_BUF 256 ++ + #define NUL '\0' + diff --git a/games-mud/mcl/mcl-0.53.00.ebuild b/games-mud/mcl/mcl-0.53.00.ebuild index 051389f9d14c..fa0aa6da33e0 100644 --- a/games-mud/mcl/mcl-0.53.00.ebuild +++ b/games-mud/mcl/mcl-0.53.00.ebuild @@ -1,6 +1,6 @@ # Copyright 1999-2007 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 -# $Header: /var/cvsroot/gentoo-x86/games-mud/mcl/mcl-0.53.00.ebuild,v 1.15 2007/04/09 18:34:31 nyhm Exp $ +# $Header: /var/cvsroot/gentoo-x86/games-mud/mcl/mcl-0.53.00.ebuild,v 1.16 2007/10/21 05:54:09 mr_bones_ Exp $ inherit eutils games @@ -25,12 +25,19 @@ src_unpack() { "${FILESDIR}"/${PV}-vc.patch \ "${FILESDIR}"/${P}-gcc34.patch \ "${FILESDIR}"/${PV}-dynacomplete.patch \ - "${FILESDIR}"/${P}-libdir.patch + "${FILESDIR}"/${P}-libdir.patch \ + "${FILESDIR}"/${P}-inputlines.patch sed -i \ -e "/MCL_LIBRARY_PATH/ s:/usr/lib/mcl:$(games_get_libdir)/${PN}:" \ h/mcl.h \ || die "sed h/mcl.h failed" + + # no strip for you + sed -i \ + -e "/LDFLAGS=.*-s/s:-s::" \ + configure \ + || die "sed failed" } src_compile() { |