Apply the BSD echo version submitted by Jonas Holmberg <jonas.holmberg@axis.com>
This commit is contained in:
parent
ddea368dbe
commit
8fff78d66e
@ -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
92
echo.c
@ -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
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user