summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMichael Sterrett <mr_bones_@gentoo.org>2007-10-21 05:54:10 +0000
committerMichael Sterrett <mr_bones_@gentoo.org>2007-10-21 05:54:10 +0000
commit87f490eaf6c333714401ecacd1d6c3168ce58cc2 (patch)
tree87ef72a5f72a4936d611767cbed0696bcdef80d7 /games-mud/mcl
parentAdding ~amd64 and ~ppc for seaview. (diff)
downloadhistorical-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/ChangeLog9
-rw-r--r--games-mud/mcl/Manifest30
-rw-r--r--games-mud/mcl/files/mcl-0.53.00-inputlines.patch648
-rw-r--r--games-mud/mcl/mcl-0.53.00.ebuild11
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() {