diff options
author | Tatsuya Kinoshita <tats@vega.ocn.ne.jp> | 2011-05-04 07:18:09 +0000 |
---|---|---|
committer | Tatsuya Kinoshita <tats@vega.ocn.ne.jp> | 2011-05-04 07:18:09 +0000 |
commit | 5f8e0f8ef9a422691dd72e8a953a42a41478fcb4 (patch) | |
tree | 4b2df4796a534793648b3c4fc532fc36bd0cd525 /libwc/combining.c | |
parent | Releasing debian version 0.3-2.4 (diff) | |
download | w3m-5f8e0f8ef9a422691dd72e8a953a42a41478fcb4.tar.gz w3m-5f8e0f8ef9a422691dd72e8a953a42a41478fcb4.zip |
Releasing debian version 0.5.1-1debian/0.5.1-1
Diffstat (limited to '')
-rw-r--r-- | libwc/combining.c | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/libwc/combining.c b/libwc/combining.c new file mode 100644 index 0000000..e40c7f4 --- /dev/null +++ b/libwc/combining.c @@ -0,0 +1,43 @@ + +#include "wc.h" +#ifdef USE_UNICODE +#include "ucs.h" +#endif +#include "map/iso88596_combining.map" +#include "map/iso885911_combining.map" +#include "map/cp864_combining.map" +#include "map/cp874_combining.map" +#include "map/cp1255_combining.map" +#include "map/cp1256_combining.map" +#include "map/cp1258_combining.map" +#include "map/tcvn5712_combining.map" + +wc_bool +wc_is_combining(wc_wchar_t cc) +{ + switch (WC_CCS_SET(cc.ccs)) { + case WC_CCS_ISO_8859_6: + return iso88596_combining_map[cc.code & 0x7f]; + case WC_CCS_ISO_8859_11: + return iso885911_combining_map[cc.code & 0x7f]; + case WC_CCS_CP864: + return cp864_combining_map[cc.code & 0x7f]; + case WC_CCS_CP874: + return cp874_combining_map[cc.code & 0x7f]; + case WC_CCS_CP1255: + return cp1255_combining_map[cc.code & 0x7f]; + case WC_CCS_CP1256: + return cp1256_combining_map[cc.code & 0x7f]; + case WC_CCS_CP1258_1: + return cp1258_combining_map[cc.code & 0x7f]; + case WC_CCS_TCVN_5712_1: + return tcvn5712_combining_map[cc.code & 0x7f]; +#ifdef USE_UNICODE + case WC_CCS_UCS2: + case WC_CCS_UCS4: + case WC_CCS_UCS_TAG: + return wc_is_ucs_combining(cc.code); +#endif + } + return WC_FALSE; +} |