Commit bfdd6a71 authored by Tatsuo Ishii's avatar Tatsuo Ishii

Change pg_mblen and pg_encoding_mblen return types from void

to int so that they return the number of whcars.
parent 86ff9d29
......@@ -4,7 +4,7 @@
# Makefile for utils/mb
#
# IDENTIFICATION
# $Header: /cvsroot/pgsql/src/backend/utils/mb/Makefile,v 1.8 2000/05/29 05:45:34 tgl Exp $
# $Header: /cvsroot/pgsql/src/backend/utils/mb/Makefile,v 1.9 2000/08/27 10:40:48 ishii Exp $
#
#-------------------------------------------------------------------------
......@@ -19,9 +19,22 @@ all: SUBSYS.o
SUBSYS.o: $(OBJS)
$(LD) $(LDREL) $(LDOUT) SUBSYS.o $(OBJS)
sjistest: $(OBJS)
$(CC) -c $(CFLAGS) -DDEBUGMAIN conv.c
$(CC) -o sjistest conv.o \
palloc.o: palloc.c
$(CC) -c $(CFLAGS) palloc.c
sjistest.o: sjistest.c
$(CC) -c $(CFLAGS) sjistest.c
liketest.o: liketest.c
$(CC) -c $(CFLAGS) liketest.c
sjistest: $(OBJS) sjistest.o palloc.o
$(CC) -o sjistest sjistest.o palloc.o \
common.o mbutils.o wchar.o wstrcmp.o wstrncmp.o variable.o \
big5.o $(LDFLAGS)
liketest: $(OBJS) liketest.o palloc.o
$(CC) -o liketest liketest.o palloc.o conv.o \
common.o mbutils.o wchar.o wstrcmp.o wstrncmp.o variable.o \
big5.o $(LDFLAGS)
......
......@@ -6,7 +6,7 @@
* WIN1250 client encoding support contributed by Pavel Behal
* SJIS UDC (NEC selection IBM kanji) support contributed by Eiji Tokuya
*
* $Id: conv.c,v 1.16 2000/06/28 03:32:45 tgl Exp $
* $Id: conv.c,v 1.17 2000/08/27 10:40:48 ishii Exp $
*
*
*/
......@@ -1519,70 +1519,3 @@ pg_encoding_conv_tbl pg_conv_tbl[] = {
{WIN1250, "WIN1250", 1, win12502mic, mic2win1250}, /* WIN 1250 */
{-1, "", 0, 0, 0} /* end mark */
};
#ifdef DEBUGMAIN
#include "postgres.h"
#include "utils/memutils.h"
/*
* testing for sjis2mic() and mic2sjis()
*/
int
main()
{
unsigned char eucbuf[1024];
unsigned char sjisbuf[1024];
unsigned char sjis[] = {0x81, 0x40, 0xa1, 0xf0, 0x40, 0xf0, 0x9e, 0xf5, 0x40, 0xfa, 0x40, 0xfa, 0x54, 0xfa, 0x7b, 0x00};
int i;
sjis2mic(sjis, eucbuf, 1024);
for (i = 0; i < 1024; i++)
{
if (eucbuf[i])
printf("%02x ", eucbuf[i]);
else
{
printf("\n");
break;
}
}
mic2sjis(eucbuf, sjisbuf, 1024);
for (i = 0; i < 1024; i++)
{
if (sjisbuf[i])
printf("%02x ", sjisbuf[i]);
else
{
printf("\n");
break;
}
}
return (0);
}
void
elog(int lev, const char *fmt,...)
{
}
MemoryContext CurrentMemoryContext;
void *
MemoryContextAlloc(MemoryContext context, Size size)
{
}
void
pfree(void *pointer)
{
}
void *
repalloc(void *pointer, Size size)
{
}
#endif
......@@ -3,7 +3,7 @@
* client encoding and server internal encoding.
* (currently mule internal code (mic) is used)
* Tatsuo Ishii
* $Id: mbutils.c,v 1.10 2000/06/13 07:35:12 tgl Exp $ */
* $Id: mbutils.c,v 1.11 2000/08/27 10:40:48 ishii Exp $ */
#include "postgres.h"
......@@ -173,17 +173,17 @@ pg_server_to_client(unsigned char *s, int len)
}
/* convert a multi-byte string to a wchar */
void
int
pg_mb2wchar(const unsigned char *from, pg_wchar * to)
{
(*pg_wchar_table[GetDatabaseEncoding()].mb2wchar_with_len) (from, to, strlen(from));
return (*pg_wchar_table[GetDatabaseEncoding()].mb2wchar_with_len) (from, to, strlen(from));
}
/* convert a multi-byte string to a wchar with a limited length */
void
int
pg_mb2wchar_with_len(const unsigned char *from, pg_wchar * to, int len)
{
(*pg_wchar_table[GetDatabaseEncoding()].mb2wchar_with_len) (from, to, len);
return (*pg_wchar_table[GetDatabaseEncoding()].mb2wchar_with_len) (from, to, len);
}
/* returns the byte length of a multi-byte word */
......
/*
* conversion functions between pg_wchar and multi-byte streams.
* Tatsuo Ishii
* $Id: wchar.c,v 1.11 2000/04/12 17:16:06 momjian Exp $
* $Id: wchar.c,v 1.12 2000/08/27 10:40:48 ishii Exp $
*
* WIN1250 client encoding updated by Pavel Behal
*
......@@ -20,15 +20,19 @@
/*
* SQL/ASCII
*/
static void pg_ascii2wchar_with_len
static int pg_ascii2wchar_with_len
(const unsigned char *from, pg_wchar * to, int len)
{
int cnt = 0;
while (*from && len > 0)
{
*to++ = *from++;
len--;
cnt++;
}
*to = 0;
return(cnt);
}
static int
......@@ -41,9 +45,11 @@ pg_ascii_mblen(const unsigned char *s)
* EUC
*/
static void pg_euc2wchar_with_len
static int pg_euc2wchar_with_len
(const unsigned char *from, pg_wchar * to, int len)
{
int cnt = 0;
while (*from && len > 0)
{
if (*from == SS2)
......@@ -72,8 +78,10 @@ static void pg_euc2wchar_with_len
len--;
}
to++;
cnt++;
}
*to = 0;
return(cnt);
}
static int
......@@ -95,10 +103,10 @@ pg_euc_mblen(const unsigned char *s)
/*
* EUC_JP
*/
static void pg_eucjp2wchar_with_len
static int pg_eucjp2wchar_with_len
(const unsigned char *from, pg_wchar * to, int len)
{
pg_euc2wchar_with_len(from, to, len);
return(pg_euc2wchar_with_len(from, to, len));
}
static int
......@@ -110,10 +118,10 @@ pg_eucjp_mblen(const unsigned char *s)
/*
* EUC_KR
*/
static void pg_euckr2wchar_with_len
static int pg_euckr2wchar_with_len
(const unsigned char *from, pg_wchar * to, int len)
{
pg_euc2wchar_with_len(from, to, len);
return(pg_euc2wchar_with_len(from, to, len));
}
static int
......@@ -125,9 +133,11 @@ pg_euckr_mblen(const unsigned char *s)
/*
* EUC_CN
*/
static void pg_euccn2wchar_with_len
static int pg_euccn2wchar_with_len
(const unsigned char *from, pg_wchar * to, int len)
{
int cnt = 0;
while (*from && len > 0)
{
if (*from == SS2)
......@@ -157,8 +167,10 @@ static void pg_euccn2wchar_with_len
len--;
}
to++;
cnt++;
}
*to = 0;
return(cnt);
}
static int
......@@ -176,9 +188,11 @@ pg_euccn_mblen(const unsigned char *s)
/*
* EUC_TW
*/
static void pg_euctw2wchar_with_len
static int pg_euctw2wchar_with_len
(const unsigned char *from, pg_wchar * to, int len)
{
int cnt = 0;
while (*from && len > 0)
{
if (*from == SS2)
......@@ -209,8 +223,10 @@ static void pg_euctw2wchar_with_len
len--;
}
to++;
cnt++;
}
*to = 0;
return(cnt);
}
static int
......@@ -235,12 +251,13 @@ pg_euctw_mblen(const unsigned char *s)
* len: length of from.
* "from" not necessarily null terminated.
*/
static void
static int
pg_utf2wchar_with_len(const unsigned char *from, pg_wchar * to, int len)
{
unsigned char c1,
c2,
c3;
int cnt = 0;
while (*from && len > 0)
{
......@@ -273,8 +290,10 @@ pg_utf2wchar_with_len(const unsigned char *from, pg_wchar * to, int len)
len--;
}
to++;
cnt++;
}
*to = 0;
return(cnt);
}
static int
......@@ -297,9 +316,11 @@ pg_utf_mblen(const unsigned char *s)
* len: length of from.
* "from" not necessarily null terminated.
*/
static void
static int
pg_mule2wchar_with_len(const unsigned char *from, pg_wchar * to, int len)
{
int cnt = 0;
while (*from && len > 0)
{
if (IS_LC1(*from))
......@@ -336,8 +357,10 @@ pg_mule2wchar_with_len(const unsigned char *from, pg_wchar * to, int len)
len--;
}
to++;
cnt++;
}
*to = 0;
return(cnt);
}
int
......@@ -363,12 +386,18 @@ pg_mule_mblen(const unsigned char *s)
/*
* ISO8859-1
*/
static void
static int
pg_latin12wchar_with_len(const unsigned char *from, pg_wchar * to, int len)
{
int cnt = 0;
while (*from && len-- > 0)
{
*to++ = *from++;
cnt++;
}
*to = 0;
return(cnt);
}
static int
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment