summaryrefslogtreecommitdiff
path: root/usr.bin/openssl/s_client.c
diff options
context:
space:
mode:
authorScott Soule Cheloha <cheloha@cvs.openbsd.org>2021-10-31 21:34:17 +0000
committerScott Soule Cheloha <cheloha@cvs.openbsd.org>2021-10-31 21:34:17 +0000
commitdfed0fbc5b65fbc8656999c8812099e0ce4bd5cc (patch)
tree6f50f08bc4bc60d512081b2b4f10b29349bcb946 /usr.bin/openssl/s_client.c
parent6939737ddd1c9390c190631e43a893f7ba8bf563 (diff)
tr(1): backslash(): fix octal escape parsing
There are two bugs in backslash(): 1. 8 and 9 are not octal digits. If we see '8' or '9' we should terminate the octal escape. 2. We return octal escape values larger than UCHAR_MAX even though tr(1) is (currently) a byte-oriented program and values larger than UCHAR_MAX make no sense. So, fix them both. In particular, (a) stop parsing if we see characters outside of '0'-'7' and (b) escaped octal values larger than UCHAR_MAX are a terminal error. While here, some cleanup: - Check for empty escapes at the top of the function. This simplifies later cases. - Use the for-loop conditional to terminate octal escape parsing after three characters. - Use an ANSI-style function definition. We can fix the switch-statement indentation later, in a larger KNF patch. ok millert@
Diffstat (limited to 'usr.bin/openssl/s_client.c')
0 files changed, 0 insertions, 0 deletions