Merge branch 'rs/t-ctype-simplify'

Code simplification to one unit-test program.

* rs/t-ctype-simplify:
  t-ctype: avoid duplicating class names
  t-ctype: align output of i
  t-ctype: simplify EOF check
  t-ctype: allow NUL anywhere in the specification string
This commit is contained in:
Junio C Hamano
2024-03-11 14:12:30 -07:00

View File

@ -1,30 +1,19 @@
#include "test-lib.h" #include "test-lib.h"
static int is_in(const char *s, int ch) #define TEST_CHAR_CLASS(class, string) do { \
{ size_t len = ARRAY_SIZE(string) - 1 + \
/* BUILD_ASSERT_OR_ZERO(ARRAY_SIZE(string) > 0) + \
* We can't find NUL using strchr. Accept it as the first BUILD_ASSERT_OR_ZERO(sizeof(string[0]) == sizeof(char)); \
* character in the spec -- there are no empty classes. int skip = test__run_begin(); \
*/ if (!skip) { \
if (ch == '\0') for (int i = 0; i < 256; i++) { \
return ch == *s; if (!check_int(class(i), ==, !!memchr(string, i, len)))\
if (*s == '\0') test_msg(" i: 0x%02x", i); \
s++; } \
return !!strchr(s, ch); check(!class(EOF)); \
}
/* Macro to test a character type */
#define TEST_CTYPE_FUNC(func, string) \
static void test_ctype_##func(void) { \
for (int i = 0; i < 256; i++) { \
if (!check_int(func(i), ==, is_in(string, i))) \
test_msg(" i: 0x%02x", i); \
} \ } \
if (!check(!func(EOF))) \ test__run_end(!skip, TEST_LOCATION(), #class " works"); \
test_msg(" i: 0x%02x (EOF)", EOF); \ } while (0)
}
#define TEST_CHAR_CLASS(class) TEST(test_ctype_##class(), #class " works")
#define DIGIT "0123456789" #define DIGIT "0123456789"
#define LOWER "abcdefghijklmnopqrstuvwxyz" #define LOWER "abcdefghijklmnopqrstuvwxyz"
@ -44,37 +33,21 @@ static void test_ctype_##func(void) { \
"\x10\x11\x12\x13\x14\x15\x16\x17\x18\x19\x1a\x1b\x1c\x1d\x1e\x1f" \ "\x10\x11\x12\x13\x14\x15\x16\x17\x18\x19\x1a\x1b\x1c\x1d\x1e\x1f" \
"\x7f" "\x7f"
TEST_CTYPE_FUNC(isdigit, DIGIT)
TEST_CTYPE_FUNC(isspace, " \n\r\t")
TEST_CTYPE_FUNC(isalpha, LOWER UPPER)
TEST_CTYPE_FUNC(isalnum, LOWER UPPER DIGIT)
TEST_CTYPE_FUNC(is_glob_special, "*?[\\")
TEST_CTYPE_FUNC(is_regex_special, "$()*+.?[\\^{|")
TEST_CTYPE_FUNC(is_pathspec_magic, "!\"#%&',-/:;<=>@_`~")
TEST_CTYPE_FUNC(isascii, ASCII)
TEST_CTYPE_FUNC(islower, LOWER)
TEST_CTYPE_FUNC(isupper, UPPER)
TEST_CTYPE_FUNC(iscntrl, CNTRL)
TEST_CTYPE_FUNC(ispunct, PUNCT)
TEST_CTYPE_FUNC(isxdigit, DIGIT "abcdefABCDEF")
TEST_CTYPE_FUNC(isprint, LOWER UPPER DIGIT PUNCT " ")
int cmd_main(int argc, const char **argv) { int cmd_main(int argc, const char **argv) {
/* Run all character type tests */ TEST_CHAR_CLASS(isspace, " \n\r\t");
TEST_CHAR_CLASS(isspace); TEST_CHAR_CLASS(isdigit, DIGIT);
TEST_CHAR_CLASS(isdigit); TEST_CHAR_CLASS(isalpha, LOWER UPPER);
TEST_CHAR_CLASS(isalpha); TEST_CHAR_CLASS(isalnum, LOWER UPPER DIGIT);
TEST_CHAR_CLASS(isalnum); TEST_CHAR_CLASS(is_glob_special, "*?[\\");
TEST_CHAR_CLASS(is_glob_special); TEST_CHAR_CLASS(is_regex_special, "$()*+.?[\\^{|");
TEST_CHAR_CLASS(is_regex_special); TEST_CHAR_CLASS(is_pathspec_magic, "!\"#%&',-/:;<=>@_`~");
TEST_CHAR_CLASS(is_pathspec_magic); TEST_CHAR_CLASS(isascii, ASCII);
TEST_CHAR_CLASS(isascii); TEST_CHAR_CLASS(islower, LOWER);
TEST_CHAR_CLASS(islower); TEST_CHAR_CLASS(isupper, UPPER);
TEST_CHAR_CLASS(isupper); TEST_CHAR_CLASS(iscntrl, CNTRL);
TEST_CHAR_CLASS(iscntrl); TEST_CHAR_CLASS(ispunct, PUNCT);
TEST_CHAR_CLASS(ispunct); TEST_CHAR_CLASS(isxdigit, DIGIT "abcdefABCDEF");
TEST_CHAR_CLASS(isxdigit); TEST_CHAR_CLASS(isprint, LOWER UPPER DIGIT PUNCT " ");
TEST_CHAR_CLASS(isprint);
return test_done(); return test_done();
} }