[Top][All Lists]
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Nmh-commits] nmh/uip picksbr.c
From: |
Paul Fox |
Subject: |
[Nmh-commits] nmh/uip picksbr.c |
Date: |
Fri, 31 Mar 2006 15:14:49 +0000 |
CVSROOT: /sources/nmh
Module name: nmh
Branch:
Changes by: Paul Fox <address@hidden> 06/03/31 15:14:49
Modified files:
uip : picksbr.c
Log message:
this commit:
- adds range support to character classes
- fixes out-of-bounds references to the case-folding array
when doing case comparisons for 8-bit message text
- makes character classes as case tolerant as the rest
of the pick regexp machine. (where lowercase chars in
patterns should match uppercase in the text.)
- fixes an uninitialized pointer warning, which might actually have
been a real bug
CVSWeb URLs:
http://cvs.savannah.gnu.org/viewcvs/nmh/nmh/uip/picksbr.c.diff?tr1=1.9&tr2=1.10&r1=text&r2=text
Patches:
Index: nmh/uip/picksbr.c
diff -u nmh/uip/picksbr.c:1.9 nmh/uip/picksbr.c:1.10
--- nmh/uip/picksbr.c:1.9 Wed Mar 8 12:14:16 2006
+++ nmh/uip/picksbr.c Fri Mar 31 15:14:49 2006
@@ -2,7 +2,7 @@
/*
* picksbr.c -- routines to help pick along...
*
- * $Id: picksbr.c,v 1.9 2006/03/08 12:14:16 bress Exp $
+ * $Id: picksbr.c,v 1.10 2006/03/31 15:14:49 pgf Exp $
*
* This code is Copyright (c) 2002, by the authors of nmh. See the
* COPYRIGHT file in the root directory of the nmh distribution for
@@ -82,7 +82,7 @@
#define STAR 01
#define LBSIZE 1024
-#define ESIZE 256
+#define ESIZE 1024
static char linebuf[LBSIZE + 1];
@@ -105,6 +105,23 @@
0150,0151,0152,0153,0154,0155,0156,0157,
0160,0161,0162,0163,0164,0165,0166,0167,
0170,0171,0172,0173,0174,0175,0176,0177,
+
+ 0200,0201,0202,0203,0204,0205,0206,0207,
+ 0210,0211,0212,0213,0214,0215,0216,0217,
+ 0220,0221,0222,0223,0224,0225,0226,0227,
+ 0230,0231,0232,0233,0234,0235,0236,0237,
+ 0240,0241,0242,0243,0244,0245,0246,0247,
+ 0250,0251,0252,0253,0254,0255,0256,0257,
+ 0260,0261,0262,0263,0264,0265,0266,0267,
+ 0270,0271,0272,0273,0274,0275,0276,0277,
+ 0300,0301,0302,0303,0304,0305,0306,0307,
+ 0310,0311,0312,0313,0314,0315,0316,0317,
+ 0320,0321,0322,0323,0324,0325,0326,0327,
+ 0330,0331,0332,0333,0334,0335,0336,0337,
+ 0340,0341,0342,0343,0344,0345,0346,0347,
+ 0350,0351,0352,0353,0354,0355,0356,0357,
+ 0360,0361,0362,0363,0364,0365,0366,0367,
+ 0370,0371,0372,0373,0374,0375,0376,0377,
};
/*
@@ -558,7 +575,7 @@
{
register int c;
int cclcnt;
- register char *ep, *dp, *sp, *lastep;
+ register char *ep, *dp, *sp, *lastep = 0;
dp = (ep = n->n_expbuf) + sizeof n->n_expbuf;
sp = astr;
@@ -602,11 +619,25 @@
c = *sp++;
ep[-2] = NCCL;
}
- do {
+ if (c == '-') {
*ep++ = c;
cclcnt++;
- if (c == '\0' || ep >= dp)
- goto cerror;
+ c = *sp++;
+ }
+ do {
+ if (c == '-' && *sp != '\0' && *sp != ']') {
+ for (c = ep[-1]+1; c < *sp; c++) {
+ *ep++ = c;
+ cclcnt++;
+ if (c == '\0' || ep >= dp)
+ goto cerror;
+ }
+ } else {
+ *ep++ = c;
+ cclcnt++;
+ if (c == '\0' || ep >= dp)
+ goto cerror;
+ }
} while ((c = *sp++) != ']');
lastep[1] = cclcnt;
continue;
@@ -800,7 +831,7 @@
n = *set++;
while (--n)
- if (*set++ == c)
+ if (*set++ == c || set[-1] == cc[(unsigned char)c])
return (af);
return (!af);
[Prev in Thread] |
Current Thread |
[Next in Thread] |
- [Nmh-commits] nmh/uip picksbr.c,
Paul Fox <=