blob: ca7a8f2fec3973f91d394af4568663e7b73f713e (
plain)
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
|
int match(char r, char t)
{
return r == '.' || r == t;
}
int matchstr(const char *r, const char *t)
{
int state = 0, i = (r[0] == '^' ? 1 : 0), j = 0;
while (1)
{
if (r[i] == '\0')
return 1;
if (r[i] == '$' && r[i + 1] == '\0')
return t[j] == '\0';
if (t[j] == '\0')
return 0;
if (state == 0) // base case
{
if (r[i + 1] == '*')
state = 1;
else if (match(r[i], t[j]))
i++, j++;
else if (r[0] == '^')
return 0;
else
i = 0;
}
if (state == 1) // star
{
if (!match(r[i], t[j]) || match(r[i + 2], t[j]))
state = 0, i += 2;
else
j++;
}
}
return 0;
}
#include <stdio.h>
int main(int argc, char **argv)
{
if (argc != 3)
{
printf("Usage: %s <regex> <text>\n", argv[0]);
return 2;
}
return !matchstr(argv[1], argv[2]);
}
|