mirror of
https://github.com/openssl/openssl.git
synced 2025-04-18 20:40:45 +08:00
Check for EOF in ASCII conversions.
The C standard defines EOF as: ... an integer constant expression, with type int and a negative value... This means a conforming implemenetation could define this as a one of the printable characters. This won't be a problem for ASCII. A specific test case has been added for EOF. Reviewed-by: Richard Levitte <levitte@openssl.org> (Merged from https://github.com/openssl/openssl/pull/4240)
This commit is contained in:
parent
f7d1d2a479
commit
678c462e21
@ -8,6 +8,7 @@
|
||||
*/
|
||||
|
||||
#include <string.h>
|
||||
#include <stdio.h>
|
||||
#include "internal/ctype.h"
|
||||
#include "openssl/ebcdic.h"
|
||||
|
||||
@ -225,7 +226,7 @@ static const unsigned short ctype_char_map[128] = {
|
||||
#ifdef CHARSET_EBCDIC
|
||||
int ossl_toascii(int c)
|
||||
{
|
||||
if (c < -128 || c > 256)
|
||||
if (c < -128 || c > 256 || c == EOF)
|
||||
return c;
|
||||
/*
|
||||
* Adjust negatively signed characters.
|
||||
@ -240,7 +241,7 @@ int ossl_toascii(int c)
|
||||
|
||||
int ossl_fromascii(int c)
|
||||
{
|
||||
if (c < -128 || c > 256)
|
||||
if (c < -128 || c > 256 || c == EOF)
|
||||
return c;
|
||||
if (c < 0)
|
||||
c += 256;
|
||||
|
@ -68,10 +68,16 @@ static int test_ctype_tolower(int n)
|
||||
&& TEST_int_eq(ossl_tolower(case_change[n].l), case_change[n].l);
|
||||
}
|
||||
|
||||
static int test_ctype_eof(void)
|
||||
{
|
||||
return test_ctype_chars(EOF);
|
||||
}
|
||||
|
||||
int setup_tests(void)
|
||||
{
|
||||
ADD_ALL_TESTS(test_ctype_chars, 128);
|
||||
ADD_ALL_TESTS(test_ctype_toupper, OSSL_NELEM(case_change));
|
||||
ADD_ALL_TESTS(test_ctype_tolower, OSSL_NELEM(case_change));
|
||||
ADD_TEST(test_ctype_eof);
|
||||
return 1;
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user