1
0
mirror of https://github.com/postgres/postgres.git synced 2025-10-25 13:17:41 +03:00

Fix use of 'char' to hold result of getc, per bug report forwarded by

Oliver Elphick.  A few other minor cleanups while at it.
This commit is contained in:
Tom Lane
2002-01-09 19:13:41 +00:00
parent 8ff263f362
commit 9facc585ad
2 changed files with 111 additions and 125 deletions

View File

@@ -10,7 +10,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $Header: /cvsroot/pgsql/src/backend/libpq/hba.c,v 1.78 2001/11/12 04:29:23 tgl Exp $ * $Header: /cvsroot/pgsql/src/backend/libpq/hba.c,v 1.79 2002/01/09 19:13:40 tgl Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
@@ -111,7 +111,7 @@ next_token(FILE *fp, char *buf, const int bufsz)
static void static void
read_to_eol(FILE *file) read_through_eol(FILE *file)
{ {
int c; int c;
@@ -162,7 +162,7 @@ tokenize_file(FILE *file)
if (comment_ptr != NULL) if (comment_ptr != NULL)
{ {
/* Found a comment, so skip the rest of the line */ /* Found a comment, so skip the rest of the line */
read_to_eol(file); read_through_eol(file);
next_line = NIL; next_line = NIL;
} }
@@ -1159,14 +1159,12 @@ GetCharSetByHost(char *TableName, int host, const char *DataDir)
OrigCharset[MAX_TOKEN], OrigCharset[MAX_TOKEN],
DestCharset[MAX_TOKEN], DestCharset[MAX_TOKEN],
HostCharset[MAX_TOKEN], HostCharset[MAX_TOKEN],
c,
eof = false,
*map_file; *map_file;
int key = 0, int key,
ChIndex = 0, ChIndex = 0,
c,
i, i,
bufsize; bufsize;
struct CharsetItem *ChArray[MAX_CHARSETS]; struct CharsetItem *ChArray[MAX_CHARSETS];
*TableName = '\0'; *TableName = '\0';
@@ -1174,95 +1172,90 @@ GetCharSetByHost(char *TableName, int host, const char *DataDir)
map_file = (char *) palloc(bufsize); map_file = (char *) palloc(bufsize);
snprintf(map_file, bufsize, "%s/%s", DataDir, CHARSET_FILE); snprintf(map_file, bufsize, "%s/%s", DataDir, CHARSET_FILE);
file = AllocateFile(map_file, PG_BINARY_R); file = AllocateFile(map_file, PG_BINARY_R);
pfree(map_file);
if (file == NULL) if (file == NULL)
{ {
/* XXX should we log a complaint? */ /* XXX should we log a complaint? */
return; return;
} }
while (!eof) while ((c = getc(file)) != EOF)
{ {
c = getc(file); if (c == '#')
ungetc(c, file); read_through_eol(file);
if (c == EOF)
eof = true;
else else
{ {
if (c == '#') /* Read the key */
read_to_eol(file); ungetc(c, file);
else next_token(file, buf, sizeof(buf));
if (buf[0] != '\0')
{ {
/* Read the key */ key = 0;
next_token(file, buf, sizeof(buf)); if (strcasecmp(buf, "HostCharset") == 0)
if (buf[0] != '\0') key = KEY_HOST;
if (strcasecmp(buf, "BaseCharset") == 0)
key = KEY_BASE;
if (strcasecmp(buf, "RecodeTable") == 0)
key = KEY_TABLE;
switch (key)
{ {
if (strcasecmp(buf, "HostCharset") == 0) case KEY_HOST:
key = KEY_HOST; /* Read the host */
if (strcasecmp(buf, "BaseCharset") == 0) next_token(file, buf, sizeof(buf));
key = KEY_BASE; if (buf[0] != '\0')
if (strcasecmp(buf, "RecodeTable") == 0) {
key = KEY_TABLE; if (CharSetInRange(buf, host))
switch (key)
{
case KEY_HOST:
/* Read the host */
next_token(file, buf, sizeof(buf));
if (buf[0] != '\0')
{ {
if (CharSetInRange(buf, host)) /* Read the charset */
{ next_token(file, buf, sizeof(buf));
/* Read the charset */ if (buf[0] != '\0')
next_token(file, buf, sizeof(buf)); strcpy(HostCharset, buf);
if (buf[0] != '\0')
strcpy(HostCharset, buf);
}
} }
break; }
case KEY_BASE: break;
/* Read the base charset */ case KEY_BASE:
next_token(file, buf, sizeof(buf)); /* Read the base charset */
if (buf[0] != '\0') next_token(file, buf, sizeof(buf));
strcpy(BaseCharset, buf); if (buf[0] != '\0')
break; strcpy(BaseCharset, buf);
case KEY_TABLE: break;
/* Read the original charset */ case KEY_TABLE:
/* Read the original charset */
next_token(file, buf, sizeof(buf));
if (buf[0] != '\0')
{
strcpy(OrigCharset, buf);
/* Read the destination charset */
next_token(file, buf, sizeof(buf)); next_token(file, buf, sizeof(buf));
if (buf[0] != '\0') if (buf[0] != '\0')
{ {
strcpy(OrigCharset, buf); strcpy(DestCharset, buf);
/* Read the destination charset */ /* Read the table filename */
next_token(file, buf, sizeof(buf)); next_token(file, buf, sizeof(buf));
if (buf[0] != '\0') if (buf[0] != '\0')
{ {
strcpy(DestCharset, buf); ChArray[ChIndex] =
/* Read the table filename */ (struct CharsetItem *) palloc(sizeof(struct CharsetItem));
next_token(file, buf, sizeof(buf)); strcpy(ChArray[ChIndex]->Orig, OrigCharset);
if (buf[0] != '\0') strcpy(ChArray[ChIndex]->Dest, DestCharset);
{ strcpy(ChArray[ChIndex]->Table, buf);
ChArray[ChIndex] = ChIndex++;
(struct CharsetItem *) palloc(sizeof(struct CharsetItem));
strcpy(ChArray[ChIndex]->Orig, OrigCharset);
strcpy(ChArray[ChIndex]->Dest, DestCharset);
strcpy(ChArray[ChIndex]->Table, buf);
ChIndex++;
}
} }
} }
break; }
} break;
read_to_eol(file);
} }
read_through_eol(file);
} }
} }
} }
FreeFile(file); FreeFile(file);
pfree(map_file);
for (i = 0; i < ChIndex; i++) for (i = 0; i < ChIndex; i++)
{ {
if (!strcasecmp(BaseCharset, ChArray[i]->Orig) && if (strcasecmp(BaseCharset, ChArray[i]->Orig) == 0 &&
!strcasecmp(HostCharset, ChArray[i]->Dest)) strcasecmp(HostCharset, ChArray[i]->Dest) == 0)
strncpy(TableName, ChArray[i]->Table, 79); strncpy(TableName, ChArray[i]->Table, 79);
pfree((struct CharsetItem *) ChArray[i]); pfree(ChArray[i]);
} }
} }

View File

@@ -8,7 +8,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $Header: /cvsroot/pgsql/src/backend/utils/init/miscinit.c,v 1.81 2001/10/25 05:49:51 momjian Exp $ * $Header: /cvsroot/pgsql/src/backend/utils/init/miscinit.c,v 1.82 2002/01/09 19:13:41 tgl Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
@@ -227,75 +227,80 @@ pg_convert2(PG_FUNCTION_ARGS)
#define MAX_TOKEN 80 #define MAX_TOKEN 80
/* Some standard C libraries, including GNU, have an isblank() function. /*
Others, including Solaris, do not. So we have our own. * Some standard C libraries, including GNU, have an isblank() function.
*/ * Others, including Solaris, do not. So we have our own.
*/
static bool static bool
isblank(const char c) isblank(const char c)
{ {
return c == ' ' || c == 9 /* tab */ ; return c == ' ' || c == '\t';
} }
/*
* Grab one token out of fp. Tokens are strings of non-blank
* characters bounded by blank characters, beginning of line, and end
* of line. Blank means space or tab. Return the token as *buf.
* Leave file positioned to character immediately after the token or
* EOF, whichever comes first. If no more tokens on line, return null
* string as *buf and position file to beginning of next line or EOF,
* whichever comes first.
*/
static void static void
next_token(FILE *fp, char *buf, const int bufsz) next_token(FILE *fp, char *buf, const int bufsz)
{ {
/*--------------------------------------------------------------------------
Grab one token out of fp. Tokens are strings of non-blank
characters bounded by blank characters, beginning of line, and end
of line. Blank means space or tab. Return the token as *buf.
Leave file positioned to character immediately after the token or
EOF, whichever comes first. If no more tokens on line, return null
string as *buf and position file to beginning of next line or EOF,
whichever comes first.
--------------------------------------------------------------------------*/
int c; int c;
char *eb = buf + (bufsz - 1); char *eb = buf + (bufsz - 1);
/* Move over inital token-delimiting blanks */ /* Move over initial token-delimiting blanks */
while (isblank(c = getc(fp))); while ((c = getc(fp)) != EOF && isblank(c))
;
if (c != '\n') if (c != EOF && c != '\n')
{ {
/* /*
* build a token in buf of next characters up to EOF, eol, or * build a token in buf of next characters up to EOF, eol, or
* blank. * blank. If the token gets too long, we still parse it
* correctly, but the excess characters are not stored into *buf.
*/ */
while (c != EOF && c != '\n' && !isblank(c)) while (c != EOF && c != '\n' && !isblank(c))
{ {
if (buf < eb) if (buf < eb)
*buf++ = c; *buf++ = c;
c = getc(fp); c = getc(fp);
/*
* Put back the char right after the token (putting back EOF
* is ok)
*/
} }
ungetc(c, fp);
/*
* Put back the char right after the token (critical in case it is
* eol, since we need to detect end-of-line at next call).
*/
if (c != EOF)
ungetc(c, fp);
} }
*buf = '\0'; *buf = '\0';
} }
static void static void
read_through_eol(FILE *file) read_through_eol(FILE *file)
{ {
int c; int c;
do while ((c = getc(file)) != EOF && c != '\n')
c = getc(file); ;
while (c != '\n' && c != EOF);
} }
void void
SetCharSet() SetCharSet(void)
{ {
FILE *file; FILE *file;
char *p, char *p;
c,
eof = false;
char *map_file; char *map_file;
char buf[MAX_TOKEN]; char buf[MAX_TOKEN];
int i; int i,
c;
unsigned char FromChar, unsigned char FromChar,
ToChar; ToChar;
char ChTable[80]; char ChTable[80];
@@ -316,49 +321,37 @@ SetCharSet()
if (p && *p != '\0') if (p && *p != '\0')
{ {
map_file = malloc(strlen(DataDir) + strlen(p) + 2); map_file = palloc(strlen(DataDir) + strlen(p) + 2);
if (!map_file)
elog(FATAL, "out of memory");
sprintf(map_file, "%s/%s", DataDir, p); sprintf(map_file, "%s/%s", DataDir, p);
file = AllocateFile(map_file, PG_BINARY_R); file = AllocateFile(map_file, PG_BINARY_R);
pfree(map_file);
if (file == NULL) if (file == NULL)
{
free(map_file);
return; return;
} while ((c = getc(file)) != EOF)
eof = false;
while (!eof)
{ {
c = getc(file); if (c == '#')
ungetc(c, file); read_through_eol(file);
if (c == EOF)
eof = true;
else else
{ {
if (c == '#') /* Read the FromChar */
read_through_eol(file); ungetc(c, file);
else next_token(file, buf, sizeof(buf));
if (buf[0] != '\0')
{ {
/* Read the FromChar */ FromChar = strtoul(buf, 0, 0);
/* Read the ToChar */
next_token(file, buf, sizeof(buf)); next_token(file, buf, sizeof(buf));
if (buf[0] != '\0') if (buf[0] != '\0')
{ {
FromChar = strtoul(buf, 0, 0); ToChar = strtoul(buf, 0, 0);
/* Read the ToChar */ RecodeForwTable[FromChar - 128] = ToChar;
next_token(file, buf, sizeof(buf)); RecodeBackTable[ToChar - 128] = FromChar;
if (buf[0] != '\0')
{
ToChar = strtoul(buf, 0, 0);
RecodeForwTable[FromChar - 128] = ToChar;
RecodeBackTable[ToChar - 128] = FromChar;
}
read_through_eol(file); read_through_eol(file);
} }
} }
} }
} }
FreeFile(file); FreeFile(file);
free(map_file);
} }
} }