diff --git a/src/backend/utils/adt/Makefile b/src/backend/utils/adt/Makefile index 1b301d75750085bee18158c46e94bc3a8d03b3ed..702326f7371fd51d0deeef8c946f41f9b4af5957 100644 --- a/src/backend/utils/adt/Makefile +++ b/src/backend/utils/adt/Makefile @@ -1,7 +1,7 @@ # # Makefile for utils/adt # -# $Header: /cvsroot/pgsql/src/backend/utils/adt/Makefile,v 1.43 2000/08/04 20:46:43 momjian Exp $ +# $Header: /cvsroot/pgsql/src/backend/utils/adt/Makefile,v 1.44 2000/08/05 14:59:17 momjian Exp $ # subdir = src/backend/utils/adt @@ -23,7 +23,8 @@ OBJS = acl.o arrayfuncs.o arrayutils.o bool.o cash.o char.o \ regexp.o regproc.o ruleutils.o selfuncs.o sets.o \ tid.o timestamp.o varbit.o varchar.o varlena.o version.o \ network.o mac.o inet_net_ntop.o inet_net_pton.o \ - ri_triggers.o pg_lzcompress.o pg_locale.o formatting.o + ri_triggers.o pg_lzcompress.o pg_locale.o formatting.o \ + ascii.o all: SUBSYS.o diff --git a/src/backend/utils/adt/ascii.c b/src/backend/utils/adt/ascii.c index e69de29bb2d1d6434b8b29ae775ad8c2e48c5391..5eb0d8e08bd840bbd5a3be26d01c1fe651242eb1 100644 --- a/src/backend/utils/adt/ascii.c +++ b/src/backend/utils/adt/ascii.c @@ -0,0 +1,201 @@ + +/* ----------------------------------------------------------------------- + * ascii.c + * + * $Header: /cvsroot/pgsql/src/backend/utils/adt/ascii.c,v 1.3 2000/08/05 14:59:17 momjian Exp $ + * + * Portions Copyright (c) 1999-2000, PostgreSQL, Inc + * + * + * TO_ASCII() + * + * The PostgreSQL routine for string to ascii conversion. + * + * ----------------------------------------------------------------------- + */ + +#include "postgres.h" +#include "utils/builtins.h" +#include "mb/pg_wchar.h" +#include "utils/ascii.h" + +/* ---------- + * even if MULTIBYTE is not enabled, these functions are necessary + * since pg_proc.h has references to them. + * ---------- + */ +#ifndef MULTIBYTE + +static void multibyte_error(void); + +static void +multibyte_error() +{ + elog(ERROR, "multibyte not supported."); +} + +Datum +to_ascii_encname(PG_FUNCTION_ARGS) +{ + multibyte_error(); +} + +Datum +to_ascii_enc(PG_FUNCTION_ARGS) +{ + multibyte_error(); +} + +Datum +to_ascii_default(PG_FUNCTION_ARGS) +{ + multibyte_error(); +} + + +#else /* with MULTIBYTE */ + + +/* ---------- + * even if MULTIBYTE is enabled + * ---------- + */ + +static text *encode_to_ascii(text *data, int enc); + +/* ---------- + * to_ascii + * ---------- + */ +char * +pg_to_ascii(unsigned char *src, unsigned char *src_end, unsigned char *desc, int enc) +{ + unsigned char *x = NULL; + unsigned char *ascii = NULL ; + int range = 0; + + /* + * relevant start for an encoding + */ + #define RANGE_128 128 + #define RANGE_160 160 + + + if (enc == LATIN1) + { + /* ---------- + * ISO-8859-1 <range: 160 -- 255> + * ---------- + */ + ascii = " cL Y \"Ca -R 'u ., ?AAAAAAACEEEEIIII NOOOOOxOUUUUYTBaaaaaaaceeeeiiii nooooo/ouuuuyty"; + range = RANGE_160; + } + else if (enc == LATIN2) + { + /* ---------- + * ISO-8859-2 <range: 160 -- 255> + * ---------- + */ + ascii = " A L LS \"SSTZ-ZZ a,l'ls ,sstz\"zzRAAAALCCCEEEEIIDDNNOOOOxRUUUUYTBraaaalccceeeeiiddnnoooo/ruuuuyt."; + range = RANGE_160; + } + else if (enc == WIN1250) + { + /* ---------- + * Window CP1250 <range: 128 -- 255> + * ---------- + */ + ascii = " ' \" %S<STZZ `'\"\".-- s>stzz L A \"CS -RZ ,l'u .,as L\"lzRAAAALCCCEEEEIIDDNNOOOOxRUUUUYTBraaaalccceeeeiiddnnoooo/ruuuuyt "; + range = RANGE_128; + } + else + { + elog(ERROR, "pg_to_ascii(): unsupported encoding from %s", + pg_encoding_to_char(enc)); + } + + /* ---------- + * Encode + * ---------- + */ + for (x = src; x <= src_end; x++) + { + if (*x < 128) + *desc++ = *x; + else if (*x < range) + *desc++ = ' '; /* bogus 128 to 'range' */ + else + *desc++ = ascii[*x - range]; + } + + return desc; +} + +/* ---------- + * encode text + * ---------- + */ +static text * +encode_to_ascii(text *data, int enc) +{ + pg_to_ascii( + (unsigned char *) VARDATA(data), /* src */ + VARDATA(data) + VARSIZE(data), /* src end */ + (unsigned char *) VARDATA(data), /* desc */ + enc); /* encoding */ + + return data; +} + +/* ---------- + * convert to ASCII - enc is set as 'name' arg. + * ---------- + */ +Datum +to_ascii_encname(PG_FUNCTION_ARGS) +{ + PG_RETURN_TEXT_P + ( + encode_to_ascii + ( + PG_GETARG_TEXT_P_COPY(0), + pg_char_to_encoding( NameStr(*PG_GETARG_NAME(1)) ) + ) + ); +} + +/* ---------- + * convert to ASCII - enc is set as int4 + * ---------- + */ +Datum +to_ascii_enc(PG_FUNCTION_ARGS) +{ + PG_RETURN_TEXT_P + ( + encode_to_ascii + ( + PG_GETARG_TEXT_P_COPY(0), + PG_GETARG_INT32(1) + ) + ); +} + +/* ---------- + * convert to ASCII - current enc is DatabaseEncoding + * ---------- + */ +Datum +to_ascii_default(PG_FUNCTION_ARGS) +{ + PG_RETURN_TEXT_P + ( + encode_to_ascii + ( + PG_GETARG_TEXT_P_COPY(0), + GetDatabaseEncoding() + ) + ); +} + +#endif /* MULTIBYTE */ \ No newline at end of file diff --git a/src/include/catalog/pg_proc.h b/src/include/catalog/pg_proc.h index 3703689d96b5dcf7f825f7e813c6b125f3d2f08a..4bc8609521f26a955a397e437df479057f4474d7 100644 --- a/src/include/catalog/pg_proc.h +++ b/src/include/catalog/pg_proc.h @@ -7,7 +7,7 @@ * Portions Copyright (c) 1996-2000, PostgreSQL, Inc * Portions Copyright (c) 1994, Regents of the University of California * - * $Id: pg_proc.h,v 1.159 2000/08/04 20:46:43 momjian Exp $ + * $Id: pg_proc.h,v 1.160 2000/08/05 14:59:19 momjian Exp $ * * NOTES * The script catalog/genbki.sh reads this file and generates .bki @@ -2442,6 +2442,14 @@ DESCR("aggregate transition function"); DATA(insert OID = 1844 ( interval_avg PGUID 12 f t t t 1 f 1186 "1187" 100 0 0 100 interval_avg - )); DESCR("AVG aggregate final function"); +/* To ASCII conversion */ +DATA(insert OID = 1845 ( to_ascii PGUID 12 f t t t 1 f 25 "25" 100 0 0 100 to_ascii_default - )); +DESCR("encode text from DB encoding to ASCII text"); +DATA(insert OID = 1846 ( to_ascii PGUID 12 f t t t 2 f 25 "25 23" 100 0 0 100 to_ascii_enc - )); +DESCR("encode text from encoding to ASCII text"); +DATA(insert OID = 1847 ( to_ascii PGUID 12 f t t t 2 f 25 "25 19" 100 0 0 100 to_ascii_encname - )); +DESCR("encode text from encoding to ASCII text"); + DATA(insert OID = 1850 ( int28eq PGUID 12 f t t t 2 f 16 "21 20" 100 0 0 100 int28eq - )); DESCR("equal"); DATA(insert OID = 1851 ( int28ne PGUID 12 f t t t 2 f 16 "21 20" 100 0 0 100 int28ne - )); diff --git a/src/include/utils/ascii.h b/src/include/utils/ascii.h index e69de29bb2d1d6434b8b29ae775ad8c2e48c5391..c29d2dc904cfc93c015bc11470a2394a2e9cc737 100644 --- a/src/include/utils/ascii.h +++ b/src/include/utils/ascii.h @@ -0,0 +1,27 @@ + +/* ----------------------------------------------------------------------- + * ascii.h + * + * $Id: ascii.h,v 1.3 2000/08/05 14:59:29 momjian Exp $ + * + * Portions Copyright (c) 1999-2000, PostgreSQL, Inc + * + * ----------------------------------------------------------------------- + */ + +#ifndef _ASCII_H_ +#define _ASCII_H_ + +#include "fmgr.h" + +extern Datum to_ascii_encname(PG_FUNCTION_ARGS); +extern Datum to_ascii_enc(PG_FUNCTION_ARGS); +extern Datum to_ascii_default(PG_FUNCTION_ARGS); + +#ifdef MULTIBYTE + +extern char *pg_to_ascii(unsigned char *src, unsigned char *src_end, + unsigned char *desc, int enc); +#endif /* MULTIBYTE */ + +#endif /* _ASCII_H_ */