1 /* $OpenBSD: modes.c,v 1.6 2003/06/02 23:36:53 millert Exp $ */ 2 /* $NetBSD: modes.c,v 1.3 1997/10/20 08:08:31 scottr Exp $ */ 3 4 /*- 5 * Copyright (c) 1991, 1993, 1994 6 * The Regents of the University of California. All rights reserved. 7 * 8 * Redistribution and use in source and binary forms, with or without 9 * modification, are permitted provided that the following conditions 10 * are met: 11 * 1. Redistributions of source code must retain the above copyright 12 * notice, this list of conditions and the following disclaimer. 13 * 2. Redistributions in binary form must reproduce the above copyright 14 * notice, this list of conditions and the following disclaimer in the 15 * documentation and/or other materials provided with the distribution. 16 * 3. Neither the name of the University nor the names of its contributors 17 * may be used to endorse or promote products derived from this software 18 * without specific prior written permission. 19 * 20 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 21 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 22 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 23 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 24 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 25 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 26 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 27 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 28 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 29 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 30 * SUCH DAMAGE. 31 */ 32 33 #ifndef lint 34 #if 0 35 static const char sccsid[] = "@(#)modes.c 8.3 (Berkeley) 4/2/94"; 36 #else 37 static const char rcsid[] = "$OpenBSD: modes.c,v 1.6 2003/06/02 23:36:53 millert Exp $"; 38 #endif 39 #endif /* not lint */ 40 41 #include <sys/param.h> 42 #include <sys/types.h> 43 #include <stddef.h> 44 #include <string.h> 45 #include <termios.h> 46 #include "extern.h" 47 48 struct modes { 49 char *name; 50 long set; 51 long unset; 52 }; 53 54 /* 55 * The code in optlist() depends on minus options following regular 56 * options, i.e. "foo" must immediately precede "-foo". 57 */ 58 const struct modes cmodes[] = { 59 { "cs5", CS5, CSIZE }, 60 { "cs6", CS6, CSIZE }, 61 { "cs7", CS7, CSIZE }, 62 { "cs8", CS8, CSIZE }, 63 { "cstopb", CSTOPB, 0 }, 64 { "-cstopb", 0, CSTOPB }, 65 { "cread", CREAD, 0 }, 66 { "-cread", 0, CREAD }, 67 { "parenb", PARENB, 0 }, 68 { "-parenb", 0, PARENB }, 69 { "parodd", PARODD, 0 }, 70 { "-parodd", 0, PARODD }, 71 { "parity", PARENB | CS7, PARODD | CSIZE }, 72 { "-parity", CS8, PARODD | PARENB | CSIZE }, 73 { "evenp", PARENB | CS7, PARODD | CSIZE }, 74 { "-evenp", CS8, PARODD | PARENB | CSIZE }, 75 { "oddp", PARENB | CS7 | PARODD, CSIZE }, 76 { "-oddp", CS8, PARODD | PARENB | CSIZE }, 77 { "pass8", CS8, PARODD | PARENB | CSIZE }, 78 { "-pass8", PARENB | CS7, PARODD | CSIZE }, 79 { "hupcl", HUPCL, 0 }, 80 { "-hupcl", 0, HUPCL }, 81 { "hup", HUPCL, 0 }, 82 { "-hup", 0, HUPCL }, 83 { "clocal", CLOCAL, 0 }, 84 { "-clocal", 0, CLOCAL }, 85 { "crtscts", CRTSCTS, 0 }, 86 { "-crtscts", 0, CRTSCTS }, 87 { "mdmbuf", MDMBUF, 0 }, 88 { "-mdmbuf", 0, MDMBUF }, 89 { NULL }, 90 }; 91 92 const struct modes imodes[] = { 93 { "ignbrk", IGNBRK, 0 }, 94 { "-ignbrk", 0, IGNBRK }, 95 { "brkint", BRKINT, 0 }, 96 { "-brkint", 0, BRKINT }, 97 { "ignpar", IGNPAR, 0 }, 98 { "-ignpar", 0, IGNPAR }, 99 { "parmrk", PARMRK, 0 }, 100 { "-parmrk", 0, PARMRK }, 101 { "inpck", INPCK, 0 }, 102 { "-inpck", 0, INPCK }, 103 { "istrip", ISTRIP, 0 }, 104 { "-istrip", 0, ISTRIP }, 105 { "inlcr", INLCR, 0 }, 106 { "-inlcr", 0, INLCR }, 107 { "igncr", IGNCR, 0 }, 108 { "-igncr", 0, IGNCR }, 109 { "icrnl", ICRNL, 0 }, 110 { "-icrnl", 0, ICRNL }, 111 { "iuclc", IUCLC, 0 }, 112 { "-iuclc", 0, IUCLC }, 113 { "ixon", IXON, 0 }, 114 { "-ixon", 0, IXON }, 115 { "flow", IXON, 0 }, 116 { "-flow", 0, IXON }, 117 { "ixoff", IXOFF, 0 }, 118 { "-ixoff", 0, IXOFF }, 119 { "tandem", IXOFF, 0 }, 120 { "-tandem", 0, IXOFF }, 121 { "ixany", IXANY, 0 }, 122 { "-ixany", 0, IXANY }, 123 { "decctlq", 0, IXANY }, 124 { "-decctlq", IXANY, 0 }, 125 { "imaxbel", IMAXBEL, 0 }, 126 { "-imaxbel", 0, IMAXBEL }, 127 { NULL }, 128 }; 129 130 const struct modes lmodes[] = { 131 { "echo", ECHO, 0 }, 132 { "-echo", 0, ECHO }, 133 { "echoe", ECHOE, 0 }, 134 { "-echoe", 0, ECHOE }, 135 { "crterase", ECHOE, 0 }, 136 { "-crterase", 0, ECHOE }, 137 { "crtbs", ECHOE, 0 }, /* crtbs not supported, close enough */ 138 { "-crtbs", 0, ECHOE }, 139 { "echok", ECHOK, 0 }, 140 { "-echok", 0, ECHOK }, 141 { "echoke", ECHOKE, 0 }, 142 { "-echoke", 0, ECHOKE }, 143 { "crtkill", ECHOKE, 0 }, 144 { "-crtkill", 0, ECHOKE }, 145 { "altwerase", ALTWERASE, 0 }, 146 { "-altwerase", 0, ALTWERASE }, 147 { "iexten", IEXTEN, 0 }, 148 { "-iexten", 0, IEXTEN }, 149 { "echonl", ECHONL, 0 }, 150 { "-echonl", 0, ECHONL }, 151 { "echoctl", ECHOCTL, 0 }, 152 { "-echoctl", 0, ECHOCTL }, 153 { "ctlecho", ECHOCTL, 0 }, 154 { "-ctlecho", 0, ECHOCTL }, 155 { "echoprt", ECHOPRT, 0 }, 156 { "-echoprt", 0, ECHOPRT }, 157 { "prterase", ECHOPRT, 0 }, 158 { "-prterase", 0, ECHOPRT }, 159 { "isig", ISIG, 0 }, 160 { "-isig", 0, ISIG }, 161 { "icanon", ICANON, 0 }, 162 { "-icanon", 0, ICANON }, 163 { "noflsh", NOFLSH, 0 }, 164 { "-noflsh", 0, NOFLSH }, 165 { "tostop", TOSTOP, 0 }, 166 { "-tostop", 0, TOSTOP }, 167 { "flusho", FLUSHO, 0 }, 168 { "-flusho", 0, FLUSHO }, 169 { "pendin", PENDIN, 0 }, 170 { "-pendin", 0, PENDIN }, 171 { "crt", ECHOE|ECHOKE|ECHOCTL, ECHOK|ECHOPRT }, 172 { "-crt", ECHOK, ECHOE|ECHOKE|ECHOCTL }, 173 { "newcrt", ECHOE|ECHOKE|ECHOCTL, ECHOK|ECHOPRT }, 174 { "-newcrt", ECHOK, ECHOE|ECHOKE|ECHOCTL }, 175 { "nokerninfo", NOKERNINFO, 0 }, 176 { "-nokerninfo",0, NOKERNINFO }, 177 { "kerninfo", 0, NOKERNINFO }, 178 { "-kerninfo", NOKERNINFO, 0 }, 179 { "xcase", XCASE, 0 }, 180 { "-xcase", 0, XCASE }, 181 { NULL }, 182 }; 183 184 const struct modes omodes[] = { 185 { "opost", OPOST, 0 }, 186 { "-opost", 0, OPOST }, 187 { "litout", 0, OPOST }, 188 { "-litout", OPOST, 0 }, 189 { "ocrnl", OCRNL, 0 }, 190 { "-ocrnl", 0, OCRNL }, 191 { "olcuc", OLCUC, 0 }, 192 { "-olcuc", 0, OLCUC }, 193 { "onlcr", ONLCR, 0 }, 194 { "-onlcr", 0, ONLCR }, 195 { "onlret", ONLRET, 0 }, 196 { "-onlret", 0, ONLRET }, 197 { "onocr", ONOCR, 0 }, 198 { "-onocr", 0, ONOCR }, 199 { "tabs", 0, OXTABS }, /* "preserve" tabs */ 200 { "-tabs", OXTABS, 0 }, 201 { "oxtabs", OXTABS, 0 }, 202 { "-oxtabs", 0, OXTABS }, 203 { NULL }, 204 }; 205 206 #define CHK(s) (*name == s[0] && !strcmp(name, s)) 207 208 int 209 msearch(char ***argvp, struct info *ip) 210 { 211 const struct modes *mp; 212 char *name; 213 214 name = **argvp; 215 216 for (mp = cmodes; mp->name; ++mp) 217 if (CHK(mp->name)) { 218 ip->t.c_cflag &= ~mp->unset; 219 ip->t.c_cflag |= mp->set; 220 ip->set = 1; 221 return (1); 222 } 223 for (mp = imodes; mp->name; ++mp) 224 if (CHK(mp->name)) { 225 ip->t.c_iflag &= ~mp->unset; 226 ip->t.c_iflag |= mp->set; 227 ip->set = 1; 228 return (1); 229 } 230 for (mp = lmodes; mp->name; ++mp) 231 if (CHK(mp->name)) { 232 ip->t.c_lflag &= ~mp->unset; 233 ip->t.c_lflag |= mp->set; 234 ip->set = 1; 235 return (1); 236 } 237 for (mp = omodes; mp->name; ++mp) 238 if (CHK(mp->name)) { 239 ip->t.c_oflag &= ~mp->unset; 240 ip->t.c_oflag |= mp->set; 241 ip->set = 1; 242 return (1); 243 } 244 return (0); 245 } 246