From 9f38169b560848e9f0a0f13c3020ad76357d30f7 Mon Sep 17 00:00:00 2001 From: Michiel Broek Date: Thu, 3 Feb 2005 20:44:17 +0000 Subject: [PATCH] Increased the diesel parser stringlength --- ChangeLog | 3 +++ lib/diesel.h | 2 +- lib/mbdiesel.c | 56 +++++++++++++++++++++++++------------------------- 3 files changed, 32 insertions(+), 29 deletions(-) diff --git a/ChangeLog b/ChangeLog index a0f0c893..ac4ce64c 100644 --- a/ChangeLog +++ b/ChangeLog @@ -7,6 +7,9 @@ v0.71.2 16-Jan-2005 Changed rfc-2045 name x-mac to mac. Changed x-ibmpc to cp437. This allows rfc mime headers to show official names. + libdiesel.a: + Changed the maximum string length from 2560 to 4096 characters. + mbcico: Added protection during binkp receive for zero bytes compressed data frames, this will case uncompress error -5 because zero diff --git a/lib/diesel.h b/lib/diesel.h index f15e63cb..e298adfc 100644 --- a/lib/diesel.h +++ b/lib/diesel.h @@ -24,7 +24,7 @@ int tracing = TRUE; /* Trace macro evalution */ /* Local variables. */ #define MAXARGS 10 /* Maximum arguments to a macro */ -#define MAXSTR 2560 /* Maximum string length */ +#define MAXSTR 4096 /* Maximum string length */ /* Was 2560 */ #define MAXDEPTH 32 /* Maximum recursion depth for eval */ #define MACROCHAR '@' /* Macro trigger character */ diff --git a/lib/mbdiesel.c b/lib/mbdiesel.c index 22a010db..6532d257 100644 --- a/lib/mbdiesel.c +++ b/lib/mbdiesel.c @@ -4,7 +4,7 @@ * Purpose ...............: MBSE BBS functions for TURBODIESEL * ***************************************************************************** - * Copyright (C) 1997-2004 + * Copyright (C) 1997-2005 * * Michiel Broek FIDO: 2:280/2802 * Beekmansbos 10 @@ -38,48 +38,48 @@ static int firstrandom = TRUE; void MacroVars( const char *codes, const char *fmt, ...) { - char *tmp1, *tmp2; - va_list ap; - int j; - int dieselrc; - char *vs; - int vd; - char vc; - double vf; + char *tmp1, *tmp2, *vs, vc; + va_list ap; + int j, dieselrc, vd; + double vf; - tmp1=calloc(MAXSTR, sizeof(char)); - tmp2=calloc(MAXSTR, sizeof(char)); + tmp1 = calloc(MAXSTR, sizeof(char)); + tmp2 = calloc(MAXSTR, sizeof(char)); - va_start(ap,fmt); - for ( j=0; (codes[j] != '\0') && (fmt[j] != '\0') ; j++ ){ - tmp1[0]='\0'; - switch(fmt[j]) { - case 's': /* string */ + va_start(ap,fmt); + for (j = 0; (codes[j] != '\0') && (fmt[j] != '\0') ; j++ ){ + tmp1[0] = '\0'; + switch (fmt[j]) { + case 's': /* string */ vs = va_arg(ap, char *); sprintf(tmp1,"@(setvar,%c,\"%s\")",codes[j],vs); break; - case 'd': /* int */ + case 'd': /* int */ vd = va_arg(ap, int); sprintf(tmp1,"@(setvar,%c,%d)",codes[j],vd); break; - case 'c': /* char */ + case 'c': /* char */ vc = va_arg(ap, int); sprintf(tmp1,"@(setvar,%c,%c)",codes[j],vc); break; - case 'f': /* char */ + case 'f': /* char */ vf = va_arg(ap, double); sprintf(tmp1,"@(setvar,%c,%f)",codes[j],vf); break; - } - dieselrc=diesel(tmp1,tmp2); - if (dieselrc) { - Syslog('!', "MacroVars error %d argument %d, macro %c type %c", dieselrc, j, codes[j], fmt[j]); - } - } - va_end(ap); + } + dieselrc = diesel(tmp1,tmp2); + if (dieselrc) { + Syslog('!', "MacroVars error %d argument %d, macro %c type %c", dieselrc, j, codes[j], fmt[j]); + if (fmt[j] == 's') + Syslogp('!', printable(va_arg(ap, char *), 0)); + Syslogp('!', printable(tmp1, 0)); + Syslogp('!', printable(tmp2, 0)); + } + } + va_end(ap); - free(tmp1); - free(tmp2); + free(tmp1); + free(tmp2); }