⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 wchar.c

📁 关系型数据库 Postgresql 6.5.2
💻 C
字号:
/* * conversion functions between pg_wchar and multi-byte streams. * Tatsuo Ishii * $Id: wchar.c,v 1.9 1999/07/11 22:47:20 ishii Exp $ * * WIN1250 client encoding updated by Pavel Behal * */#include "mb/pg_wchar.h"/* * conversion to pg_wchar is done by "table driven." * to add an encoding support, define mb2wchar_with_len(), mblen() * for the particular encoding. Note that if the encoding is only * supported in the client, you don't need to define * mb2wchar_with_len() function (SJIS is the case). *//* * SQL/ASCII */static void pg_ascii2wchar_with_len			(const unsigned char *from, pg_wchar * to, int len){	while (*from && len > 0)	{		*to++ = *from++;		len--;	}	*to = 0;}static intpg_ascii_mblen(const unsigned char *s){	return (1);}/* * EUC */static void pg_euc2wchar_with_len			(const unsigned char *from, pg_wchar * to, int len){	while (*from && len > 0)	{		if (*from == SS2)		{			from++;			len--;			*to = 0xff & *from++;			len--;		}		else if (*from == SS3)		{			from++;			*to = *from++ << 8;			*to |= 0x3f & *from++;			len -= 3;		}		else if (*from & 0x80)		{			*to = *from++ << 8;			*to |= *from++;			len -= 2;		}		else		{			*to = *from++;			len--;		}		to++;	}	*to = 0;}static intpg_euc_mblen(const unsigned char *s){	int			len;	if (*s == SS2)		len = 2;	else if (*s == SS3)		len = 3;	else if (*s & 0x80)		len = 2;	else		len = 1;	return (len);}/* * EUC_JP */static void pg_eucjp2wchar_with_len			(const unsigned char *from, pg_wchar * to, int len){	pg_euc2wchar_with_len(from, to, len);}static intpg_eucjp_mblen(const unsigned char *s){	return (pg_euc_mblen(s));}/* * EUC_KR */static void pg_euckr2wchar_with_len			(const unsigned char *from, pg_wchar * to, int len){	pg_euc2wchar_with_len(from, to, len);}static intpg_euckr_mblen(const unsigned char *s){	return (pg_euc_mblen(s));}/* * EUC_CN */static void pg_euccn2wchar_with_len			(const unsigned char *from, pg_wchar * to, int len){	while (*from && len > 0)	{		if (*from == SS2)		{			from++;			len--;			*to = 0x3f00 & (*from++ << 8);			*to = *from++;			len -= 2;		}		else if (*from == SS3)		{			from++;			*to = *from++ << 8;			*to |= 0x3f & *from++;			len -= 3;		}		else if (*from & 0x80)		{			*to = *from++ << 8;			*to |= *from++;			len -= 2;		}		else		{			*to = *from++;			len--;		}		to++;	}	*to = 0;}static intpg_euccn_mblen(const unsigned char *s){	int			len;	if (*s == SS2)		len = 3;	else if (*s == SS3)		len = 3;	else if (*s & 0x80)		len = 2;	else		len = 1;	return (len);}/* * EUC_TW */static void pg_euctw2wchar_with_len			(const unsigned char *from, pg_wchar * to, int len){	while (*from && len > 0)	{		if (*from == SS2)		{			from++;			len--;			*to = *from++ << 16;			*to |= *from++ << 8;			*to |= *from++;			len -= 3;		}		else if (*from == SS3)		{			from++;			*to = *from++ << 8;			*to |= 0x3f & *from++;			len -= 3;		}		else if (*from & 0x80)		{			*to = *from++ << 8;			*to |= *from++;			len -= 2;		}		else		{			*to = *from++;			len--;		}		to++;	}	*to = 0;}static intpg_euctw_mblen(const unsigned char *s){	int			len;	if (*s == SS2)		len = 4;	else if (*s == SS3)		len = 3;	else if (*s & 0x80)		len = 2;	else		len = 1;	return (len);}/* * convert UTF-8 to pg_wchar (UCS-2) * caller should allocate enough space for "to" * len: length of from. * "from" not necessarily null terminated. */static voidpg_utf2wchar_with_len(const unsigned char *from, pg_wchar * to, int len){	unsigned char c1,				c2,				c3;	while (*from && len > 0)	{		if ((*from & 0x80) == 0)		{			*to = *from++;			len--;		}		else if ((*from & 0xe0) == 0xc0)		{			c1 = *from++ & 0x1f;			c2 = *from++ & 0x3f;			len -= 2;			*to = c1 << 6;			*to |= c2;		}		else if ((*from & 0xe0) == 0xe0)		{			c1 = *from++ & 0x0f;			c2 = *from++ & 0x3f;			c3 = *from++ & 0x3f;			len -= 3;			*to = c1 << 12;			*to |= c2 << 6;			*to |= c3;		}		else		{			*to = *from++;			len--;		}		to++;	}	*to = 0;}static intpg_utf_mblen(const unsigned char *s){	int			len = 1;	if ((*s & 0x80) == 0)		len = 1;	else if ((*s & 0xe0) == 0xc0)		len = 2;	else if ((*s & 0xe0) == 0xe0)		len = 3;	return (len);}/* * convert mule internal code to pg_wchar * caller should allocate enough space for "to" * len: length of from. * "from" not necessarily null terminated. */static voidpg_mule2wchar_with_len(const unsigned char *from, pg_wchar * to, int len){	while (*from && len > 0)	{		if (IS_LC1(*from))		{			*to = *from++ << 16;			*to |= *from++;			len -= 2;		}		else if (IS_LCPRV1(*from))		{			from++;			*to = *from++ << 16;			*to |= *from++;			len -= 3;		}		else if (IS_LC2(*from))		{			*to = *from++ << 16;			*to |= *from++ << 8;			*to |= *from++;			len -= 3;		}		else if (IS_LCPRV2(*from))		{			from++;			*to = *from++ << 16;			*to |= *from++ << 8;			*to |= *from++;			len -= 4;		}		else		{						/* assume ASCII */			*to = (unsigned char) *from++;			len--;		}		to++;	}	*to = 0;}intpg_mule_mblen(const unsigned char *s){	int			len;	if (IS_LC1(*s))		len = 2;	else if (IS_LCPRV1(*s))		len = 3;	else if (IS_LC2(*s))		len = 3;	else if (IS_LCPRV2(*s))		len = 4;	else	{							/* assume ASCII */		len = 1;	}	return (len);}/* * ISO8859-1 */static voidpg_latin12wchar_with_len(const unsigned char *from, pg_wchar * to, int len){	while (*from && len-- > 0)		*to++ = *from++;	*to = 0;}static intpg_latin1_mblen(const unsigned char *s){	return (1);}/* * SJIS */static intpg_sjis_mblen(const unsigned char *s){	int			len;	if (*s >= 0xa1 && *s <= 0xdf)	{							/* 1 byte kana? */		len = 1;	}	else if (*s > 0x7f)	{							/* kanji? */		len = 2;	}	else	{							/* should be ASCII */		len = 1;	}	return (len);}/* * Big5 */static intpg_big5_mblen(const unsigned char *s){	int			len;	if (*s > 0x7f)	{							/* kanji? */		len = 2;	}	else	{							/* should be ASCII */		len = 1;	}	return (len);}pg_wchar_tbl pg_wchar_table[] = {	{pg_ascii2wchar_with_len, pg_ascii_mblen},	/* 0 */	{pg_eucjp2wchar_with_len, pg_eucjp_mblen},	/* 1 */	{pg_euccn2wchar_with_len, pg_euccn_mblen},	/* 2 */	{pg_euckr2wchar_with_len, pg_euckr_mblen},	/* 3 */	{pg_euctw2wchar_with_len, pg_euctw_mblen},	/* 4 */	{pg_utf2wchar_with_len, pg_utf_mblen},		/* 5 */	{pg_mule2wchar_with_len, pg_mule_mblen},	/* 6 */	{pg_latin12wchar_with_len, pg_latin1_mblen},		/* 7 */	{pg_latin12wchar_with_len, pg_latin1_mblen},		/* 8 */	{pg_latin12wchar_with_len, pg_latin1_mblen},		/* 9 */	{pg_latin12wchar_with_len, pg_latin1_mblen},		/* 10 */	{pg_latin12wchar_with_len, pg_latin1_mblen},		/* 11 */	{pg_latin12wchar_with_len, pg_latin1_mblen},		/* 12 */	{pg_latin12wchar_with_len, pg_latin1_mblen},		/* 13 */	{pg_latin12wchar_with_len, pg_latin1_mblen},		/* 14 */	{pg_latin12wchar_with_len, pg_latin1_mblen},		/* 15 */	{pg_latin12wchar_with_len, pg_latin1_mblen},		/* 16 */	{pg_latin12wchar_with_len, pg_latin1_mblen},		/* 17 */	{pg_latin12wchar_with_len, pg_latin1_mblen},		/* 18 */	{pg_latin12wchar_with_len, pg_latin1_mblen},		/* 19 */	{pg_latin12wchar_with_len, pg_latin1_mblen},		/* 20 */	{pg_latin12wchar_with_len, pg_latin1_mblen},		/* 21 */	{pg_latin12wchar_with_len, pg_latin1_mblen},		/* 22 */	{pg_latin12wchar_with_len, pg_latin1_mblen},		/* 23 */	{pg_latin12wchar_with_len, pg_latin1_mblen},		/* 24 */	{pg_latin12wchar_with_len, pg_latin1_mblen},		/* 25 */	{pg_latin12wchar_with_len, pg_latin1_mblen},		/* 26 */	{pg_latin12wchar_with_len, pg_latin1_mblen},		/* 27 */	{pg_latin12wchar_with_len, pg_latin1_mblen},		/* 28 */	{pg_latin12wchar_with_len, pg_latin1_mblen},		/* 29 */	{pg_latin12wchar_with_len, pg_latin1_mblen},		/* 30 */	{pg_latin12wchar_with_len, pg_latin1_mblen},		/* 31 */	{0, pg_sjis_mblen},			/* 32 */	{0, pg_big5_mblen},			/* 33 */	{pg_latin12wchar_with_len, pg_latin1_mblen}		/* 34 */};/* returns the byte length of a word for mule internal code */intpg_mic_mblen(const unsigned char *mbstr){	return (pg_mule_mblen(mbstr));}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -