diff --git a/doc/src/sgml/catalogs.sgml b/doc/src/sgml/catalogs.sgml
index 98cd438618a777f89e36957de1ba794f6ffd1f54..d0c7673a8e47144d5cce90b9cb2d11b0b096b379 100644
--- a/doc/src/sgml/catalogs.sgml
+++ b/doc/src/sgml/catalogs.sgml
@@ -1,4 +1,4 @@
-<!-- $PostgreSQL: pgsql/doc/src/sgml/catalogs.sgml,v 2.158 2007/09/20 17:56:30 tgl Exp $ -->
+<!-- $PostgreSQL: pgsql/doc/src/sgml/catalogs.sgml,v 2.159 2007/10/01 21:10:40 tgl Exp $ -->
 <!--
  Documentation of the system catalogs, directed toward PostgreSQL developers
  -->
@@ -218,6 +218,31 @@
       <entry>triggers</entry>
      </row>
 
+     <row>
+      <entry><link linkend="catalog-pg-ts-config"><structname>pg_ts_config</structname></link></entry>
+      <entry>text search configurations</entry>
+     </row>
+
+     <row>
+      <entry><link linkend="catalog-pg-ts-config-map"><structname>pg_ts_config_map</structname></link></entry>
+      <entry>text search configurations' token mappings</entry>
+     </row>
+
+     <row>
+      <entry><link linkend="catalog-pg-ts-dict"><structname>pg_ts_dict</structname></link></entry>
+      <entry>text search dictionaries</entry>
+     </row>
+
+     <row>
+      <entry><link linkend="catalog-pg-ts-parser"><structname>pg_ts_parser</structname></link></entry>
+      <entry>text search parsers</entry>
+     </row>
+
+     <row>
+      <entry><link linkend="catalog-pg-ts-template"><structname>pg_ts_template</structname></link></entry>
+      <entry>text search templates</entry>
+     </row>
+
      <row>
       <entry><link linkend="catalog-pg-type"><structname>pg_type</structname></link></entry>
       <entry>data types</entry>
@@ -2481,6 +2506,7 @@
   </table>
  </sect1>
 
+
  <sect1 id="catalog-pg-index">
   <title><structname>pg_index</structname></title>
 
@@ -3269,7 +3295,7 @@
    Each operator family is a collection of operators and associated
    support routines that implement the semantics specified for a particular
    index access method.  Furthermore, the operators in a family are all
-   <quote>compatible</>, in a way that depends on the access method.
+   <quote>compatible</>, in a way that is specified by the access method.
    The operator family concept allows cross-data-type operators to be used
    with indexes and to be reasoned about using knowledge of access method
    semantics.
@@ -4404,6 +4430,382 @@
  </sect1>
 
 
+ <sect1 id="catalog-pg-ts-config">
+  <title><structname>pg_ts_config</structname></title>
+
+  <indexterm zone="catalog-pg-ts-config">
+   <primary>pg_ts_config</primary>
+  </indexterm>
+
+  <para>
+   The <structname>pg_ts_config</structname> catalog contains entries
+   representing text search configurations.  A configuration specifies
+   a particular text search parser and a list of dictionaries to use
+   for each of the parser's output token types.  The parser is shown
+   in the <structname>pg_ts_config</structname> entry, but the
+   token-to-dictionary mapping is defined by subsidiary entries in <link
+   linkend="catalog-pg-ts-config-map"><structname>pg_ts_config_map</structname></link>.
+  </para>
+
+  <para>
+   <productname>PostgreSQL</productname>'s text search features are
+   described at length in <xref linkend="textsearch">.
+  </para>
+
+  <table>
+   <title><structname>pg_ts_config</> Columns</title>
+
+   <tgroup cols=4>
+    <thead>
+     <row>
+      <entry>Name</entry>
+      <entry>Type</entry>
+      <entry>References</entry>
+      <entry>Description</entry>
+     </row>
+    </thead>
+
+    <tbody>
+     <row>
+      <entry><structfield>cfgname</structfield></entry>
+      <entry><type>name</type></entry>
+      <entry></entry>
+      <entry>Text search configuration name</entry>
+     </row>
+
+     <row>
+      <entry><structfield>cfgnamespace</structfield></entry>
+      <entry><type>oid</type></entry>
+      <entry><literal><link linkend="catalog-pg-namespace"><structname>pg_namespace</structname></link>.oid</literal></entry>
+      <entry>
+       The OID of the namespace that contains this configuration
+      </entry>
+     </row>
+
+     <row>
+      <entry><structfield>cfgowner</structfield></entry>
+      <entry><type>oid</type></entry>
+      <entry><literal><link linkend="catalog-pg-authid"><structname>pg_authid</structname></link>.oid</literal></entry>
+      <entry>Owner of the configuration</entry>
+     </row>
+
+     <row>
+      <entry><structfield>cfgparser</structfield></entry>
+      <entry><type>oid</type></entry>
+      <entry><literal><link linkend="catalog-pg-ts-parser"><structname>pg_ts_parser</structname></link>.oid</literal></entry>
+      <entry>The OID of the text search parser for this configuration</entry>
+     </row>
+    </tbody>
+   </tgroup>
+  </table>
+ </sect1>
+
+
+ <sect1 id="catalog-pg-ts-config-map">
+  <title><structname>pg_ts_config_map</structname></title>
+
+  <indexterm zone="catalog-pg-ts-config-map">
+   <primary>pg_ts_config_map</primary>
+  </indexterm>
+
+  <para>
+   The <structname>pg_ts_config_map</structname> catalog contains entries
+   showing which text search dictionaries should be consulted, and in
+   what order, for each output token type of each text search configuration's
+   parser.
+  </para>
+
+  <para>
+   <productname>PostgreSQL</productname>'s text search features are
+   described at length in <xref linkend="textsearch">.
+  </para>
+
+  <table>
+   <title><structname>pg_ts_config_map</> Columns</title>
+
+   <tgroup cols=4>
+    <thead>
+     <row>
+      <entry>Name</entry>
+      <entry>Type</entry>
+      <entry>References</entry>
+      <entry>Description</entry>
+     </row>
+    </thead>
+
+    <tbody>
+     <row>
+      <entry><structfield>mapcfg</structfield></entry>
+      <entry><type>oid</type></entry>
+      <entry><literal><link linkend="catalog-pg-ts-config"><structname>pg_ts_config</structname></link>.oid</literal></entry>
+      <entry>The OID of the <structname>pg_ts_config</> entry owning this map entry</entry>
+     </row>
+
+     <row>
+      <entry><structfield>maptokentype</structfield></entry>
+      <entry><type>integer</type></entry>
+      <entry></entry>
+      <entry>A token type emitted by the configuration's parser</entry>
+     </row>
+
+     <row>
+      <entry><structfield>mapseqno</structfield></entry>
+      <entry><type>integer</type></entry>
+      <entry></entry>
+      <entry>Order in which to consult this entry (lower
+       <structfield>mapseqno</>s first)</entry>
+     </row>
+
+     <row>
+      <entry><structfield>mapdict</structfield></entry>
+      <entry><type>oid</type></entry>
+      <entry><literal><link linkend="catalog-pg-ts-dict"><structname>pg_ts_dict</structname></link>.oid</literal></entry>
+      <entry>The OID of the text search dictionary to consult</entry>
+     </row>
+    </tbody>
+   </tgroup>
+  </table>
+ </sect1>
+
+
+ <sect1 id="catalog-pg-ts-dict">
+  <title><structname>pg_ts_dict</structname></title>
+
+  <indexterm zone="catalog-pg-ts-dict">
+   <primary>pg_ts_dict</primary>
+  </indexterm>
+
+  <para>
+   The <structname>pg_ts_dict</structname> catalog contains entries
+   defining text search dictionaries.  A dictionary depends on a text
+   search template, which specifies all the implementation functions
+   needed; the dictionary itself provides values for the user-settable
+   parameters supported by the template.  This division of labor allows
+   dictionaries to be created by unprivileged users.  The parameters
+   are specified by a text string <structfield>dictinitoption</>,
+   whose format and meaning vary depending on the template.
+  </para>
+
+  <para>
+   <productname>PostgreSQL</productname>'s text search features are
+   described at length in <xref linkend="textsearch">.
+  </para>
+
+  <table>
+   <title><structname>pg_ts_dict</> Columns</title>
+
+   <tgroup cols=4>
+    <thead>
+     <row>
+      <entry>Name</entry>
+      <entry>Type</entry>
+      <entry>References</entry>
+      <entry>Description</entry>
+     </row>
+    </thead>
+
+    <tbody>
+     <row>
+      <entry><structfield>dictname</structfield></entry>
+      <entry><type>name</type></entry>
+      <entry></entry>
+      <entry>Text search dictionary name</entry>
+     </row>
+
+     <row>
+      <entry><structfield>dictnamespace</structfield></entry>
+      <entry><type>oid</type></entry>
+      <entry><literal><link linkend="catalog-pg-namespace"><structname>pg_namespace</structname></link>.oid</literal></entry>
+      <entry>
+       The OID of the namespace that contains this dictionary
+      </entry>
+     </row>
+
+     <row>
+      <entry><structfield>dictowner</structfield></entry>
+      <entry><type>oid</type></entry>
+      <entry><literal><link linkend="catalog-pg-authid"><structname>pg_authid</structname></link>.oid</literal></entry>
+      <entry>Owner of the dictionary</entry>
+     </row>
+
+     <row>
+      <entry><structfield>dicttemplate</structfield></entry>
+      <entry><type>oid</type></entry>
+      <entry><literal><link linkend="catalog-pg-ts-template"><structname>pg_ts_template</structname></link>.oid</literal></entry>
+      <entry>The OID of the text search template for this dictionary</entry>
+     </row>
+
+     <row>
+      <entry><structfield>dictinitoption</structfield></entry>
+      <entry><type>text</type></entry>
+      <entry></entry>
+      <entry>Initialization option string for the template</entry>
+     </row>
+    </tbody>
+   </tgroup>
+  </table>
+ </sect1>
+
+
+ <sect1 id="catalog-pg-ts-parser">
+  <title><structname>pg_ts_parser</structname></title>
+
+  <indexterm zone="catalog-pg-ts-parser">
+   <primary>pg_ts_parser</primary>
+  </indexterm>
+
+  <para>
+   The <structname>pg_ts_parser</structname> catalog contains entries
+   defining text search parsers.  A parser is responsible for splitting
+   input text into lexemes and assigning a token type to each lexeme.
+   Since a parser must be implemented by C-language-level functions,
+   creation of new parsers is restricted to database superusers.
+  </para>
+
+  <para>
+   <productname>PostgreSQL</productname>'s text search features are
+   described at length in <xref linkend="textsearch">.
+  </para>
+
+  <table>
+   <title><structname>pg_ts_parser</> Columns</title>
+
+   <tgroup cols=4>
+    <thead>
+     <row>
+      <entry>Name</entry>
+      <entry>Type</entry>
+      <entry>References</entry>
+      <entry>Description</entry>
+     </row>
+    </thead>
+
+    <tbody>
+     <row>
+      <entry><structfield>prsname</structfield></entry>
+      <entry><type>name</type></entry>
+      <entry></entry>
+      <entry>Text search parser name</entry>
+     </row>
+
+     <row>
+      <entry><structfield>prsnamespace</structfield></entry>
+      <entry><type>oid</type></entry>
+      <entry><literal><link linkend="catalog-pg-namespace"><structname>pg_namespace</structname></link>.oid</literal></entry>
+      <entry>
+       The OID of the namespace that contains this parser
+      </entry>
+     </row>
+
+     <row>
+      <entry><structfield>prsstart</structfield></entry>
+      <entry><type>regproc</type></entry>
+      <entry><literal><link linkend="catalog-pg-proc"><structname>pg_proc</structname></link>.oid</literal></entry>
+      <entry>OID of the parser's startup function</entry>
+     </row>
+
+     <row>
+      <entry><structfield>prstoken</structfield></entry>
+      <entry><type>regproc</type></entry>
+      <entry><literal><link linkend="catalog-pg-proc"><structname>pg_proc</structname></link>.oid</literal></entry>
+      <entry>OID of the parser's next-token function</entry>
+     </row>
+
+     <row>
+      <entry><structfield>prsend</structfield></entry>
+      <entry><type>regproc</type></entry>
+      <entry><literal><link linkend="catalog-pg-proc"><structname>pg_proc</structname></link>.oid</literal></entry>
+      <entry>OID of the parser's shutdown function</entry>
+     </row>
+
+     <row>
+      <entry><structfield>prsheadline</structfield></entry>
+      <entry><type>regproc</type></entry>
+      <entry><literal><link linkend="catalog-pg-proc"><structname>pg_proc</structname></link>.oid</literal></entry>
+      <entry>OID of the parser's headline function</entry>
+     </row>
+
+     <row>
+      <entry><structfield>prslextype</structfield></entry>
+      <entry><type>regproc</type></entry>
+      <entry><literal><link linkend="catalog-pg-proc"><structname>pg_proc</structname></link>.oid</literal></entry>
+      <entry>OID of the parser's lextype function</entry>
+     </row>
+    </tbody>
+   </tgroup>
+  </table>
+ </sect1>
+
+
+ <sect1 id="catalog-pg-ts-template">
+  <title><structname>pg_ts_template</structname></title>
+
+  <indexterm zone="catalog-pg-ts-template">
+   <primary>pg_ts_template</primary>
+  </indexterm>
+
+  <para>
+   The <structname>pg_ts_template</structname> catalog contains entries
+   defining text search templates.  A template is the implementation
+   skeleton for a class of text search dictionaries.
+   Since a template must be implemented by C-language-level functions,
+   creation of new templates is restricted to database superusers.
+  </para>
+
+  <para>
+   <productname>PostgreSQL</productname>'s text search features are
+   described at length in <xref linkend="textsearch">.
+  </para>
+
+  <table>
+   <title><structname>pg_ts_template</> Columns</title>
+
+   <tgroup cols=4>
+    <thead>
+     <row>
+      <entry>Name</entry>
+      <entry>Type</entry>
+      <entry>References</entry>
+      <entry>Description</entry>
+     </row>
+    </thead>
+
+    <tbody>
+     <row>
+      <entry><structfield>tmplname</structfield></entry>
+      <entry><type>name</type></entry>
+      <entry></entry>
+      <entry>Text search template name</entry>
+     </row>
+
+     <row>
+      <entry><structfield>tmplnamespace</structfield></entry>
+      <entry><type>oid</type></entry>
+      <entry><literal><link linkend="catalog-pg-namespace"><structname>pg_namespace</structname></link>.oid</literal></entry>
+      <entry>
+       The OID of the namespace that contains this template
+      </entry>
+     </row>
+
+     <row>
+      <entry><structfield>tmplinit</structfield></entry>
+      <entry><type>regproc</type></entry>
+      <entry><literal><link linkend="catalog-pg-proc"><structname>pg_proc</structname></link>.oid</literal></entry>
+      <entry>OID of the template's initialization function</entry>
+     </row>
+
+     <row>
+      <entry><structfield>tmpllexize</structfield></entry>
+      <entry><type>regproc</type></entry>
+      <entry><literal><link linkend="catalog-pg-proc"><structname>pg_proc</structname></link>.oid</literal></entry>
+      <entry>OID of the template's lexize function</entry>
+     </row>
+    </tbody>
+   </tgroup>
+  </table>
+ </sect1>
+
+
  <sect1 id="catalog-pg-type">
   <title><structname>pg_type</structname></title>