qse/qse/lib/cmn/chr.c

146 lines
3.1 KiB
C
Raw Normal View History

2008-08-21 02:24:36 +00:00
/*
* $Id: ctype.c 132 2008-03-17 10:27:02Z baconevi $
*
* {License}
*/
2008-12-21 21:35:07 +00:00
#include <qse/cmn/chr.h>
2008-08-21 02:24:36 +00:00
2008-12-21 21:35:07 +00:00
#if defined(QSE_CHAR_IS_MCHAR)
2008-08-21 02:24:36 +00:00
#include <ctype.h>
2008-12-21 21:35:07 +00:00
static qse_bool_t is_upper (qse_cint_t c) { return isupper(c); }
static qse_bool_t is_lower (qse_cint_t c) { return islower(c); }
static qse_bool_t is_alpha (qse_cint_t c) { return isalpha(c); }
static qse_bool_t is_digit (qse_cint_t c) { return isdigit(c); }
static qse_bool_t is_xdigit (qse_cint_t c) { return isxdigit(c); }
static qse_bool_t is_alnum (qse_cint_t c) { return isalnum(c); }
static qse_bool_t is_space (qse_cint_t c) { return isspace(c); }
static qse_bool_t is_print (qse_cint_t c) { return isprint(c); }
static qse_bool_t is_graph (qse_cint_t c) { return isgraph(c); }
static qse_bool_t is_cntrl (qse_cint_t c) { return iscntrl(c); }
static qse_bool_t is_punct (qse_cint_t c) { return ispunct(c); }
qse_bool_t qse_ccls_is (qse_cint_t c, qse_ccls_type_t type)
2008-08-21 02:24:36 +00:00
{
/* TODO: use GetStringTypeW/A for WIN32 to implement these */
2008-08-27 02:50:12 +00:00
2008-12-21 21:35:07 +00:00
static qse_bool_t (*f[]) (qse_cint_t) =
2008-08-27 02:50:12 +00:00
{
is_upper,
is_lower,
is_alpha,
is_digit,
is_xdigit,
is_alnum,
is_space,
is_print,
is_graph,
is_cntrl,
is_punct
};
2008-12-21 21:35:07 +00:00
QSE_ASSERTX (type >= QSE_CCLS_UPPER && type <= QSE_CCLS_PUNCT,
"The character type should be one of qse_ccls_type_t values");
2008-08-27 02:50:12 +00:00
return f[type] (c);
2008-08-21 02:24:36 +00:00
}
2008-12-21 21:35:07 +00:00
qse_cint_t qse_ccls_to (qse_cint_t c, qse_ccls_type_t type)
2008-08-21 02:24:36 +00:00
{
2008-12-21 21:35:07 +00:00
QSE_ASSERTX (type >= QSE_CCLS_UPPER && type <= QSE_CCLS_LOWER,
"The character type should be one of QSE_CCLS_UPPER and QSE_CCLS_LOWER");
2008-08-21 02:24:36 +00:00
2008-12-21 21:35:07 +00:00
if (type == QSE_CCLS_UPPER) return toupper(c);
if (type == QSE_CCLS_LOWER) return tolower(c);
2008-08-21 02:24:36 +00:00
return c;
}
2008-12-21 21:35:07 +00:00
#elif defined(QSE_CHAR_IS_WCHAR)
2008-08-21 02:24:36 +00:00
#include <wctype.h>
2008-12-21 21:35:07 +00:00
qse_bool_t qse_ccls_is (qse_cint_t c, qse_ccls_type_t type)
2008-08-21 02:24:36 +00:00
{
2008-08-21 03:58:42 +00:00
static const char* name[] =
{
"upper",
"lower",
"alpha",
"digit",
"xdigit",
"alnum",
"space",
"print",
"graph",
"cntrl",
"punct"
};
2008-08-21 02:24:36 +00:00
static wctype_t desc[] =
{
2008-08-21 03:58:42 +00:00
(wctype_t)0,
(wctype_t)0,
(wctype_t)0,
(wctype_t)0,
(wctype_t)0,
(wctype_t)0,
(wctype_t)0,
(wctype_t)0,
(wctype_t)0,
(wctype_t)0,
(wctype_t)0
2008-08-21 02:24:36 +00:00
};
2008-12-21 21:35:07 +00:00
QSE_ASSERTX (type >= QSE_CCLS_UPPER && type <= QSE_CCLS_PUNCT,
"The character type should be one of qse_ccls_type_t values");
2008-08-21 02:24:36 +00:00
2008-08-21 03:58:42 +00:00
if (desc[type] == (wctype_t)0) desc[type] = wctype(name[type]);
2008-08-21 02:24:36 +00:00
return iswctype (c, desc[type]);
}
2008-12-21 21:35:07 +00:00
qse_cint_t qse_ccls_to (qse_cint_t c, qse_ccls_type_t type)
2008-08-21 02:24:36 +00:00
{
2008-08-21 03:58:42 +00:00
static const char* name[] =
{
2008-09-26 22:31:40 +00:00
"toupper",
"tolower"
2008-08-21 03:58:42 +00:00
};
static wctrans_t desc[] =
2008-08-21 02:24:36 +00:00
{
2008-08-21 03:58:42 +00:00
(wctrans_t)0,
(wctrans_t)0
2008-08-21 02:24:36 +00:00
};
2008-12-21 21:35:07 +00:00
QSE_ASSERTX (type >= QSE_CCLS_UPPER && type <= QSE_CCLS_LOWER,
"The character type should be one of QSE_CCLS_UPPER and QSE_CCLS_LOWER");
2008-08-21 02:24:36 +00:00
2008-08-21 03:58:42 +00:00
if (desc[type] == (wctrans_t)0) desc[type] = wctrans(name[type]);
2008-08-21 02:24:36 +00:00
return towctrans (c, desc[type]);
}
#else
#error unsupported character type
#endif
2008-12-21 21:35:07 +00:00
static qse_bool_t ccls_is (void* data, qse_cint_t c, qse_ccls_type_t type)
2008-08-21 04:58:19 +00:00
{
2008-12-21 21:35:07 +00:00
return qse_ccls_is (c, type);
2008-08-21 04:58:19 +00:00
}
2008-12-21 21:35:07 +00:00
static qse_cint_t ccls_to (void* data, qse_cint_t c, qse_ccls_type_t type)
2008-08-21 04:58:19 +00:00
{
2008-12-21 21:35:07 +00:00
return qse_ccls_to (c, type);
2008-08-21 04:58:19 +00:00
}
2008-12-21 21:35:07 +00:00
static qse_ccls_t ccls =
2008-08-21 02:24:36 +00:00
{
ccls_is,
ccls_to,
2008-12-21 21:35:07 +00:00
QSE_NULL
2008-08-21 02:24:36 +00:00
};
2008-12-21 21:35:07 +00:00
qse_ccls_t* qse_ccls = &ccls;
2008-10-14 05:32:58 +00:00