mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-08-01 15:03:39 +02:00
Implement and document g_ascii_isxxx.
2001-08-25 Alexander Larsson <alla@lysator.liu.se> * glib/gstrfuncs.[ch]: * docs/reference/glib/glib-overrides.txt: * docs/reference/glib/glib-sections.txt: * docs/reference/glib/tmpl/string_utils.sgml: Implement and document g_ascii_isxxx. * tests/strfunc-test.c: Add tests for g_ascii_isxxx * glib/guniprop.c (g_unichar_ispunct): include symbols, not just punctuation. (g_unichar_isspace): Vertical tab is not considered whitespace. * tests/shell-test.c: Output errors on stderr
This commit is contained in:
committed by
Alexander Larsson
parent
3ff815fd7c
commit
a7a76cfac7
@@ -95,25 +95,23 @@ print_test (const gchar *cmdline, gint argc, gchar **argv,
|
||||
{
|
||||
gint i;
|
||||
|
||||
printf ("\nCommand line was: '%s'\n", cmdline);
|
||||
fprintf (stderr, "Command line was: '%s'\n", cmdline);
|
||||
|
||||
printf ("Expected result (%d args):\n", result->argc);
|
||||
fprintf (stderr, "Expected result (%d args):\n", result->argc);
|
||||
|
||||
i = 0;
|
||||
while (result->argv[i])
|
||||
{
|
||||
printf (" %3d '%s'\n", i, result->argv[i]);
|
||||
|
||||
fprintf (stderr, " %3d '%s'\n", i, result->argv[i]);
|
||||
++i;
|
||||
}
|
||||
|
||||
printf ("Actual result (%d args):\n", argc);
|
||||
fprintf (stderr, "Actual result (%d args):\n", argc);
|
||||
|
||||
i = 0;
|
||||
while (argv[i])
|
||||
{
|
||||
printf (" %3d '%s'\n", i, argv[i]);
|
||||
|
||||
fprintf (stderr, " %3d '%s'\n", i, argv[i]);
|
||||
++i;
|
||||
}
|
||||
}
|
||||
@@ -170,10 +168,7 @@ run_tests (void)
|
||||
i = 0;
|
||||
while (test_command_lines[i])
|
||||
{
|
||||
printf ("g_shell_parse_argv() test %d - ", i);
|
||||
do_argv_test (test_command_lines[i], &correct_results[i]);
|
||||
printf ("ok (%s)\n", test_command_lines[i]);
|
||||
|
||||
++i;
|
||||
}
|
||||
}
|
||||
|
@@ -30,6 +30,7 @@
|
||||
#include <string.h>
|
||||
#include "glib.h"
|
||||
#include <stdarg.h>
|
||||
#include <ctype.h>
|
||||
|
||||
static gboolean any_failed = FALSE;
|
||||
static gboolean failed = FALSE;
|
||||
@@ -37,15 +38,17 @@ static gboolean failed = FALSE;
|
||||
#define TEST(m,cond) G_STMT_START { failed = !(cond); \
|
||||
if (failed) \
|
||||
{ if (!m) \
|
||||
g_print ("\n(%s:%d) failed for: %s\n", __FILE__, __LINE__, ( # cond )); \
|
||||
g_print ("(%s:%d) failed for: %s\n", __FILE__, __LINE__, ( # cond )); \
|
||||
else \
|
||||
g_print ("\n(%s:%d) failed for: %s: (%s)\n", __FILE__, __LINE__, ( # cond ), (gchar*)m); \
|
||||
any_failed = TRUE; \
|
||||
g_print ("(%s:%d) failed for: %s: (%s)\n", __FILE__, __LINE__, ( # cond ), (gchar*)m); \
|
||||
fflush (stdout); \
|
||||
any_failed = TRUE; \
|
||||
} \
|
||||
else \
|
||||
g_print ("."); fflush (stdout); \
|
||||
} G_STMT_END
|
||||
|
||||
#define TEST_FAILED(message) \
|
||||
G_STMT_START { g_print ("Error: "); g_print message; g_print ("\n"); any_failed = TRUE; } G_STMT_END
|
||||
|
||||
#define GLIB_TEST_STRING "el dorado "
|
||||
|
||||
static gboolean
|
||||
@@ -77,6 +80,156 @@ strv_check (gchar **strv, ...)
|
||||
return ok;
|
||||
}
|
||||
|
||||
static gboolean
|
||||
test_isalnum (gchar c)
|
||||
{
|
||||
return g_ascii_isalnum (c);
|
||||
}
|
||||
|
||||
static gboolean
|
||||
test_isalpha (gchar c)
|
||||
{
|
||||
return g_ascii_isalpha (c);
|
||||
}
|
||||
|
||||
static gboolean
|
||||
test_iscntrl (gchar c)
|
||||
{
|
||||
return g_ascii_iscntrl (c);
|
||||
}
|
||||
|
||||
static gboolean
|
||||
test_isdigit (gchar c)
|
||||
{
|
||||
return g_ascii_isdigit (c);
|
||||
}
|
||||
|
||||
static gboolean
|
||||
test_isgraph (gchar c)
|
||||
{
|
||||
return g_ascii_isgraph (c);
|
||||
}
|
||||
|
||||
static gboolean
|
||||
test_islower (gchar c)
|
||||
{
|
||||
return g_ascii_islower (c);
|
||||
}
|
||||
|
||||
static gboolean
|
||||
test_isprint (gchar c)
|
||||
{
|
||||
return g_ascii_isprint (c);
|
||||
}
|
||||
|
||||
static gboolean
|
||||
test_ispunct (gchar c)
|
||||
{
|
||||
return g_ascii_ispunct (c);
|
||||
}
|
||||
|
||||
static gboolean
|
||||
test_isspace (gchar c)
|
||||
{
|
||||
return g_ascii_isspace (c);
|
||||
}
|
||||
|
||||
static gboolean
|
||||
test_isupper (gchar c)
|
||||
{
|
||||
return g_ascii_isupper (c);
|
||||
}
|
||||
|
||||
static gboolean
|
||||
test_isxdigit (gchar c)
|
||||
{
|
||||
return g_ascii_isxdigit (c);
|
||||
}
|
||||
|
||||
|
||||
|
||||
static void
|
||||
test_is_function (const char *name,
|
||||
gboolean (* ascii_function) (gchar),
|
||||
int (* c_library_function) (int),
|
||||
gboolean (* unicode_function) (gunichar))
|
||||
{
|
||||
int c;
|
||||
|
||||
for (c = 0; c <= 0x7F; c++)
|
||||
{
|
||||
gboolean ascii_result = ascii_function ((gchar)c);
|
||||
gboolean c_library_result = c_library_function (c) != 0;
|
||||
gboolean unicode_result = unicode_function ((gunichar) c);
|
||||
if (ascii_result != c_library_result && c != '\v')
|
||||
TEST_FAILED (("g_ascii_%s returned %d and %s returned %d for 0x%X",
|
||||
name, ascii_result, name, c_library_result, c));
|
||||
if (ascii_result != unicode_result)
|
||||
TEST_FAILED (("g_ascii_%s returned %d and g_unichar_%s returned %d for 0x%X",
|
||||
name, ascii_result, name, unicode_result, c));
|
||||
}
|
||||
for (c = 0x80; c <= 0xFF; c++)
|
||||
{
|
||||
gboolean ascii_result = ascii_function ((gchar)c);
|
||||
if (ascii_result)
|
||||
TEST_FAILED (("g_ascii_%s returned TRUE for 0x%X",
|
||||
name, c));
|
||||
}
|
||||
}
|
||||
|
||||
static void
|
||||
test_to_function (const char *name,
|
||||
gchar (* ascii_function) (gchar),
|
||||
int (* c_library_function) (int),
|
||||
gunichar (* unicode_function) (gunichar))
|
||||
{
|
||||
int c;
|
||||
|
||||
for (c = 0; c <= 0x7F; c++)
|
||||
{
|
||||
int ascii_result = (guchar) ascii_function ((gchar) c);
|
||||
int c_library_result = c_library_function (c);
|
||||
int unicode_result = unicode_function ((gunichar) c);
|
||||
if (ascii_result != c_library_result)
|
||||
TEST_FAILED (("g_ascii_%s returned 0x%X and %s returned 0x%X for 0x%X",
|
||||
name, ascii_result, name, c_library_result, c));
|
||||
if (ascii_result != unicode_result)
|
||||
TEST_FAILED (("g_ascii_%s returned 0x%X and g_unichar_%s returned 0x%X for 0x%X",
|
||||
name, ascii_result, name, unicode_result, c));
|
||||
}
|
||||
for (c = 0x80; c <= 0xFF; c++)
|
||||
{
|
||||
int ascii_result = (guchar) ascii_function ((gchar) c);
|
||||
if (ascii_result != c)
|
||||
TEST_FAILED (("g_ascii_%s returned 0x%X for 0x%X",
|
||||
name, ascii_result, c));
|
||||
}
|
||||
}
|
||||
|
||||
static void
|
||||
test_digit_function (const char *name,
|
||||
int (* ascii_function) (gchar),
|
||||
int (* unicode_function) (gunichar))
|
||||
{
|
||||
int c;
|
||||
|
||||
for (c = 0; c <= 0x7F; c++)
|
||||
{
|
||||
int ascii_result = ascii_function ((gchar) c);
|
||||
int unicode_result = unicode_function ((gunichar) c);
|
||||
if (ascii_result != unicode_result)
|
||||
TEST_FAILED (("g_ascii_%s_value returned %d and g_unichar_%s_value returned %d for 0x%X",
|
||||
name, ascii_result, name, unicode_result, c));
|
||||
}
|
||||
for (c = 0x80; c <= 0xFF; c++)
|
||||
{
|
||||
int ascii_result = ascii_function ((gchar) c);
|
||||
if (ascii_result != -1)
|
||||
TEST_FAILED (("g_ascii_%s_value returned %d for 0x%X",
|
||||
name, ascii_result, c));
|
||||
}
|
||||
}
|
||||
|
||||
int
|
||||
main (int argc,
|
||||
char *argv[])
|
||||
@@ -171,7 +324,35 @@ main (int argc,
|
||||
TEST (NULL, strv_check (g_strsplit (",,x,,y,,z,,", ",", 2), "", ",x,,y,,z,,", NULL));
|
||||
TEST (NULL, strv_check (g_strsplit (",,x,,y,,z,,", ",,", 2), "", "x,,y,,z,,", NULL));
|
||||
|
||||
g_print ("\n");
|
||||
#define TEST_IS(name) test_is_function (#name, test_##name, name, g_unichar_##name)
|
||||
|
||||
TEST_IS (isalnum);
|
||||
TEST_IS (isalpha);
|
||||
TEST_IS (iscntrl);
|
||||
TEST_IS (isdigit);
|
||||
TEST_IS (isgraph);
|
||||
TEST_IS (islower);
|
||||
TEST_IS (isprint);
|
||||
TEST_IS (ispunct);
|
||||
TEST_IS (isspace);
|
||||
TEST_IS (isupper);
|
||||
TEST_IS (isxdigit);
|
||||
|
||||
#undef TEST_IS
|
||||
|
||||
#define TEST_TO(name) test_to_function (#name, g_ascii_##name, name, g_unichar_##name)
|
||||
|
||||
TEST_TO (tolower);
|
||||
TEST_TO (toupper);
|
||||
|
||||
#undef TEST_TO
|
||||
|
||||
#define TEST_DIGIT(name) test_digit_function (#name, g_ascii_##name##_value, g_unichar_##name##_value)
|
||||
|
||||
TEST_DIGIT (digit);
|
||||
TEST_DIGIT (xdigit);
|
||||
|
||||
#undef TEST_DIGIT
|
||||
|
||||
return any_failed;
|
||||
}
|
||||
|
Reference in New Issue
Block a user