1 /*-------------------------------------------------------------------------
2  *
3  *	  SJIS <--> UTF8
4  *
5  * Portions Copyright (c) 1996-2019, PostgreSQL Global Development Group
6  * Portions Copyright (c) 1994, Regents of the University of California
7  *
8  * IDENTIFICATION
9  *	  src/backend/utils/mb/conversion_procs/utf8_and_sjis/utf8_and_sjis.c
10  *
11  *-------------------------------------------------------------------------
12  */
13 
14 #include "postgres.h"
15 #include "fmgr.h"
16 #include "mb/pg_wchar.h"
17 #include "../../Unicode/sjis_to_utf8.map"
18 #include "../../Unicode/utf8_to_sjis.map"
19 
20 PG_MODULE_MAGIC;
21 
22 PG_FUNCTION_INFO_V1(sjis_to_utf8);
23 PG_FUNCTION_INFO_V1(utf8_to_sjis);
24 
25 /* ----------
26  * conv_proc(
27  *		INTEGER,	-- source encoding id
28  *		INTEGER,	-- destination encoding id
29  *		CSTRING,	-- source string (null terminated C string)
30  *		CSTRING,	-- destination string (null terminated C string)
31  *		INTEGER		-- source string length
32  * ) returns VOID;
33  * ----------
34  */
35 Datum
sjis_to_utf8(PG_FUNCTION_ARGS)36 sjis_to_utf8(PG_FUNCTION_ARGS)
37 {
38 	unsigned char *src = (unsigned char *) PG_GETARG_CSTRING(2);
39 	unsigned char *dest = (unsigned char *) PG_GETARG_CSTRING(3);
40 	int			len = PG_GETARG_INT32(4);
41 
42 	CHECK_ENCODING_CONVERSION_ARGS(PG_SJIS, PG_UTF8);
43 
44 	LocalToUtf(src, len, dest,
45 			   &sjis_to_unicode_tree,
46 			   NULL, 0,
47 			   NULL,
48 			   PG_SJIS);
49 
50 	PG_RETURN_VOID();
51 }
52 
53 Datum
utf8_to_sjis(PG_FUNCTION_ARGS)54 utf8_to_sjis(PG_FUNCTION_ARGS)
55 {
56 	unsigned char *src = (unsigned char *) PG_GETARG_CSTRING(2);
57 	unsigned char *dest = (unsigned char *) PG_GETARG_CSTRING(3);
58 	int			len = PG_GETARG_INT32(4);
59 
60 	CHECK_ENCODING_CONVERSION_ARGS(PG_UTF8, PG_SJIS);
61 
62 	UtfToLocal(src, len, dest,
63 			   &sjis_from_unicode_tree,
64 			   NULL, 0,
65 			   NULL,
66 			   PG_SJIS);
67 
68 	PG_RETURN_VOID();
69 }
70