]> git.cameronkatri.com Git - bsdgames-darwin.git/blobdiff - monop/getinp.c
Fix merge conflicts
[bsdgames-darwin.git] / monop / getinp.c
index b9e5fcc0084817b962121c41f7a91334473514de..3d0dc637f04dc359343f9ca4f5fd05cd6b717d79 100644 (file)
@@ -1,4 +1,4 @@
-/*     $NetBSD: getinp.c,v 1.4 1995/04/24 12:24:20 cgd Exp $   */
+/*     $NetBSD: getinp.c,v 1.19 2012/06/19 05:35:32 dholland Exp $     */
 
 /*
  * Copyright (c) 1980, 1993
  * 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
 #if 0
 static char sccsid[] = "@(#)getinp.c   8.1 (Berkeley) 5/31/93";
 #else
-static char rcsid[] = "$NetBSD: getinp.c,v 1.4 1995/04/24 12:24:20 cgd Exp $";
+__RCSID("$NetBSD: getinp.c,v 1.19 2012/06/19 05:35:32 dholland Exp $");
 #endif
 #endif /* not lint */
 
-# include      <stdio.h>
-# include      <string.h>
-# include      <ctype.h>
+#include <stdio.h>
+#include <string.h>
+#include <ctype.h>
 
-# define       reg     register
+#include "monop.h"
 
-# define       LINE    70
+#define        LINE    70
 
 static char    buf[257];
 
-getinp(prompt, list)
-char   *prompt, *list[]; {
+static int comp(const char *);
 
-       reg int i, n_match, match;
-       char    *sp;
-       int     plen;
-       static int comp();
+int
+getinp(const char *prompt, const char *const lst [])
+{
+       int i, n_match, match = 0;
+       char *sp;
 
        for (;;) {
-inter:
-               printf(prompt);
-               for (sp = buf; (*sp=getchar()) != '\n'; )
-                       if (*sp == -1)  /* check for interupted system call */
-                               goto inter;
-                       else if (sp != buf || *sp != ' ')
-                               sp++;
+               printf("%s", prompt);
+               fgets(buf, sizeof(buf), stdin);
+               if (feof(stdin)) {
+                       return 0;
+               }
                if (buf[0] == '?' && buf[1] == '\n') {
                        printf("Valid inputs are: ");
-                       for (i = 0, match = 18; list[i]; i++) {
-                               if ((match+=(n_match=strlen(list[i]))) > LINE) {
+                       for (i = 0, match = 18; lst[i]; i++) {
+                               if ((match+=(n_match=strlen(lst[i]))) > LINE) {
                                        printf("\n\t");
                                        match = n_match + 8;
                                }
-                               if (*list[i] == '\0') {
+                               if (*lst[i] == '\0') {
                                        match += 8;
                                        printf("<RETURN>");
                                }
                                else
-                                       printf(list[i]);
-                               if (list[i+1])
+                                       printf("%s", lst[i]);
+                               if (lst[i+1])
                                        printf(", ");
                                else
                                        putchar('\n');
@@ -88,31 +83,32 @@ inter:
                        }
                        continue;
                }
-               *sp = '\0';
+               if ((sp = strchr(buf, '\n')) != NULL)
+                       *sp = '\0';
                for (sp = buf; *sp; sp++)
-                       if (isupper(*sp))
-                               *sp = tolower(*sp);
-               for (i = n_match = 0; list[i]; i++)
-                       if (comp(list[i])) {
+                       *sp = tolower((unsigned char)*sp);
+               for (i = n_match = 0; lst[i]; i++)
+                       if (comp(lst[i])) {
                                n_match++;
                                match = i;
                        }
                if (n_match == 1)
                        return match;
                else if (buf[0] != '\0')
-                       printf("Illegal response: \"%s\".  Use '?' to get list of valid answers\n", buf);
+                       printf("Illegal response: \"%s\".  "
+                           "Use '?' to get list of valid answers\n", buf);
        }
 }
 
-static
-comp(s1)
-char   *s1; {
-
-       reg char        *sp, *tsp, c;
+static int
+comp(const char *s1)
+{
+       const char *sp, *tsp;
+       char c;
 
        if (buf[0] != '\0')
                for (sp = buf, tsp = s1; *sp; ) {
-                       c = isupper(*tsp) ? tolower(*tsp) : *tsp;
+                       c = tolower((unsigned char)*tsp);
                        tsp++;
                        if (c != *sp++)
                                return 0;