2002-01-28 20:33:41 -05:00
|
|
|
#ifndef __UTF8_H
|
|
|
|
#define __UTF8_H
|
|
|
|
|
2003-10-19 15:09:51 -04:00
|
|
|
/* XXX I didn't check the encoding range of big5+. This is standard big5. */
|
|
|
|
#define is_big5_los(lo) (0x40 <= (lo) && (lo) <= 0x7E) /* standard */
|
|
|
|
#define is_big5_lox(lo) (0x80 <= (lo) && (lo) <= 0xFE) /* extended */
|
|
|
|
#define is_big5_lo(lo) ((is_big5_los(lo) || is_big5_lox(lo)))
|
|
|
|
#define is_big5_hi(hi) (0x81 <= (hi) && (hi) <= 0xFE)
|
|
|
|
#define is_big5(hi,lo) (is_big5_hi(hi) && is_big5_lo(lo))
|
|
|
|
|
2016-05-12 19:26:33 -04:00
|
|
|
#include <glib.h>
|
|
|
|
typedef guint32 unichar;
|
|
|
|
|
2002-10-14 14:33:29 -04:00
|
|
|
/* Returns width for character (0-2). */
|
2007-05-25 17:56:30 -04:00
|
|
|
int mk_wcwidth(unichar c);
|
2002-10-14 14:33:29 -04:00
|
|
|
|
2016-05-12 19:39:14 -04:00
|
|
|
/* Advance the str pointer one character further; return the number of columns
|
|
|
|
* occupied by the skipped character.
|
|
|
|
*/
|
2016-05-12 20:27:19 -04:00
|
|
|
int string_advance(char const **str, int policy);
|
2016-05-12 19:39:14 -04:00
|
|
|
|
2016-05-12 20:10:02 -04:00
|
|
|
/* TREAT_STRING_AS_BYTES means strings are to be treated using strncpy,
|
|
|
|
* strnlen, etc.
|
|
|
|
* TREAT_STRING_AS_UTF8 means strings are to be treated using g_utf8_*
|
|
|
|
* functions.
|
|
|
|
*/
|
|
|
|
#define TREAT_STRING_AS_BYTES 0
|
|
|
|
#define TREAT_STRING_AS_UTF8 1
|
|
|
|
|
|
|
|
/* Return how the str string ought to be treated: TREAT_STRING_AS_UTF8 if the
|
|
|
|
* terminal handles UTF-8 and if the string appears to be a valid UTF-8 string;
|
|
|
|
* TREAT_STRING_AS_BYTES otherwise.
|
|
|
|
*/
|
|
|
|
int string_policy(const char *str);
|
|
|
|
|
2016-05-12 20:47:26 -04:00
|
|
|
/* Return the length of the str string according to the given policy; if policy
|
|
|
|
* is -1, this function will call string_policy().
|
|
|
|
*/
|
|
|
|
int string_length(const char *str, int policy);
|
|
|
|
/* Return the screen width of the str string according to the given policy; if
|
|
|
|
* policy is -1, this function will call string_policy().
|
|
|
|
*/
|
|
|
|
int string_width(const char *str, int policy);
|
|
|
|
|
2016-05-12 21:04:08 -04:00
|
|
|
/* Return the amount of characters from str it takes to reach n columns, or -1 if
|
|
|
|
* str is NULL. Optionally return the equivalent amount of bytes.
|
|
|
|
* If policy is -1, this function will call string_policy().
|
|
|
|
*/
|
|
|
|
int string_chars_for_width(const char *str, int policy, unsigned int n, unsigned int *bytes);
|
|
|
|
|
2007-05-31 09:19:05 -04:00
|
|
|
#define unichar_isprint(c) (((c) & ~0x80) >= 32)
|
2014-01-08 09:03:25 -05:00
|
|
|
#define is_utf8_leading(c) (((c) & 0xc0) != 0x80)
|
2007-05-31 09:19:05 -04:00
|
|
|
|
2002-01-28 20:33:41 -05:00
|
|
|
#endif
|