forked from Wikinaut/agrep
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdelim.c
96 lines (87 loc) · 3.09 KB
/
delim.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
/* Copyright (c) 1994 Burra Gopal, Udi Manber. All Rights Reserved. */
#include "agrep.h"
extern int EASYSEARCH, TCOMPRESSED;
/* Accesses src completely before dest, so that dest can be = src */
void
preprocess_delimiter(src, srclen, dest, pdestlen)
unsigned char *src, *dest;
int srclen, *pdestlen;
{
CHAR temp[Maxline];
int i, j;
strcpy(temp, src);
temp[srclen] = '\0';
for (i=0, j=0; i<srclen; i++) {
if (temp[i] == '\\') {
i++;
dest[j++] = temp[i];
}
if (temp[i] == '^') dest[j++] = '\n';
else if (temp[i] == '$') dest[j++] = '\n';
else dest[j++] = temp[i];
}
dest[j] = '\0';
*pdestlen = strlen(dest);
}
/* Simple quadratic search for delimiters: from, to, delim, len: offset after begin where delimiter begins, -1 otherwise */
int
exists_delimiter(begin, end, delim, len)
unsigned char *begin, *end, *delim;
int len;
{
register unsigned char *curbegin, *curbuf, *curdelim;
if (begin + len > end) return -1;
if (TCOMPRESSED == ON) return (exists_tcompressed_word(delim, len, begin, end - begin, EASYSEARCH));
for (curbegin = begin; curbegin + len <= end; curbegin ++) {
for (curbuf = curbegin, curdelim = delim; curbuf < curbegin + len; curbuf ++, curdelim++)
if (*curbuf != *curdelim) break;
if (curbuf >= curbegin + len) return (curbegin - begin);
}
return -1;
}
/* return where delimiter begins or ends (=outtail): range = [begin, end) */
unsigned char *
forward_delimiter(begin, end, delim, len, outtail)
unsigned char *begin, *end, *delim;
int len, outtail;
{
register unsigned char *curbegin, *curbuf, *curdelim;
if (begin + len > end) return end + 1;
if ((len == 1) && (*delim == '\n')) {
begin ++;
while ((begin < end) && (*begin != '\n')) begin ++;
if (outtail && (*begin == '\n')) begin++;
return begin;
}
if (TCOMPRESSED == ON) return forward_tcompressed_word(begin, end, delim, len, outtail, EASYSEARCH);
for (curbegin = begin; curbegin + len <= end; curbegin ++) {
for (curbuf = curbegin, curdelim = delim; curbuf < curbegin + len; curbuf ++, curdelim++)
if (*curbuf != *curdelim) break;
if (curbuf >= curbegin + len) break;
}
if (!outtail) return (curbegin <= end - len ? curbegin: end + 1);
else return (curbegin <= end - len ? curbegin + len : end + 1);
}
/* return where the delimiter begins or ends (=outtail): range = [begin, end) */
unsigned char *
backward_delimiter(end, begin, delim, len, outtail)
unsigned char *end, *begin, *delim;
int len, outtail;
{
register unsigned char *curbegin, *curbuf, *curdelim;
if (end - len < begin) return begin;
if ((len == 1) && (*delim == '\n')) {
end --;
while ((end > begin) && (*end != '\n')) end --;
if (outtail && (*end == '\n')) end++;
return end;
}
if (TCOMPRESSED == ON) return backward_tcompressed_word(end, begin, delim, len, outtail, EASYSEARCH);
for (curbegin = end-len; curbegin >= begin; curbegin --) {
for (curbuf = curbegin, curdelim = delim; curbuf < curbegin + len; curbuf ++, curdelim++)
if (*curbuf != *curdelim) break;
if (curbuf >= curbegin + len) break;
}
if (!outtail) return (curbegin >= begin ? curbegin : begin);
else return (curbegin >= begin ? curbegin + len : begin);
}