165 lines
3.0 KiB
C
165 lines
3.0 KiB
C
|
/*
|
||
|
* Simple timing program for regcomp().
|
||
|
* Usage: timer ncomp nexec nsub
|
||
|
* or
|
||
|
* timer ncomp nexec nsub regexp string [ answer [ sub ] ]
|
||
|
*
|
||
|
* The second form is for timing repetitions of a single test case.
|
||
|
* The first form's test data is a compiled-in copy of the "tests" file.
|
||
|
* Ncomp, nexec, nsub are how many times to do each regcomp, regexec,
|
||
|
* and regsub. The way to time an operation individually is to do something
|
||
|
* like "timer 1 50 1".
|
||
|
*/
|
||
|
#include <stdio.h>
|
||
|
|
||
|
struct try {
|
||
|
char *re, *str, *ans, *src, *dst;
|
||
|
} tests[] = {
|
||
|
#include "timer.t.h"
|
||
|
{ NULL, NULL, NULL, NULL, NULL }
|
||
|
};
|
||
|
|
||
|
#include <regexp.h>
|
||
|
|
||
|
int errreport = 0; /* Report errors via errseen? */
|
||
|
char *errseen = NULL; /* Error message. */
|
||
|
|
||
|
char *progname;
|
||
|
|
||
|
/* ARGSUSED */
|
||
|
main(argc, argv)
|
||
|
int argc;
|
||
|
char *argv[];
|
||
|
{
|
||
|
int ncomp, nexec, nsub;
|
||
|
struct try one;
|
||
|
char dummy[512];
|
||
|
|
||
|
if (argc < 4) {
|
||
|
ncomp = 1;
|
||
|
nexec = 1;
|
||
|
nsub = 1;
|
||
|
} else {
|
||
|
ncomp = atoi(argv[1]);
|
||
|
nexec = atoi(argv[2]);
|
||
|
nsub = atoi(argv[3]);
|
||
|
}
|
||
|
|
||
|
progname = argv[0];
|
||
|
if (argc > 5) {
|
||
|
one.re = argv[4];
|
||
|
one.str = argv[5];
|
||
|
if (argc > 6)
|
||
|
one.ans = argv[6];
|
||
|
else
|
||
|
one.ans = "y";
|
||
|
if (argc > 7) {
|
||
|
one.src = argv[7];
|
||
|
one.dst = "xxx";
|
||
|
} else {
|
||
|
one.src = "x";
|
||
|
one.dst = "x";
|
||
|
}
|
||
|
errreport = 1;
|
||
|
try(one, ncomp, nexec, nsub);
|
||
|
} else
|
||
|
multiple(ncomp, nexec, nsub);
|
||
|
exit(0);
|
||
|
}
|
||
|
|
||
|
void
|
||
|
regerror(s)
|
||
|
char *s;
|
||
|
{
|
||
|
if (errreport)
|
||
|
errseen = s;
|
||
|
else
|
||
|
error(s, "");
|
||
|
}
|
||
|
|
||
|
#ifndef ERRAVAIL
|
||
|
error(s1, s2)
|
||
|
char *s1;
|
||
|
char *s2;
|
||
|
{
|
||
|
fprintf(stderr, "regexp: ");
|
||
|
fprintf(stderr, s1, s2);
|
||
|
fprintf(stderr, "\n");
|
||
|
exit(1);
|
||
|
}
|
||
|
#endif
|
||
|
|
||
|
int lineno = 0;
|
||
|
|
||
|
multiple(ncomp, nexec, nsub)
|
||
|
int ncomp, nexec, nsub;
|
||
|
{
|
||
|
register int i;
|
||
|
extern char *strchr();
|
||
|
|
||
|
errreport = 1;
|
||
|
for (i = 0; tests[i].re != NULL; i++) {
|
||
|
lineno++;
|
||
|
try(tests[i], ncomp, nexec, nsub);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
try(fields, ncomp, nexec, nsub)
|
||
|
struct try fields;
|
||
|
int ncomp, nexec, nsub;
|
||
|
{
|
||
|
regexp *r;
|
||
|
char dbuf[BUFSIZ];
|
||
|
register int i;
|
||
|
|
||
|
errseen = NULL;
|
||
|
r = regcomp(fields.re);
|
||
|
if (r == NULL) {
|
||
|
if (*fields.ans != 'c')
|
||
|
complain("regcomp failure in `%s'", fields.re);
|
||
|
return;
|
||
|
}
|
||
|
if (*fields.ans == 'c') {
|
||
|
complain("unexpected regcomp success in `%s'", fields.re);
|
||
|
free((char *)r);
|
||
|
return;
|
||
|
}
|
||
|
for (i = ncomp-1; i > 0; i--) {
|
||
|
free((char *)r);
|
||
|
r = regcomp(fields.re);
|
||
|
}
|
||
|
if (!regexec(r, fields.str)) {
|
||
|
if (*fields.ans != 'n')
|
||
|
complain("regexec failure in `%s'", "");
|
||
|
free((char *)r);
|
||
|
return;
|
||
|
}
|
||
|
if (*fields.ans == 'n') {
|
||
|
complain("unexpected regexec success", "");
|
||
|
free((char *)r);
|
||
|
return;
|
||
|
}
|
||
|
for (i = nexec-1; i > 0; i--)
|
||
|
(void) regexec(r, fields.str);
|
||
|
errseen = NULL;
|
||
|
for (i = nsub; i > 0; i--)
|
||
|
regsub(r, fields.src, dbuf);
|
||
|
if (errseen != NULL) {
|
||
|
complain("regsub complaint", "");
|
||
|
free((char *)r);
|
||
|
return;
|
||
|
}
|
||
|
if (strcmp(dbuf, fields.dst) != 0)
|
||
|
complain("regsub result `%s' wrong", dbuf);
|
||
|
free((char *)r);
|
||
|
}
|
||
|
|
||
|
complain(s1, s2)
|
||
|
char *s1;
|
||
|
char *s2;
|
||
|
{
|
||
|
fprintf(stderr, "try: %d: ", lineno);
|
||
|
fprintf(stderr, s1, s2);
|
||
|
fprintf(stderr, " (%s)\n", (errseen != NULL) ? errseen : "");
|
||
|
}
|