*
  *
  * IDENTIFICATION
- *   $PostgreSQL: pgsql/src/backend/tsearch/ts_parse.c,v 1.13 2009/07/16 06:33:44 petere Exp $
+ *   $PostgreSQL: pgsql/src/backend/tsearch/ts_parse.c,v 1.14 2009/08/18 10:30:41 teodor Exp $
  *
  *-------------------------------------------------------------------------
  */
    int         type;
    char       *lemm;
    int         lenlemm;
-   bool        resfollow;
    struct ParsedLex *next;
 } ParsedLex;
 
        while (ld->towork.head)
        {
            ParsedLex  *curVal = ld->towork.head;
+           char       *curValLemm = curVal->lemm;
+           int         curValLenLemm = curVal->lenlemm;
 
            map = ld->cfg->map + curVal->type;
 
                res = (TSLexeme *) DatumGetPointer(FunctionCall4(
                                                             &(dict->lexize),
                                             PointerGetDatum(dict->dictData),
-                                              PointerGetDatum(curVal->lemm),
-                                             Int32GetDatum(curVal->lenlemm),
+                                                PointerGetDatum(curValLemm),
+                                               Int32GetDatum(curValLenLemm),
                                              PointerGetDatum(&ld->dictState)
                                                                 ));
 
                if (!res)       /* dictionary doesn't know this lexeme */
                    continue;
 
+               if ( res->flags & TSL_FILTER )
+               {
+                   curValLemm = res->lexeme;
+                   curValLenLemm = strlen(res->lexeme);
+                   continue;
+               }
+
                RemoveHead(ld);
                setCorrLex(ld, correspondLexem);
                return res;
 
  *
  * Copyright (c) 1998-2009, PostgreSQL Global Development Group
  *
- * $PostgreSQL: pgsql/src/include/tsearch/ts_public.h,v 1.15 2009/07/16 06:33:45 petere Exp $
+ * $PostgreSQL: pgsql/src/include/tsearch/ts_public.h,v 1.16 2009/08/18 10:30:41 teodor Exp $
  *
  *-------------------------------------------------------------------------
  */
 
 #define TSL_ADDPOS     0x01
 #define TSL_PREFIX     0x02
+#define TSL_FILTER     0x04
 
 /*
  * Struct for supporting complex dictionaries like thesaurus.
 
  * Portions Copyright (c) 1996-2009, PostgreSQL Global Development Group
  * Portions Copyright (c) 1994, Regents of the University of California
  *
- * $PostgreSQL: pgsql/src/test/regress/pg_regress.c,v 1.63 2009/06/11 14:49:15 momjian Exp $
+ * $PostgreSQL: pgsql/src/test/regress/pg_regress.c,v 1.64 2009/08/18 10:30:41 teodor Exp $
  *
  *-------------------------------------------------------------------------
  */
     */
    header(_("creating database \"%s\""), dbname);
    if (encoding)
-       psql_command("postgres", "CREATE DATABASE \"%s\" TEMPLATE=template0 ENCODING='%s'", dbname, encoding);
+       psql_command("postgres", "CREATE DATABASE \"%s\" TEMPLATE=template0 ENCODING='%s'%s", dbname, encoding,
+                    (nolocale) ? " LC_COLLATE='C' LC_CTYPE='C'" : "");
    else
-       psql_command("postgres", "CREATE DATABASE \"%s\" TEMPLATE=template0", dbname);
+       psql_command("postgres", "CREATE DATABASE \"%s\" TEMPLATE=template0%s", dbname,
+                    (nolocale) ? " LC_COLLATE='C' LC_CTYPE='C'" : "");
    psql_command(dbname,
                 "ALTER DATABASE \"%s\" SET lc_messages TO 'C';"
                 "ALTER DATABASE \"%s\" SET lc_monetary TO 'C';"