1 1.15 dholland /* $NetBSD: pig.c,v 1.15 2012/06/19 05:46:09 dholland Exp $ */ 2 1.2 cgd 3 1.1 cgd /*- 4 1.1 cgd * Copyright (c) 1992, 1993 5 1.1 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.9 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.5 lukem #include <sys/cdefs.h> 33 1.1 cgd #ifndef lint 34 1.13 lukem __COPYRIGHT("@(#) Copyright (c) 1992, 1993\ 35 1.13 lukem The Regents of the University of California. All rights reserved."); 36 1.1 cgd #endif /* not lint */ 37 1.1 cgd 38 1.1 cgd #ifndef lint 39 1.2 cgd #if 0 40 1.4 tls static char sccsid[] = "@(#)pig.c 8.2 (Berkeley) 5/4/95"; 41 1.2 cgd #else 42 1.15 dholland __RCSID("$NetBSD: pig.c,v 1.15 2012/06/19 05:46:09 dholland Exp $"); 43 1.2 cgd #endif 44 1.1 cgd #endif /* not lint */ 45 1.1 cgd 46 1.1 cgd #include <sys/types.h> 47 1.1 cgd 48 1.1 cgd #include <ctype.h> 49 1.6 lukem #include <err.h> 50 1.1 cgd #include <stdio.h> 51 1.1 cgd #include <stdlib.h> 52 1.1 cgd #include <string.h> 53 1.4 tls #include <unistd.h> 54 1.1 cgd 55 1.10 jsm int main(int, char *[]); 56 1.14 dholland static void pigout(char *, int); 57 1.14 dholland static void usage(void) __dead; 58 1.1 cgd 59 1.1 cgd int 60 1.15 dholland main(int argc, char *argv[]) 61 1.1 cgd { 62 1.5 lukem int len; 63 1.1 cgd int ch; 64 1.1 cgd char buf[1024]; 65 1.1 cgd 66 1.5 lukem while ((ch = getopt(argc, argv, "")) != -1) 67 1.1 cgd switch(ch) { 68 1.1 cgd case '?': 69 1.1 cgd default: 70 1.1 cgd usage(); 71 1.1 cgd } 72 1.1 cgd argc -= optind; 73 1.1 cgd argv += optind; 74 1.1 cgd 75 1.1 cgd for (len = 0; (ch = getchar()) != EOF;) { 76 1.1 cgd if (isalpha(ch)) { 77 1.8 jsm if ((size_t)len >= sizeof(buf)) 78 1.6 lukem errx(1, "ate too much!"); 79 1.1 cgd buf[len++] = ch; 80 1.1 cgd continue; 81 1.1 cgd } 82 1.1 cgd if (len != 0) { 83 1.1 cgd pigout(buf, len); 84 1.1 cgd len = 0; 85 1.1 cgd } 86 1.1 cgd (void)putchar(ch); 87 1.1 cgd } 88 1.1 cgd exit(0); 89 1.1 cgd } 90 1.1 cgd 91 1.14 dholland static void 92 1.15 dholland pigout(char *buf, int len) 93 1.1 cgd { 94 1.5 lukem int ch, start, i; 95 1.3 cgd int olen, allupper, firstupper; 96 1.3 cgd 97 1.3 cgd /* See if the word is all upper case */ 98 1.11 dsl allupper = firstupper = isupper((unsigned char)buf[0]); 99 1.3 cgd for (i = 1; i < len && allupper; i++) 100 1.11 dsl allupper = allupper && isupper((unsigned char)buf[i]); 101 1.1 cgd 102 1.1 cgd /* 103 1.1 cgd * If the word starts with a vowel, append "way". Don't treat 'y' 104 1.1 cgd * as a vowel if it appears first. 105 1.1 cgd */ 106 1.6 lukem if (strchr("aeiouAEIOU", buf[0]) != NULL) { 107 1.3 cgd (void)printf("%.*s%s", len, buf, 108 1.3 cgd allupper ? "WAY" : "way"); 109 1.1 cgd return; 110 1.1 cgd } 111 1.1 cgd 112 1.1 cgd /* 113 1.1 cgd * Copy leading consonants to the end of the word. The unit "qu" 114 1.1 cgd * isn't treated as a vowel. 115 1.1 cgd */ 116 1.3 cgd if (!allupper) 117 1.11 dsl buf[0] = tolower((unsigned char)buf[0]); 118 1.1 cgd for (start = 0, olen = len; 119 1.6 lukem !strchr("aeiouyAEIOUY", buf[start]) && start < olen;) { 120 1.1 cgd ch = buf[len++] = buf[start++]; 121 1.1 cgd if ((ch == 'q' || ch == 'Q') && start < olen && 122 1.1 cgd (buf[start] == 'u' || buf[start] == 'U')) 123 1.1 cgd buf[len++] = buf[start++]; 124 1.1 cgd } 125 1.3 cgd if (firstupper) 126 1.11 dsl buf[start] = toupper((unsigned char)buf[start]); 127 1.3 cgd (void)printf("%.*s%s", olen, buf + start, allupper ? "AY" : "ay"); 128 1.1 cgd } 129 1.1 cgd 130 1.14 dholland static void 131 1.15 dholland usage(void) 132 1.1 cgd { 133 1.1 cgd (void)fprintf(stderr, "usage: pig\n"); 134 1.1 cgd exit(1); 135 1.1 cgd } 136