Apply the BSD echo version submitted by Jonas Holmberg <jonas.holmberg@axis.com>

This commit is contained in:
Eric Andersen 2000-11-29 22:40:59 +00:00
parent ddea368dbe
commit 8fff78d66e
2 changed files with 134 additions and 58 deletions

View File

@ -28,47 +28,86 @@
extern int extern int
echo_main(int argc, char** argv) echo_main(int argc, char** argv)
{ {
register char **ap;
char *p;
int c;
int nflag = 0; int nflag = 0;
int eflag = 0; int eflag = 0;
/* Skip argv[0]. */
argc--;
argv++;
while ((c = getopt(argc, argv, "neE")) != EOF) { while (argc > 0 && *argv[0] == '-')
switch (c) { {
case 'n': register char *temp;
register int index;
/*
* If it appears that we are handling options, then make sure
* that all of the options specified are actually valid.
* Otherwise, the string should just be echoed.
*/
temp = argv[0] + 1;
for (index = 0; temp[index]; index++)
{
if (strrchr("neE", temp[index]) == 0)
goto just_echo;
}
if (!*temp)
goto just_echo;
/*
* All of the options in temp are valid options to echo.
* Handle them.
*/
while (*temp)
{
if (*temp == 'n')
nflag = 1; nflag = 1;
break; else if (*temp == 'e')
case 'e':
eflag = 1; eflag = 1;
break; else if (*temp == 'E')
case 'E':
eflag = 0; eflag = 0;
break; else
default: goto just_echo;
usage(echo_usage);
temp++;
}
argc--;
argv++;
}
just_echo:
while (argc > 0) {
char *arg = argv[0];
register int c;
while ((c = *arg++)) {
/* Check for escape sequence. */
if (c == '\\' && eflag && *arg) {
if (*arg == 'c') {
/* '\c' means cancel newline. */
nflag = 1;
arg++;
continue;
} else {
c = process_escape_sequence(&arg);
} }
} }
ap = &argv[optind];
while ((p = *ap++) != NULL) {
while ((c = *p++) != '\0') {
if (c == '\\' && eflag) {
if (*p == 'c')
exit(0);
else
c = process_escape_sequence(&p);
}
putchar(c); putchar(c);
} }
if (*ap) argc--;
argv++;
if (argc > 0)
putchar(' '); putchar(' ');
} }
if (! nflag) if (!nflag)
putchar('\n'); putchar('\n');
fflush(stdout); fflush(stdout);
return( 0);
return 0;
} }
/*- /*-
@ -90,6 +129,7 @@ echo_main(int argc, char** argv)
* 3. <BSD Advertising Clause omitted per the July 22, 1999 licensing change * 3. <BSD Advertising Clause omitted per the July 22, 1999 licensing change
* ftp://ftp.cs.berkeley.edu/pub/4bsd/README.Impt.License.Change> * ftp://ftp.cs.berkeley.edu/pub/4bsd/README.Impt.License.Change>
* *
* California, Berkeley and its contributors.
* 4. Neither the name of the University nor the names of its contributors * 4. Neither the name of the University nor the names of its contributors
* may be used to endorse or promote products derived from this software * may be used to endorse or promote products derived from this software
* without specific prior written permission. * without specific prior written permission.
@ -108,5 +148,3 @@ echo_main(int argc, char** argv)
* *
* @(#)echo.c 8.1 (Berkeley) 5/31/93 * @(#)echo.c 8.1 (Berkeley) 5/31/93
*/ */

92
echo.c
View File

@ -28,47 +28,86 @@
extern int extern int
echo_main(int argc, char** argv) echo_main(int argc, char** argv)
{ {
register char **ap;
char *p;
int c;
int nflag = 0; int nflag = 0;
int eflag = 0; int eflag = 0;
/* Skip argv[0]. */
argc--;
argv++;
while ((c = getopt(argc, argv, "neE")) != EOF) { while (argc > 0 && *argv[0] == '-')
switch (c) { {
case 'n': register char *temp;
register int index;
/*
* If it appears that we are handling options, then make sure
* that all of the options specified are actually valid.
* Otherwise, the string should just be echoed.
*/
temp = argv[0] + 1;
for (index = 0; temp[index]; index++)
{
if (strrchr("neE", temp[index]) == 0)
goto just_echo;
}
if (!*temp)
goto just_echo;
/*
* All of the options in temp are valid options to echo.
* Handle them.
*/
while (*temp)
{
if (*temp == 'n')
nflag = 1; nflag = 1;
break; else if (*temp == 'e')
case 'e':
eflag = 1; eflag = 1;
break; else if (*temp == 'E')
case 'E':
eflag = 0; eflag = 0;
break; else
default: goto just_echo;
usage(echo_usage);
temp++;
}
argc--;
argv++;
}
just_echo:
while (argc > 0) {
char *arg = argv[0];
register int c;
while ((c = *arg++)) {
/* Check for escape sequence. */
if (c == '\\' && eflag && *arg) {
if (*arg == 'c') {
/* '\c' means cancel newline. */
nflag = 1;
arg++;
continue;
} else {
c = process_escape_sequence(&arg);
} }
} }
ap = &argv[optind];
while ((p = *ap++) != NULL) {
while ((c = *p++) != '\0') {
if (c == '\\' && eflag) {
if (*p == 'c')
exit(0);
else
c = process_escape_sequence(&p);
}
putchar(c); putchar(c);
} }
if (*ap) argc--;
argv++;
if (argc > 0)
putchar(' '); putchar(' ');
} }
if (! nflag) if (!nflag)
putchar('\n'); putchar('\n');
fflush(stdout); fflush(stdout);
return( 0);
return 0;
} }
/*- /*-
@ -90,6 +129,7 @@ echo_main(int argc, char** argv)
* 3. <BSD Advertising Clause omitted per the July 22, 1999 licensing change * 3. <BSD Advertising Clause omitted per the July 22, 1999 licensing change
* ftp://ftp.cs.berkeley.edu/pub/4bsd/README.Impt.License.Change> * ftp://ftp.cs.berkeley.edu/pub/4bsd/README.Impt.License.Change>
* *
* California, Berkeley and its contributors.
* 4. Neither the name of the University nor the names of its contributors * 4. Neither the name of the University nor the names of its contributors
* may be used to endorse or promote products derived from this software * may be used to endorse or promote products derived from this software
* without specific prior written permission. * without specific prior written permission.
@ -108,5 +148,3 @@ echo_main(int argc, char** argv)
* *
* @(#)echo.c 8.1 (Berkeley) 5/31/93 * @(#)echo.c 8.1 (Berkeley) 5/31/93
*/ */