Commit b5b31348 authored by Teodor Sigaev's avatar Teodor Sigaev

Fix incorrect dereferencing of char* to array's index.

Per Tommy Gildseth <tommy.gildseth@usit.uio.no> report
parent 7adbd766
...@@ -7,7 +7,7 @@ ...@@ -7,7 +7,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $PostgreSQL: pgsql/src/backend/tsearch/spell.c,v 1.14 2009/01/01 17:23:48 momjian Exp $ * $PostgreSQL: pgsql/src/backend/tsearch/spell.c,v 1.15 2009/01/29 16:22:10 teodor Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -521,7 +521,7 @@ addFlagValue(IspellDict *Conf, char *s, uint32 val) ...@@ -521,7 +521,7 @@ addFlagValue(IspellDict *Conf, char *s, uint32 val)
(errcode(ERRCODE_CONFIG_FILE_ERROR), (errcode(ERRCODE_CONFIG_FILE_ERROR),
errmsg("multibyte flag character is not allowed"))); errmsg("multibyte flag character is not allowed")));
Conf->flagval[(unsigned int) *s] = (unsigned char) val; Conf->flagval[*(unsigned char*) s] = (unsigned char) val;
Conf->usecompound = true; Conf->usecompound = true;
} }
...@@ -654,7 +654,7 @@ NIImportOOAffixes(IspellDict *Conf, const char *filename) ...@@ -654,7 +654,7 @@ NIImportOOAffixes(IspellDict *Conf, const char *filename)
ptr = repl + (ptr - prepl) + 1; ptr = repl + (ptr - prepl) + 1;
while (*ptr) while (*ptr)
{ {
aflg |= Conf->flagval[(unsigned int) *ptr]; aflg |= Conf->flagval[*(unsigned char*) ptr];
ptr++; ptr++;
} }
} }
...@@ -735,7 +735,7 @@ NIImportAffixes(IspellDict *Conf, const char *filename) ...@@ -735,7 +735,7 @@ NIImportAffixes(IspellDict *Conf, const char *filename)
if (*s && pg_mblen(s) == 1) if (*s && pg_mblen(s) == 1)
{ {
Conf->flagval[(unsigned int) *s] = FF_COMPOUNDFLAG; Conf->flagval[*(unsigned char*) s] = FF_COMPOUNDFLAG;
Conf->usecompound = true; Conf->usecompound = true;
} }
oldformat = true; oldformat = true;
...@@ -791,7 +791,7 @@ NIImportAffixes(IspellDict *Conf, const char *filename) ...@@ -791,7 +791,7 @@ NIImportAffixes(IspellDict *Conf, const char *filename)
(errcode(ERRCODE_CONFIG_FILE_ERROR), (errcode(ERRCODE_CONFIG_FILE_ERROR),
errmsg("multibyte flag character is not allowed"))); errmsg("multibyte flag character is not allowed")));
flag = (unsigned char) *s; flag = *(unsigned char*) s;
goto nextline; goto nextline;
} }
if (STRNCMP(recoded, "COMPOUNDFLAG") == 0 || STRNCMP(recoded, "COMPOUNDMIN") == 0 || if (STRNCMP(recoded, "COMPOUNDFLAG") == 0 || STRNCMP(recoded, "COMPOUNDMIN") == 0 ||
...@@ -851,7 +851,7 @@ makeCompoundFlags(IspellDict *Conf, int affix) ...@@ -851,7 +851,7 @@ makeCompoundFlags(IspellDict *Conf, int affix)
while (str && *str) while (str && *str)
{ {
flag |= Conf->flagval[(unsigned int) *str]; flag |= Conf->flagval[*(unsigned char*) str];
str++; str++;
} }
......
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