From b7c72a75981aa1d980e21b228edc74752a66ded1 Mon Sep 17 00:00:00 2001 From: Michiel Broek Date: Thu, 23 Dec 2004 16:04:00 +0000 Subject: [PATCH] Small fixes to mbnntp --- ChangeLog | 10 ++++++++++ mbfido/rfc2ftn.c | 5 +++++ mbnntp/commands.c | 3 --- mbnntp/lhash.c | 21 --------------------- mbnntp/mbnntp.c | 1 - mbnntp/rfc2ftn.c | 7 ++++++- mbnntp/ttyio.c | 25 ++----------------------- 7 files changed, 23 insertions(+), 49 deletions(-) diff --git a/ChangeLog b/ChangeLog index d4799e5e..e858d9d6 100644 --- a/ChangeLog +++ b/ChangeLog @@ -34,6 +34,16 @@ v0.71.1 28-Nov-2004 The import command now also figures out the difference between 8.3 and long filenames and does the right thing during import. + mbfido: + In rfc2ftn a debug logmessage added to check for unrecognised + message ids. + + mbnntp: + Removed dead timercode. + Code cleanup. + When a message is posted without RFC Messageid, a fidonet MSGID + is fresh created. + examples: Removed bbs list items from the English menus and txtfiles and the Spanish menus and txtfiles. diff --git a/mbfido/rfc2ftn.c b/mbfido/rfc2ftn.c index a981a43a..e8826fd7 100644 --- a/mbfido/rfc2ftn.c +++ b/mbfido/rfc2ftn.c @@ -342,6 +342,11 @@ int rfc2ftn(FILE *fp, faddr *recipient) fprintf(ofp, "\001INTL %d:%d/%d %d:%d/%d\n", fmsg->to->zone, fmsg->to->net, fmsg->to->node, fmsg->from->zone, fmsg->from->net, fmsg->from->node); } + + if ((fmsg->msgid_a == NULL) || (fmsg->msgid_n == 0)) { + Syslog('!', "Warning, no MSGID %s %08lx", MBSE_SS(fmsg->msgid_a), fmsg->msgid_n); + } + fprintf(ofp, "\001MSGID: %s %08lx\n", MBSE_SS(fmsg->msgid_a),fmsg->msgid_n); if (fmsg->reply_s) fprintf(ofp, "\1REPLY: %s\n", fmsg->reply_s); diff --git a/mbnntp/commands.c b/mbnntp/commands.c index b625a836..af65a861 100644 --- a/mbnntp/commands.c +++ b/mbnntp/commands.c @@ -374,9 +374,6 @@ void command_list(char *cmd) * No recognized LIST command */ send_nntp("503 Function not available"); - - msleep(1); /* For the linker only */ - mbse_colour(0, 0); } diff --git a/mbnntp/lhash.c b/mbnntp/lhash.c index 7f7b7c20..dcc2cb4f 100644 --- a/mbnntp/lhash.c +++ b/mbnntp/lhash.c @@ -449,22 +449,6 @@ static LHASH_NODE **getrn(LHASH *lh, char *data, unsigned long *rhash) return(ret); } -/* -static unsigned long lh_strhash(str) -char *str; - { - int i,l; - unsigned long ret=0; - unsigned short *s; - - if (str == NULL) return(0); - l=(strlen(str)+1)/2; - s=(unsigned short *)str; - for (i=0; imsgid_a),fmsg->msgid_n); + if ((fmsg->msgid_a == NULL) && (fmsg->msgid_n == 0)) { + Syslog('n', "No Messageid from poster, creating new MSGID"); + fprintf(ofp, "\001MSGID: %s %08lx\n", aka2str(msgs.Aka), sequencer()); + } else { + fprintf(ofp, "\001MSGID: %s %08lx\n", MBSE_SS(fmsg->msgid_a),fmsg->msgid_n); + } if (fmsg->reply_s) fprintf(ofp, "\1REPLY: %s\n", fmsg->reply_s); else if (fmsg->reply_a) diff --git a/mbnntp/ttyio.c b/mbnntp/ttyio.c index 85c6f3ee..d82bad0e 100644 --- a/mbnntp/ttyio.c +++ b/mbnntp/ttyio.c @@ -35,7 +35,6 @@ extern int hanged_up; extern char *inetaddr; #define TT_BUFSIZ 1024 -#define NUMTIMERS 3 int tty_status = 0; @@ -45,7 +44,6 @@ static char *next; static int left = 0; -static time_t timer[NUMTIMERS]; char *ttystat[]= {(char *)"Ok", (char *)"Error", @@ -62,8 +60,7 @@ char *ttystat[]= {(char *)"Ok", */ static int tty_read(char *buf, int size, int tot) { - time_t timeout, now; - int i, rc; + int rc; fd_set readfds, writefds, exceptfds; struct timeval seltimer; @@ -71,30 +68,12 @@ static int tty_read(char *buf, int size, int tot) return 0; tty_status = 0; - now = time(NULL); - timeout = (time_t)300; /* maximum of 5 minutes */ - - for (i = 0; i < NUMTIMERS; i++) { - if (timer[i]) { - if (now >= timer[i]) { - tty_status=STAT_TIMEOUT; - Syslog('!', "tty_read: timer %d already expired, return", i); - return -tty_status; - } else { - if (timeout > (timer[i]-now)) - timeout=timer[i]-now; - } - } - } - if ((tot != -1) && (timeout > tot)) - timeout=tot; - FD_ZERO(&readfds); FD_ZERO(&writefds); FD_ZERO(&exceptfds); FD_SET(0,&readfds); FD_SET(0,&exceptfds); - seltimer.tv_sec=timeout; + seltimer.tv_sec=tot; seltimer.tv_usec=0; rc = select(1,&readfds,&writefds,&exceptfds,&seltimer);