summaryrefslogtreecommitdiff
path: root/libc/regexp/try.c
diff options
context:
space:
mode:
Diffstat (limited to 'libc/regexp/try.c')
-rw-r--r--libc/regexp/try.c238
1 files changed, 238 insertions, 0 deletions
diff --git a/libc/regexp/try.c b/libc/regexp/try.c
new file mode 100644
index 0000000..71620c2
--- /dev/null
+++ b/libc/regexp/try.c
@@ -0,0 +1,238 @@
+/*
+ * Simple test program for regexp(3) stuff. Knows about debugging hooks.
+ *
+ * Copyright (c) 1986 by University of Toronto.
+ * Written by Henry Spencer. Not derived from licensed software.
+ *
+ * Permission is granted to anyone to use this software for any
+ * purpose on any computer system, and to redistribute it freely,
+ * subject to the following restrictions:
+ *
+ * 1. The author is not responsible for the consequences of use of
+ * this software, no matter how awful, even if they arise
+ * from defects in it.
+ *
+ * 2. The origin of this software must not be misrepresented, either
+ * by explicit claim or by omission.
+ *
+ * 3. Altered versions must be plainly marked as such, and must not
+ * be misrepresented as being the original software.
+ *
+ * Usage: try re [string [output [-]]]
+ * The re is compiled and dumped, regexeced against the string, the result
+ * is applied to output using regsub(). The - triggers a running narrative
+ * from regexec(). Dumping and narrative don't happen unless DEBUG.
+ *
+ * If there are no arguments, stdin is assumed to be a stream of lines with
+ * five fields: a r.e., a string to match it against, a result code, a
+ * source string for regsub, and the proper result. Result codes are 'c'
+ * for compile failure, 'y' for match success, 'n' for match failure.
+ * Field separator is tab.
+ */
+#include <stdio.h>
+#include <regexp.h>
+
+#ifdef ERRAVAIL
+char *progname;
+extern char *mkprogname();
+#endif
+
+#ifdef DEBUG
+extern int regnarrate;
+#endif
+
+char buf[BUFSIZ];
+
+int errreport = 0; /* Report errors via errseen? */
+char *errseen = NULL; /* Error message. */
+int status = 0; /* Exit status. */
+
+/* ARGSUSED */
+main(argc, argv)
+int argc;
+char *argv[];
+{
+ regexp *r;
+ int i;
+
+#ifdef ERRAVAIL
+ progname = mkprogname(argv[0]);
+#endif
+
+ if (argc == 1) {
+ multiple();
+ exit(status);
+ }
+
+ r = regcomp(argv[1]);
+ if (r == NULL)
+ error("regcomp failure", "");
+#ifdef DEBUG
+ regdump(r);
+ if (argc > 4)
+ regnarrate++;
+#endif
+ if (argc > 2) {
+ i = regexec(r, argv[2]);
+ printf("%d", i);
+ for (i = 1; i < NSUBEXP; i++)
+ if (r->startp[i] != NULL && r->endp[i] != NULL)
+ printf(" \\%d", i);
+ printf("\n");
+ }
+ if (argc > 3) {
+ regsub(r, argv[3], buf);
+ printf("%s\n", buf);
+ }
+ exit(status);
+}
+
+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;
+
+regexp badregexp; /* Implicit init to 0. */
+
+multiple()
+{
+ char rbuf[BUFSIZ];
+ char *field[5];
+ char *scan;
+ int i;
+ regexp *r;
+ extern char *strchr();
+
+ errreport = 1;
+ lineno = 0;
+ while (fgets(rbuf, sizeof(rbuf), stdin) != NULL) {
+ rbuf[strlen(rbuf)-1] = '\0'; /* Dispense with \n. */
+ lineno++;
+ scan = rbuf;
+ for (i = 0; i < 5; i++) {
+ field[i] = scan;
+ if (field[i] == NULL) {
+ complain("bad testfile format", "");
+ exit(1);
+ }
+ scan = strchr(scan, '\t');
+ if (scan != NULL)
+ *scan++ = '\0';
+ }
+ try(field);
+ }
+
+ /* And finish up with some internal testing... */
+ lineno = 9990;
+ errseen = NULL;
+ if (regcomp((char *)NULL) != NULL || errseen == NULL)
+ complain("regcomp(NULL) doesn't complain", "");
+ lineno = 9991;
+ errseen = NULL;
+ if (regexec((regexp *)NULL, "foo") || errseen == NULL)
+ complain("regexec(NULL, ...) doesn't complain", "");
+ lineno = 9992;
+ r = regcomp("foo");
+ if (r == NULL) {
+ complain("regcomp(\"foo\") fails", "");
+ return;
+ }
+ lineno = 9993;
+ errseen = NULL;
+ if (regexec(r, (char *)NULL) || errseen == NULL)
+ complain("regexec(..., NULL) doesn't complain", "");
+ lineno = 9994;
+ errseen = NULL;
+ regsub((regexp *)NULL, "foo", rbuf);
+ if (errseen == NULL)
+ complain("regsub(NULL, ..., ...) doesn't complain", "");
+ lineno = 9995;
+ errseen = NULL;
+ regsub(r, (char *)NULL, rbuf);
+ if (errseen == NULL)
+ complain("regsub(..., NULL, ...) doesn't complain", "");
+ lineno = 9996;
+ errseen = NULL;
+ regsub(r, "foo", (char *)NULL);
+ if (errseen == NULL)
+ complain("regsub(..., ..., NULL) doesn't complain", "");
+ lineno = 9997;
+ errseen = NULL;
+ if (regexec(&badregexp, "foo") || errseen == NULL)
+ complain("regexec(nonsense, ...) doesn't complain", "");
+ lineno = 9998;
+ errseen = NULL;
+ regsub(&badregexp, "foo", rbuf);
+ if (errseen == NULL)
+ complain("regsub(nonsense, ..., ...) doesn't complain", "");
+}
+
+try(fields)
+char **fields;
+{
+ regexp *r;
+ char dbuf[BUFSIZ];
+
+ errseen = NULL;
+ r = regcomp(fields[0]);
+ if (r == NULL) {
+ if (*fields[2] != 'c')
+ complain("regcomp failure in `%s'", fields[0]);
+ return;
+ }
+ if (*fields[2] == 'c') {
+ complain("unexpected regcomp success in `%s'", fields[0]);
+ free((char *)r);
+ return;
+ }
+ if (!regexec(r, fields[1])) {
+ if (*fields[2] != 'n')
+ complain("regexec failure in `%s'", "");
+ free((char *)r);
+ return;
+ }
+ if (*fields[2] == 'n') {
+ complain("unexpected regexec success", "");
+ free((char *)r);
+ return;
+ }
+ errseen = NULL;
+ regsub(r, fields[3], dbuf);
+ if (errseen != NULL) {
+ complain("regsub complaint", "");
+ free((char *)r);
+ return;
+ }
+ if (strcmp(dbuf, fields[4]) != 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 : "");
+ status = 1;
+}