]> git.cameronkatri.com Git - bsdgames-darwin.git/blobdiff - battlestar/getcom.c
cgram: allow navigation with KEY_PPAGE and KEY_NPAGE
[bsdgames-darwin.git] / battlestar / getcom.c
index 29a34560f09791633afe6c58fc425b8211767571..7e13b5f92799fd442877fad8adccfb5d909fcec3 100644 (file)
@@ -1,4 +1,4 @@
-/*     $NetBSD: getcom.c,v 1.11 2003/08/07 09:37:02 agc Exp $  */
+/*     $NetBSD: getcom.c,v 1.14 2012/01/16 17:38:16 christos Exp $     */
 
 /*
  * Copyright (c) 1983, 1993
 #if 0
 static char sccsid[] = "@(#)getcom.c   8.1 (Berkeley) 5/31/93";
 #else
-__RCSID("$NetBSD: getcom.c,v 1.11 2003/08/07 09:37:02 agc Exp $");
+__RCSID("$NetBSD: getcom.c,v 1.14 2012/01/16 17:38:16 christos Exp $");
 #endif
 #endif                         /* not lint */
 
 #include "extern.h"
 
-char   *
-getcom(buf, size, prompt, error)
-       char   *buf;
-       int     size;
-       const char   *prompt, *error;
+char *
+getcom(char *buf, int size, const char *prompt, const char *error)
 {
        for (;;) {
                fputs(prompt, stdout);
-               if (fgets(buf, size, stdin) == 0) {
+               if (fgets(buf, size, stdin) == NULL) {
                        if (feof(stdin))
                                die();
                        clearerr(stdin);
                        continue;
                }
-               while (isspace(*buf))
+               while (isspace((unsigned char)*buf))
                        buf++;
                if (*buf)
                        break;
                if (error)
                        puts(error);
        }
-       /* If we didn't get to the end of the line, don't read it in next time. */
+       /* If we didn't get to the end of line, don't read it in next time. */
        if (buf[strlen(buf) - 1] != '\n') {
                int i;
                while ((i = getchar()) != '\n' && i != EOF)
@@ -76,32 +73,33 @@ getcom(buf, size, prompt, error)
  * and leaves it unchanged if flag = 0
  */
 char   *
-getword(buf1, buf2, flag)
-       char   *buf1, *buf2;
-       int     flag;
+getword(char *buf1, char *buf2, int flag)
 {
        int cnt;
 
        cnt = 1;
-       while (isspace(*buf1))
+       while (isspace((unsigned char)*buf1))
                buf1++;
        if (*buf1 != ',') {
                if (!*buf1) {
                        *buf2 = 0;
                        return (0);
                }
-               while (cnt < WORDLEN && *buf1 && !isspace(*buf1) && *buf1 != ',')
+               while (cnt < WORDLEN && *buf1 && 
+                   !isspace((unsigned char)*buf1) && *buf1 != ',')
                        if (flag < 0) {
-                               if (isupper(*buf1)) {
-                                       *buf2++ = tolower(*buf1++);
+                               if (isupper((unsigned char)*buf1)) {
+                                       *buf2++ = 
+                                           tolower((unsigned char)*buf1++);
                                        cnt++;
                                } else {
                                        *buf2++ = *buf1++;
                                        cnt++;
                                }
                        } else if (flag > 0) {
-                               if (islower(*buf1)) {
-                                       *buf2++ = toupper(*buf1++);
+                               if (islower((unsigned char)*buf1)) {
+                                       *buf2++ = 
+                                           toupper((unsigned char)*buf1++);
                                        cnt++;
                                } else {
                                        *buf2++ = *buf1++;
@@ -112,12 +110,12 @@ getword(buf1, buf2, flag)
                                cnt++;
                        }
                if (cnt == WORDLEN)
-                       while (*buf1 && !isspace(*buf1))
+                       while (*buf1 && !isspace((unsigned char)*buf1))
                                buf1++;
        } else
                *buf2++ = *buf1++;
        *buf2 = '\0';
-       while (isspace(*buf1))
+       while (isspace((unsigned char)*buf1))
                buf1++;
        return (*buf1 ? buf1 : NULL);
 }