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
|
|
|
|