]> git.cameronkatri.com Git - bsdgames-darwin.git/blobdiff - quiz/rxp.c
Fix merge conflicts
[bsdgames-darwin.git] / quiz / rxp.c
index 7adf8b5f23893ff09baac0e110d18986e60cd40d..015d8a51a3292651320e7ced4cb62ca3b1203582 100644 (file)
@@ -1,9 +1,12 @@
+/*     $NetBSD: rxp.c,v 1.13 2009/08/27 00:31:12 dholland Exp $        */
+
 /*-
- * Copyright (c) 1991 The Regents of the University of California.
- * All rights reserved.
+ * Copyright (c) 1991, 1993
+ *     The Regents of the University of California.  All rights reserved.
  *
  * This code is derived from software contributed to Berkeley by
- * Jim R. Oldroyd at The Instruction Set.
+ * Jim R. Oldroyd at The Instruction Set and Keith Gabryelski at
+ * Commodore Business Machines.
  *
  * Redistribution and use in source and binary forms, with or without
  * modification, are permitted provided that the following conditions
  * 2. Redistributions in binary form must reproduce the above copyright
  *    notice, this list of conditions and the following disclaimer in the
  *    documentation and/or other materials provided with the distribution.
- * 3. All advertising materials mentioning features or use of this software
- *    must display the following acknowledgement:
- *     This product includes software developed by the University of
- *     California, Berkeley and its contributors.
- * 4. Neither the name of the University nor the names of its contributors
+ * 3. Neither the name of the University nor the names of its contributors
  *    may be used to endorse or promote products derived from this software
  *    without specific prior written permission.
  *
  * SUCH DAMAGE.
  */
 
+#include <sys/cdefs.h>
 #ifndef lint
-static char sccsid[] = "@(#)rxp.c      5.1 (Berkeley) 11/10/91";
+#if 0
+static char sccsid[] = "@(#)rxp.c      8.1 (Berkeley) 5/31/93";
+#else
+__RCSID("$NetBSD: rxp.c,v 1.13 2009/08/27 00:31:12 dholland Exp $");
+#endif
 #endif /* not lint */
 
 /*
@@ -60,6 +64,7 @@ static char sccsid[] = "@(#)rxp.c     5.1 (Berkeley) 11/10/91";
  */
 
 #include <stdio.h>
+#include <stdlib.h>
 #include <ctype.h>
 #include "quiz.h"
                                        /* regexp tokens,       arg */
@@ -77,24 +82,21 @@ typedef short Rxp_t;                        /* type for regexp tokens */
 static Rxp_t rxpbuf[RXP_LINE_SZ];      /* compiled regular expression buffer */
 char rxperr[128];                      /* parser error message */
 
-int     rxp__compile __P((char *, int));
-char   *rxp__expand __P((int));
-int     rxp__match __P((char *, int, Rxp_t *, Rxp_t *, char *));
+static int      rxp__compile(const char *, int);
+static char    *rxp__expand(int);
+static int      rxp__match(const char *, int, Rxp_t *, Rxp_t *, const char *);
 
 int
-rxp_compile(s)
-       register char * s;
+rxp_compile(const char *s)
 {
        return (rxp__compile(s, TRUE));
 }
 
 static int
-rxp__compile(s, first)
-       register char *s;
-       int first;
+rxp__compile(const char *s, int first)
 {
        static Rxp_t *rp;
-       static char *sp;
+       static const char *sp;
        Rxp_t *grp_ptr;
        Rxp_t *alt_ptr;
        int esc, err;
@@ -187,25 +189,22 @@ rxp__compile(s, first)
  * match string against compiled regular expression
  */
 int
-rxp_match(s)
-       register char * s;
+rxp_match(const char *s)
 {
        return (rxp__match(s, TRUE, NULL, NULL, NULL));
 }
 
 static int
-rxp__match(s, first, j_succ, j_fail, sp_fail)
-       char *s;
-       int first;
-       Rxp_t *j_succ;          /* jump here on successful alt match */
-       Rxp_t *j_fail;          /* jump here on failed match */
-       char *sp_fail;          /* reset sp to here on failed match */
+rxp__match(const char *s,
+          int first,
+          Rxp_t *j_succ,               /* jump here on successful alt match */
+          Rxp_t *j_fail,               /* jump here on failed match */
+          const char *sp_fail)         /* reset sp to here on failed match */
 {
        static Rxp_t *rp;
-       static char *sp;
-       register int ch;
-       Rxp_t *grp_end;
-       int err;
+       static const char *sp;
+       int ch;
+       Rxp_t *grp_end = NULL;
 
        if (first) {
                rp = rxpbuf;
@@ -219,7 +218,7 @@ rxp__match(s, first, j_succ, j_fail, sp_fail)
                        if (ch != *sp++) {
                                rp = j_fail;
                                sp = sp_fail;
-                               return (TRUE);
+                               return (FALSE);
                        }
                        rp++;
                        break;
@@ -239,16 +238,17 @@ rxp__match(s, first, j_succ, j_fail, sp_fail)
                        break;
                case ALT_S:
                        rp++;
-                       if ((err = rxp__match(sp,
-                           FALSE, grp_end, rxpbuf + *rp++, sp)) != TRUE)
-                               return (err);
+                       rxp__match(sp, FALSE, grp_end, rxpbuf + *rp++, sp);
                        break;
                case ALT_E:
                        rp = j_succ;
                        return (TRUE);
                case GRP_E:
-               default:
+                       rp = j_fail;
+                       sp = sp_fail;
                        return (FALSE);
+               default:
+                       abort();
                }
        return (*rp != END ? FALSE : TRUE);
 }
@@ -257,14 +257,13 @@ rxp__match(s, first, j_succ, j_fail, sp_fail)
  * Reverse engineer the regular expression, by picking first of all alternates.
  */
 char *
-rxp_expand()
+rxp_expand(void)
 {
        return (rxp__expand(TRUE));
 }
 
 static char *
-rxp__expand(first)
-       int first;
+rxp__expand(int first)
 {
        static char buf[RXP_LINE_SZ/2];
        static Rxp_t *rp;