blob: 1ca37346753005b0b21005acb5f73bc1c6678f02 [file] [log] [blame]
Erik Andersen13456d12000-03-16 08:09:57 +00001/* vi: set sw=4 ts=4: */
2/*
3 * echo implementation for busybox
4 *
5 * Copyright (c) 1991, 1993
6 * The Regents of the University of California. All rights reserved.
7 *
8 * This program is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License as published by
10 * the Free Software Foundation; either version 2 of the License, or
11 * (at your option) any later version.
12 *
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 * General Public License for more details.
17 *
18 * You should have received a copy of the GNU General Public License
19 * along with this program; if not, write to the Free Software
20 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
21 *
22 * Original copyright notice is retained at the end of this file.
23 */
24
Erik Andersen13456d12000-03-16 08:09:57 +000025#include <stdio.h>
Eric Andersened3ef502001-01-27 08:24:39 +000026#include <string.h>
27#include <stdlib.h>
Eric Andersencbe31da2001-02-20 06:14:08 +000028#include "busybox.h"
Erik Andersen13456d12000-03-16 08:09:57 +000029
30extern int
31echo_main(int argc, char** argv)
32{
Erik Andersen13456d12000-03-16 08:09:57 +000033 int nflag = 0;
34 int eflag = 0;
35
Eric Andersen8fff78d2000-11-29 22:40:59 +000036 /* Skip argv[0]. */
37 argc--;
38 argv++;
Eric Andersenadd09fd2000-07-14 18:39:08 +000039
Eric Andersen8fff78d2000-11-29 22:40:59 +000040 while (argc > 0 && *argv[0] == '-')
41 {
42 register char *temp;
Eric Andersen1ca20a72001-03-21 07:34:27 +000043 register int ix;
Eric Andersen8fff78d2000-11-29 22:40:59 +000044
45 /*
46 * If it appears that we are handling options, then make sure
47 * that all of the options specified are actually valid.
48 * Otherwise, the string should just be echoed.
49 */
50 temp = argv[0] + 1;
51
Eric Andersen1ca20a72001-03-21 07:34:27 +000052 for (ix = 0; temp[ix]; ix++)
Eric Andersen8fff78d2000-11-29 22:40:59 +000053 {
Eric Andersen1ca20a72001-03-21 07:34:27 +000054 if (strrchr("neE", temp[ix]) == 0)
Eric Andersen8fff78d2000-11-29 22:40:59 +000055 goto just_echo;
Erik Andersen13456d12000-03-16 08:09:57 +000056 }
Eric Andersen8fff78d2000-11-29 22:40:59 +000057
58 if (!*temp)
59 goto just_echo;
60
61 /*
62 * All of the options in temp are valid options to echo.
63 * Handle them.
64 */
65 while (*temp)
66 {
67 if (*temp == 'n')
68 nflag = 1;
69 else if (*temp == 'e')
70 eflag = 1;
71 else if (*temp == 'E')
72 eflag = 0;
73 else
74 goto just_echo;
75
76 temp++;
77 }
78 argc--;
79 argv++;
Erik Andersen13456d12000-03-16 08:09:57 +000080 }
Eric Andersenadd09fd2000-07-14 18:39:08 +000081
Eric Andersen8fff78d2000-11-29 22:40:59 +000082just_echo:
83 while (argc > 0) {
84 char *arg = argv[0];
85 register int c;
86
87 while ((c = *arg++)) {
88
89 /* Check for escape sequence. */
90 if (c == '\\' && eflag && *arg) {
91 if (*arg == 'c') {
92 /* '\c' means cancel newline. */
93 nflag = 1;
94 arg++;
95 continue;
96 } else {
97 c = process_escape_sequence(&arg);
98 }
Erik Andersen13456d12000-03-16 08:09:57 +000099 }
Eric Andersen8fff78d2000-11-29 22:40:59 +0000100
Erik Andersen13456d12000-03-16 08:09:57 +0000101 putchar(c);
102 }
Eric Andersen8fff78d2000-11-29 22:40:59 +0000103 argc--;
104 argv++;
105 if (argc > 0)
Erik Andersen13456d12000-03-16 08:09:57 +0000106 putchar(' ');
107 }
Eric Andersen8fff78d2000-11-29 22:40:59 +0000108 if (!nflag)
Erik Andersen13456d12000-03-16 08:09:57 +0000109 putchar('\n');
110 fflush(stdout);
Eric Andersen8fff78d2000-11-29 22:40:59 +0000111
Matt Kraai3e856ce2000-12-01 02:55:13 +0000112 return EXIT_SUCCESS;
Erik Andersen13456d12000-03-16 08:09:57 +0000113}
114
115/*-
116 * Copyright (c) 1991, 1993
117 * The Regents of the University of California. All rights reserved.
118 *
119 * This code is derived from software contributed to Berkeley by
120 * Kenneth Almquist.
121 *
122 * Redistribution and use in source and binary forms, with or without
123 * modification, are permitted provided that the following conditions
124 * are met:
125 * 1. Redistributions of source code must retain the above copyright
126 * notice, this list of conditions and the following disclaimer.
127 * 2. Redistributions in binary form must reproduce the above copyright
128 * notice, this list of conditions and the following disclaimer in the
129 * documentation and/or other materials provided with the distribution.
Eric Andersen4e573f42000-11-14 23:29:24 +0000130 *
131 * 3. <BSD Advertising Clause omitted per the July 22, 1999 licensing change
132 * ftp://ftp.cs.berkeley.edu/pub/4bsd/README.Impt.License.Change>
133 *
Eric Andersen8fff78d2000-11-29 22:40:59 +0000134 * California, Berkeley and its contributors.
Erik Andersen13456d12000-03-16 08:09:57 +0000135 * 4. Neither the name of the University nor the names of its contributors
136 * may be used to endorse or promote products derived from this software
137 * without specific prior written permission.
138 *
139 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
140 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
141 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
142 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
143 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
144 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
145 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
146 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
147 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
148 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
149 * SUCH DAMAGE.
150 *
151 * @(#)echo.c 8.1 (Berkeley) 5/31/93
152 */