diff options
author | Eric Andersen | 2001-07-09 21:32:29 +0000 |
---|---|---|
committer | Eric Andersen | 2001-07-09 21:32:29 +0000 |
commit | 5a4a46a2519af1e79d931a856ee1a3b70e60d168 (patch) | |
tree | 8984e4a7c0db121de64ca8de078a0d3ff13dba6e /coreutils | |
parent | f52947ba71cafc771a5858ee2347f31e724376fc (diff) | |
download | busybox-5a4a46a2519af1e79d931a856ee1a3b70e60d168.zip busybox-5a4a46a2519af1e79d931a856ee1a3b70e60d168.tar.gz |
Patch from vodz to support 'tr a-z A-Z' syntax.
Diffstat (limited to 'coreutils')
-rw-r--r-- | coreutils/tr.c | 18 |
1 files changed, 13 insertions, 5 deletions
diff --git a/coreutils/tr.c b/coreutils/tr.c index a5d0682..5b7b8d0 100644 --- a/coreutils/tr.c +++ b/coreutils/tr.c @@ -54,7 +54,7 @@ static void convert() if (in_index == read_chars) { if ((read_chars = read(0, (char *) pinput, BUFSIZ)) <= 0) { if (write(1, (char *) poutput, out_index) != out_index) - write(2, write_error, strlen(write_error)); + error_msg("%s", write_error); exit(0); } in_index = 0; @@ -67,10 +67,8 @@ static void convert() continue; poutput[out_index++] = last = coded; if (out_index == BUFSIZ) { - if (write(1, (char *) poutput, out_index) != out_index) { - write(2, write_error, strlen(write_error)); - exit(1); - } + if (write(1, (char *) poutput, out_index) != out_index) + error_msg_and_die("%s", write_error); out_index = 0; } } @@ -105,6 +103,16 @@ static unsigned int expand(const char *arg, register unsigned char *buffer) if (*arg == '\\') { arg++; *buffer++ = process_escape_sequence(&arg); + } else if (*(arg+1) == '-') { + ac = *(arg+2); + if(ac == 0) { + *buffer++ = *arg++; + continue; + } + i = *arg; + while (i <= ac) + *buffer++ = i++; + arg += 3; /* Skip the assumed a-z */ } else if (*arg == '[') { arg++; i = *arg++; |