utf8_and_big5.c

来自「postgresql8.3.4源码,开源数据库」· C语言 代码 · 共 71 行

C
71
字号
/*------------------------------------------------------------------------- * *	  BIG5 <--> UTF8 * * Portions Copyright (c) 1996-2008, PostgreSQL Global Development Group * Portions Copyright (c) 1994, Regents of the University of California * * IDENTIFICATION *	  $PostgreSQL: pgsql/src/backend/utils/mb/conversion_procs/utf8_and_big5/utf8_and_big5.c,v 1.18 2008/01/01 19:45:54 momjian Exp $ * *------------------------------------------------------------------------- */#include "postgres.h"#include "fmgr.h"#include "mb/pg_wchar.h"#include "../../Unicode/big5_to_utf8.map"#include "../../Unicode/utf8_to_big5.map"PG_MODULE_MAGIC;PG_FUNCTION_INFO_V1(big5_to_utf8);PG_FUNCTION_INFO_V1(utf8_to_big5);extern Datum big5_to_utf8(PG_FUNCTION_ARGS);extern Datum utf8_to_big5(PG_FUNCTION_ARGS);/* ---------- * conv_proc( *		INTEGER,	-- source encoding id *		INTEGER,	-- destination encoding id *		CSTRING,	-- source string (null terminated C string) *		CSTRING,	-- destination string (null terminated C string) *		INTEGER		-- source string length * ) returns VOID; * ---------- */Datumbig5_to_utf8(PG_FUNCTION_ARGS){	unsigned char *src = (unsigned char *) PG_GETARG_CSTRING(2);	unsigned char *dest = (unsigned char *) PG_GETARG_CSTRING(3);	int			len = PG_GETARG_INT32(4);	Assert(PG_GETARG_INT32(0) == PG_BIG5);	Assert(PG_GETARG_INT32(1) == PG_UTF8);	Assert(len >= 0);	LocalToUtf(src, dest, LUmapBIG5, NULL,			   sizeof(LUmapBIG5) / sizeof(pg_local_to_utf), 0, PG_BIG5, len);	PG_RETURN_VOID();}Datumutf8_to_big5(PG_FUNCTION_ARGS){	unsigned char *src = (unsigned char *) PG_GETARG_CSTRING(2);	unsigned char *dest = (unsigned char *) PG_GETARG_CSTRING(3);	int			len = PG_GETARG_INT32(4);	Assert(PG_GETARG_INT32(0) == PG_UTF8);	Assert(PG_GETARG_INT32(1) == PG_BIG5);	Assert(len >= 0);	UtfToLocal(src, dest, ULmapBIG5, NULL,			   sizeof(ULmapBIG5) / sizeof(pg_utf_to_local), 0, PG_BIG5, len);	PG_RETURN_VOID();}

⌨️ 快捷键说明

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