diff --git a/src/backend/commands/copy.c b/src/backend/commands/copy.c index b9eecf4b8be1f87fcbd657075aa36847393ae912..56d40c5bf0f2db91dbfc2aa36afd45297e63346a 100644 --- a/src/backend/commands/copy.c +++ b/src/backend/commands/copy.c @@ -7,7 +7,7 @@ * * * IDENTIFICATION - * $Header: /cvsroot/pgsql/src/backend/commands/copy.c,v 1.168 2002/08/29 00:17:03 tgl Exp $ + * $Header: /cvsroot/pgsql/src/backend/commands/copy.c,v 1.169 2002/08/29 07:22:21 ishii Exp $ * *------------------------------------------------------------------------- */ @@ -39,10 +39,7 @@ #include "utils/relcache.h" #include "utils/lsyscache.h" #include "utils/syscache.h" - -#ifdef MULTIBYTE #include "mb/pg_wchar.h" -#endif #define ISOCTAL(c) (((c) >= '0') && ((c) <= '7')) #define OCTVALUE(c) ((c) - '0') @@ -85,11 +82,8 @@ static bool fe_eof; */ static StringInfoData attribute_buf; -#ifdef MULTIBYTE static int client_encoding; static int server_encoding; -#endif - /* * Internal communications functions @@ -387,10 +381,9 @@ DoCopy(const CopyStmt *stmt) * Set up variables to avoid per-attribute overhead. */ initStringInfo(&attribute_buf); -#ifdef MULTIBYTE + client_encoding = pg_get_client_encoding(); server_encoding = GetDatabaseEncoding(); -#endif if (is_from) { /* copy from file to database */ @@ -1231,14 +1224,12 @@ CopyReadAttribute(FILE *fp, const char *delim, CopyReadResult *result) { int c; int delimc = (unsigned char) delim[0]; -#ifdef MULTIBYTE int mblen; unsigned char s[2]; char *cvt; int j; s[1] = 0; -#endif /* reset attribute_buf to empty */ attribute_buf.len = 0; @@ -1354,7 +1345,7 @@ CopyReadAttribute(FILE *fp, const char *delim, CopyReadResult *result) } } appendStringInfoCharMacro(&attribute_buf, c); -#ifdef MULTIBYTE + /* XXX shouldn't this be done even when encoding is the same? */ if (client_encoding != server_encoding) { @@ -1372,12 +1363,10 @@ CopyReadAttribute(FILE *fp, const char *delim, CopyReadResult *result) appendStringInfoCharMacro(&attribute_buf, c); } } -#endif } copy_eof: -#ifdef MULTIBYTE if (client_encoding != server_encoding) { cvt = (char *) pg_client_to_server((unsigned char *) attribute_buf.data, @@ -1391,7 +1380,6 @@ copy_eof: pfree(cvt); } } -#endif return attribute_buf.data; } @@ -1403,14 +1391,11 @@ CopyAttributeOut(FILE *fp, char *server_string, char *delim) char c; char delimc = delim[0]; -#ifdef MULTIBYTE bool same_encoding; char *string_start; int mblen; int i; -#endif -#ifdef MULTIBYTE same_encoding = (server_encoding == client_encoding); if (!same_encoding) { @@ -1423,19 +1408,11 @@ CopyAttributeOut(FILE *fp, char *server_string, char *delim) string = server_string; string_start = NULL; } -#else - string = server_string; -#endif -#ifdef MULTIBYTE for (; (c = *string) != '\0'; string += mblen) -#else - for (; (c = *string) != '\0'; string++) -#endif { -#ifdef MULTIBYTE mblen = 1; -#endif + switch (c) { case '\b': @@ -1463,7 +1440,7 @@ CopyAttributeOut(FILE *fp, char *server_string, char *delim) if (c == delimc) CopySendChar('\\', fp); CopySendChar(c, fp); -#ifdef MULTIBYTE + /* XXX shouldn't this be done even when encoding is same? */ if (!same_encoding) { @@ -1472,15 +1449,12 @@ CopyAttributeOut(FILE *fp, char *server_string, char *delim) for (i = 1; i < mblen; i++) CopySendChar(string[i], fp); } -#endif break; } } -#ifdef MULTIBYTE if (string_start) pfree(string_start); /* pfree pg_server_to_client result */ -#endif } /* diff --git a/src/backend/commands/dbcommands.c b/src/backend/commands/dbcommands.c index 53c8391c0c515e1c7b6f00ea43006df19ec789d5..c511199a8b4d470dd4498da765b16ebd26361e90 100644 --- a/src/backend/commands/dbcommands.c +++ b/src/backend/commands/dbcommands.c @@ -9,7 +9,7 @@ * * * IDENTIFICATION - * $Header: /cvsroot/pgsql/src/backend/commands/dbcommands.c,v 1.99 2002/08/09 16:45:14 tgl Exp $ + * $Header: /cvsroot/pgsql/src/backend/commands/dbcommands.c,v 1.100 2002/08/29 07:22:21 ishii Exp $ * *------------------------------------------------------------------------- */ @@ -39,9 +39,7 @@ #include "utils/lsyscache.h" #include "utils/syscache.h" -#ifdef MULTIBYTE #include "mb/pg_wchar.h" /* encoding check */ -#endif /* non-export function prototypes */ @@ -214,13 +212,9 @@ createdb(const CreatedbStmt *stmt) if (encoding < 0) encoding = src_encoding; -#ifdef MULTIBYTE /* Some encodings are client only */ if (!PG_VALID_BE_ENCODING(encoding)) elog(ERROR, "CREATE DATABASE: invalid backend encoding"); -#else - Assert(encoding == 0); /* zero is PG_SQL_ASCII */ -#endif /* * Preassign OID for pg_database tuple, so that we can compute db diff --git a/src/backend/parser/analyze.c b/src/backend/parser/analyze.c index 514573b79a6f160ff8cbbfaf9595e8b1e54ea3ad..7abb2abfd600f8133e5b67afdb65a21bfb0c9298 100644 --- a/src/backend/parser/analyze.c +++ b/src/backend/parser/analyze.c @@ -6,7 +6,7 @@ * Portions Copyright (c) 1996-2002, PostgreSQL Global Development Group * Portions Copyright (c) 1994, Regents of the University of California * - * $Header: /cvsroot/pgsql/src/backend/parser/analyze.c,v 1.245 2002/08/28 20:46:23 momjian Exp $ + * $Header: /cvsroot/pgsql/src/backend/parser/analyze.c,v 1.246 2002/08/29 07:22:22 ishii Exp $ * *------------------------------------------------------------------------- */ @@ -42,9 +42,7 @@ #include "utils/lsyscache.h" #include "utils/relcache.h" #include "utils/syscache.h" -#ifdef MULTIBYTE #include "mb/pg_wchar.h" -#endif /* State shared by transformCreateSchemaStmt and its subroutines */ @@ -634,12 +632,10 @@ makeObjectName(char *name1, char *name2, char *typename) name2chars--; } -#ifdef MULTIBYTE if (name1) name1chars = pg_mbcliplen(name1, name1chars, name1chars); if (name2) name2chars = pg_mbcliplen(name2, name2chars, name2chars); -#endif /* Now construct the string using the chosen lengths */ name = palloc(name1chars + name2chars + overhead + 1); diff --git a/src/backend/parser/scan.l b/src/backend/parser/scan.l index 5092f82e5e01bced287ce2ee750a48aa64a795eb..21534561ed21ddccb3639273a2492c07ab6a498b 100644 --- a/src/backend/parser/scan.l +++ b/src/backend/parser/scan.l @@ -9,7 +9,7 @@ * * * IDENTIFICATION - * $Header: /cvsroot/pgsql/src/backend/parser/scan.l,v 1.100 2002/08/18 03:35:08 tgl Exp $ + * $Header: /cvsroot/pgsql/src/backend/parser/scan.l,v 1.101 2002/08/29 07:22:23 ishii Exp $ * *------------------------------------------------------------------------- */ @@ -26,10 +26,7 @@ #include "parser/keywords.h" #include "parser/parse.h" #include "utils/builtins.h" - -#ifdef MULTIBYTE #include "mb/pg_wchar.h" -#endif /* No reason to constrain amount of data slurped */ #define YY_READ_BUF_SIZE 16777216 @@ -402,12 +399,9 @@ other . if (literallen >= NAMEDATALEN) { int len; -#ifdef MULTIBYTE + len = pg_mbcliplen(literalbuf, literallen, NAMEDATALEN-1); -#else - len = NAMEDATALEN-1; -#endif elog(NOTICE, "identifier \"%s\" will be truncated to \"%.*s\"", literalbuf, len, literalbuf); literalbuf[len] = '\0'; @@ -562,11 +556,8 @@ other . if (i >= NAMEDATALEN) { int len; -#ifdef MULTIBYTE + len = pg_mbcliplen(ident, i, NAMEDATALEN-1); -#else - len = NAMEDATALEN-1; -#endif elog(NOTICE, "identifier \"%s\" will be truncated to \"%.*s\"", ident, len, ident); ident[len] = '\0'; diff --git a/src/backend/postmaster/pgstat.c b/src/backend/postmaster/pgstat.c index 7da055179d19db21985e925899f0c6217f6e97ef..c5aacab95b1686a1e9134952fa2b5952735a265c 100644 --- a/src/backend/postmaster/pgstat.c +++ b/src/backend/postmaster/pgstat.c @@ -16,7 +16,7 @@ * * Copyright (c) 2001, PostgreSQL Global Development Group * - * $Header: /cvsroot/pgsql/src/backend/postmaster/pgstat.c,v 1.23 2002/08/04 05:09:36 momjian Exp $ + * $Header: /cvsroot/pgsql/src/backend/postmaster/pgstat.c,v 1.24 2002/08/29 07:22:23 ishii Exp $ * ---------- */ #include "postgres.h" @@ -38,9 +38,7 @@ #include "catalog/pg_shadow.h" #include "catalog/pg_database.h" #include "libpq/pqsignal.h" -#ifdef MULTIBYTE #include "mb/pg_wchar.h" -#endif #include "miscadmin.h" #include "utils/memutils.h" #include "storage/backendid.h" @@ -434,12 +432,7 @@ pgstat_report_activity(char *what) return; len = strlen(what); -#ifdef MULTIBYTE len = pg_mbcliplen((const unsigned char *)what, len, PGSTAT_ACTIVITY_SIZE - 1); -#else - if (len >= PGSTAT_ACTIVITY_SIZE) - len = PGSTAT_ACTIVITY_SIZE - 1; -#endif memcpy(msg.m_what, what, len); msg.m_what[len] = '\0'; diff --git a/src/backend/regex/engine.c b/src/backend/regex/engine.c index 7e77054eecf0167a1047c44e3123a2e8d6a1af67..4a64ec8c992559c89ed7f8f37a4b29f44fffe905 100644 --- a/src/backend/regex/engine.c +++ b/src/backend/regex/engine.c @@ -108,13 +108,8 @@ static states step(struct re_guts * g, sopno start, #define EOW (BOL+5) #define CODEMAX (BOL+5) /* highest code used */ -#ifdef MULTIBYTE #define NONCHAR(c) ((c) > 16777216) /* 16777216 == 2^24 == 3 bytes */ #define NNONCHAR (CODEMAX-16777216) -#else -#define NONCHAR(c) ((c) > CHAR_MAX) -#define NNONCHAR (CODEMAX-CHAR_MAX) -#endif #ifdef REDEBUG static void print(struct match * m, pg_wchar *caption, states st, int ch, @@ -168,11 +163,7 @@ matcher(struct re_guts * g, pg_wchar *string, size_t nmatch, else { start = string; -#ifdef MULTIBYTE stop = start + pg_wchar_strlen(start); -#else - stop = start + strlen(start); -#endif } if (stop < start) return REG_INVARG; @@ -182,11 +173,7 @@ matcher(struct re_guts * g, pg_wchar *string, size_t nmatch, { for (dp = start; dp < stop; dp++) if (*dp == g->must[0] && stop - dp >= g->mlen && -#ifdef MULTIBYTE memcmp(dp, g->must, (size_t) (g->mlen * sizeof(pg_wchar))) == 0 -#else - memcmp(dp, g->must, (size_t) g->mlen) == 0 -#endif ) break; if (dp == stop) /* we didn't find g->must */ @@ -1090,11 +1077,7 @@ pchar(int ch) static int pg_isprint(int c) { -#ifdef MULTIBYTE return (c >= 0 && c <= UCHAR_MAX && isprint((unsigned char) c)); -#else - return (isprint((unsigned char) c)); -#endif } #endif #endif diff --git a/src/backend/regex/regcomp.c b/src/backend/regex/regcomp.c index d6f7b26fa1a4cb77579963312a8b768664dee2c8..ae079ff4c4db28b2a11578533f9d34f20695080c 100644 --- a/src/backend/regex/regcomp.c +++ b/src/backend/regex/regcomp.c @@ -91,13 +91,7 @@ static void p_b_cclass(struct parse * p, cset *cs); static void p_b_eclass(struct parse * p, cset *cs); static pg_wchar p_b_symbol(struct parse * p); static char p_b_coll_elem(struct parse * p, int endc); - -#ifdef MULTIBYTE static unsigned char othercase(int ch); - -#else -static char othercase(int ch); -#endif static void bothcases(struct parse * p, int ch); static void ordinary(struct parse * p, int ch); static void nonnewline(struct parse * p); @@ -184,10 +178,7 @@ pg_regcomp(regex_t *preg, const char *pattern, int cflags) struct parse *p = &pa; int i; size_t len; - -#ifdef MULTIBYTE pg_wchar *wcp; -#endif if ( cclasses == NULL ) cclasses = cclass_init(); @@ -204,29 +195,19 @@ pg_regcomp(regex_t *preg, const char *pattern, int cflags) if (cflags & REG_PEND) { -#ifdef MULTIBYTE wcp = preg->patsave; if (preg->re_endp < wcp) return REG_INVARG; len = preg->re_endp - wcp; -#else - if (preg->re_endp < pattern) - return REG_INVARG; - len = preg->re_endp - pattern; -#endif } else { -#ifdef MULTIBYTE wcp = (pg_wchar *) malloc((strlen(pattern) + 1) * sizeof(pg_wchar)); if (wcp == NULL) return REG_ESPACE; preg->patsave = wcp; (void) pg_mb2wchar((unsigned char *) pattern, wcp); len = pg_wchar_strlen(wcp); -#else - len = strlen((char *) pattern); -#endif } /* do the mallocs early so failure handling is easy */ @@ -246,12 +227,7 @@ pg_regcomp(regex_t *preg, const char *pattern, int cflags) /* set things up */ p->g = g; -#ifdef MULTIBYTE p->next = wcp; -#else - p->next = (pg_wchar *) pattern; /* convenience; we do not modify - * it */ -#endif p->end = p->next + len; p->error = 0; p->ncsalloc = 0; @@ -591,11 +567,7 @@ p_simp_re(struct parse * p, if (c == '\\') { REQUIRE(MORE(), REG_EESCAPE); -#ifdef MULTIBYTE c = BACKSL | (pg_wchar) GETNEXT(); -#else - c = BACKSL | (unsigned char) GETNEXT(); -#endif } switch (c) { @@ -736,27 +708,17 @@ p_bracket(struct parse * p) cset *cs = allocset(p); int invert = 0; -#ifdef MULTIBYTE pg_wchar sp1[] = {'[', ':', '<', ':', ']', ']'}; pg_wchar sp2[] = {'[', ':', '>', ':', ']', ']'}; -#endif /* Dept of Truly Sickening Special-Case Kludges */ -#ifdef MULTIBYTE if (p->next + 5 < p->end && pg_wchar_strncmp(p->next, sp1, 6) == 0) -#else - if (p->next + 5 < p->end && strncmp(p->next, "[:<:]]", 6) == 0) -#endif { EMIT(OBOW, 0); NEXTn(6); return; } -#ifdef MULTIBYTE if (p->next + 5 < p->end && pg_wchar_strncmp(p->next, sp2, 6) == 0) -#else - if (p->next + 5 < p->end && strncmp(p->next, "[:>:]]", 6) == 0) -#endif { EMIT(OEOW, 0); NEXTn(6); @@ -881,10 +843,10 @@ p_b_term(struct parse * p, cset *cs) finish = start; /* xxx what about signed chars here... */ REQUIRE(start <= finish, REG_ERANGE); -#ifdef MULTIBYTE + if (CHlc(start) != CHlc(finish)) SETERROR(REG_ERANGE); -#endif + for (i = start; i <= finish; i++) CHadd(cs, i); break; @@ -906,13 +868,11 @@ p_b_cclass(struct parse * p, cset *cs) while (MORE() && pg_isalpha(PEEK())) NEXT(); len = p->next - sp; + for (cp = cclasses; cp->name != NULL; cp++) -#ifdef MULTIBYTE if (pg_char_and_wchar_strncmp(cp->name, sp, len) == 0 && cp->name[len] == '\0') -#else - if (strncmp(cp->name, sp, len) == 0 && cp->name[len] == '\0') -#endif break; + if (cp->name == NULL) { /* oops, didn't find it */ @@ -977,13 +937,11 @@ p_b_coll_elem(struct parse * p, int endc) return 0; } len = p->next - sp; + for (cp = cnames; cp->name != NULL; cp++) -#ifdef MULTIBYTE if (pg_char_and_wchar_strncmp(cp->name, sp, len) == 0 && cp->name[len] == '\0') -#else - if (strncmp(cp->name, sp, len) == 0 && cp->name[len] == '\0') -#endif return cp->code; /* known name */ + if (len == 1) return *sp; /* single character */ SETERROR(REG_ECOLLATE); /* neither */ @@ -993,33 +951,17 @@ p_b_coll_elem(struct parse * p, int endc) /* * othercase - return the case counterpart of an alphabetic */ -#ifdef MULTIBYTE static unsigned char /* if no counterpart, return ch */ -#else -static char /* if no counterpart, return ch */ -#endif othercase(int ch) { assert(pg_isalpha(ch)); if (pg_isupper(ch)) -#ifdef MULTIBYTE return (unsigned char) tolower((unsigned char) ch); -#else - return tolower((unsigned char) ch); -#endif else if (pg_islower(ch)) -#ifdef MULTIBYTE return (unsigned char) toupper((unsigned char) ch); -#else - return toupper((unsigned char) ch); -#endif else /* peculiar, but could happen */ -#ifdef MULTIBYTE return (unsigned char) ch; -#else - return ch; -#endif } /* @@ -1058,11 +1000,7 @@ ordinary(struct parse * p, int ch) bothcases(p, ch); else { -#ifdef MULTIBYTE EMIT(OCHAR, (pg_wchar) ch); -#else - EMIT(OCHAR, (unsigned char) ch); -#endif if (ch >= CHAR_MIN && ch <= CHAR_MAX && cap[ch] == 0) cap[ch] = p->g->ncategories++; } @@ -1633,11 +1571,7 @@ findmust(struct parse * p, struct re_guts * g) return; /* turn it into a character string */ -#ifdef MULTIBYTE g->must = (pg_wchar *) malloc((size_t) (g->mlen + 1) * sizeof(pg_wchar)); -#else - g->must = malloc((size_t) g->mlen + 1); -#endif if (g->must == NULL) { /* argh; just forget it */ g->mlen = 0; @@ -1697,91 +1631,55 @@ pluscount(struct parse * p, struct re_guts * g) static int pg_isdigit(int c) { -#ifdef MULTIBYTE return (c >= 0 && c <= UCHAR_MAX && isdigit((unsigned char) c)); -#else - return (isdigit((unsigned char) c)); -#endif } static int pg_isalpha(int c) { -#ifdef MULTIBYTE return (c >= 0 && c <= UCHAR_MAX && isalpha((unsigned char) c)); -#else - return (isalpha((unsigned char) c)); -#endif } static int pg_isalnum(int c) { -#ifdef MULTIBYTE return (c >= 0 && c <= UCHAR_MAX && isalnum((unsigned char) c)); -#else - return (isalnum((unsigned char) c)); -#endif } static int pg_isupper(int c) { -#ifdef MULTIBYTE return (c >= 0 && c <= UCHAR_MAX && isupper((unsigned char) c)); -#else - return (isupper((unsigned char) c)); -#endif } static int pg_islower(int c) { -#ifdef MULTIBYTE return (c >= 0 && c <= UCHAR_MAX && islower((unsigned char) c)); -#else - return (islower((unsigned char) c)); -#endif } static int pg_iscntrl(int c) { -#ifdef MULTIBYTE return (c >= 0 && c <= UCHAR_MAX && iscntrl((unsigned char) c)); -#else - return (iscntrl((unsigned char) c)); -#endif } static int pg_isgraph(int c) { -#ifdef MULTIBYTE return (c >= 0 && c <= UCHAR_MAX && isgraph((unsigned char) c)); -#else - return (isgraph((unsigned char) c)); -#endif } static int pg_isprint(int c) { -#ifdef MULTIBYTE return (c >= 0 && c <= UCHAR_MAX && isprint((unsigned char) c)); -#else - return (isprint((unsigned char) c)); -#endif } static int pg_ispunct(int c) { -#ifdef MULTIBYTE return (c >= 0 && c <= UCHAR_MAX && ispunct((unsigned char) c)); -#else - return (ispunct((unsigned char) c)); -#endif } static struct cclass * diff --git a/src/backend/regex/regerror.c b/src/backend/regex/regerror.c index fb12cba3048ee78dda4d4f425438702133abf230..b3d1d472dfb443e2823907954086524fafc14da3 100644 --- a/src/backend/regex/regerror.c +++ b/src/backend/regex/regerror.c @@ -171,12 +171,9 @@ regatoi(const regex_t *preg, char *localbuf) struct rerr *r; for (r = rerrs; r->code != 0; r++) -#ifdef MULTIBYTE if (pg_char_and_wchar_strcmp(r->name, preg->re_endp) == 0) -#else - if (strcmp(r->name, preg->re_endp) == 0) -#endif break; + if (r->code == 0) return "0"; diff --git a/src/backend/regex/regexec.c b/src/backend/regex/regexec.c index 06459ef1dbcaefec6d33d44df2ba88ebb6b85031..59c9ede9f7cfdc729d538ae498876204d4e5c705 100644 --- a/src/backend/regex/regexec.c +++ b/src/backend/regex/regexec.c @@ -154,10 +154,8 @@ pg_regexec(const regex_t *preg, const char *string, size_t nmatch, { struct re_guts *g = preg->re_g; -#ifdef MULTIBYTE pg_wchar *str; int sts; -#endif #ifdef REDEBUG #define GOODFLAGS(f) (f) @@ -172,7 +170,6 @@ pg_regexec(const regex_t *preg, const char *string, size_t nmatch, return REG_BADPAT; eflags = GOODFLAGS(eflags); -#ifdef MULTIBYTE str = (pg_wchar *) malloc((strlen(string) + 1) * sizeof(pg_wchar)); if (!str) return (REG_ESPACE); @@ -183,12 +180,4 @@ pg_regexec(const regex_t *preg, const char *string, size_t nmatch, sts = lmatcher(g, str, nmatch, pmatch, eflags); free((char *) str); return (sts); - -#else - - if (g->nstates <= CHAR_BIT * sizeof(states1) && !(eflags & REG_LARGE)) - return smatcher(g, (pg_wchar *) string, nmatch, pmatch, eflags); - else - return lmatcher(g, (pg_wchar *) string, nmatch, pmatch, eflags); -#endif } diff --git a/src/backend/regex/regfree.c b/src/backend/regex/regfree.c index 5672fcf240f4f9f7358f26f3d53d4ddefe36d041..b022dddc75af20e7fcafe0e63aa295bef33e2b8f 100644 --- a/src/backend/regex/regfree.c +++ b/src/backend/regex/regfree.c @@ -61,10 +61,9 @@ pg_regfree(regex_t *preg) return; preg->re_magic = 0; /* mark it invalid */ g->magic = 0; /* mark it invalid */ -#ifdef MULTIBYTE + if (preg->patsave != NULL) free((char *) preg->patsave); -#endif if (g->strip != NULL) free((char *) g->strip); if (g->sets != NULL) diff --git a/src/backend/tcop/postgres.c b/src/backend/tcop/postgres.c index 28576b8fad610864929606cf0d96f9bda3f96777..d16edabfe3fc002e7183ecc01f648a0e612ac5a3 100644 --- a/src/backend/tcop/postgres.c +++ b/src/backend/tcop/postgres.c @@ -8,7 +8,7 @@ * * * IDENTIFICATION - * $Header: /cvsroot/pgsql/src/backend/tcop/postgres.c,v 1.284 2002/08/27 04:55:11 tgl Exp $ + * $Header: /cvsroot/pgsql/src/backend/tcop/postgres.c,v 1.285 2002/08/29 07:22:23 ishii Exp $ * * NOTES * this is the "main" module of the postgres backend and @@ -57,9 +57,7 @@ #include "utils/guc.h" #include "utils/memutils.h" #include "utils/ps_status.h" -#ifdef MULTIBYTE #include "mb/pg_wchar.h" -#endif #include "pgstat.h" @@ -1666,7 +1664,7 @@ PostgresMain(int argc, char *argv[], const char *username) if (!IsUnderPostmaster) { puts("\nPOSTGRES backend interactive interface "); - puts("$Revision: 1.284 $ $Date: 2002/08/27 04:55:11 $\n"); + puts("$Revision: 1.285 $ $Date: 2002/08/29 07:22:23 $\n"); } /* diff --git a/src/backend/utils/adt/ascii.c b/src/backend/utils/adt/ascii.c index a62672a5e539bb3b6dedb5de8165965623a18b0e..0a2820721dcc7dcdebaf61f9b4abb5f99ac888ce 100644 --- a/src/backend/utils/adt/ascii.c +++ b/src/backend/utils/adt/ascii.c @@ -1,7 +1,7 @@ /* ----------------------------------------------------------------------- * ascii.c * - * $Header: /cvsroot/pgsql/src/backend/utils/adt/ascii.c,v 1.12 2001/11/05 17:46:28 momjian Exp $ + * $Header: /cvsroot/pgsql/src/backend/utils/adt/ascii.c,v 1.13 2002/08/29 07:22:26 ishii Exp $ * * Portions Copyright (c) 1999-2000, PostgreSQL Global Development Group * @@ -18,46 +18,6 @@ #include "mb/pg_wchar.h" #include "utils/ascii.h" -/* ---------- - * even if MULTIBYTE is not enabled, these functions must exist - * since pg_proc.h has references to them. - * ---------- - */ -#ifndef MULTIBYTE - -static void multibyte_error(void); - -static void -multibyte_error(void) -{ - elog(ERROR, "Multi-byte support is not enabled"); -} - -Datum -to_ascii_encname(PG_FUNCTION_ARGS) -{ - multibyte_error(); - return 0; /* keep compiler quiet */ -} - -Datum -to_ascii_enc(PG_FUNCTION_ARGS) -{ - multibyte_error(); - return 0; /* keep compiler quiet */ -} - -Datum -to_ascii_default(PG_FUNCTION_ARGS) -{ - multibyte_error(); - return 0; /* keep compiler quiet */ -} - - -#else /* with MULTIBYTE */ - - static text *encode_to_ascii(text *data, int enc); /* ---------- @@ -190,5 +150,3 @@ to_ascii_default(PG_FUNCTION_ARGS) ) ); } - -#endif /* MULTIBYTE */ diff --git a/src/backend/utils/adt/format_type.c b/src/backend/utils/adt/format_type.c index 2aca3d7fc5fe0f8ebf00776fb81bcad864372d75..02e0dc8f27da50f6c4fa878df71e1cdc13e1c462 100644 --- a/src/backend/utils/adt/format_type.c +++ b/src/backend/utils/adt/format_type.c @@ -8,7 +8,7 @@ * Portions Copyright (c) 1994, Regents of the University of California * * IDENTIFICATION - * $Header: /cvsroot/pgsql/src/backend/utils/adt/format_type.c,v 1.32 2002/08/24 15:00:46 tgl Exp $ + * $Header: /cvsroot/pgsql/src/backend/utils/adt/format_type.c,v 1.33 2002/08/29 07:22:26 ishii Exp $ * *------------------------------------------------------------------------- */ @@ -25,9 +25,7 @@ #include "utils/numeric.h" #include "utils/lsyscache.h" #include "utils/syscache.h" -#ifdef MULTIBYTE #include "mb/pg_wchar.h" -#endif #define MAX_INT32_LEN 11 #define _textin(str) DirectFunctionCall1(textin, CStringGetDatum(str)) @@ -433,14 +431,11 @@ type_maximum_size(Oid type_oid, int32 typemod) case BPCHAROID: case VARCHAROID: /* typemod includes varlena header */ -#ifdef MULTIBYTE + /* typemod is in characters not bytes */ return (typemod - VARHDRSZ) * pg_encoding_max_length(GetDatabaseEncoding()) + VARHDRSZ; -#else - return typemod; -#endif case NUMERICOID: /* precision (ie, max # of digits) is in upper bits of typmod */ diff --git a/src/backend/utils/adt/like.c b/src/backend/utils/adt/like.c index 1ce4de6d99aac6b28a71328e48f188fadd84ae57..3e67e947a9d7ef900442c20929eb13d8c0a2c928 100644 --- a/src/backend/utils/adt/like.c +++ b/src/backend/utils/adt/like.c @@ -11,7 +11,7 @@ * Portions Copyright (c) 1994, Regents of the University of California * * IDENTIFICATION - * $Header: /cvsroot/pgsql/src/backend/utils/adt/like.c,v 1.50 2002/08/22 04:45:11 momjian Exp $ + * $Header: /cvsroot/pgsql/src/backend/utils/adt/like.c,v 1.51 2002/08/29 07:22:26 ishii Exp $ * *------------------------------------------------------------------------- */ @@ -19,9 +19,7 @@ #include <ctype.h> -#ifdef MULTIBYTE #include "mb/pg_wchar.h" -#endif #include "utils/builtins.h" @@ -38,7 +36,6 @@ static int MatchBytea(unsigned char *t, int tlen, unsigned char *p, int plen); static text *do_like_escape(text *, text *); -#ifdef MULTIBYTE static int MBMatchText(unsigned char *t, int tlen, unsigned char *p, int plen); static int MBMatchTextIC(unsigned char *t, int tlen, @@ -107,9 +104,7 @@ iwchareq(unsigned char *p1, unsigned char *p2) c2[0] = tolower(c2[0]); return (c1[0] == c2[0]); } -#endif -#ifdef MULTIBYTE #define CHAREQ(p1, p2) wchareq(p1, p2) #define ICHAREQ(p1, p2) iwchareq(p1, p2) #define NextChar(p, plen) \ @@ -132,7 +127,6 @@ iwchareq(unsigned char *p1, unsigned char *p2) #undef MatchText #undef MatchTextIC #undef do_like_escape -#endif #define CHAREQ(p1, p2) (*(p1) == *(p2)) #define ICHAREQ(p1, p2) (tolower(*(p1)) == tolower(*(p2))) @@ -164,14 +158,10 @@ namelike(PG_FUNCTION_ARGS) p = VARDATA(pat); plen = (VARSIZE(pat) - VARHDRSZ); -#ifdef MULTIBYTE if (pg_database_encoding_max_length() == 1) result = (MatchText(s, slen, p, plen) == LIKE_TRUE); else result = (MBMatchText(s, slen, p, plen) == LIKE_TRUE); -#else - result = (MatchText(s, slen, p, plen) == LIKE_TRUE); -#endif PG_RETURN_BOOL(result); } @@ -192,14 +182,10 @@ namenlike(PG_FUNCTION_ARGS) p = VARDATA(pat); plen = (VARSIZE(pat) - VARHDRSZ); -#ifdef MULTIBYTE if (pg_database_encoding_max_length() == 1) result = (MatchText(s, slen, p, plen) != LIKE_TRUE); else result = (MBMatchText(s, slen, p, plen) != LIKE_TRUE); -#else - result = (MatchText(s, slen, p, plen) != LIKE_TRUE); -#endif PG_RETURN_BOOL(result); } @@ -220,14 +206,10 @@ textlike(PG_FUNCTION_ARGS) p = VARDATA(pat); plen = (VARSIZE(pat) - VARHDRSZ); -#ifdef MULTIBYTE if (pg_database_encoding_max_length() == 1) result = (MatchText(s, slen, p, plen) == LIKE_TRUE); else result = (MBMatchText(s, slen, p, plen) == LIKE_TRUE); -#else - result = (MatchText(s, slen, p, plen) == LIKE_TRUE); -#endif PG_RETURN_BOOL(result); } @@ -248,14 +230,10 @@ textnlike(PG_FUNCTION_ARGS) p = VARDATA(pat); plen = (VARSIZE(pat) - VARHDRSZ); -#ifdef MULTIBYTE if (pg_database_encoding_max_length() == 1) result = (MatchText(s, slen, p, plen) != LIKE_TRUE); else result = (MBMatchText(s, slen, p, plen) != LIKE_TRUE); -#else - result = (MatchText(s, slen, p, plen) != LIKE_TRUE); -#endif PG_RETURN_BOOL(result); } @@ -322,14 +300,10 @@ nameiclike(PG_FUNCTION_ARGS) p = VARDATA(pat); plen = (VARSIZE(pat) - VARHDRSZ); -#ifdef MULTIBYTE if (pg_database_encoding_max_length() == 1) result = (MatchTextIC(s, slen, p, plen) == LIKE_TRUE); else result = (MBMatchTextIC(s, slen, p, plen) == LIKE_TRUE); -#else - result = (MatchTextIC(s, slen, p, plen) == LIKE_TRUE); -#endif PG_RETURN_BOOL(result); } @@ -350,14 +324,10 @@ nameicnlike(PG_FUNCTION_ARGS) p = VARDATA(pat); plen = (VARSIZE(pat) - VARHDRSZ); -#ifdef MULTIBYTE if (pg_database_encoding_max_length() == 1) result = (MatchTextIC(s, slen, p, plen) != LIKE_TRUE); else result = (MBMatchTextIC(s, slen, p, plen) != LIKE_TRUE); -#else - result = (MatchTextIC(s, slen, p, plen) != LIKE_TRUE); -#endif PG_RETURN_BOOL(result); } @@ -378,14 +348,10 @@ texticlike(PG_FUNCTION_ARGS) p = VARDATA(pat); plen = (VARSIZE(pat) - VARHDRSZ); -#ifdef MULTIBYTE if (pg_database_encoding_max_length() == 1) result = (MatchTextIC(s, slen, p, plen) == LIKE_TRUE); else result = (MBMatchTextIC(s, slen, p, plen) == LIKE_TRUE); -#else - result = (MatchTextIC(s, slen, p, plen) == LIKE_TRUE); -#endif PG_RETURN_BOOL(result); } @@ -406,14 +372,10 @@ texticnlike(PG_FUNCTION_ARGS) p = VARDATA(pat); plen = (VARSIZE(pat) - VARHDRSZ); -#ifdef MULTIBYTE if (pg_database_encoding_max_length() == 1) result = (MatchTextIC(s, slen, p, plen) != LIKE_TRUE); else result = (MBMatchTextIC(s, slen, p, plen) != LIKE_TRUE); -#else - result = (MatchTextIC(s, slen, p, plen) != LIKE_TRUE); -#endif PG_RETURN_BOOL(result); } @@ -429,14 +391,10 @@ like_escape(PG_FUNCTION_ARGS) text *esc = PG_GETARG_TEXT_P(1); text *result; -#ifdef MULTIBYTE if (pg_database_encoding_max_length() == 1) result = do_like_escape(pat, esc); else result = MB_do_like_escape(pat, esc); -#else - result = do_like_escape(pat, esc); -#endif PG_RETURN_TEXT_P(result); } diff --git a/src/backend/utils/adt/oracle_compat.c b/src/backend/utils/adt/oracle_compat.c index bd2d884b3fd0c1b682f40f626f81a8afff964780..e71604719f776f2cf88588f681c1cd9a099e12fa 100644 --- a/src/backend/utils/adt/oracle_compat.c +++ b/src/backend/utils/adt/oracle_compat.c @@ -9,7 +9,7 @@ * * * IDENTIFICATION - * $Header: /cvsroot/pgsql/src/backend/utils/adt/oracle_compat.c,v 1.41 2002/08/22 05:05:19 momjian Exp $ + * $Header: /cvsroot/pgsql/src/backend/utils/adt/oracle_compat.c,v 1.42 2002/08/29 07:22:27 ishii Exp $ * *------------------------------------------------------------------------- */ @@ -20,9 +20,7 @@ #include "utils/builtins.h" -#ifdef MULTIBYTE #include "mb/pg_wchar.h" -#endif /******************************************************************** * @@ -172,9 +170,7 @@ lpad(PG_FUNCTION_ARGS) s1len, s2len; -#ifdef MULTIBYTE int bytelen; -#endif /* Negative len is silently taken as zero */ if (len < 0) @@ -188,16 +184,14 @@ lpad(PG_FUNCTION_ARGS) if (s2len < 0) s2len = 0; /* shouldn't happen */ -#ifdef MULTIBYTE s1len = pg_mbstrlen_with_len(VARDATA(string1), s1len); -#endif + if (s1len > len) s1len = len; /* truncate string1 to len chars */ if (s2len <= 0) len = s1len; /* nothing to pad with, so don't pad */ -#ifdef MULTIBYTE bytelen = pg_database_encoding_max_length() * len; /* check for integer overflow */ @@ -205,16 +199,13 @@ lpad(PG_FUNCTION_ARGS) elog(ERROR, "Requested length too large"); ret = (text *) palloc(VARHDRSZ + bytelen); -#else - ret = (text *) palloc(VARHDRSZ + len); -#endif + m = len - s1len; ptr2 = VARDATA(string2); ptr2end = ptr2 + s2len; ptr_ret = VARDATA(ret); -#ifdef MULTIBYTE while (m--) { int mlen = pg_mblen(ptr2); @@ -225,18 +216,9 @@ lpad(PG_FUNCTION_ARGS) if (ptr2 == ptr2end) /* wrap around at end of s2 */ ptr2 = VARDATA(string2); } -#else - while (m--) - { - *ptr_ret++ = *ptr2++; - if (ptr2 == ptr2end) /* wrap around at end of s2 */ - ptr2 = VARDATA(string2); - } -#endif ptr1 = VARDATA(string1); -#ifdef MULTIBYTE while (s1len--) { int mlen = pg_mblen(ptr1); @@ -245,10 +227,6 @@ lpad(PG_FUNCTION_ARGS) ptr_ret += mlen; ptr1 += mlen; } -#else - while (s1len--) - *ptr_ret++ = *ptr1++; -#endif VARATT_SIZEP(ret) = ptr_ret - (char *) ret; @@ -287,9 +265,7 @@ rpad(PG_FUNCTION_ARGS) s1len, s2len; -#ifdef MULTIBYTE int bytelen; -#endif /* Negative len is silently taken as zero */ if (len < 0) @@ -303,9 +279,7 @@ rpad(PG_FUNCTION_ARGS) if (s2len < 0) s2len = 0; /* shouldn't happen */ -#ifdef MULTIBYTE s1len = pg_mbstrlen_with_len(VARDATA(string1), s1len); -#endif if (s1len > len) s1len = len; /* truncate string1 to len chars */ @@ -313,7 +287,6 @@ rpad(PG_FUNCTION_ARGS) if (s2len <= 0) len = s1len; /* nothing to pad with, so don't pad */ -#ifdef MULTIBYTE bytelen = pg_database_encoding_max_length() * len; /* Check for integer overflow */ @@ -321,15 +294,11 @@ rpad(PG_FUNCTION_ARGS) elog(ERROR, "Requested length too large"); ret = (text *) palloc(VARHDRSZ + bytelen); -#else - ret = (text *) palloc(VARHDRSZ + len); -#endif m = len - s1len; ptr1 = VARDATA(string1); ptr_ret = VARDATA(ret); -#ifdef MULTIBYTE while (s1len--) { int mlen = pg_mblen(ptr1); @@ -338,15 +307,10 @@ rpad(PG_FUNCTION_ARGS) ptr_ret += mlen; ptr1 += mlen; } -#else - while (s1len--) - *ptr_ret++ = *ptr1++; -#endif ptr2 = VARDATA(string2); ptr2end = ptr2 + s2len; -#ifdef MULTIBYTE while (m--) { int mlen = pg_mblen(ptr2); @@ -357,14 +321,6 @@ rpad(PG_FUNCTION_ARGS) if (ptr2 == ptr2end) /* wrap around at end of s2 */ ptr2 = VARDATA(string2); } -#else - while (m--) - { - *ptr_ret++ = *ptr2++; - if (ptr2 == ptr2end) /* wrap around at end of s2 */ - ptr2 = VARDATA(string2); - } -#endif VARATT_SIZEP(ret) = ptr_ret - (char *) ret; @@ -399,13 +355,11 @@ btrim(PG_FUNCTION_ARGS) *end2; int m; -#ifdef MULTIBYTE char **mp; int mplen; char *p; int mblen; int len; -#endif if ((m = VARSIZE(string) - VARHDRSZ) <= 0 || (VARSIZE(set) - VARHDRSZ) <= 0) @@ -413,7 +367,6 @@ btrim(PG_FUNCTION_ARGS) ptr = VARDATA(string); -#ifdef MULTIBYTE len = m; mp = (char **) palloc(len * sizeof(char *)); p = ptr; @@ -428,12 +381,8 @@ btrim(PG_FUNCTION_ARGS) len -= mblen; } mplen--; -#else - end = VARDATA(string) + VARSIZE(string) - VARHDRSZ - 1; -#endif end2 = VARDATA(set) + VARSIZE(set) - VARHDRSZ - 1; -#ifdef MULTIBYTE while (m > 0) { int str_len = pg_mblen(ptr); @@ -475,37 +424,6 @@ btrim(PG_FUNCTION_ARGS) m -= str_len; } pfree(mp); -#else - while (m > 0) - { - ptr2 = VARDATA(set); - while (ptr2 <= end2) - { - if (*ptr == *ptr2) - break; - ++ptr2; - } - if (ptr2 > end2) - break; - ptr++; - m--; - } - - while (m > 0) - { - ptr2 = VARDATA(set); - while (ptr2 <= end2) - { - if (*end == *ptr2) - break; - ++ptr2; - } - if (ptr2 > end2) - break; - end--; - m--; - } -#endif ret = (text *) palloc(VARHDRSZ + m); VARATT_SIZEP(ret) = VARHDRSZ + m; memcpy(VARDATA(ret), ptr, m); @@ -619,7 +537,6 @@ ltrim(PG_FUNCTION_ARGS) ptr = VARDATA(string); end2 = VARDATA(set) + VARSIZE(set) - VARHDRSZ - 1; -#ifdef MULTIBYTE while (m > 0) { int str_len = pg_mblen(ptr); @@ -639,22 +556,6 @@ ltrim(PG_FUNCTION_ARGS) ptr += str_len; m -= str_len; } -#else - while (m > 0) - { - ptr2 = VARDATA(set); - while (ptr2 <= end2) - { - if (*ptr == *ptr2) - break; - ++ptr2; - } - if (ptr2 > end2) - break; - ptr++; - m--; - } -#endif ret = (text *) palloc(VARHDRSZ + m); VARATT_SIZEP(ret) = VARHDRSZ + m; memcpy(VARDATA(ret), ptr, m); @@ -691,13 +592,11 @@ rtrim(PG_FUNCTION_ARGS) *end2; int m; -#ifdef MULTIBYTE char **mp; int mplen; char *p; int mblen; int len; -#endif if ((m = VARSIZE(string) - VARHDRSZ) <= 0 || (VARSIZE(set) - VARHDRSZ) <= 0) @@ -705,7 +604,6 @@ rtrim(PG_FUNCTION_ARGS) ptr = VARDATA(string); -#ifdef MULTIBYTE len = m; mp = (char **) palloc(len * sizeof(char *)); p = ptr; @@ -720,12 +618,8 @@ rtrim(PG_FUNCTION_ARGS) len -= mblen; } mplen--; -#else - end = VARDATA(string) + VARSIZE(string) - VARHDRSZ - 1; -#endif end2 = VARDATA(set) + VARSIZE(set) - VARHDRSZ - 1; -#ifdef MULTIBYTE while (m > 0) { int str_len; @@ -747,22 +641,6 @@ rtrim(PG_FUNCTION_ARGS) m -= str_len; } pfree(mp); -#else - while (m > 0) - { - ptr2 = VARDATA(set); - while (ptr2 <= end2) - { - if (*end == *ptr2) - break; - ++ptr2; - } - if (ptr2 > end2) - break; - end--; - m--; - } -#endif ret = (text *) palloc(VARHDRSZ + m); VARATT_SIZEP(ret) = VARHDRSZ + m; memcpy(VARDATA(ret), ptr, m); @@ -805,13 +683,11 @@ translate(PG_FUNCTION_ARGS) retlen, i; -#ifdef MULTIBYTE int str_len; int estimate_len; int len; int source_len; int from_index; -#endif if ((m = VARSIZE(string) - VARHDRSZ) <= 0) PG_RETURN_TEXT_P(string); @@ -821,20 +697,15 @@ translate(PG_FUNCTION_ARGS) tolen = VARSIZE(to) - VARHDRSZ; to_ptr = VARDATA(to); -#ifdef MULTIBYTE str_len = VARSIZE(string); estimate_len = (tolen * 1.0 / fromlen + 0.5) * str_len; estimate_len = estimate_len > str_len ? estimate_len : str_len; result = (text *) palloc(estimate_len); -#else - result = (text *) palloc(VARSIZE(string)); -#endif source = VARDATA(string); target = VARDATA(result); retlen = 0; -#ifdef MULTIBYTE while (m > 0) { source_len = pg_mblen(source); @@ -880,37 +751,6 @@ translate(PG_FUNCTION_ARGS) source += source_len; m -= source_len; } -#else - while (m-- > 0) - { - char rep = *source++; - - for (i = 0; i < fromlen; i++) - { - if (from_ptr[i] == rep) - break; - } - if (i < fromlen) - { - if (i < tolen) - { - /* substitute */ - *target++ = to_ptr[i]; - retlen++; - } - else - { - /* discard */ - } - } - else - { - /* no match, so copy */ - *target++ = rep; - retlen++; - } - } -#endif VARATT_SIZEP(result) = retlen + VARHDRSZ; diff --git a/src/backend/utils/adt/quote.c b/src/backend/utils/adt/quote.c index 537e97a50eec3438752d1c57c09196cd839266e1..97946866d011eaf31b794a187458f7fbe837102e 100644 --- a/src/backend/utils/adt/quote.c +++ b/src/backend/utils/adt/quote.c @@ -7,7 +7,7 @@ * * * IDENTIFICATION - * $Header: /cvsroot/pgsql/src/backend/utils/adt/quote.c,v 1.7 2002/04/04 04:25:49 momjian Exp $ + * $Header: /cvsroot/pgsql/src/backend/utils/adt/quote.c,v 1.8 2002/08/29 07:22:27 ishii Exp $ * *------------------------------------------------------------------------- */ @@ -70,102 +70,6 @@ quote_literal(PG_FUNCTION_ARGS) * */ - -#ifndef MULTIBYTE - -/* Check if a given identifier needs quoting */ -static bool -quote_ident_required(text *iptr) -{ - char *cp; - char *ep; - - cp = VARDATA(iptr); - ep = VARDATA(iptr) + VARSIZE(iptr) - VARHDRSZ; - - if (cp >= ep) - return true; - - if (!(*cp == '_' || (*cp >= 'a' && *cp <= 'z'))) - return true; - - while ((++cp) < ep) - { - if (*cp >= 'a' && *cp <= 'z') - continue; - if (*cp >= '0' && *cp <= '9') - continue; - if (*cp == '_') - continue; - - return true; - } - - return false; -} - -/* Return a properly quoted identifier */ -static text * -do_quote_ident(text *iptr) -{ - text *result; - char *cp1; - char *cp2; - int len; - - len = VARSIZE(iptr) - VARHDRSZ; - result = (text *) palloc(len * 2 + VARHDRSZ + 2); - - cp1 = VARDATA(iptr); - cp2 = VARDATA(result); - - *cp2++ = '"'; - while (len-- > 0) - { - if (*cp1 == '"') - *cp2++ = '"'; - *cp2++ = *cp1++; - } - *cp2++ = '"'; - - VARATT_SIZEP(result) = cp2 - ((char *) result); - - return result; -} - -/* Return a properly quoted literal value */ -static text * -do_quote_literal(text *lptr) -{ - text *result; - char *cp1; - char *cp2; - int len; - - len = VARSIZE(lptr) - VARHDRSZ; - result = (text *) palloc(len * 2 + VARHDRSZ + 2); - - cp1 = VARDATA(lptr); - cp2 = VARDATA(result); - - *cp2++ = '\''; - while (len-- > 0) - { - if (*cp1 == '\'') - *cp2++ = '\''; - if (*cp1 == '\\') - *cp2++ = '\\'; - *cp2++ = *cp1++; - } - *cp2++ = '\''; - - VARATT_SIZEP(result) = cp2 - ((char *) result); - - return result; -} - -#else - /* Check if a given identifier needs quoting (MULTIBYTE version) */ static bool quote_ident_required(text *iptr) @@ -285,5 +189,3 @@ do_quote_literal(text *lptr) return result; } - -#endif diff --git a/src/backend/utils/adt/selfuncs.c b/src/backend/utils/adt/selfuncs.c index 986c7659f2ceb4c815f04b92a9b6af65ce1b813e..4835b0c3a5e339a7aecfe2d9dcb44113711b6a2e 100644 --- a/src/backend/utils/adt/selfuncs.c +++ b/src/backend/utils/adt/selfuncs.c @@ -15,7 +15,7 @@ * * * IDENTIFICATION - * $Header: /cvsroot/pgsql/src/backend/utils/adt/selfuncs.c,v 1.113 2002/08/22 00:01:44 tgl Exp $ + * $Header: /cvsroot/pgsql/src/backend/utils/adt/selfuncs.c,v 1.114 2002/08/29 07:22:27 ishii Exp $ * *------------------------------------------------------------------------- */ @@ -3250,12 +3250,8 @@ make_greater_string(const char *str, Oid datatype) * Truncate off the last character, which might be more than 1 * byte in MULTIBYTE case. */ -#ifdef MULTIBYTE len = pg_mbcliplen((const unsigned char *) workstr, len, len - 1); workstr[len] = '\0'; -#else - *lastchar = '\0'; -#endif } /* Failed... */ diff --git a/src/backend/utils/adt/varchar.c b/src/backend/utils/adt/varchar.c index cdf5c301d2e88a4bd2aafae3620f929ea11fd681..e1181dd375f49f44c14527cd99175387f75cd12a 100644 --- a/src/backend/utils/adt/varchar.c +++ b/src/backend/utils/adt/varchar.c @@ -8,7 +8,7 @@ * * * IDENTIFICATION - * $Header: /cvsroot/pgsql/src/backend/utils/adt/varchar.c,v 1.91 2002/08/26 17:53:59 tgl Exp $ + * $Header: /cvsroot/pgsql/src/backend/utils/adt/varchar.c,v 1.92 2002/08/29 07:22:27 ishii Exp $ * *------------------------------------------------------------------------- */ @@ -21,9 +21,7 @@ #include "utils/builtins.h" #include "utils/fmgroids.h" -#ifdef MULTIBYTE #include "mb/pg_wchar.h" -#endif /* @@ -76,37 +74,26 @@ bpcharin(PG_FUNCTION_ARGS) maxlen; int i; -#ifdef MULTIBYTE int charlen; /* number of charcters in the input string */ char *ermsg; -#endif len = strlen(s); -#ifdef MULTIBYTE + if ((ermsg = pg_verifymbstr(s, len))) elog(ERROR, "%s", ermsg); charlen = pg_mbstrlen(s); -#endif + /* If typmod is -1 (or invalid), use the actual string length */ if (atttypmod < (int32) VARHDRSZ) -#ifdef MULTIBYTE maxlen = charlen; -#else - maxlen = len; -#endif else maxlen = atttypmod - VARHDRSZ; -#ifdef MULTIBYTE if (charlen > maxlen) -#else - if (len > maxlen) -#endif { /* Verify that extra characters are spaces, and clip them off */ -#ifdef MULTIBYTE size_t mbmaxlen = pg_mbcharcliplen(s, len, maxlen); /* @@ -125,15 +112,7 @@ bpcharin(PG_FUNCTION_ARGS) * the number of CHARACTERS! */ maxlen = len; -#else - if (strspn(s + maxlen, " ") == len - maxlen) - len = maxlen; - else - elog(ERROR, "value too long for type character(%d)", - (int) maxlen); -#endif } -#ifdef MULTIBYTE else { /* @@ -142,7 +121,6 @@ bpcharin(PG_FUNCTION_ARGS) */ maxlen = len + (maxlen - charlen); } -#endif result = palloc(maxlen + VARHDRSZ); VARATT_SIZEP(result) = maxlen + VARHDRSZ; @@ -202,26 +180,19 @@ bpchar(PG_FUNCTION_ARGS) char *s; int i; -#ifdef MULTIBYTE int charlen; /* number of charcters in the input string * + VARHDRSZ */ -#endif - len = VARSIZE(source); -#ifdef MULTIBYTE + charlen = pg_mbstrlen_with_len(VARDATA(source), len - VARHDRSZ) + VARHDRSZ; -#endif + /* No work if typmod is invalid or supplied data matches it already */ if (maxlen < (int32) VARHDRSZ || len == maxlen) PG_RETURN_BPCHAR_P(source); -#ifdef MULTIBYTE + if (charlen > maxlen) -#else - if (len > maxlen) -#endif { /* Verify that extra characters are spaces, and clip them off */ -#ifdef MULTIBYTE size_t maxmblen; maxmblen = pg_mbcharcliplen(VARDATA(source), len - VARHDRSZ, @@ -239,16 +210,7 @@ bpchar(PG_FUNCTION_ARGS) * length+VARHDRSZ, not the number of CHARACTERS! */ maxlen = len; -#else - for (i = maxlen - VARHDRSZ; i < len - VARHDRSZ; i++) - if (*(VARDATA(source) + i) != ' ') - elog(ERROR, "value too long for type character(%d)", - maxlen - VARHDRSZ); - - len = maxlen; -#endif } -#ifdef MULTIBYTE else { /* @@ -257,7 +219,6 @@ bpchar(PG_FUNCTION_ARGS) */ maxlen = len + (maxlen - charlen); } -#endif s = VARDATA(source); @@ -408,29 +369,22 @@ varcharin(PG_FUNCTION_ARGS) size_t len, maxlen; -#ifdef MULTIBYTE char *ermsg; -#endif len = strlen(s); -#ifdef MULTIBYTE + if ((ermsg = pg_verifymbstr(s, len))) elog(ERROR, "%s", ermsg); -#endif + maxlen = atttypmod - VARHDRSZ; if (atttypmod >= (int32) VARHDRSZ && len > maxlen) { /* Verify that extra characters are spaces, and clip them off */ -#ifdef MULTIBYTE size_t mbmaxlen = pg_mbcharcliplen(s, len, maxlen); if (strspn(s + mbmaxlen, " ") == len - mbmaxlen) len = mbmaxlen; -#else - if (strspn(s + maxlen, " ") == len - maxlen) - len = maxlen; -#endif else elog(ERROR, "value too long for type character varying(%d)", (int) maxlen); @@ -493,7 +447,6 @@ varchar(PG_FUNCTION_ARGS) /* only reach here if string is too long... */ -#ifdef MULTIBYTE { size_t maxmblen; @@ -508,15 +461,6 @@ varchar(PG_FUNCTION_ARGS) len = maxmblen; } -#else - for (i = maxlen - VARHDRSZ; i < len - VARHDRSZ; i++) - if (*(VARDATA(source) + i) != ' ') - elog(ERROR, "value too long for type character varying(%d)", - maxlen - VARHDRSZ); - - /* clip extra spaces */ - len = maxlen; -#endif result = palloc(len); VARATT_SIZEP(result) = len; @@ -584,7 +528,6 @@ bpcharlen(PG_FUNCTION_ARGS) { BpChar *arg = PG_GETARG_BPCHAR_P(0); -#ifdef MULTIBYTE /* optimization for single byte encoding */ if (pg_database_encoding_max_length() <= 1) PG_RETURN_INT32(VARSIZE(arg) - VARHDRSZ); @@ -592,9 +535,6 @@ bpcharlen(PG_FUNCTION_ARGS) PG_RETURN_INT32( pg_mbstrlen_with_len(VARDATA(arg), VARSIZE(arg) - VARHDRSZ) ); -#else - PG_RETURN_INT32(VARSIZE(arg) - VARHDRSZ); -#endif } Datum @@ -796,7 +736,6 @@ varcharlen(PG_FUNCTION_ARGS) { VarChar *arg = PG_GETARG_VARCHAR_P(0); -#ifdef MULTIBYTE /* optimization for single byte encoding */ if (pg_database_encoding_max_length() <= 1) PG_RETURN_INT32(VARSIZE(arg) - VARHDRSZ); @@ -804,9 +743,6 @@ varcharlen(PG_FUNCTION_ARGS) PG_RETURN_INT32( pg_mbstrlen_with_len(VARDATA(arg), VARSIZE(arg) - VARHDRSZ) ); -#else - PG_RETURN_INT32(VARSIZE(arg) - VARHDRSZ); -#endif } Datum diff --git a/src/backend/utils/adt/varlena.c b/src/backend/utils/adt/varlena.c index 52598aba9e88f4f14c634b3de788618566ea6671..6e00a3e28359687fce7cf89306bc1f00fbcca365 100644 --- a/src/backend/utils/adt/varlena.c +++ b/src/backend/utils/adt/varlena.c @@ -8,7 +8,7 @@ * * * IDENTIFICATION - * $Header: /cvsroot/pgsql/src/backend/utils/adt/varlena.c,v 1.89 2002/08/28 20:46:24 momjian Exp $ + * $Header: /cvsroot/pgsql/src/backend/utils/adt/varlena.c,v 1.90 2002/08/29 07:22:27 ishii Exp $ * *------------------------------------------------------------------------- */ @@ -217,16 +217,12 @@ textin(PG_FUNCTION_ARGS) text *result; int len; -#ifdef MULTIBYTE char *ermsg; -#endif len = strlen(inputText) + VARHDRSZ; -#ifdef MULTIBYTE if ((ermsg = pg_verifymbstr(inputText, len - VARHDRSZ))) elog(ERROR, "%s", ermsg); -#endif result = (text *) palloc(len); VARATT_SIZEP(result) = len; @@ -1476,12 +1472,8 @@ SplitIdentifierString(char *rawstring, char separator, curlen = strlen(curname); if (curlen >= NAMEDATALEN) { -#ifdef MULTIBYTE curlen = pg_mbcliplen(curname, curlen, NAMEDATALEN - 1); curname[curlen] = '\0'; -#else - curname[NAMEDATALEN - 1] = '\0'; -#endif } /* diff --git a/src/backend/utils/error/elog.c b/src/backend/utils/error/elog.c index d26e55368db83deb540e81669bb2e894a775794d..fdd4388e5ca0f080478d5112c1b3f75a39fedc83 100644 --- a/src/backend/utils/error/elog.c +++ b/src/backend/utils/error/elog.c @@ -8,7 +8,7 @@ * * * IDENTIFICATION - * $Header: /cvsroot/pgsql/src/backend/utils/error/elog.c,v 1.99 2002/06/20 20:29:39 momjian Exp $ + * $Header: /cvsroot/pgsql/src/backend/utils/error/elog.c,v 1.100 2002/08/29 07:22:28 ishii Exp $ * *------------------------------------------------------------------------- */ @@ -35,9 +35,7 @@ #include "tcop/tcopprot.h" #include "utils/memutils.h" -#ifdef MULTIBYTE #include "mb/pg_wchar.h" -#endif int server_min_messages; char *server_min_messages_str = NULL; @@ -694,14 +692,14 @@ write_syslog(int level, const char *line) *strchr(buf, '\n') = '\0'; l = strlen(buf); -#ifdef MULTIBYTE + /* trim to multibyte letter boundary */ buflen = pg_mbcliplen(buf, l, l); if (buflen <= 0) return; buf[buflen] = '\0'; l = strlen(buf); -#endif + /* already word boundary? */ if (isspace((unsigned char) line[l]) || line[l] == '\0') buflen = l; diff --git a/src/backend/utils/init/postinit.c b/src/backend/utils/init/postinit.c index 433b9a5ed052ac3df12627949299e73bfe75eae9..f36c1d981fa08c6a2721b44f7c47b2a9e7737aa8 100644 --- a/src/backend/utils/init/postinit.c +++ b/src/backend/utils/init/postinit.c @@ -8,7 +8,7 @@ * * * IDENTIFICATION - * $Header: /cvsroot/pgsql/src/backend/utils/init/postinit.c,v 1.109 2002/07/20 05:16:59 momjian Exp $ + * $Header: /cvsroot/pgsql/src/backend/utils/init/postinit.c,v 1.110 2002/08/29 07:22:28 ishii Exp $ * * *------------------------------------------------------------------------- @@ -130,17 +130,10 @@ ReverifyMyDatabase(const char *name) * encoding info out of the pg_database tuple --- or complain, if we * can't support it. */ -#ifdef MULTIBYTE SetDatabaseEncoding(dbform->encoding); /* If we have no other source of client_encoding, use server encoding */ SetConfigOption("client_encoding", GetDatabaseEncodingName(), PGC_BACKEND, PGC_S_DEFAULT); -#else - if (dbform->encoding != PG_SQL_ASCII) - elog(FATAL, "database was initialized with MULTIBYTE encoding %d,\n\tbut the backend was compiled without multibyte support.\n\tlooks like you need to initdb or recompile.", - dbform->encoding); -#endif - /* * Set up database-specific configuration variables. */ diff --git a/src/backend/utils/mb/mbutils.c b/src/backend/utils/mb/mbutils.c index 4b77dcfa6a1b1ed96d19f711b3034b2df897d7e0..ef96f7d04b4b2ea97e7afa65c16dc2619ed83638 100644 --- a/src/backend/utils/mb/mbutils.c +++ b/src/backend/utils/mb/mbutils.c @@ -3,7 +3,7 @@ * client encoding and server internal encoding. * (currently mule internal code (mic) is used) * Tatsuo Ishii - * $Id: mbutils.c,v 1.32 2002/08/19 04:08:08 ishii Exp $ + * $Id: mbutils.c,v 1.33 2002/08/29 07:22:28 ishii Exp $ */ #include "postgres.h" #include "access/xact.h" @@ -34,6 +34,9 @@ static FmgrInfo *ToClientConvPorc = NULL; static unsigned char * perform_default_encoding_conversion(unsigned char *src, int len, bool is_client_to_server); +static int +cliplen(const unsigned char *str, int len, int limit); + /* * Set the client encoding and save fmgrinfo for the converion * function if necessary. if encoding conversion between client/server @@ -371,6 +374,10 @@ pg_mbstrlen(const unsigned char *mbstr) { int len = 0; + /* optimization for single byte encoding */ + if (pg_database_encoding_max_length() == 1) + return strlen((char *)mbstr); + while (*mbstr) { mbstr += pg_mblen(mbstr); @@ -409,6 +416,10 @@ pg_mbcliplen(const unsigned char *mbstr, int len, int limit) int clen = 0; int l; + /* optimization for single byte encoding */ + if (pg_database_encoding_max_length() == 1) + return cliplen(mbstr, len, limit); + while (len > 0 && *mbstr) { l = pg_mblen(mbstr); @@ -424,7 +435,7 @@ pg_mbcliplen(const unsigned char *mbstr, int len, int limit) } /* - * Similar to pg_mbcliplen but the limit parameter specifies the + * Similar to pg_mbcliplen except the limit parameter specifies the * character length, not the byte length. */ int pg_mbcharcliplen(const unsigned char *mbstr, int len, int limit) @@ -433,6 +444,10 @@ pg_mbcharcliplen(const unsigned char *mbstr, int len, int limit) int nch = 0; int l; + /* optimization for single byte encoding */ + if (pg_database_encoding_max_length() == 1) + return cliplen(mbstr, len, limit); + while (len > 0 && *mbstr) { l = pg_mblen(mbstr); @@ -489,3 +504,17 @@ pg_client_encoding(PG_FUNCTION_ARGS) Assert(ClientEncoding); return DirectFunctionCall1(namein, CStringGetDatum(ClientEncoding->name)); } + +static int +cliplen(const unsigned char *str, int len, int limit) +{ + int l = 0; + const unsigned char *s; + + for (s = str; *s; s++, l++) + { + if (l >= len || l >= limit) + return l; + } + return (s - str); +} diff --git a/src/include/regex/regex.h b/src/include/regex/regex.h index dd8e0da171bd61491535dbf9ab4921e07d1c70d7..cf20160b6d90d6622f15c2114f35629ef87644be 100644 --- a/src/include/regex/regex.h +++ b/src/include/regex/regex.h @@ -52,10 +52,7 @@ typedef struct size_t re_nsub; /* number of parenthesized subexpressions */ const pg_wchar *re_endp; /* end pointer for REG_PEND */ struct re_guts *re_g; /* none of your business :-) */ -#ifdef MULTIBYTE pg_wchar *patsave; /* me too :-) */ -#endif - } regex_t; typedef struct diff --git a/src/include/regex/regex2.h b/src/include/regex/regex2.h index 98bf46a52e3d42c4eb58175519e5e2c0e64f096f..5ceed7fe9c0ea978ca2f5f112393bf0cae5b9637 100644 --- a/src/include/regex/regex2.h +++ b/src/include/regex/regex2.h @@ -113,18 +113,13 @@ typedef struct { uch *ptr; /* -> uch [csetsize] */ uch mask; /* bit within array */ -#ifdef MULTIBYTE pg_wchar hash; /* hash code */ unsigned int lc; /* leading character (character-set) */ -#else - uch hash; /* hash code */ -#endif size_t smultis; char *multis; /* -> char[smulti] ab\0cd\0ef\0\0 */ } cset; /* note that CHadd and CHsub are unsafe, and CHIN doesn't yield 0/1 */ -#ifdef MULTIBYTE #define CHlc(c) (((unsigned)(c)&0xff0000)>>16) #define CHadd(cs, c) ((cs)->ptr[(unsigned)(c)&0xffff] |= (cs)->mask, (cs)->hash += (unsigned)(c)&0xffff,\ (cs)->lc = CHlc(c)) @@ -135,15 +130,6 @@ typedef struct * fns */ #define MCsub(p, cs, cp) mcsub(p, cs, cp) #define MCin(p, cs, cp) mcin(p, cs, cp) -#else -#define CHadd(cs, c) ((cs)->ptr[(uch)(c)] |= (cs)->mask, (cs)->hash += (c)) -#define CHsub(cs, c) ((cs)->ptr[(uch)(c)] &= ~(cs)->mask, (cs)->hash -= (c)) -#define CHIN(cs, c) ((cs)->ptr[(uch)(c)] & (cs)->mask) -#define MCadd(p, cs, cp) mcadd(p, cs, cp) /* regcomp() internal - * fns */ -#define MCsub(p, cs, cp) mcsub(p, cs, cp) -#define MCin(p, cs, cp) mcin(p, cs, cp) -#endif /* stuff for character categories */ typedef unsigned char cat_t; @@ -182,16 +168,7 @@ struct re_guts }; /* misc utilities */ -#ifdef MULTIBYTE #define OUT (16777216+1) /* 16777216 == 2^24 == 3 bytes */ -#else -#define OUT (CHAR_MAX+1) /* a non-character value */ -#endif -#ifdef MULTIBYTE #define ISWORD(c) (((c) >= 0 && (c) <= UCHAR_MAX) && \ (isalnum((unsigned char) (c)) || (c) == '_')) -#else -#define ISWORD(c) (isalnum((unsigned char) (c)) || (c) == '_') - -#endif diff --git a/src/include/regex/utils.h b/src/include/regex/utils.h index 282bb791ad6572f8fe01e50a6fc5b6fa9e09555d..5831122f7c9167957be2ea2c93791149ed7c0940 100644 --- a/src/include/regex/utils.h +++ b/src/include/regex/utils.h @@ -46,11 +46,7 @@ #define DUPMAX 100000000 /* xxx is this right? */ #define INFINITY (DUPMAX + 1) -#ifdef MULTIBYTE #define NC (SHRT_MAX - SHRT_MIN + 1) -#else -#define NC (CHAR_MAX - CHAR_MIN + 1) -#endif typedef unsigned char uch; diff --git a/src/include/utils/ascii.h b/src/include/utils/ascii.h index 068cf61a6c9695217d6c92af246bd76addd38a56..a2a983f242865a619c02bbe088c8c381b502518c 100644 --- a/src/include/utils/ascii.h +++ b/src/include/utils/ascii.h @@ -2,7 +2,7 @@ /* ----------------------------------------------------------------------- * ascii.h * - * $Id: ascii.h,v 1.8 2001/11/05 17:46:36 momjian Exp $ + * $Id: ascii.h,v 1.9 2002/08/29 07:22:29 ishii Exp $ * * Portions Copyright (c) 1999-2000, PostgreSQL Global Development Group * @@ -18,10 +18,7 @@ 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_ */ diff --git a/src/include/utils/builtins.h b/src/include/utils/builtins.h index 6f33ee4e42c9a541d8aa563d4d2754f20826c9c2..33467c2ff03e3e73582b6df20b02352bf4892b0b 100644 --- a/src/include/utils/builtins.h +++ b/src/include/utils/builtins.h @@ -7,7 +7,7 @@ * Portions Copyright (c) 1996-2002, PostgreSQL Global Development Group * Portions Copyright (c) 1994, Regents of the University of California * - * $Id: builtins.h,v 1.196 2002/08/29 00:17:06 tgl Exp $ + * $Id: builtins.h,v 1.197 2002/08/29 07:22:29 ishii Exp $ * *------------------------------------------------------------------------- */ @@ -661,9 +661,7 @@ extern Datum RI_FKey_setnull_upd(PG_FUNCTION_ARGS); extern Datum RI_FKey_setdefault_del(PG_FUNCTION_ARGS); extern Datum RI_FKey_setdefault_upd(PG_FUNCTION_ARGS); -/* even if MULTIBYTE is not enabled, these functions are necessary - * since pg_proc.h has references to them. - */ +/* multibyte support functions */ extern Datum getdatabaseencoding(PG_FUNCTION_ARGS); extern Datum database_character_set(PG_FUNCTION_ARGS); extern Datum pg_client_encoding(PG_FUNCTION_ARGS); diff --git a/src/interfaces/libpq/fe-connect.c b/src/interfaces/libpq/fe-connect.c index 6ccc702c99440942d339077637c8899513557297..3272de9be5f0e5fa7627a80e4fcff59cb3ed94c6 100644 --- a/src/interfaces/libpq/fe-connect.c +++ b/src/interfaces/libpq/fe-connect.c @@ -8,7 +8,7 @@ * * * IDENTIFICATION - * $Header: /cvsroot/pgsql/src/interfaces/libpq/fe-connect.c,v 1.197 2002/08/27 16:21:51 momjian Exp $ + * $Header: /cvsroot/pgsql/src/interfaces/libpq/fe-connect.c,v 1.198 2002/08/29 07:22:29 ishii Exp $ * *------------------------------------------------------------------------- */ @@ -45,9 +45,7 @@ #include <crypt.h> #endif -#ifdef MULTIBYTE #include "mb/pg_wchar.h" -#endif #ifdef WIN32 static int @@ -157,11 +155,9 @@ static const struct EnvironmentOptions { "PGTZ", "timezone" }, -#ifdef MULTIBYTE { "PGCLIENTENCODING", "client_encoding" }, -#endif /* internal performance-related settings */ { "PGGEQO", "geqo" @@ -1584,12 +1580,7 @@ PQsetenvStart(PGconn *conn) conn->setenv_state != SETENV_STATE_IDLE) return false; -#ifdef MULTIBYTE conn->setenv_state = SETENV_STATE_ENCODINGS_SEND; -#else - conn->setenv_state = SETENV_STATE_OPTION_SEND; -#endif - conn->next_eo = EnvironmentOptions; return true; @@ -1606,9 +1597,7 @@ PQsetenvPoll(PGconn *conn) { PGresult *res; -#ifdef MULTIBYTE static const char envname[] = "PGCLIENTENCODING"; -#endif if (conn == NULL || conn->status == CONNECTION_BAD) return PGRES_POLLING_FAILED; @@ -1617,9 +1606,7 @@ PQsetenvPoll(PGconn *conn) switch (conn->setenv_state) { /* These are reading states */ -#ifdef MULTIBYTE case SETENV_STATE_ENCODINGS_WAIT: -#endif case SETENV_STATE_OPTION_WAIT: { /* Load waiting data */ @@ -1634,9 +1621,7 @@ PQsetenvPoll(PGconn *conn) } /* These are writing states, so we just proceed. */ -#ifdef MULTIBYTE case SETENV_STATE_ENCODINGS_SEND: -#endif case SETENV_STATE_OPTION_SEND: break; @@ -1660,7 +1645,6 @@ keep_going: /* We will come back to here until there switch (conn->setenv_state) { -#ifdef MULTIBYTE case SETENV_STATE_ENCODINGS_SEND: { const char *env; @@ -1734,7 +1718,6 @@ keep_going: /* We will come back to here until there conn->setenv_state = SETENV_STATE_OPTION_SEND; goto keep_going; } -#endif case SETENV_STATE_OPTION_SEND: { @@ -2788,9 +2771,6 @@ PQclientEncoding(const PGconn *conn) int PQsetClientEncoding(PGconn *conn, const char *encoding) { - -#ifdef MULTIBYTE - char qbuf[128]; static char query[] = "set client_encoding to '%s'"; PGresult *res; @@ -2822,9 +2802,6 @@ PQsetClientEncoding(PGconn *conn, const char *encoding) } PQclear(res); return (status); -#else - return -1; /* Multibyte support isn't compiled in */ -#endif } void diff --git a/src/interfaces/libpq/fe-misc.c b/src/interfaces/libpq/fe-misc.c index be91d796c083d047b0d5b0755ef3771f78bbf7f4..8e40a531c287855668b0eab076d3732bac1a67b1 100644 --- a/src/interfaces/libpq/fe-misc.c +++ b/src/interfaces/libpq/fe-misc.c @@ -25,7 +25,7 @@ * * * IDENTIFICATION - * $Header: /cvsroot/pgsql/src/interfaces/libpq/fe-misc.c,v 1.77 2002/08/17 12:33:18 momjian Exp $ + * $Header: /cvsroot/pgsql/src/interfaces/libpq/fe-misc.c,v 1.78 2002/08/29 07:22:30 ishii Exp $ * *------------------------------------------------------------------------- */ @@ -50,10 +50,7 @@ #include "libpq-fe.h" #include "libpq-int.h" #include "pqsignal.h" - -#ifdef MULTIBYTE #include "mb/pg_wchar.h" -#endif #define DONOTICE(conn,message) \ ((*(conn)->noticeHook) ((conn)->noticeArg, (message))) @@ -847,7 +844,6 @@ retry5: * to be in fe-print.c but that file is doomed. */ -#ifdef MULTIBYTE /* * returns the byte length of the word beginning s, using the * specified encoding. @@ -873,23 +869,6 @@ PQenv2encoding(void) return (encoding); } -#else - -/* Provide a default definition in case someone calls it anyway */ -int -PQmblen(const unsigned char *s, int encoding) -{ - (void) s; - (void) encoding; - return 1; -} -int -PQenv2encoding(void) -{ - return 0; -} -#endif /* MULTIBYTE */ - #ifdef ENABLE_NLS char * diff --git a/src/interfaces/libpq/fe-print.c b/src/interfaces/libpq/fe-print.c index 33f370f46f17969cdcbfab20df6ee524cfa1f55c..baa9700934ca609dab9913f4df4294adb9cfee4e 100644 --- a/src/interfaces/libpq/fe-print.c +++ b/src/interfaces/libpq/fe-print.c @@ -10,7 +10,7 @@ * didn't really belong there. * * IDENTIFICATION - * $Header: /cvsroot/pgsql/src/interfaces/libpq/fe-print.c,v 1.45 2002/06/20 20:29:54 momjian Exp $ + * $Header: /cvsroot/pgsql/src/interfaces/libpq/fe-print.c,v 1.46 2002/08/29 07:22:30 ishii Exp $ * *------------------------------------------------------------------------- */ @@ -352,11 +352,7 @@ do_field(const PQprintOpt *po, const PGresult *res, /* Detect whether field contains non-numeric data */ char ch = '0'; -#ifdef MULTIBYTE for (p = pval; *p; p += PQmblen(p, res->client_encoding)) -#else - for (p = pval; *p; p++) -#endif { ch = *p; if (!((ch >= '0' && ch <= '9') || diff --git a/src/pl/plpgsql/src/pl_funcs.c b/src/pl/plpgsql/src/pl_funcs.c index 6ca9f5833576bd3b24d8119ee44e717812d615aa..33103a9eb4ae25a5eeeadbf65f4e6b9a3ac61a0a 100644 --- a/src/pl/plpgsql/src/pl_funcs.c +++ b/src/pl/plpgsql/src/pl_funcs.c @@ -3,7 +3,7 @@ * procedural language * * IDENTIFICATION - * $Header: /cvsroot/pgsql/src/pl/plpgsql/src/pl_funcs.c,v 1.19 2002/08/08 01:36:05 tgl Exp $ + * $Header: /cvsroot/pgsql/src/pl/plpgsql/src/pl_funcs.c,v 1.20 2002/08/29 07:22:30 ishii Exp $ * * This software is copyrighted by Jan Wieck - Hamburg. * @@ -46,9 +46,7 @@ #include "plpgsql.h" #include "pl.tab.h" -#ifdef MULTIBYTE #include "mb/pg_wchar.h" -#endif /* ---------- @@ -404,11 +402,7 @@ plpgsql_convert_ident(const char *s, char **output, int numidents) { int len; -#ifdef MULTIBYTE len = pg_mbcliplen(curident, i, NAMEDATALEN-1); -#else - len = NAMEDATALEN-1; -#endif curident[len] = '\0'; }