1 1.15 rillig /* $NetBSD: getcom.c,v 1.15 2021/05/02 12:50:43 rillig Exp $ */ 2 1.3 cgd 3 1.1 cgd /* 4 1.3 cgd * Copyright (c) 1983, 1993 5 1.3 cgd * The Regents of the University of California. All rights reserved. 6 1.1 cgd * 7 1.1 cgd * Redistribution and use in source and binary forms, with or without 8 1.1 cgd * modification, are permitted provided that the following conditions 9 1.1 cgd * are met: 10 1.1 cgd * 1. Redistributions of source code must retain the above copyright 11 1.1 cgd * notice, this list of conditions and the following disclaimer. 12 1.1 cgd * 2. Redistributions in binary form must reproduce the above copyright 13 1.1 cgd * notice, this list of conditions and the following disclaimer in the 14 1.1 cgd * documentation and/or other materials provided with the distribution. 15 1.11 agc * 3. Neither the name of the University nor the names of its contributors 16 1.1 cgd * may be used to endorse or promote products derived from this software 17 1.1 cgd * without specific prior written permission. 18 1.1 cgd * 19 1.1 cgd * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 20 1.1 cgd * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 21 1.1 cgd * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 22 1.1 cgd * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 23 1.1 cgd * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 24 1.1 cgd * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 25 1.1 cgd * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 26 1.1 cgd * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 27 1.1 cgd * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 28 1.1 cgd * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 29 1.1 cgd * SUCH DAMAGE. 30 1.1 cgd */ 31 1.1 cgd 32 1.4 lukem #include <sys/cdefs.h> 33 1.1 cgd #ifndef lint 34 1.3 cgd #if 0 35 1.3 cgd static char sccsid[] = "@(#)getcom.c 8.1 (Berkeley) 5/31/93"; 36 1.3 cgd #else 37 1.15 rillig __RCSID("$NetBSD: getcom.c,v 1.15 2021/05/02 12:50:43 rillig Exp $"); 38 1.3 cgd #endif 39 1.5 lukem #endif /* not lint */ 40 1.1 cgd 41 1.4 lukem #include "extern.h" 42 1.1 cgd 43 1.13 jmc char * 44 1.13 jmc getcom(char *buf, int size, const char *prompt, const char *error) 45 1.1 cgd { 46 1.1 cgd for (;;) { 47 1.5 lukem fputs(prompt, stdout); 48 1.14 christos if (fgets(buf, size, stdin) == NULL) { 49 1.8 jsm if (feof(stdin)) 50 1.8 jsm die(); 51 1.1 cgd clearerr(stdin); 52 1.1 cgd continue; 53 1.1 cgd } 54 1.12 dsl while (isspace((unsigned char)*buf)) 55 1.1 cgd buf++; 56 1.1 cgd if (*buf) 57 1.1 cgd break; 58 1.1 cgd if (error) 59 1.1 cgd puts(error); 60 1.10 jsm } 61 1.13 jmc /* If we didn't get to the end of line, don't read it in next time. */ 62 1.10 jsm if (buf[strlen(buf) - 1] != '\n') { 63 1.10 jsm int i; 64 1.10 jsm while ((i = getchar()) != '\n' && i != EOF) 65 1.10 jsm continue; 66 1.1 cgd } 67 1.1 cgd return (buf); 68 1.1 cgd } 69 1.1 cgd 70 1.1 cgd 71 1.1 cgd /* 72 1.1 cgd * shifts to UPPERCASE if flag > 0, lowercase if flag < 0, 73 1.1 cgd * and leaves it unchanged if flag = 0 74 1.1 cgd */ 75 1.5 lukem char * 76 1.13 jmc getword(char *buf1, char *buf2, int flag) 77 1.1 cgd { 78 1.9 jsm int cnt; 79 1.9 jsm 80 1.9 jsm cnt = 1; 81 1.12 dsl while (isspace((unsigned char)*buf1)) 82 1.1 cgd buf1++; 83 1.1 cgd if (*buf1 != ',') { 84 1.1 cgd if (!*buf1) { 85 1.1 cgd *buf2 = 0; 86 1.1 cgd return (0); 87 1.1 cgd } 88 1.15 rillig while (cnt < WORDLEN && *buf1 && 89 1.13 jmc !isspace((unsigned char)*buf1) && *buf1 != ',') 90 1.7 jsm if (flag < 0) { 91 1.12 dsl if (isupper((unsigned char)*buf1)) { 92 1.15 rillig *buf2++ = 93 1.13 jmc tolower((unsigned char)*buf1++); 94 1.9 jsm cnt++; 95 1.9 jsm } else { 96 1.1 cgd *buf2++ = *buf1++; 97 1.9 jsm cnt++; 98 1.9 jsm } 99 1.7 jsm } else if (flag > 0) { 100 1.12 dsl if (islower((unsigned char)*buf1)) { 101 1.15 rillig *buf2++ = 102 1.13 jmc toupper((unsigned char)*buf1++); 103 1.9 jsm cnt++; 104 1.9 jsm } else { 105 1.1 cgd *buf2++ = *buf1++; 106 1.9 jsm cnt++; 107 1.9 jsm } 108 1.9 jsm } else { 109 1.7 jsm *buf2++ = *buf1++; 110 1.9 jsm cnt++; 111 1.9 jsm } 112 1.9 jsm if (cnt == WORDLEN) 113 1.12 dsl while (*buf1 && !isspace((unsigned char)*buf1)) 114 1.9 jsm buf1++; 115 1.1 cgd } else 116 1.1 cgd *buf2++ = *buf1++; 117 1.9 jsm *buf2 = '\0'; 118 1.12 dsl while (isspace((unsigned char)*buf1)) 119 1.1 cgd buf1++; 120 1.9 jsm return (*buf1 ? buf1 : NULL); 121 1.1 cgd } 122