-Remove the TOC first page kludge. It's fixed proper now in ldp.dsl.in.
[privoxy.git] / doc / source / user-manual.sgml
index 15ac7f6..b777ac0 100644 (file)
@@ -25,7 +25,7 @@
                 This file belongs into
                 ijbswa.sourceforge.net:/home/groups/i/ij/ijbswa/htdocs/
                 
- $Id: user-manual.sgml,v 1.95 2002/04/26 17:23:29 swa Exp $
+ $Id: user-manual.sgml,v 1.102 2002/05/03 17:46:00 oes Exp $
 
  Written by and Copyright (C) 2001 the SourceForge
  Privoxy team. http://www.privoxy.org/
@@ -46,7 +46,7 @@
 <artheader>
 <title>Privoxy User Manual</title>
 
-<pubdate>$Id: user-manual.sgml,v 1.95 2002/04/26 17:23:29 swa Exp $</pubdate>
+<pubdate>$Id: user-manual.sgml,v 1.102 2002/05/03 17:46:00 oes Exp $</pubdate>
 
 <authorgroup>
  <author>
 
 </artheader>
 
-<!--   ~~~~~       New section      ~~~~~     -->
-<sect1 id="intro" label=""><title></title>
-<!-- dummy section to force TOC on page by itself -->
-<!-- DO NOT REMOVE! please ;) -->
-<para> </para>
-</sect1>
-
 <!--   ~~~~~       New section      ~~~~~     -->
 <sect1 label="1" id="introduction"><title>Introduction</title>
 <para>
  packages for a wide range of operating systems, and as raw source code.
  For most users, we recommend using the packages, which can be downloaded from our
  <ulink url="http://sourceforge.net/projects/ijbswa/">Privoxy Project
- Page</ulink>. For installing and compiling the source code, please look 
- into our Developer Manual.
+ Page</ulink>.
 </para>
 
-<para>
- If you like to live on the bleeding edge and are not afraid of using
- possibly unstable development versions, you can check out the up-to-the-minute
- version directly from <ulink url="http://sourceforge.net/cvs/?group_id=11118">the
- CVS repository</ulink> or simply download <ulink
- url="http://cvs.sourceforge.net/cvstarballs/ijbswa-cvsroot.tar.gz">the nightly CVS
- tarball.</ulink> Again, we refer you to the Developer Manual.
-</para>
-
-<!-- Include supported.sgml boilerplate -->
- &supported; 
-<!-- end boilerplate -->
-
 <para>
  Note: If you have a previous <application>Junkbuster</application> or
  <application>Privoxy</application> installation on your system, you
  will need to remove it.  Some platforms do this for you as part 
  of their installation procedure. (See below for your platform).
-</para>
-
-<para>
  In any case <emphasis>be sure to backup your old configuration
  if it is valuable to you.</emphasis> See the
  <link linkend="upgradersnote">note to upgraders</link> section
  below.
 </para>
 
+<!--   ~~~~~       New section      ~~~~~     --> 
+<sect2 id="installation-packages"><title>Binary Packages</title>
+<para>
+How to install the binary packages depends on your operating system:
+</para>
+
 <!--   ~~~~~       New section      ~~~~~     -->
-<sect2 id="installation-pack-rpm"><title>Red Hat and SuSE RPMs</title>
+<sect3 id="installation-pack-rpm"><title>Red Hat and SuSE RPMs</title>
 
 <para>
  RPMs can be installed with <literal>rpm -Uvh privoxy-&p-version;-1.rpm</literal>,
@@ -207,17 +189,17 @@ automatically start Privoxy in the boot process.
  Otherwise, RPM will try to remove <application>Junkbuster</application>
  automatically, before installing <application>Privoxy</application>.
 </para>
-</sect2>
+</sect3>
 
 <!--   ~~~~~       New section      ~~~~~     -->
-<sect2 id="installation-deb"><title>Debian</title>
+<sect3 id="installation-deb"><title>Debian</title>
 <para>
  FIXME.
 </para>
-</sect2>
+</sect3>
 
 <!--   ~~~~~       New section      ~~~~~     -->
-<sect2 id="installation-pack-win"><title>Windows</title>
+<sect3 id="installation-pack-win"><title>Windows</title>
 
 <para>
  Just double-click the installer, which will guide you through
@@ -225,20 +207,20 @@ automatically start Privoxy in the boot process.
  in the same directory as you installed Privoxy in. We do not
  use the registry of Windows. 
 </para>
-</sect2>
+</sect3>
 
 <!--   ~~~~~       New section      ~~~~~     -->
-<sect2 id="installation-pack-bintgz"><title>Solaris, NetBSD, FreeBSD, HP-UX</title>
+<sect3 id="installation-pack-bintgz"><title>Solaris, NetBSD, FreeBSD, HP-UX</title>
 
 <para>
  Create a new directory, <literal>cd</literal> to it, then unzip and
  untar the archive. For the most part, you'll have to figure out where
  things go. FIXME.
 </para>
-</sect2>
+</sect3>
 
 <!--   ~~~~~       New section      ~~~~~     -->
-<sect2 id="installation-os2"><title>OS/2</title>
+<sect3 id="installation-os2"><title>OS/2</title>
 
 <para>
  First, make sure that no previous installations of
@@ -258,10 +240,10 @@ automatically start Privoxy in the boot process.
  The directory you choose to install <application>Privoxy</application>
  into will contain all of the configuration files.
 </para>
-</sect2>
+</sect3>
 
 <!--   ~~~~~       New section      ~~~~~     -->
-<sect2 id="installation-mac"><title>Max OSX</title>
+<sect3 id="installation-mac"><title>Max OSX</title>
 <para>
  Unzip the downloaded package (you can either double-click on the file
  in the finder, or on the desktop if you downloaded it there).  Then,
@@ -273,10 +255,10 @@ automatically start Privoxy in the boot process.
  automatically on system bring-up via
  <literal>/System/Library/StartupItems/Privoxy</literal>.
 </para>
-</sect2>
+</sect3>
 
 <!--   ~~~~~       New section      ~~~~~     -->
-<sect2 id="installation-amiga"><title>AmigaOS</title>
+<sect3 id="installation-amiga"><title>AmigaOS</title>
 <para>
  Copy and then unpack the <filename>lha</filename> archive to a suitable location. 
  All necessary files will be installed into <application>Privoxy</application>
@@ -292,7 +274,35 @@ automatically start Privoxy in the boot process.
  TCP/IP stack (just ignore the harmless warning your TCP/IP stack may display that
  <application>Privoxy</application> is still running).
 </para>
+</sect3>
 </sect2>
+
+<!--   ~~~~~       New section      ~~~~~     -->
+<sect2 id="installation-source"><title>Building from Source</title>
+
+<para>
+ The most convenient way to obtain the <application>Privoxy</application> sources
+ is to download the source tarball from our <ulink url="http://sf.net/projects/ijbswa/">project
+ page</ulink>.
+</para>
+
+<para>
+ If you like to live on the bleeding edge and are not afraid of using
+ possibly unstable development versions, you can check out the up-to-the-minute
+ version directly from <ulink url="http://sourceforge.net/cvs/?group_id=11118">the
+ CVS repository</ulink> or simply download <ulink
+ url="http://cvs.sourceforge.net/cvstarballs/ijbswa-cvsroot.tar.gz">the nightly CVS
+ tarball.</ulink>
+</para>
+
+<!-- include buildsource.sgml boilerplate: -->
+&buildsource;
+<!-- end boilerplate -->
+
+
+
+</sect2>
+
 </sect1>
 
 <!--  ~  End section  ~  -->
@@ -301,22 +311,25 @@ automatically start Privoxy in the boot process.
 <sect1 id="upgradersnote">
 <title>Note to Upgraders</title>
 <para>
- There are very significant changes from older versions of 
- <application>Junkbuster</application> to the current
- <application>Privoxy</application>. Configuration is substantially 
- changed. <application>Junkbuster 2.0.x</application> and earlier 
- configuration files will not migrate. The functionality of the old
- <filename>blockfile</filename>, <filename>cookiefile</filename> and
- <filename>imagelist</filename>, are now combined into the
- <quote>actions files</quote>.  <filename>default.action</filename>, 
- is the main actions file. Local exceptions should best be put into 
- <filename>user.action</filename>.
+ There are very significant changes from earlier 
+ <application>Junkbuster</application> versions to the current
+ <application>Privoxy</application>. The number, names, syntax, and
+ purposes of configuration files have substantially  changed.
+ <application>Junkbuster 2.0.x</application> configuration
+ files will not migrate, <application>Junkbuster 2.9.x</application>
+ and <application>Privoxy</application> configurations will need to be
+ ported. The functionalities of the old <filename>blockfile</filename>,
+ <filename>cookiefile</filename> and <filename>imagelist</filename> 
+ are now combined into the <ulink url="actions-file.html"><quote>actions
+ files</quote></ulink>.  
+ <filename>default.action</filename>, is the main actions file. Local
+ exceptions should best be put into <filename>user.action</filename>.
 </para>
 <para>
- A <quote>filter file</quote> (typically <filename>default.filter</filename>)
- is new as of <application>Privoxy 2.9.x</application>, and provides some
- of the new sophistication (explained below). <filename>config</filename> is 
- much the same as before.
+ A <ulink url="filter-file.html"><quote>filter file</quote></ulink> (typically
+ <filename>default.filter</filename>) is new as of <application>Privoxy
+ 2.9.x</application>, and provides some of the new sophistication (explained
below). <filename>config</filename> is much the same as before.
 </para>
 <para>
  If upgrading from a 2.0.x version, you will have to use the new config 
@@ -359,9 +372,9 @@ automatically start Privoxy in the boot process.
   <para>
    The primary configuration file for cookie management, ad and banner 
    blocking, and many other aspects of <application>Privoxy</application>
-   configuration is in the <quote>actions</quote> files. It is strongly
-   recommended to become familiar with the new actions concept below, 
-   before modifying these files. Locally defined rules 
+   configuration is in the <ulink url="actions-file.html">actions
+   files</ulink>. It is strongly recommended to become familiar with the new
+   actions concept below, before modifying these files. Locally defined rules 
    should go into <filename>user.action</filename>.
   </para>
  </listitem> 
@@ -385,32 +398,68 @@ automatically start Privoxy in the boot process.
 
  <listitem>
   <para>
-  Install <application>Privoxy</application>. See the section <link linkend="installation">Installing</link>.
+   If upgrading, please back up any configuration files. See 
+   the <link linkend="upgradersnote">Note to Upgraders</link> Section.
   </para>
+</listitem> 
+ <listitem>
+  <para>
+  Install <application>Privoxy</application>. See the <link
+  linkend="installation">Installation Section</link> for platform specific
+  information. 
+ </para>
  </listitem>  
 
  <listitem>
   <para>
-  Start <application>Privoxy</application>. See the section <link linkend="startup">Starting <application>Privoxy</application></link>.
+  Start <application>Privoxy</application>, if the installation program has
+  not done this already. See the section <link linkend="startup">Starting
+  <application>Privoxy</application></link>.
   </para>
  </listitem>  
 
  <listitem>
   <para>
-  Change your browser's configuration to use the proxy <literal>localhost</literal> on port
-  <literal>8118</literal>. See the section <link linkend="startup">Starting <application>Privoxy</application></link>.
+  Set your browser to use <application>Privoxy</application> as HTTP and HTTPS
+  proxy by setting the proxy configuration for address of
+  <literal>localhost</literal> and port <literal>8118</literal>.
+  (<application>Junkbuster</application> and earlier versions of
+  <application>Privoxy</application> used port 8000.) See the section <link
+  linkend="startup">Starting <application>Privoxy</application></link>.
   </para>
  </listitem>  
 
  <listitem>
   <para>
-  Enjoy surfing with enhanced comfort and privacy. Please see the section
-  <link linkend="contact">Contacting the Developers</link> on how to report
-  bugs or problems with websites or to get help. You may want to change the
-  file <filename>user.action</filename> to further tweak your new browsing
-  experience.
+    Flush your browser's caches, to remove any cached ad images.
   </para>
- </listitem>  
+</listitem> 
+
+ <listitem>
+  <para>
+  Enjoy surfing with enhanced comfort and privacy.  You may want to customize the
+  <link linkend="actions-file"><filename>user.action</filename></link> file to
+  personalize your new browsing experience. See the <link
+  linkend="configuration">Configuration section</link> for more configuration
+  options, and how to further customize your installation.
+  </para>
+ </listitem> 
+ <listitem>
+  <para>
+   If you experience problems with sites that <quote>misbehave</quote>, see
+   the <link linkend="actionsanat">Anatomy of an Action</link> section in the
+   Appendix.
+  </para>
+ </listitem> 
+ <listitem>
+  <para>
+   Please see the section <link linkend="contact">Contacting the
+   Developers</link> on how to report bugs or problems with websites or to get
+   help. 
+  </para>
+ </listitem> 
 
  </itemizedlist>
 </para>
@@ -421,11 +470,11 @@ automatically start Privoxy in the boot process.
 <sect1 id="startup">
 <title>Starting <application>Privoxy</application></title>
 <para>
- Before launching <application>Privoxy</application> for the first time, you 
- will want to configure your browser(s) to use <application>Privoxy</application>
- as a HTTP and HTTPS proxy. The default is localhost for the proxy address,
- and port 8118 (earlier versions used port 8000). This is the one
- configuration step that must be done! 
+ Before launching <application>Privoxy</application> for the first time, you
+ will want to configure your browser(s) to use
+ <application>Privoxy</application> as a HTTP and HTTPS proxy. The default is
+ localhost for the proxy address, and port 8118 (earlier versions used port
+ 8000). This is the one configuration step that must be done!
 </para>
  
 <para> 
@@ -445,53 +494,102 @@ automatically start Privoxy in the boot process.
  <application>Privoxy</application>!
 </para>
 
-
 <para>
  <application>Privoxy</application> is typically started by specifying the
- main configuration file to be used on the command line. Example Unix startup
- command:
+ main configuration file to be used on the command line. If no configuration
+ file is specified on the command line, <application>Privoxy</application>
+ will look for a file named <filename>config</filename> in the current
+ directory. Except on Win32 where it will try <filename>config.txt</filename>.
 </para>
 
+<sect2 id="start-redhatdebian">
+<title>RedHat and Debian</title>
+<para>
+We use a script. Note that RedHat does not start Privoxy upon booting per
+default. It will use the file <filename>/etc/privoxy/config</filename> as its
+main configuration file. FIXME: Debian??
+</para>
 <para>
  <screen>
- # /usr/sbin/privoxy /etc/privoxy/config
+ # /etc/rc.d/init.d/privoxy start
 </screen>
 </para>
+</sect2>
+
+<sect2 id="start-suse">
+<title>SuSE</title>
+<para>
+We use a script. It will use the file <filename>/etc/privoxy/config</filename>
+as its main configuration file. Note that SuSE starts Privoxy upon booting
+your PC.
+</para>
+<para>
+ <screen>
+ # rcprivoxy start
+</screen>
+</para>
+</sect2>
+
+<sect2 id="start-windows">
+<title>Windows</title>
+<para>
+Click on the Privoxy Icon to start Privoxy. If no configuration file is
+ specified on the command line, <application>Privoxy</application> will look
+ for a file named <filename>config.txt</filename>. Note that Windows will
+ automatically start Privoxy upon booting you PC.
+</para>
+</sect2>
 
+<sect2 id="start-unices">
+<title>Solaris, NetBSD, FreeBSD, HP-UX and others</title>
+<para>
+Example Unix startup command:
+</para>
 <para>
- See <link linkend="cmdoptions">below</link> for other command line options.
+ <screen>
+ # /usr/sbin/privoxy /etc/privoxy/config
+</screen>
 </para>
+</sect2>
 
+<sect2 id="start-os2">
+<title>OS/2</title>
 <para>
- An init script is provided for SuSE and Red Hat.
+FIXME.
 </para>
+</sect2>
 
+<sect2 id="start-macosx">
+<title>MAX OSX</title>
 <para>
- For for SuSE: <command>rcprivoxy start</command>
+FIXME.
 </para>
+</sect2>
 
+
+<sect2 id="start-amigaos">
+<title>AmigaOS</title>
 <para>
- For Red Hat and Debian: <command>/etc/rc.d/init.d/privoxy start</command>
+FIXME.
 </para>
+</sect2>
 
+<!--
 
 <para>
- If no configuration file is specified on the command line,
- <application>Privoxy</application> will look for a file named
- <filename>config</filename> in the current directory. Except on Win32 where
- it will try <filename>config.txt</filename>. If no file is specified on the
- command line and no default configuration file can be found, 
- <application>Privoxy</application> will fail to start.
+ See the section <link linkend="cmdoptions">Command line options</link> for
+ furher info.
 </para>
 
+must find a better place for this paragraph
 
 <para>
  The included default configuration files should give a reasonable starting
  point. Most of the per site configuration is done in the
- <quote>actions</quote> files. These are where various cookie actions are
- defined, ad and banner blocking, and other aspects of
- <application>Privoxy</application> configuration. There are several such
- files included, with varying levels of aggressiveness. 
+ <ulink url="actions-file.html"><quote>actions</quote></ulink> files. These are
+ where various cookie actions are defined, ad and banner blocking, and other
+ aspects of <application>Privoxy</application> configuration. There are several
such files included, with varying levels of aggressiveness. 
 </para>
 
 <para>
@@ -508,9 +606,12 @@ automatically start Privoxy in the boot process.
 
 <para>
  Another feature where you will probably want to define exceptions for trusted
- sites is the popup-killing (through the <literal>+popup</literal> and
- <literal>+filter{popups}</literal> actions), because your favorite shopping,
- banking, or leisure site may need popups (explained below). 
+ sites is the popup-killing (through the <ulink
+ url="actions-file.html#KILL-POPUPS"><quote>+kill-popups</quote></ulink> and
+ <ulink
+ url="actions-file.html#FILTER-POPUPS"><quote>+filter{popups}</quote></ulink>
+ actions), because your favorite shopping, banking, or leisure site may need
+ popups (explained below). 
 </para>
 
 <para>
@@ -559,7 +660,7 @@ automatically start Privoxy in the boot process.
 
 <para>
  If the above paragraph sounds gibberish to you, you might want to <ulink
- url="configuration.html#ACTIONSFILE">read more about the actions concept</ulink>
+ url="actions-file.html#ACTIONSFILE">read more about the actions concept</ulink>
  or even dive deep into the <ulink url="appendix.html#ACTIONSANAT">Appendix
  on actions</ulink>.
 </para>
@@ -571,6 +672,8 @@ automatically start Privoxy in the boot process.
  Developers</quote></ulink> below. 
 </para>
 
+-->
+
 <!--   ~~~~~       New section      ~~~~~     -->
 <sect2 id="cmdoptions">
 <title>Command Line Options</title>
@@ -705,8 +808,8 @@ automatically start Privoxy in the boot process.
 
 <para>
  This should be self-explanatory. Note the first item leads to an editor for the
- <quote>actions list</quote>, which is where the ad, banner, cookie,
- and URL blocking magic is configured as well as other advanced features of
+ <link linkend="actions-file">actions files</link>, which is where the ad, banner,
cookie, and URL blocking magic is configured as well as other advanced features of
  <application>Privoxy</application>. This is an easy way to adjust various
  aspects of <application>Privoxy</application> configuration. The actions
  file, and other configuration files, are explained in detail below. 
@@ -717,7 +820,8 @@ automatically start Privoxy in the boot process.
  have problems with your current actions and filters. You can in fact use
  it as a test to see whether it is <application>Privoxy</application> 
  causing the problem or not. <application>Privoxy</application> continues 
- to run as a proxy in this case, but all filtering is disabled. There
+ to run as a proxy in this case, but all manipulation is disabled, i.e.
+ <application>Privoxy</application> acts like a normal forwarding proxy. There
  is even a toggle <link linkend="bookmarklets">Bookmarklet</link> offered, so
  that you can toggle <application>Privoxy</application> with one click from
  your browser.
@@ -754,7 +858,7 @@ automatically start Privoxy in the boot process.
 
   <listitem>
    <para>
-     The main configuration file is named <link linkend="config">config</link>
+     The <link linkend="config">main configuration file</link> is named <filename>config</filename>
      on Linux, Unix, BSD, OS/2, and AmigaOS and <filename>config.txt</filename>
      on Windows. This is a required file.
    </para>
@@ -762,25 +866,29 @@ automatically start Privoxy in the boot process.
 
   <listitem>
    <para>
-    <filename>default.action</filename> (the main <link linkend="actions-file">actions file</link>) is used to define
-    the default settings for various <quote>actions</quote> relating to images, banners, 
-    pop-ups, access restrictions, banners and cookies.
+    <filename>default.action</filename> (the main <link linkend="actions-file">actions file</link>)
+    is used to define which <quote>actions</quote> relating to banner-blocking, images, pop-ups,
+    content modification, cookie handling etc should be applied by default. It also defines many
+    exceptions (both positive and negative) from this default set of actions that enable 
+    <application>Privoxy</application> to selectively eliminate the junk, and only the junk, on
+    as many websites as possible.
    </para>
    <para>
     Multiple actions files may be defined in <filename>config</filename>. These 
     are processed in the order they are defined. Local customizations and locally 
-    preferred exceptions to the default policies as defined in
-    <filename>default.action</filename> are probably best applied in
-    <filename>user.action</filename>, which should be preserved across
-    upgrades. <filename>standard.action</filename> is also included. This is mostly 
-    for <application>Privoxy's</application> internal use.
+    preferred exceptions to the default policies  as defined in
+    <filename>default.action</filename> (which you will most propably want
+    to define sooner or later) are probably best applied in
+    <filename>user.action</filename>, where you can preserve them across
+    upgrades. <filename>standard.action</filename> is for
+    <application>Privoxy's</application> internal use.
    </para>
    <para>    
     There is also a web based editor that can be accessed from
     <ulink
-    url="http://config.privoxy.org/show-status/">http://config.privoxy.org/show-status/</ulink>
+    url="http://config.privoxy.org/show-status">http://config.privoxy.org/show-status</ulink>
     (Shortcut: <ulink
-    url="http://p.p/show-status/">http://p.p/show-status/</ulink>) for the
+    url="http://p.p/show-status">http://p.p/show-status</ulink>) for the
     various actions files. 
    </para>
   </listitem> 
@@ -800,7 +908,7 @@ automatically start Privoxy in the boot process.
 
 <para>
  All files use the <quote><literal>#</literal></quote> character to denote a
- comment (the rest of the line will be ignored) angd understand line continuation
+ comment (the rest of the line will be ignored) and understand line continuation
  through placing a backslash ("<literal>\</literal>") as the very last character
  in a line. If the <literal>#</literal> is preceded by a backslash, it looses
  its special function. Placing a <literal>#</literal> in front of an otherwise
@@ -832,13 +940,17 @@ automatically start Privoxy in the boot process.
  please check all your configuration files on important issues.
 </para>
 ]]>
+
 </sect2>
+</sect1>
+<!--  ~  End section  ~  -->
 
 
-<!--   ~~~~~       New section      ~~~~~     -->
+<!--   ~~~~~~~~       New section Header    ~~~~~~~~~     -->
 
-<sect2 id="config">
+<sect1 id="config">
 <title>The Main Configuration File</title>
+
 <para>
  Again, the main configuration file is named <filename>config</filename> on
  Linux/Unix/BSD and OS/2, and <filename>config.txt</filename> on Windows.
@@ -851,8 +963,7 @@ automatically start Privoxy in the boot process.
  <literal>
   <msgtext> 
    <literallayout>
-  <emphasis>confdir /etc/privoxy</emphasis>
-   </literallayout>
+  <emphasis>confdir /etc/privoxy</emphasis></literallayout>
   </msgtext>
  </literal> 
 </para>
@@ -878,18 +989,23 @@ automatically start Privoxy in the boot process.
 
 <!--   ~~~~~       New section      ~~~~~     -->
 
-<sect3 id="conf-log-loc">
+<sect2 id="conf-log-loc">
 <title>Configuration and Log File Locations</title>
 
 <para>
  <application>Privoxy</application> can (and normally does) use a number of
- other files for additional configuration and logging.
+ other files for additional configuration, help and logging.
  This section of the configuration file tells <application>Privoxy</application>
  where to find those other files. 
 </para>
 
+<para>
+ The user running Privoxy, must have read permission for all 
+ configuration files, and write permission to any files that would 
+ be modified, such as log files.
+</para>
 
-<sect4 id="confdir"><title>confdir</title>
+<sect3 renderas="sect4" id="confdir"><title>confdir</title>
 
 <variablelist>
  <varlistentry>
@@ -932,10 +1048,10 @@ automatically start Privoxy in the boot process.
   </listitem>
  </varlistentry>
 </variablelist>
-</sect4>
+</sect3>
 
 
-<sect4 id="logdir"><title>logdir</title>
+<sect3 renderas="sect4" id="logdir"><title>logdir</title>
 
 <variablelist>
  <varlistentry>
@@ -974,28 +1090,28 @@ automatically start Privoxy in the boot process.
   </listitem>
  </varlistentry>
 </variablelist>
-</sect4>
+</sect3>
 
-<sect4 id="actionsfile"><title>
+<sect3 renderas="sect4" id="actionsfile"><title>
 actionsfile
 </title>
 <anchor id="default.action">
 <anchor id="standard.action">
 <anchor id="user.action">
-
+<!-- Note: slightly modified this section 04/28/02, hal. See NOTE. -->
 <variablelist>
  <varlistentry>
   <term>Specifies:</term>
   <listitem>
    <para>
-    The <link linkend="actions">actions</link> file(s) to use
+    The <link linkend="actions-file">actions file(s)</link> to use
    </para>
   </listitem>
  </varlistentry>
  <varlistentry>
   <term>Type of value:</term>
   <listitem>
-   <para>File name, relative to <literal>confdir</literal></para>
+   <para>File name, relative to <literal>confdir</literal>, without the <literal>.action</literal> suffix</para>
   </listitem>
  </varlistentry>
  <varlistentry>
@@ -1003,7 +1119,7 @@ actionsfile
   <listitem>
    <simplelist>
     <member>
-     <msgtext><literallayout>  standard     # Internal purposes, recommended not editing</literallayout></msgtext>
+     <msgtext><literallayout>  standard     # Internal purposes, no editing recommended</literallayout></msgtext>
     </member>
     <member>
      <msgtext><literallayout>  default      # Main actions file</literallayout></msgtext>
@@ -1026,7 +1142,7 @@ actionsfile
   <term>Notes:</term>
   <listitem>
    <para>
-    Multiple <literal>actionsfile</literal> lines are OK and are in fact recommended!
+    Multiple <literal>actionsfile</literal> lines are permitted, and are in fact recommended!
    </para>
    <para> 
     The default values include standard.action, which is used for internal
@@ -1035,14 +1151,17 @@ actionsfile
     <filename>user.action</filename>, where you can make your personal additions.
    </para>
    <para> 
-    There is no point in using <application>Privoxy</application> without an actions file.
+    Actions files are where all the per site and per URL configuration is done for 
+    ad blocking, cookie management, privacy considerations, etc.
+    There is no point in using <application>Privoxy</application> without at 
+    least one actions file.
    </para>
   </listitem>
  </varlistentry>
 </variablelist>
-</sect4>
+</sect3>
 
-<sect4 id="filterfile"><title>filterfile</title>
+<sect3 renderas="sect4" id="filterfile"><title>filterfile</title>
 <anchor id="default.filter">
 <variablelist>
  <varlistentry>
@@ -1071,7 +1190,7 @@ actionsfile
    <para>
     No textual content filtering takes place, i.e. all
     <literal>+filter{<replaceable class="parameter">name</replaceable>}</literal>
-    actions in the actions files are turned off
+    actions in the actions files are turned neutral.
    </para>
   </listitem>
  </varlistentry>
@@ -1089,9 +1208,9 @@ actionsfile
   </listitem>
  </varlistentry>
 </variablelist>
-</sect4>
+</sect3>
 
-<sect4 id="logfile"><title>logfile</title>
+<sect3 renderas="sect4" id="logfile"><title>logfile</title>
 
 <variablelist>
  <varlistentry>
@@ -1147,12 +1266,16 @@ actionsfile
     the effect that cron.daily will automatically archive, gzip, and empty the
     log, when it exceeds 1M size.
    </para>
+   <para>
+    Any log files must be writable by whatever user <application>Privoxy</application>
+    is being run as (default on UNIX, user id is <quote>privoxy</quote>).
+   </para>
   </listitem>
  </varlistentry>
 </variablelist>
-</sect4>
+</sect3>
 
-<sect4 id="jarfile"><title>jarfile</title>
+<sect3 renderas="sect4" id="jarfile"><title>jarfile</title>
 
 <variablelist>
  <varlistentry>
@@ -1192,10 +1315,9 @@ actionsfile
   </listitem>
  </varlistentry>
 </variablelist>
-</sect4>
-
-<sect4 id="trustfile"><title>trustfile</title>
+</sect3>
 
+<sect3 renderas="sect4" id="trustfile"><title>trustfile</title>
 <variablelist>
  <varlistentry>
   <term>Specifies:</term>
@@ -1247,9 +1369,8 @@ actionsfile
   </listitem>
  </varlistentry>
 </variablelist>
-</sect4>
-
 </sect3>
+</sect2>
 
 <!--  ~  End section  ~  -->
 
@@ -1257,7 +1378,7 @@ actionsfile
 
 <!--   ~~~~~       New section      ~~~~~     -->
 
-<sect3 id="local-set-up">
+<sect2 id="local-set-up">
 <title>Local Set-up Documentation</title>
 
   <para>
@@ -1266,7 +1387,73 @@ actionsfile
     you, what you block and why you do that, your policies etc.
    </para>
 
-<sect4 id="trust-info-url"><title>trust-info-url</title>
+<sect3 renderas="sect4" id="user-manual"><title>user-manual</title>
+<variablelist>
+ <varlistentry>
+  <term>Specifies:</term>
+  <listitem>
+   <para>
+    Location of the <application>Privoxy</application> User Manual.
+   </para>
+  </listitem>
+ </varlistentry>
+ <varlistentry>
+  <term>Type of value:</term>
+  <listitem>
+   <para>A fully qualified URI</para>
+  </listitem>
+ </varlistentry>
+ <varlistentry>
+  <term>Default value:</term>
+  <listitem>
+   <para><emphasis>Unset</emphasis></para>
+  </listitem>
+ </varlistentry>
+ <varlistentry>
+  <term>Effect if unset:</term>
+  <listitem>
+   <para>
+    <ulink url="http://www.privoxy.org/user-manual/">http://www.privoxy.org/<replaceable class="parameter">version</replaceable>/user-manual/</ulink>
+    will be used, where <replaceable class="parameter">version</replaceable> is the <application>Privoxy</application> version.
+   </para>
+  </listitem>
+ </varlistentry>
+ <varlistentry>
+  <term>Notes:</term>
+  <listitem>
+    <para>
+    The User Manual URI is used for help links from some of the internal CGI pages. 
+    The manual itself is normally packaged with the binary distributions, so you propably want
+    to set this to a locally installed copy. For multi-user setups, you could provide a copy on
+    a local webserver for all your users and use the corresponding URL here.
+   </para>
+   <para>
+    Examples:
+   </para>
+  <para>
+   Unix, in local filesystem:
+  </para>
+  <para>
+   <screen>user-manual&nbsp;&nbsp;file:///usr/share/doc/privoxy-&p-version;/user-manual/</screen>
+  </para>
+  <para>
+   Any platform, on local webserver (called <quote>local-webserver</quote>):
+  </para>
+  <para>
+   <screen>user-manual&nbsp;&nbsp;http://local-webserver/privoxy-user-manual/</screen>
+  </para>
+  <warning>
+   <para>
+     If set, this option should be <emphasis>the first option in the config file</emphasis>, because
+     it is used while the config file is being read.
+   </para>
+  </warning>     
+ </listitem>
+ </varlistentry>
+</variablelist>
+</sect3>
+
+<sect3 renderas="sect4" id="trust-info-url"><title>trust-info-url</title>
 
 <variablelist>
  <varlistentry>
@@ -1316,9 +1503,9 @@ actionsfile
   </listitem>
  </varlistentry>
 </variablelist>
-</sect4>
+</sect3>
 
-<sect4 id="admin-address"><title>admin-address</title>
+<sect3 renderas="sect4" id="admin-address"><title>admin-address</title>
 
 <variablelist>
  <varlistentry>
@@ -1360,9 +1547,9 @@ actionsfile
   </listitem>
  </varlistentry>
 </variablelist>
-</sect4>
+</sect3>
 
-<sect4 id="proxy-info-url"><title>proxy-info-url</title>
+<sect3 renderas="sect4" id="proxy-info-url"><title>proxy-info-url</title>
 
 <variablelist>
  <varlistentry>
@@ -1408,14 +1595,14 @@ actionsfile
   </listitem>
  </varlistentry>
 </variablelist>
-</sect4>
-
 </sect3>
+
+</sect2>
 <!--  ~  End section  ~  -->
 
 <!--   ~~~~~       New section      ~~~~~     -->
 
-<sect3 id="debugging">
+<sect2 id="debugging">
 <title>Debugging</title>
 
  <para>
@@ -1425,7 +1612,7 @@ actionsfile
   command line option when debugging.
  </para>
 
-<sect4 id="debug"><title>debug</title>
+<sect3 renderas="sect4" id="debug"><title>debug</title>
 
 <variablelist>
  <varlistentry>
@@ -1502,9 +1689,9 @@ actionsfile
   </listitem>
  </varlistentry>
 </variablelist>
-</sect4>
+</sect3>
 
-<sect4 id="single-threaded"><title>single-threaded</title>
+<sect3 renderas="sect4" id="single-threaded"><title>single-threaded</title>
 
 <variablelist>
  <varlistentry>
@@ -1546,13 +1733,13 @@ actionsfile
   </listitem>
  </varlistentry>
 </variablelist>
-</sect4>
-
 </sect3>
 
+</sect2>
+
 <!--   ~~~~~       New section      ~~~~~     -->
 
-<sect3 id="access-control">
+<sect2 id="access-control">
 <title>Access Control and Security</title>
 
  <para>
@@ -1560,7 +1747,7 @@ actionsfile
   of <application>Privoxy</application>'s configuration.
  </para>
 
-<sect4 id="listen-address"><title>listen-address</title>
+<sect3 renderas="sect4" id="listen-address"><title>listen-address</title>
 
 <variablelist>
  <varlistentry>
@@ -1578,6 +1765,7 @@ actionsfile
    <para>[<replaceable class="parameter">IP-Address</replaceable>]:<replaceable class="parameter">Port</replaceable></para>
   </listitem>
  </varlistentry>
+
  <varlistentry>
   <term>Default value:</term>
   <listitem>
@@ -1630,9 +1818,9 @@ actionsfile
   </listitem>
  </varlistentry>
 </variablelist>
-</sect4>
+</sect3>
 
-<sect4 id="toggle"><title>toggle</title>
+<sect3 renderas="sect4" id="toggle"><title>toggle</title>
 
 <variablelist>
  <varlistentry>
@@ -1672,7 +1860,7 @@ actionsfile
     proxy. See <literal>enable-remote-toggle</literal>
     below. This is not really useful anymore, since toggling is much easier
     via <ulink url="http://config.privoxy.org/toggle">the web
-    interface</ulink> then via editing the <filename>conf</filename> file.
+    interface</ulink> than via editing the <filename>conf</filename> file.
    </para>
    <para>
     The windows version will only display the toggle icon in the system tray
@@ -1681,10 +1869,10 @@ actionsfile
   </listitem>
  </varlistentry>
 </variablelist>
-</sect4>
+</sect3>
 
 
-<sect4 id="enable-remote-toggle"><title>enable-remote-toggle</title>
+<sect3 renderas="sect4" id="enable-remote-toggle"><title>enable-remote-toggle</title>
 <variablelist>
  <varlistentry>
   <term>Specifies:</term>
@@ -1738,10 +1926,10 @@ actionsfile
   </listitem>
  </varlistentry>
 </variablelist>
-</sect4>
+</sect3>
 
 
-<sect4 id="enable-edit-actions"><title>enable-edit-actions</title>
+<sect3 renderas="sect4" id="enable-edit-actions"><title>enable-edit-actions</title>
 <variablelist>
  <varlistentry>
   <term>Specifies:</term>
@@ -1790,9 +1978,9 @@ actionsfile
   </listitem>
  </varlistentry>
 </variablelist>
-</sect4>
+</sect3>
 
-<sect4 id="acls"><title>
+<sect3 renderas="sect4" id="acls"><title>
 ACLs: permit-access and deny-access</title>
 <anchor id="permit-acces">
 <anchor id="deny-acces">
@@ -1915,9 +2103,9 @@ ACLs: permit-access and deny-access</title>
   </listitem>
  </varlistentry>
 </variablelist>
-</sect4>
+</sect3>
 
-<sect4 id="buffer-limit"><title>buffer-limit</title>
+<sect3 renderas="sect4" id="buffer-limit"><title>buffer-limit</title>
 
 <variablelist>
  <varlistentry>
@@ -1970,16 +2158,16 @@ ACLs: permit-access and deny-access</title>
   </listitem>
  </varlistentry>
 </variablelist>
-</sect4>
-
 </sect3>
 
+</sect2>
+
 <!--  ~  End section  ~  -->
 
 
 <!--   ~~~~~       New section      ~~~~~     -->
 
-<sect3 id="forwarding">
+<sect2 id="forwarding">
 <title>Forwarding</title>
 
 <para>
@@ -1999,7 +2187,7 @@ ACLs: permit-access and deny-access</title>
  supports the SOCKS 4 and SOCKS 4A protocols.
 </para>
 
-<sect4 id="forward"><title>forward</title>
+<sect3 renderas="sect4" id="forward"><title>forward</title>
 <variablelist>
  <varlistentry>
   <term>Specifies:</term>
@@ -2078,9 +2266,9 @@ ACLs: permit-access and deny-access</title>
   </listitem>
  </varlistentry>
 </variablelist>
-</sect4>
+</sect3>
 
-<sect4 id="socks"><title>
+<sect3 renderas="sect4" id="socks"><title>
 forward-socks4 and forward-socks4a</title>
 <anchor id="forward-socks4">
 <anchor id="forward-socks4a">
@@ -2170,9 +2358,9 @@ forward-socks4 and forward-socks4a</title>
   </listitem>
  </varlistentry>
 </variablelist>
-</sect4>
+</sect3>
 
-<sect4 id="advanced-forwarding-examples"><title>Advanced Forwarding Examples</title>
+<sect3 renderas="sect4" id="advanced-forwarding-examples"><title>Advanced Forwarding Examples</title>
 
 <para>
  If you have links to multiple ISPs that provide various special content 
@@ -2246,16 +2434,16 @@ forward-socks4 and forward-socks4a</title>
  Squid normally uses port 3128. If unsure consult <literal>http_port</literal> in <filename>squid.conf</filename>.
 </para>
 
-</sect4>
-
 </sect3>
 
+</sect2>
+
 <!--  ~  End section  ~  -->
 
 
 <!--   ~~~~~       New section      ~~~~~     -->
 
-<sect3 id="windows-gui">
+<sect2 id="windows-gui">
 <title>Windows GUI Options</title>
 <para>
  <application>Privoxy</application> has a number of options specific to the
@@ -2427,59 +2615,104 @@ forward-socks4 and forward-socks4a</title>
  <literal>
   <msgtext> 
    <literallayout>
-  #hide-console
+  #<emphasis>hide-console</emphasis>
    </literallayout>
   </msgtext> 
  </literal>
 </para>
 
-</sect3>
 </sect2>
+</sect1>
 
 <!--  ~  End section  ~  -->
 
 
-<!--   ~~~~~       New section      ~~~~~     -->
-<sect2 id="actions-file"><title>Actions Files</title>
+
+<!--   ~~~~~~~~       New section Header    ~~~~~~~~~     -->
+
+<sect1 id="actions-file"><title>Actions Files</title>
 
 <para>
  The actions files are used to define what actions
- <application>Privoxy</application> takes for which URLs, and thus determines
+ <application>Privoxy</application> takes for which URLs, and thus determine
  how ad images, cookies and various other aspects of HTTP content and
  transactions are handled, and on which sites (or even parts thereof). There 
- are three such files included with <application>Privoxy</application>, 
- with slightly different purposes. <filename>default.action</filename> sets
- the default policies. <filename>standard.action</filename> is used by 
- <application>Privoxy</application> and the web based editor to set 
- pre-defined values (and normally should not be edited). Local exceptions 
- are best done in <filename>user.action</filename>. The content of these 
- can all be viewed and edited from <ulink
- url="http://config.privoxy.org/show-status">http://config.privoxy.org/show-status</ulink>.
+ are three such files included with <application>Privoxy</application> (as of 
+ version 2.9.15), with differing purposes:
  </para>
+ <para>
+  <itemizedlist>
+   <listitem>
+    <para>
+      <filename>standard.action</filename> - is used by the web based editor, 
+      to set various pre-defined sets of rules for the default actions section
+      in <filename>default.action</filename>. These have increasing levels of
+      aggressiveness <emphasis>and have no influence on your browsing unless
+      you select them explicitly in the editor</emphasis>. It is not recommend
+      to edit this file.
+    </para>
+   </listitem> 
+   <listitem>
+    <para>
+     <filename>default.action</filename> - is the primary action file 
+     that sets the initial values for all actions. It is intended to 
+     provide a base level of functionality for
+     <application>Privoxy's</application> array of features. So it is 
+     a set of broad rules that should work reasonably well for users everywhere.
+     This is the file that the developers are keeping updated, and making 
+     available to users.
+    </para>
+   </listitem> 
+   <listitem>
+    <para>
+     <filename>user.action</filename> - is intended to be for local site 
+     preferences and exceptions. As an example, if your ISP or your bank
+     has specific requirements, and need special handling, this kind of 
+     thing should go here. This file will not be upgraded.
+    </para>
+  </listitem> 
+  </itemizedlist>
+ </para> 
 
-<para> 
- Anything you want can be blocked, including ads, banners, or just some obnoxious
- URL that you would rather not see is done here. Cookies can be accepted or rejected, or
- accepted only during the current browser session (i.e. not written to disk),
- content can be modified, JavaScripts tamed, user-tracking fooled, and much more.
- See below for a complete list of available actions.
+<para>
+ The list of actions files to be used are defined in the main configuration 
+ file, and are processed in the order they are defined. The content of these
+ can all be viewed and edited from <ulink
+ url="http://config.privoxy.org/show-status">http://config.privoxy.org/show-status</ulink>.
 </para>
 
 <para>
- An actions file typically has sections. Near the top, <quote>aliases</quote> are 
- optionally defined (discussed <ulink
- url="configuration.html#ALIASES">below</ulink>), then the default set of rules
- which will apply universally to all sites and pages. And then below that,
- exceptions to the defined universal policies. 
+ An actions file typically has multiple sections. If you want to use
+ <quote>aliases</quote> in an actions file, you have to place the (optional)
+ <link linkend="aliases">alias section</link> at the top of that file.
+ Then comes the default set of rules which will apply universally to all
+ sites and pages (be <emphasis>very careful</emphasis> with using such a
+ universal set in <filename>user.action</filename> or any other actions file after 
+ <filename>default.action</filename>, because it will override the result
+ from consulting any previous file). And then below that,
+ exceptions to the defined universal policies. You can regard
+ <filename>user.action</filename> as an appendix to <filename>default.action</filename>,
+ with the advantage that is a separate file, which makes preserving your
+ personal settings across <application>Privoxy</application> upgrades easier.
+</para>
+
+<para> 
+ Actions can be used to block anything you want, including ads, banners, or
+ just some obnoxious URL that you would rather not see. Cookies can be accepted
+ or rejected, or accepted only during the current browser session (i.e. not
+ written to disk), content can be modified, JavaScripts tamed, user-tracking
+ fooled, and much more. See below for a <link linkend="actions">complete list
+ of actions</link>.
 </para>
 
 <!--   ~~~~~       New section      ~~~~~     -->
-<sect3>
+<sect2>
 <title>Finding the Right Mix</title>
 <para>
- Note that some <link linkend="actions">actions</link> like cookie suppression
- or script disabling may render some sites unusable, which rely on these
- techniques to work properly. Finding the right mix of actions is not easy and
+ Note that some <link linkend="actions">actions</link>, like cookie suppression
+ or script disabling, may render some sites unusable that rely on these
+ techniques to work properly. Finding the right mix of actions is not always easy and
  certainly a matter of personal taste. In general, it can be said that the more
  <quote>aggressive</quote> your default settings (in the top section of the
  actions file) are, the more exceptions for <quote>trusted</quote> sites you
@@ -2495,25 +2728,29 @@ forward-socks4 and forward-socks4a</title>
  things. There just are too many variables, and sites are constantly changing.
  Sooner or later you will want to change the rules (and read this chapter again :).
 </para>
-</sect3>
+</sect2>
 
 <!--   ~~~~~       New section      ~~~~~     -->
-<sect3>
+<sect2>
 <title>How to Edit</title>
 <para>
- The easiest way to edit the <quote>actions</quote> files is with a browser by
+ The easiest way to edit the actions files is with a browser by
  using our browser-based editor, which can be reached from <ulink
  url="http://config.privoxy.org/show-status">http://config.privoxy.org/show-status</ulink>.
+ The editor allows both fine-grained control over every single feature on a
+ per-URL basis, and easy choosing from wholesale sets of defaults like
+ <quote>Cautious</quote>, <quote>Medium</quote> or <quote>Advanced</quote>.
 </para>
 
 <para>
  If you prefer plain text editing to GUIs, you can of course also directly edit the
- the actions files.
+ the actions files. Look at <filename>default.action</filename> which is richly
+ commented.
 </para>
-</sect3>
+</sect2>
 
 
-<sect3>
+<sect2>
 <title>How Actions are Applied to URLs</title>
 <para>
  Actions files are divided into sections. There are special sections,
@@ -2526,18 +2763,18 @@ forward-socks4 and forward-socks4a</title>
 
 <para>
  To determine which actions apply to a request, the URL of the request is
- compared to all patterns in this file. Every time it matches, the list of
+ compared to all patterns in each action file file. Every time it matches, the list of
  applicable actions for the URL is incrementally updated, using the heading
  of the section in which the pattern is located. If multiple matches for
  the same URL set the same action differently, the last match wins. If not, 
  the effects are aggregated (e.g. a URL might match both the 
- <ulink url="configuration.html#HANDLE-AS-IMAGE"><quote>+handle-as-image</quote></ulink>
- and <ulink url="configuration.html#BLOCK"><quote>+block</quote></ulink> actions).
+ <ulink url="actions-file.html#HANDLE-AS-IMAGE"><quote>+handle-as-image</quote></ulink>
+ and <ulink url="actions-file.html#BLOCK"><quote>+block</quote></ulink> actions).
  
 </para>
 
 <para>
- You can trace this process by visiting <ulink
+ You can trace this process for any given URL by visiting <ulink
  url="http://config.privoxy.org/show-url-info">http://config.privoxy.org/show-url-info</ulink>.
 </para>
 
@@ -2545,10 +2782,10 @@ forward-socks4 and forward-socks4a</title>
  More detail on this is provided in the Appendix, <link linkend="ACTIONSANAT">
  Anatomy of an Action</link>.
 </para>
-</sect3>
+</sect2>
 
 <!--   ~~~~~       New section      ~~~~~     -->
-<sect3>
+<sect2>
 <title>Patterns</title>
 <para>
  Generally, a pattern has the form <literal>&lt;domain&gt;/&lt;path&gt;</literal>,
@@ -2604,7 +2841,9 @@ forward-socks4 and forward-socks4a</title>
  </varlistentry>
 </variablelist>
 
-<sect4><title>The Domain Pattern</title>
+
+<!--   ~~~~~       New section      ~~~~~     -->
+<sect3><title>The Domain Pattern</title>
 
 <para>
  The matching of the domain part offers some flexible options: if the
@@ -2690,9 +2929,13 @@ forward-socks4 and forward-socks4a</title>
  </varlistentry>
 </variablelist>
 
-</sect4>
+</sect3>
+
+<!--  ~  End section  ~  -->
 
-<sect4><title>The Path Pattern</title>
+
+<!--   ~~~~~       New section      ~~~~~     -->
+<sect3><title>The Path Pattern</title>
 
 <para>
  <application>Privoxy</application> uses Perl compatible regular expressions
@@ -2724,88 +2967,99 @@ forward-socks4 and forward-socks4a</title>
  documents whose path starts with <literal>PaTtErN</literal> in
  <emphasis>exactly</emphasis> this capitalization.
 </para>
-</sect4>
-
 </sect3>
 
+</sect2>
+
 <!--  ~  End section  ~  -->
 
 
 <!--   ~~~~~       New section      ~~~~~     -->
 
-<sect3 id="actions">
+<sect2 id="actions">
 <title>Actions</title>
 <para>
  All actions are disabled by default, until they are explicitly enabled
  somewhere in an actions file. Actions are turned on if preceded with a
  <quote>+</quote>, and turned off if preceded with a <quote>-</quote>. So a
- <quote>+action</quote> means <quote>do that action</quote>, e.g.
- <quote>+block</quote> means please <quote>block the following URL
- patterns</quote>. 
+ <literal>+action</literal> means <quote>do that action</quote>, e.g.
+ <literal>+block</literal> means <quote>please block URLs that match the
+ following patterns</quote>, and <literal>-block</literal> means <quote>don't
+ block URLs that match the following patterns, even if <literal>+block</literal>
+ previously applied.</quote>
+
 </para>
 
 <para> 
- Actions are invoked by enclosing the action name in curly braces (e.g.
- {+some_action}), followed by a list of URLs (or patterns that match URLs) to
- which the action applies. There are three classes of actions: 
+ Again, actions are invoked by placing them on a line, enclosed in curly braces and
+ separated by whitespace, like in 
+ <literal>{+some-action -some-other-action{some-parameter}}</literal>,
+ followed by a list of URL patterns, one per line, to which they apply.
+ Together, the actions line and the following pattern lines make up a section
+ of the actions file. 
+</para>
+
+<para> 
+ There are three classes of actions:
 </para>
 
 <para>
  <itemizedlist>
-
  <listitem>
   <para>  
-   Boolean, i.e the action can only be <quote>on</quote> or
-   <quote>off</quote>. Examples: 
- </para>
+   Boolean, i.e the action can only be <quote>enabled</quote> or
+   <quote>disabled</quote>. Syntax:
 </para>
   <para>
-   <literal>
-    <msgtext> 
-     <literallayout>
-  <emphasis>{+name}</emphasis>        # enable this action
-  <emphasis>{-name}</emphasis>        # disable this action
-     </literallayout>
-    </msgtext> 
-   </literal>
+   <screen>
+  +<replaceable class="function">name</replaceable>        # enable action <replaceable class="parameter">name</replaceable>
+  -<replaceable class="function">name</replaceable>        # disable action <replaceable class="parameter">name</replaceable></screen>
+  </para>
+  <para>  
+   Example: <literal>+block</literal>
   </para>
  </listitem>
 
 
  <listitem>
   <para>  
-   Parameterized, e.g. <quote>+/-hide-user-agent{ Mozilla 1.0 }</quote>, 
-   where some value is required in order to enable this type of action.
-   Examples:
+   Parameterized, where some value is required in order to enable this type of action.
+   Syntax:
+  </para>
+  <para>
+   <screen>
+  +<replaceable class="function">name</replaceable>{<replaceable class="parameter">param</replaceable>}  # enable action and set parameter to <replaceable class="parameter">param</replaceable>,
+               # overwriting parameter from previous match if necessary
+  -<replaceable class="function">name</replaceable>         # disable action. The parameter can be omitted</screen>
   </para>
   <para>
-   <literal>
-    <msgtext> 
-     <literallayout>
-  <emphasis>{+name{param}}</emphasis>  # enable action and set parameter to <quote>param</quote>
-  <emphasis>{-name}</emphasis>         # disable action (<quote>parameter</quote>) can be omitted
-     </literallayout>
-    </msgtext> 
-   </literal>
+   Note that if the URL matches multiple positive forms of a parameterized action,
+   the last match wins, i.e. the params from earlier matches are simply ignored.
+  </para>
+  <para>  
+   Example: <literal>+hide-user-agent{ Mozilla 1.0 }</literal>
   </para>
  </listitem>
  
  <listitem>
   <para>  
-  <!-- oes, or someone, check this. Re-worded 04/20/02 HB. -->
-   Multi-value, e.g. <quote>{+/-add-header{Name: value}}</quote> or
-   <quote>{+/-send-wafer{name=value}}</quote>), where some value needs to be defined
-   in addition to simply enabling the action. Examples:
+   Multi-value. These look exactly like parameterized actions,
+   but they behave differently: If the action applies multiple times to the
+   same URL, but with different parameters, <emphasis>all</emphasis> the parameters
+   from <emphasis>all</emphasis> matches are remembered. This is used for actions
+   that can be executed for the same request repeatedly, like adding multiple
+   headers, or filtering through multiple filters. Syntax:
   </para>
   <para>
-   <literal>
-    <msgtext> 
-     <literallayout>
-  <emphasis>{+name{param=value}}</emphasis>   # enable action and set <quote>param</quote> to <quote>value</quote>
-  <emphasis>{-name{param=value}}</emphasis>   # remove the parameter <quote>param</quote> completely
-  <emphasis>{-name}</emphasis>                # disable this action totally and remove <application>param</application> too
-     </literallayout>
-    </msgtext> 
-   </literal>
+   <screen>
+  +<replaceable class="function">name</replaceable>{<replaceable class="parameter">param</replaceable>}   # enable action and add <replaceable class="parameter">param</replaceable> to the list of parameters
+  -<replaceable class="function">name</replaceable>{<replaceable class="parameter">param</replaceable>}   # remove the parameter <replaceable class="parameter">param</replaceable> from the list of parameters
+                # If it was the last one left, disable the action.
+  <replaceable class="parameter">-name</replaceable>          # disable this action completely and remove all parameters from the list</screen>
+  </para>
+  <para>  
+   Examples: <literal>+add-header{X-Fun-Header: Some text}</literal> and
+   <literal>+filter{html-annoyances}</literal>
   </para>
  </listitem>
 
@@ -2828,12 +3082,12 @@ forward-socks4 and forward-socks4a</title>
  Actions files are processed in the order they are defined in
  <filename>config</filename> (the default installation has three actions
  files). It also quite possible for any given URL pattern to match more than
- one action!
+ one pattern and thus more than one set of actions!
 </para>
 
 <!-- start actions listing -->
 <para>
- The list of valid <application>Privoxy</application> <quote>actions</quote> are:
+ The list of valid <application>Privoxy</application> actions are:
 </para>
 
 
@@ -2846,7 +3100,7 @@ forward-socks4 and forward-socks4a</title>
 
 <!--   ~~~~~       New section      ~~~~~     -->
 
-<sect4 id="add-header">
+<sect3 renderas="sect4" id="add-header">
 <title><emphasis>+add-header</emphasis></title>
 
 <variablelist>
@@ -2859,10 +3113,10 @@ forward-socks4 and forward-socks4a</title>
  </varlistentry>
  
  <varlistentry>
-  <term>Typical uses:</term>
+  <term>Purpose and typical uses:</term>
   <listitem>
    <para>
-    Send a user defined HTTP header to the web server.
+    Send a user defined HTTP header to the web server. Can be used to confuse log analysis.
    </para>
   </listitem>
  </varlistentry>
@@ -2872,6 +3126,8 @@ forward-socks4 and forward-socks4a</title>
   <listitem>
    <para>
     Any value is possible. Validity of the defined HTTP headers is not checked.
+    It is recommended that you use the <quote><literal>X-</literal></quote> prefix
+    for custom headers.
    </para>
   </listitem>
  </varlistentry>
@@ -2881,8 +3137,7 @@ forward-socks4 and forward-socks4a</title>
   <listitem>
     <literallayout>
      <emphasis>{+add-header{X-User-Tracking: sucks}}</emphasis>
-     <emphasis>.example.com</emphasis>
-    </literallayout>
+     <emphasis>.example.com</emphasis></literallayout>
   </listitem>
  </varlistentry>
 
@@ -2898,11 +3153,11 @@ forward-socks4 and forward-socks4a</title>
   </listitem>
  </varlistentry>
 </variablelist>
-</sect4>
+</sect3>
 
 
 <!--   ~~~~~       New section      ~~~~~     -->
-<sect4 id="block">
+<sect3 renderas="sect4" id="block">
 <title><emphasis>+block</emphasis></title>
 
 <variablelist>
@@ -2915,12 +3170,14 @@ forward-socks4 and forward-socks4a</title>
  </varlistentry>
 
  <varlistentry>
-  <term>Typical uses:</term>
+  <term>Purpose and typical uses:</term>
   <listitem>
    <para>
-    Used to block a URL from reaching your browser. The URL may be 
-    anything, but is typically used to block ads or other obnoxious 
-    content.    
+    Requests for URLs to which this action applies are blocked, i.e. the requests are not
+    forwarded to the remote server, but answered locally with a substitute page or image,
+    as determined by the <link linkend="handle-as-image">handle-as-image</link> and  
+    <link linkend="set-image-blocker">set-image-blocker</link> actions.
+    It is typically used to block ads or other obnoxious content.    
    </para>
   </listitem>
  </varlistentry>
@@ -2961,15 +3218,15 @@ forward-socks4 and forward-socks4a</title>
    <para> 
     A very important exception is if the URL <emphasis>matches both</emphasis>
     <quote>+block</quote> and <ulink
-    url="configuration.html#HANDLE-AS-IMAGE"><quote>+handle-as-image</quote></ulink>,
+    url="actions-file.html#HANDLE-AS-IMAGE"><quote>+handle-as-image</quote></ulink>,
     then it will be handled by 
-    <ulink url="configuration.html#SET-IMAGE-BLOCKER"><quote>+set-image-blocker</quote></ulink>
+    <ulink url="actions-file.html#SET-IMAGE-BLOCKER"><quote>+set-image-blocker</quote></ulink>
     (see below). It is important to understand this process, in order 
     to understand how <application>Privoxy</application> is able to deal with 
     ads and other objectionable content.
    </para>
    <para>
-    The <ulink url="configuration.html#FILTER"><quote>+filter</quote></ulink>
+    The <ulink url="actions-file.html#FILTER"><quote>+filter</quote></ulink>
     action can also perform some of the 
     same functionality as <quote>+block</quote>, but by virtue of very 
     different programming techniques, and is most often used for different 
@@ -2979,11 +3236,11 @@ forward-socks4 and forward-socks4a</title>
  </varlistentry>
 
 </variablelist>
-</sect4>
+</sect3>
 
 
 <!--   ~~~~~       New section      ~~~~~     -->
-<sect4 id="deanimate-gifs">
+<sect3 renderas="sect4" id="deanimate-gifs">
 <title><emphasis>+deanimate-gifs</emphasis></title>
 
 <variablelist>
@@ -3039,10 +3296,10 @@ forward-socks4 and forward-socks4a</title>
  </varlistentry>
 
 </variablelist>
-</sect4>
+</sect3>
 
 <!--   ~~~~~       New section      ~~~~~     -->
-<sect4 id="downgrade-http-version">
+<sect3 renderas="sect4" id="downgrade-http-version">
 <title><emphasis>+downgrade-http-version</emphasis></title>
 
 <variablelist>
@@ -3096,10 +3353,10 @@ forward-socks4 and forward-socks4a</title>
  </varlistentry>
 
 </variablelist>
-</sect4>
+</sect3>
 
 <!--   ~~~~~       New section      ~~~~~     -->
-<sect4 id="fast-redirects">
+<sect3 renderas="sect4" id="fast-redirects">
 <title><emphasis>+fast-redirects</emphasis></title>
 
 <variablelist>
@@ -3169,11 +3426,11 @@ forward-socks4 and forward-socks4a</title>
  </varlistentry>
 
 </variablelist>
-</sect4>
+</sect3>
 
 
 <!--   ~~~~~       New section      ~~~~~     -->
-<sect4 id="filter">
+<sect3 renderas="sect4" id="filter">
 <title><emphasis>+filter</emphasis></title>
 
 <variablelist>
@@ -3213,61 +3470,73 @@ forward-socks4 and forward-socks4a</title>
   <listitem>
    <simplelist>
    <member>
+    <anchor id="filter-html-annoyances">
     <emphasis>+filter{html-annoyances}</emphasis>:  Get rid of particularly annoying HTML abuse.
    </member>
   </simplelist>
   <simplelist>
    <member>
+    <anchor id="filter-js-annoyances">
     <emphasis>+filter{js-annoyances}</emphasis>:    Get rid of particularly annoying JavaScript abuse
    </member>
   </simplelist>
   <simplelist>
    <member>
+    <anchor id="filter-content-cookies">
     <emphasis>+filter{content-cookies}</emphasis>:   Kill cookies that come in the HTML or JS content 
    </member>
   </simplelist>
   <simplelist>
    <member>
+    <anchor id="filter-popups">
     <emphasis>+filter{popups}</emphasis>:         Kill all popups in JS and HTML
    </member>
   </simplelist>
   <simplelist>
    <member>
+    <anchor id="filter-frameset-borders">
     <emphasis>+filter{frameset-borders}</emphasis>: Give frames a border and make them resizable 
    </member>
   </simplelist>
   <simplelist>
    <member>
+    <anchor id="filter-webbugs">
     <emphasis>+filter{webbugs}</emphasis>:          Squish WebBugs (1x1 invisible GIFs used for user tracking)
    </member>
   </simplelist>
   <simplelist>
    <member>
+    <anchor id="filter-refresh-tags">
     <emphasis>+filter{refresh-tags}</emphasis>:     Kill automatic refresh tags (for dial-on-demand setups) 
    </member>
   </simplelist>
   <simplelist>
    <member>
+    <anchor id="filter-fun">
     <emphasis>+filter{fun}</emphasis>:              Text replacements  for subversive browsing fun!
    </member>
   </simplelist>
   <simplelist>
    <member>
+    <anchor id="filter-nimda">
     <emphasis>+filter{nimda}</emphasis>:            Remove Nimda (virus) code.
    </member>
   </simplelist>
   <simplelist>
    <member>
+    <anchor id="filter-banners-by-size">
     <emphasis>+filter{banners-by-size}</emphasis>:  Kill banners by size (<emphasis>very</emphasis> efficient!)
    </member>
   </simplelist>
   <simplelist>
    <member>
+    <anchor id="filter-shockwave-flash">
     <emphasis>+filter{shockwave-flash}</emphasis>:   Kill embedded Shockwave Flash objects
    </member>
   </simplelist>
   <simplelist>
    <member>
+    <anchor id="filter-crude-parental">
     <emphasis>+filter{crude-parental}</emphasis>:   Kill all web pages that contain the words "sex" or "warez"
    </member>
   </simplelist>
@@ -3291,7 +3560,7 @@ forward-socks4 and forward-socks4a</title>
    </para>
    <para>
     Filtering can achieve some of the effects as the 
-    <ulink url="configuration.html#BLOCK"><quote>+block</quote></ulink>
+    <ulink url="actions-file#BLOCK"><quote>+block</quote></ulink>
     action, i.e. it can be used to block ads and banners. In the overall 
     scheme of things, filtering is one of the first things <quote>Privoxy</quote> 
     does with a web page. So other most other actions are applied to the 
@@ -3301,11 +3570,11 @@ forward-socks4 and forward-socks4a</title>
  </varlistentry>
 
 </variablelist>
-</sect4>
+</sect3>
 
 
 <!--   ~~~~~       New section      ~~~~~     -->
-<sect4 id="hide-forwarded-for-headers">
+<sect3 renderas="sect4" id="hide-forwarded-for-headers">
 <title><emphasis>+hide-forwarded-for-headers</emphasis></title>
 
 <variablelist>
@@ -3355,11 +3624,11 @@ forward-socks4 and forward-socks4a</title>
  </varlistentry>
 
 </variablelist>
-</sect4>
+</sect3>
 
 
 <!--   ~~~~~       New section      ~~~~~     -->
-<sect4 id="hide-from-header">
+<sect3 renderas="sect4" id="hide-from-header">
 <title><emphasis>+hide-from-header</emphasis></title>
 
 <variablelist>
@@ -3406,7 +3675,7 @@ forward-socks4 and forward-socks4a</title>
    <para>
     The keyword <quote>block</quote> will completely remove the header 
     (not to be confused with the <ulink
-    url="configuration.html#BLOCK"><quote>+block</quote></ulink> action).
+    url="actions-file.html#BLOCK"><quote>+block</quote></ulink> action).
     Alternately, you can specify any value you prefer to send to the web
     server.
    </para>
@@ -3414,11 +3683,11 @@ forward-socks4 and forward-socks4a</title>
  </varlistentry>
 
 </variablelist>
-</sect4>
+</sect3>
 
 
 <!--   ~~~~~       New section      ~~~~~     -->
-<sect4 id="hide-referer">
+<sect3 renderas="sect4" id="hide-referer">
 <title><emphasis>+hide-referer</emphasis></title>
 <anchor id="hide-referrer">
 <variablelist>
@@ -3479,11 +3748,11 @@ forward-socks4 and forward-socks4a</title>
  </varlistentry>
 
 </variablelist>
-</sect4>
+</sect3>
 
 
 <!--   ~~~~~       New section      ~~~~~     -->
-<sect4 id="hide-user-agent">
+<sect3 renderas="sect4" id="hide-user-agent">
 <title><emphasis>+hide-user-agent</emphasis></title>
 
 <variablelist>
@@ -3536,10 +3805,10 @@ forward-socks4 and forward-socks4a</title>
  </varlistentry>
 
 </variablelist>
-</sect4>
+</sect3>
 
 <!--   ~~~~~       New section      ~~~~~     -->
-<sect4 id="handle-as-image">
+<sect3 renderas="sect4" id="handle-as-image">
 <title><emphasis>+handle-as-image</emphasis></title>
 
 <variablelist>
@@ -3589,10 +3858,10 @@ forward-socks4 and forward-socks4a</title>
     <quote>+block</quote>ed, in which case a user definable image can
     be sent rather than a HTML page. This is integral to the whole concept of
     ad blocking: the URL must match <emphasis>both</emphasis> a <ulink
-    url="configuration.html#BLOCK"><quote>+block</quote></ulink> rule,
+    url="actions-file.html#BLOCK"><quote>+block</quote></ulink> rule,
     <emphasis>and</emphasis> <quote>+handle-as-image</quote>.
     (See <ulink
-    url="configuration.html#SET-IMAGE-BLOCKER"><quote>+set-image-blocker</quote></ulink>
+    url="actions-file.html#SET-IMAGE-BLOCKER"><quote>+set-image-blocker</quote></ulink>
     below for control over what will actually be displayed by the browser.)
    </para>
    <para>
@@ -3602,11 +3871,11 @@ forward-socks4 and forward-socks4a</title>
  </varlistentry>
 
 </variablelist>
-</sect4>
+</sect3>
 
 
 <!--   ~~~~~       New section      ~~~~~     -->
-<sect4 id="set-image-blocker">
+<sect3 renderas="sect4" id="set-image-blocker">
 <title><emphasis>+set-image-blocker</emphasis></title>
 
 <variablelist>
@@ -3623,9 +3892,9 @@ forward-socks4 and forward-socks4a</title>
   <listitem>
    <para>
     Decide what to do with URLs that end up tagged with <emphasis>both</emphasis> 
-    <ulink url="configuration.html#BLOCK"><quote>+block</quote></ulink>
+    <ulink url="actions-file.html#BLOCK"><quote>+block</quote></ulink>
     and <ulink
-    url="configuration.html#HANDLE-AS-IMAGE"><quote>+handle-as-image</quote></ulink>,
+    url="actions-file.html#HANDLE-AS-IMAGE"><quote>+handle-as-image</quote></ulink>,
     e.g an advertisement.
    </para>
   </listitem>
@@ -3677,10 +3946,10 @@ forward-socks4 and forward-socks4a</title>
  </varlistentry>
 
 </variablelist>
-</sect4>
+</sect3>
 
 <!--   ~~~~~       New section      ~~~~~     -->
-<sect4 id="limit-connect">
+<sect3 renderas="sect4" id="limit-connect">
 <title><emphasis>+limit-connect</emphasis></title>
 
 <variablelist>
@@ -3752,10 +4021,10 @@ forward-socks4 and forward-socks4a</title>
  </varlistentry>
 
 </variablelist>
-</sect4>
+</sect3>
 
 <!--   ~~~~~       New section      ~~~~~     -->
-<sect4 id="prevent-compression">
+<sect3 renderas="sect4" id="prevent-compression">
 <title><emphasis>+prevent-compression</emphasis></title>
 
 <variablelist>
@@ -3801,10 +4070,10 @@ forward-socks4 and forward-socks4a</title>
    <para>
     Some websites do this, which can be a problem for
     <application>Privoxy</application>, since 
-    <ulink url="configuration.html#FILTER"><quote>+filter</quote></ulink>,
-    <ulink url="configuration.html#KILL-POPUPS"><quote>+kill-popups</quote></ulink>
+    <ulink url="actions-file.html#FILTER"><quote>+filter</quote></ulink>,
+    <ulink url="actions-file.html#KILL-POPUPS"><quote>+kill-popups</quote></ulink>
     and <ulink
-    url="configuration.html#GIF-DEANIMATE"><quote>+gif-deanimate</quote></ulink>
+    url="actions-file.html#GIF-DEANIMATE"><quote>+gif-deanimate</quote></ulink>
     will not work on compressed data. This will slow down connections to those
     websites, though. Default typically is to turn
     <quote>prevent-compression</quote> on.
@@ -3813,10 +4082,10 @@ forward-socks4 and forward-socks4a</title>
  </varlistentry>
 
 </variablelist>
-</sect4>
+</sect3>
 
 <!--   ~~~~~       New section      ~~~~~     -->
-<sect4 id="session-cookies-only">
+<sect3 renderas="sect4" id="session-cookies-only">
 <title><emphasis>+session-cookies-only</emphasis></title>
 
 <variablelist>
@@ -3876,11 +4145,11 @@ forward-socks4 and forward-socks4a</title>
  </varlistentry>
 
 </variablelist>
-</sect4>
+</sect3>
 
 
 <!--   ~~~~~       New section      ~~~~~     -->
-<sect4 id="prevent-reading-cookies">
+<sect3 renderas="sect4" id="prevent-reading-cookies">
 <title><emphasis>+prevent-reading-cookies</emphasis></title>
 
 <variablelist>
@@ -3927,7 +4196,7 @@ forward-socks4 and forward-socks4a</title>
    <para>
     Often used in conjunction with <quote>+prevent-setting-cookies</quote> to 
     disable cookies completely. Note that 
-    <ulink url="configuration.html#SESSION-COOKIES-ONLY"><quote>+session-cookies-only</quote></ulink>
+    <ulink url="actions-file.html#SESSION-COOKIES-ONLY"><quote>+session-cookies-only</quote></ulink>
     requires these to both be disabled (or else it never gets any cookies to cache).
    </para>
    <para>
@@ -3939,11 +4208,11 @@ forward-socks4 and forward-socks4a</title>
  </varlistentry>
 
 </variablelist>
-</sect4>
+</sect3>
 
 
 <!--   ~~~~~       New section      ~~~~~     -->
-<sect4 id="prevent-setting-cookies">
+<sect3 renderas="sect4" id="prevent-setting-cookies">
 <title><emphasis>+prevent-setting-cookies</emphasis></title>
 
 <variablelist>
@@ -3995,11 +4264,11 @@ forward-socks4 and forward-socks4a</title>
  </varlistentry>
 
 </variablelist>
-</sect4>
+</sect3>
 
 
-<!--   ~~~~~       Nvarlistentryew section      ~~~~~     -->
-<sect4 id="kill-popup">
+<!--   ~~~~~       New section      ~~~~~     -->
+<sect3 renderas="sect4" id="kill-popup">
 <title><emphasis>+kill-popups<anchor id="kill-popups"></emphasis></title>
 <variablelist>
  <varlistentry>
@@ -4058,11 +4327,11 @@ forward-socks4 and forward-socks4a</title>
  </varlistentry>
 
 </variablelist>
-</sect4>
+</sect3>
 
 
 <!--   ~~~~~       New section      ~~~~~     -->
-<sect4 id="send-vanilla-wafer">
+<sect3 renderas="sect4" id="send-vanilla-wafer">
 <title><emphasis>+send-vanilla-wafer</emphasis></title>
 
 <variablelist>
@@ -4115,11 +4384,11 @@ forward-socks4 and forward-socks4a</title>
  </varlistentry>
 
 </variablelist>
-</sect4>
+</sect3>
 
 
 <!--   ~~~~~       New section      ~~~~~     -->
-<sect4 id="send-wafer">
+<sect3 renderas="sect4" id="send-wafer">
 <title><emphasis>+send-wafer</emphasis></title>
 
 <variablelist>
@@ -4170,30 +4439,49 @@ forward-socks4 and forward-socks4a</title>
  </varlistentry>
 
 </variablelist>
-</sect4>
+</sect3>
+
+
+<!--   ~~~~~       New section      ~~~~~     -->
+<sect3>
+<title>Summary</title>
+<para>
+ Note that many of these actions have the potential to cause a page to
+ misbehave, possibly even not to display at all. There are many ways 
+ a site designer may choose to design his site, and what HTTP header 
+ content, and other criteria, he may depend on. There is no way to have hard
+ and fast rules for all sites. See the <link
+ linkend="ACTIONSANAT">Appendix</link> for a brief example on troubleshooting
+ actions.
+</para>
+</sect3>
 
 
 <!--   ~~~~~       New section      ~~~~~     -->
-<sect4 id="act-examples" renderas="sect3">
-<title>Actions Examples</title>
+<sect3 renderas="sect2" id="act-examples">
+<title>Sample Actions Files</title>
 <para>
Note that the meaning of any of the above examples is reversed by preceding
Remember that the meaning of any of the above references is reversed by preceding
  the action with a <quote>-</quote>, in place of the <quote>+</quote>. Also, 
  that some actions are turned on in the default section of the actions file, 
  and require little to no additional configuration. These are just <quote>on</quote>.
- But, other actions that are turned on the default section <emphasis>do
+</para>
+
+<para>
+ But, other actions that are turned on in the default section <emphasis>do
  typically require</emphasis> exceptions to be listed in the latter sections of 
  one of our actions file. For instance, by default no URLs are
  <quote>blocked</quote> (i.e. in the default definitions of
  <filename>default.action</filename>). We need exceptions to this in order to
- enable ad blocking in the lower sections. But we need to be very selective
- about what we do block.
+ <emphasis>enable</emphasis> ad blocking in the lower sections. But we need to
+ be very selective about what we do block. Thus, the default is <quote>off</quote>
+ for blocking.
 </para>
 
 <para>
- Below is a liberally commented <filename>default.action</filename> file  to 
- demonstrate how all the pieces come together. And to show how exceptions to
- the default policies can be handled. This is followed by a
+ Below is a liberally commented sample <filename>default.action</filename> file
+ to demonstrate how all the pieces come together. And to show how exceptions
+ to the default policies can be handled. This is followed by a brief 
  <filename>user.action</filename> with similar examples.
 </para>
 
@@ -4201,6 +4489,7 @@ forward-socks4 and forward-socks4a</title>
  <literal>
   <msgtext> 
    <literallayout>
+# Sample default.action file &lt;developers@privoxy.org&gt;
 
 # Settings -- Don't change! For internal Privoxy use ONLY.
 {{settings}}
@@ -4208,13 +4497,19 @@ for-privoxy-version=3.0
 
 
 ##########################################################################
-# <ulink url="configuration.html#ALIASES">Aliases</ulink> must be defined *before* they are used. These are
-# easier to remember, and combine several actions into one. Once defined
-# they can be used just like any built-in action.
+# <ulink url="actions-file.html#ALIASES">Aliases</ulink> must be defined *before* they are used. These are
+# easier to remember, and can combine several actions into one. Once 
+# defined they can be used just like any built-in action -- but within 
+# this file only! Aliases do not require a + or - sign.
 ##########################################################################
 
 # Some useful aliases.
- -prevent-cookies = -prevent-setting-cookies -prevent-reading-cookies
+# Alias to turn off cookie handling, ie allow all cookies unmolested.
+ -prevent-cookies = -prevent-setting-cookies -prevent-reading-cookies \
+                    -session-cookies-only
+
+# Alias to both block and treat as if an image for ad blocking
+# purposes.
  +imageblock      = +block +handle-as-image
 
 # Fragile sites should have the minimum changes:
@@ -4227,62 +4522,63 @@ for-privoxy-version=3.0
 
 ##########################################################################
 # Begin default action settings. Anything in this section will match 
-# all URLs -- UNLESS we have exceptions that match defined below this 
+# all URLs -- UNLESS we have exceptions that also match, defined below this 
 # section. We will show all potential actions here whether they are on 
 # or off. We could omit any disabled action if we wanted, since all 
 # actions are 'off' by default anyway. Shown for completeness only.
-# Actions are enabled if preceded by a '+', otherwise they are disabled.
+# Actions are enabled if preceded by a '+', otherwise they are disabled 
+# (unless an alias has been defined without this).
 ##########################################################################
  { \
- <ulink url="configuration.html#ADD-HEADER">-add-header</ulink> \
- <ulink url="configuration.html#BLOCK">-block</ulink> \
- <ulink url="configuration.html#DEANIMATE-GIFS">-deanimate-gifs</ulink> \
- <ulink url="configuration.html#DOWNGRADE-HTTP-VERSION">-downgrade-http-version</ulink> \
- <ulink url="configuration.html#FAST-REDIRECTS">+fast-redirects</ulink> \
- <ulink url="configuration.html#FILTER">+filter{html-annoyances}</ulink> \
- <ulink url="configuration.html#FILTER">+filter{js-annoyances}</ulink> \
- <ulink url="configuration.html#FILTER">-filter{content-cookies}</ulink> \
- <ulink url="configuration.html#FILTER">-filter{popups}</ulink> \
- <ulink url="configuration.html#FILTER">+filter{webbugs}</ulink> \
- <ulink url="configuration.html#FILTER">-filter{refresh-tags}</ulink> \
- <ulink url="configuration.html#FILTER">-filter{fun}</ulink> \
- <ulink url="configuration.html#FILTER">+filter{nimda}</ulink> \
- <ulink url="configuration.html#FILTER">+filter{banners-by-size}</ulink> \
- <ulink url="configuration.html#FILTER">-filter{shockwave-flash}</ulink> \
- <ulink url="configuration.html#FILTER">-filter{crude-prental}</ulink> \
- <ulink url="configuration.html#HIDE-FORWARDED-FOR-HEADERS">+hide-forwarded-for-headers</ulink> \
- <ulink url="configuration.html#HIDE-FROM-HEADER">+hide-from-header{block}</ulink> \
- <ulink url="configuration.html#HIDE-REFERER">-hide-referrer</ulink> \
- <ulink url="configuration.html#HIDE-USER-AGENT">-hide-user-agent</ulink> \
- <ulink url="configuration.html#HANDLE-AS-IMAGE">-handle-as-image</ulink> \
- <ulink url="configuration.html#SET-IMAGE-BLOCKER">+set-image-blocker{pattern}</ulink> \
- <ulink url="configuration.html#LIMIT-CONNECT">-limit-connect</ulink> \
- <ulink url="configuration.html#PREVENT-COMPRESSION">+prevent-compression</ulink> \
- <ulink url="configuration.html#SESSION-COOKIES-ONLY">-session-cookies-only</ulink> \
- <ulink url="configuration.html#PREVENT-READING-COOKIES">-prevent-reading-cookies</ulink> \
- <ulink url="configuration.html#PREVENT-SETTING-COOKIES">-prevent-setting-cookies</ulink> \
- <ulink url="configuration.html#KILL-POPUPS">-kill-popups</ulink> \
- <ulink url="configuration.html#SEND-VANILLA-WAFER">-send-vanilla-wafer</ulink> \
- <ulink url="configuration.html#SEND-WAFER">-send-wafer</ulink> \
+ <ulink url="actions-file.html#ADD-HEADER">-add-header</ulink> \
+ <ulink url="actions-file.html#BLOCK">-block</ulink> \
+ <ulink url="actions-file.html#DEANIMATE-GIFS">-deanimate-gifs</ulink> \
+ <ulink url="actions-file.html#DOWNGRADE-HTTP-VERSION">-downgrade-http-version</ulink> \
+ <ulink url="actions-file.html#FAST-REDIRECTS">+fast-redirects</ulink> \
+ <ulink url="actions-file.html#FILTER-HTML-ANNOYANCES">+filter{html-annoyances}</ulink> \
+ <ulink url="actions-file.html#FILTER-JS-ANNOYANCES">+filter{js-annoyances}</ulink> \
+ <ulink url="actions-file.html#FILTER-CONTENT-COOKIES">-filter{content-cookies}</ulink> \
+ <ulink url="actions-file.html#FILTER-POPUPS">-filter{popups}</ulink> \
+ <ulink url="actions-file.html#FILTER-WEBBUGS">+filter{webbugs}</ulink> \
+ <ulink url="actions-file.html#FILTER-REFRESH-TAGS">-filter{refresh-tags}</ulink> \
+ <ulink url="actions-file.html#FILTER-FUN">-filter{fun}</ulink> \
+ <ulink url="actions-file.html#FILTER-NIMDA">+filter{nimda}</ulink> \
+ <ulink url="actions-file.html#FILTER-BANNERS-BY-SIZE">+filter{banners-by-size}</ulink> \
+ <ulink url="actions-file.html#FILTER-SHOCKWAVE-FLASH">-filter{shockwave-flash}</ulink> \
+ <ulink url="actions-file.html#FILTER-CRUDE-PARENTAL">-filter{crude-prental}</ulink> \
+ <ulink url="actions-file.html#HIDE-FORWARDED-FOR-HEADERS">+hide-forwarded-for-headers</ulink> \
+ <ulink url="actions-file.html#HIDE-FROM-HEADER">+hide-from-header{block}</ulink> \
+ <ulink url="actions-file.html#HIDE-REFERER">-hide-referrer</ulink> \
+ <ulink url="actions-file.html#HIDE-USER-AGENT">-hide-user-agent</ulink> \
+ <ulink url="actions-file.html#HANDLE-AS-IMAGE">-handle-as-image</ulink> \
+ <ulink url="actions-file.html#SET-IMAGE-BLOCKER">+set-image-blocker{pattern}</ulink> \
+ <ulink url="actions-file.html#LIMIT-CONNECT">-limit-connect</ulink> \
+ <ulink url="actions-file.html#PREVENT-COMPRESSION">+prevent-compression</ulink> \
+ <ulink url="actions-file.html#SESSION-COOKIES-ONLY">-session-cookies-only</ulink> \
+ <ulink url="actions-file.html#PREVENT-READING-COOKIES">-prevent-reading-cookies</ulink> \
+ <ulink url="actions-file.html#PREVENT-SETTING-COOKIES">-prevent-setting-cookies</ulink> \
+ <ulink url="actions-file.html#KILL-POPUPS">-kill-popups</ulink> \
+ <ulink url="actions-file.html#SEND-VANILLA-WAFER">-send-vanilla-wafer</ulink> \
+ <ulink url="actions-file.html#SEND-WAFER">-send-wafer</ulink> \
  }
  / # forward slash will match *all* potential URL patterns. 
 
 ##########################################################################
-# Default behavior is now set. Time for some exceptions to our 
-# default actions.
+# Default behavior is now set. Now we will define some exceptions to our 
+# default action policies.
 ##########################################################################
 
 # These sites are very complex and require very minimal interference.
-# We'll disable most actions with our 'fragile' alias.
- {fragile}
+# We'll disable most actions with our 'fragile' alias:
+ { fragile }
  .office.microsoft.com           # surprise, surprise!
  .windowsupdate.microsoft.com
 
 
 # Shopping sites - not as fragile but require some special 
 # handling. We still want to block ads, and we will allow 
-# persistant cookies via the 'shop' alias.
- {shop}
+# persistant cookies via the 'shop' alias:
+ { shop }
  .quietpc.com 
  .worldpay.com   # for quietpc.com
  .jungle.com
@@ -4291,15 +4587,14 @@ for-privoxy-version=3.0
 
 # These sites require pop-ups too :(  We'll combine our 'shop' 
 # alias with two other actions into one rule to allow all popups.
- {shop -no-popups -filter{popups}}
+ { shop <ulink url="actions-file.html#KILL-POPUPS">-kill-popups</ulink> <ulink url="actions-file.html#FILTER-POPUPS">-filter{popups}</ulink> }
  .dabs.com
  .overclockers.co.uk
 
 
 # The 'Fast-redirects' action breaks some sites. Disable this action
-# for these known sensitive sites.
- {-fast-redirects}
- www.ukc.ac.uk/cgi-bin/wac\.cgi\?
+# for these known sensitive sites:
+ { <ulink url="actions-file.html#FAST-REDIRECTS">-fast-redirects</ulink> }
  login.yahoo.com
  edit.europe.yahoo.com
  .google.com
@@ -4310,16 +4605,16 @@ for-privoxy-version=3.0
 
 # Define which file types will be treated as images. Important
 # for ad blocking.
- {+handle-as-image}
+ { <ulink url="actions-file.html#HANDLE-AS-IMAGE">+handle-as-image</ulink> }
  /.*\.(gif|jpe?g|png|bmp|ico)
 
 
 # Now lets list some domains that are known ad generators. And
-# our alias here will block these as well as force them to b
-# treated as images. This combination of actions is important 
-# for ad blocking. What the browser will show instead is 
-# determined by the setting of <ulink url="configuration.html#SET-IMAGE-BLOCKER"><quote>+set-image-blocker</quote></ulink>
- {+imageblock}
+# our alias that we use here will block these as well as forc
+# them to be treated as images. This combination of actions is 
+# important for ad blocking. What the browser will show instead is 
+# determined by the setting of <ulink url="actions-file.html#SET-IMAGE-BLOCKER"><quote>+set-image-blocker</quote></ulink>
+ { +imageblock }
  ar.atwola.com 
  .ad.doubleclick.net
  .a.yimg.com/(?:(?!/i/).)*$
@@ -4332,8 +4627,8 @@ for-privoxy-version=3.0
 
 # These will just simply be blocked. They will generate the BLOCKED
 # banner page, if matched. Heavy use of wildcards and regular 
-# expressions in this example.
- {+block}
+# expressions in this example. Enable block action:
+ { <ulink url="actions-file.html#BLOCK">+block</ulink> }
  ad*.
  .*ads.
  banner?.
@@ -4343,10 +4638,11 @@ for-privoxy-version=3.0
  .hitbox.com 
 
 
-# The above block section will catch some sites we DO NOT want 
-# blocked via the wildcards and regular expressions. Now let's set 
-# exceptions to the exceptions so the good guys get better treatment.
- {-block}
+# The above block section will probably inadvertantly catch some 
+# sites we DO NOT want blocked via the wildcards and regular expressions. 
+# Now let's set exceptions to the exceptions so the good guys get better 
+# treatment. Disable block action:
+ { <ulink url="actions-file.html#BLOCK">-block</ulink> }
  advogato.org
  adsl.
  ad[ud]*.
@@ -4364,9 +4660,9 @@ for-privoxy-version=3.0
 # Don't filter *anything* from our friends at sourceforge.
 # Notice we don't have to name the individual filter 
 # identifiers -- we just turn them all off in one fell swoop.
- {-filter}
+# Disable all filters for this one site:
+ { <ulink url="actions-file.html#FILTER">-filter</ulink> }
  .sourceforge.net
-
    </literallayout>
   </msgtext> 
  </literal>
@@ -4376,159 +4672,81 @@ for-privoxy-version=3.0
  So far we are painting with a broad brush by setting general policies. 
  The above would be a reasonable starting point for many situations. Now, 
  we want to be more specific and have customized rules that are more suitable
- to our personal habits and preferences. These should be placed in 
+ to our personal habits and preferences. These would be for narrowly defined 
+ situations like your ISP or your bank, and should be placed in 
  <filename>user.action</filename>, which is parsed after all other 
- actions files. So any settings here, will have the last word.
+ actions files and should not be clobbered by upgrades. So any settings here,
+ will have the last word and over-ride any previously defined actions.
 </para>
 
 <para>
- Now an example of a few things that one might do with a <filename>user.action</filename>
- file. This is where user preferences are defined.
+ Now a few examples of some things that one might do with a
+ <filename>user.action</filename> file. 
 </para>
 
 <!-- brief sample user.action here -->
 
-
-<!-- This is the old stuff. Left in temporarily for reference -->
-<!-- To be deleted when above is finished -->
-<para>
- Some examples:
-</para>
-
-<para>
- Turn off cookies by default, then allow a few through for specified sites 
- (showing an excerpt from the <quote>default</quote> section of an actions
- file ONLY):
-</para>
-  
 <para>
  <literal>
   <msgtext> 
    <literallayout>
- # Excerpt only:
- # Allow cookies to and from the server, but
- # for this browser session ONLY
- { 
-   # other actions normally listed here...
-   -prevent-setting-cookies \
-   -prevent-reading-cookies \
-   +session-cookies-only   \  
- }
- / # match all URLs
-
- # Exceptions to the above, sites that benefit from persistent cookies
- # that are saved from one browser session to the next.
- { -session-cookies-only }
-  .javasoft.com
-  .sun.com
-  .yahoo.com
-  .msdn.microsoft.com
-  .redhat.com
-
-   </literallayout>
-  </msgtext> 
- </literal>
-</para>
-
-<para>
- Now turn off <quote>fast redirects</quote>, and then we allow two exceptions:
-</para>
+# Sample user.action file.
 
-<para>
- <literal>
-  <msgtext> 
-   <literallayout>
- # Turn them off (excerpt only)!
- {
-  # other actions normally listed here...
-  +fast-redirects
- }
- / # match all URLs
- # Reverse it for these two sites, which don't work right without it.
- {-fast-redirects}
-  www.ukc.ac.uk/cgi-bin/wac\.cgi\?
-  login.yahoo.com
-   </literallayout>
-  </msgtext> 
- </literal>
-</para>
-
-<para>
- Turn on page filtering according to rules in the defined sections 
- of <filename>default.filter</filename>, and make one exception for 
- Sourceforge:
- </para>
-
-<para>
- <literal>
-  <msgtext> 
-   <literallayout>
- # Run everything through the filter file, using only certain
- # specified sections:
- {
-  # other actions normally listed here...
-  +filter{html-annoyances} +filter{js-annoyances} +filter{kill-popups}\
-  +filter{webbugs} +filter{nimda} +filter{banners-by-size}
- }
- / #match all URLs
-              
- # Then disable filtering of code from all sourceforge domains!
- {-filter}
-  .sourceforge.net
-   </literallayout>
-  </msgtext> 
- </literal>
-</para>
+# Any aliases you want to use need to be re-defined here.
+# Alias to turn off cookie handling, ie allow all cookies unmolested.
+ -prevent-cookies = -prevent-setting-cookies -prevent-reading-cookies \
+                    -session-cookies-only
 
-<para>
- Now some URLs that we want <quote>blocked</quote> (normally generates 
- the <quote>blocked</quote> banner). Typically, the <quote>block</quote>
- action is off by default in the upper section of an actions file, then enabled
- against certain URLs and patterns in the lower part of the file. Many of these use <link
- linkend="regex">regular expressions</link> that will expand to match multiple
- URLs: </para>
+# Fragile sites should have the minimum changes:
+ fragile     = -block -deanimate-gifs -fast-redirects -filter -hide-referer \
+               -prevent-cookies -kill-popups
 
-<para>
- <literal>
-  <msgtext> 
-   <literallayout>
-  # Blocklist:
-  {+block}
-  ad*.
-  .*ads.
-  banner?.
-  count*.
-  /.*count(er)?\.(pl|cgi|exe|dll|asp|php[34]?)
-  /(?:.*/)?(publicite|werbung|rekla(ma|me|am)|annonse|maino(kset|nta|s)?)/
-  .hitbox.com 
-  /.*/(ng)?adclient\.cgi
-  /.*/(plain|live|rotate)[-_.]?ads?/
-  /.*/abanners/
-  /autoads/
+# Allow persistent cookies for a few regular sites that we 
+# trust via our above alias. These will be saved from one browser session 
+# to the next. We are explicity turning off any and all cookie handling, 
+# even though the prevent-*-cookie settings were disabled in our above 
+# default.action anyway. So cookies from these domains will come through 
+# unmolested.
+ { -prevent-cookies }
+ .sun.com
+ .yahoo.com
+ .msdn.microsoft.com
+ .redhat.com
+
+
+# My ISP uses obnoxious self promoting images on many pages.
+# Nuke them :) Note that <ulink url="actions-file.html#HANDLE-AS-IMAGE"><quote>+handle-as-image</quote></ulink> need not be specified,
+# since all URLs ending in .gif will be tagged as images by the
+# general rules in default.action anyway.
+ { <ulink url="actions-file.html#BLOCK">+block</ulink> }
+ www.my-isp-example.com/logo[0-9].gif
+
+
+# Say the site where you do your homebanking needs to open
+# popup windows, but you have chosen to kill popups by
+# default. This will allow it for your-example-bank.com:
+#
+ { <ulink url="actions-file.html#FILTER-POPUPS">-filter{popups}</ulink> <ulink url="actions-file.html#KILL-POPUPS">-kill-popups</ulink> }
+ .my-example-bank.com
+
+
+# This site is delicate, and requires kid-glove 
+# treatment.
+ { fragile }
+ .forbes.com
    </literallayout>
   </msgtext> 
  </literal>
 </para>
 
-<para>
- Note that many of these actions have the potential to cause a page to
- misbehave, possibly even not to display at all. There are many ways 
- a site designer may choose to design his site, and what HTTP header 
- content, and other criteria, he may depend on. There is no way to have hard
- and fast rules for all sites. See the <link
- linkend="ACTIONSANAT">Appendix</link> for a brief example on troubleshooting
- actions.
-</para>
-</sect4>
-
 </sect3>
+</sect2>
 
 <!--  ~  End section  ~  -->
 
 
 <!--   ~~~~~       New section      ~~~~~     -->
-<sect3 id="aliases">
+<sect2 id="aliases">
 <title>Aliases</title>
 <para>
  Custom <quote>actions</quote>, known to <application>Privoxy</application>
@@ -4541,7 +4759,8 @@ for-privoxy-version=3.0
  <emphasis>must be defined before other actions</emphasis> in the
  actions file! And there can only be one set of <quote>aliases</quote>
  defined per file. Each actions file may have its own aliases, but they are 
- only visible within that file.
+ only visible within that file. Aliases do not requir a <quote>+</quote> or 
+ <quote>-</quote> sign in front, since they are merely expanded.
 </para>
 
 <para>
@@ -4610,20 +4829,23 @@ for-privoxy-version=3.0
 
 </para>
 
-</sect3>
 </sect2>
+</sect1>
 
 <!--  ~  End section  ~  -->
 
 
-<!--   ~~~~~       New section      ~~~~~     -->
-<sect2 id="filter-file">
+
+<!--   ~~~~~~~~       New section Header    ~~~~~~~~~     -->
+
+<sect1 id="filter-file">
 <title>The Filter File</title>
 <para>
  Any web page can be dynamically modified with the filter file. This
  modification can be removal, or re-writing, of any web page content,
  including tags and non-visible content. The default filter file is
- <filename>default.filter</filename>, located in the config directory. 
+ oddly enough <filename>default.filter</filename>, located in the config
+ directory. 
 </para>
 
 <para>
@@ -4718,56 +4940,56 @@ for-privoxy-version=3.0
 
 
 <!--   ~~~~~       New section      ~~~~~     -->
-<sect3>
-<title>The +filter Action</title>
+<sect2>
+<title>The <emphasis>+filter</emphasis> Action</title>
 <para>
  Filters are enabled with the <ulink
- url="configuration.html#FILTER"><quote>+filter</quote></ulink> action from within 
+ url="actions-file.html#FILTER"><quote>+filter</quote></ulink> action from within 
  one of the actions files. <quote>+filter</quote> requires one parameter, which 
  should match one of the section identifiers in the filter file itself. Example:
 </para>
 
-<para>
- <screen>
+<screen>
   +filter{html-annoyances}
- </screen>
-</para>
+</screen>
 
 <para>
  This would activate that particular filter. Similarly, <quote>+filter</quote>
  can be turned off for selected sites as:
- <quote>-filter{html-annoyances}</quote>. Remember, all actions are off by
+ <quote>-filter{html-annoyances}</quote>. Remember too, all actions are off by
  default, unless they are explicity enabled in one of the actions files.
 </para>
 
-</sect3>
-
 </sect2>
 
+</sect1>
+
 <!--  ~  End section  ~  -->
 
 
 
 <!--   ~~~~~       New section      ~~~~~     -->
 
-<sect2>
+<sect1 id="templates">
 <title>Templates</title>
 <para>
  When <application>Privoxy</application> displays one of its internal 
- pages, such as a 404 Not Found error page, it uses the appropriate template.
- On Linux, BSD, and Unix, these are located in
- <filename>/etc/privoxy/templates</filename> by default. These may be
- customized, if desired. <filename>cgi-style.css</filename> is 
- used to control the HTML attributes (fonts, etc).
-</para>
-<para>
- The default <quote>Blocked</quote> banner page with the bright red top 
+ pages, such as a <ulink url="http://bogus_404_page.com">404 Not Found error page</ulink>
+ (<application>Privoxy</application> must be running for link to work as
+ intended), it uses the appropriate template. On Linux, BSD, and Unix, these
+ are located in <filename>/etc/privoxy/templates</filename> by default. These
+ may be customized, if desired. <filename>cgi-style.css</filename> is used to
+ control the HTML attributes (fonts, etc).
+</para>
+<para>
+ The default 
+<ulink url="http://ads.bannerserver.example.com/nasty-ads/sponsor.html">Blocked 
+(<application>Privoxy</application> needs to be running for page to display)</ulink>
+ banner page with the bright red top 
  banner, is called just <quote><filename>blocked</filename></quote>. This 
  may be customized or replaced with something else if desired.
 
 </para>
-</sect2>
-
 </sect1>
 
 <!--  ~  End section  ~  -->
@@ -5282,13 +5504,13 @@ Requests</title>
   <para>
    Next, <application>Privoxy</application> checks to see if the URL 
    matches any <ulink
-   url="configuration.html#BLOCK"><quote>+block</quote></ulink> patterns. If
+   url="actions-file.html#BLOCK"><quote>+block</quote></ulink> patterns. If
    so, the URL is then blocked, and the remote web server will not be contacted.
-   <ulink url="configuration.html#HANDLE-AS-IMAGE"><quote>+handle-as-image</quote></ulink> 
+   <ulink url="actions-file.html#HANDLE-AS-IMAGE"><quote>+handle-as-image</quote></ulink> 
    is then checked and if it does not match, an 
    HTML <quote>BLOCKED</quote> page is sent back. Otherwise, if it does match,
    an image is returned. The type of image depends on the setting of <ulink
-   url="configuration.html#SET-IMAGE-BLOCKER"><quote>+set-image-blocker</quote></ulink>
+   url="actions-file.html#SET-IMAGE-BLOCKER"><quote>+set-image-blocker</quote></ulink>
    (blank, checkerboard pattern, or an HTTP redirect to an image elsewhere).
   </para>
  </listitem> 
@@ -5301,7 +5523,7 @@ Requests</title>
  <listitem>
   <para>
    If the URL pattern matches the <ulink
-   url="configuration.html#FAST-REDIRECTS"><quote>+fast-redirects</quote></ulink> action,
+   url="actions-file.html#FAST-REDIRECTS"><quote>+fast-redirects</quote></ulink> action,
    it is then processed. Unwanted parts of the requested URL are stripped.
   </para>
  </listitem> 
@@ -5309,7 +5531,7 @@ Requests</title>
   <para>
    Now the rest of the client browser's request headers are processed. If any
    of these match any of the relevant actions (e.g. <ulink
-   url="configuration.html#HIDE-USER-AGENT"><quote>+hide-user-agent</quote></ulink>,
+   url="actions-file.html#HIDE-USER-AGENT"><quote>+hide-user-agent</quote></ulink>,
    etc.), headers are suppressed or forged as determined by these actions and
    their parameters.
   </para>
@@ -5325,24 +5547,24 @@ Requests</title>
    First, the server headers are read and processed to determine, among other
    things, the MIME type (document type) and encoding. The headers are then
    filtered as deterimed by the 
-   <ulink url="configuration.html#PREVENT-SETTING-COOKIES"><quote>+prevent-setting-cookies</quote></ulink>,
-   <ulink url="configuration.html#SESSION-COOKIES-ONLY"><quote>+session-cookies-only</quote></ulink>,
-   and <ulink url="configuration.html#DOWNGRADE-HTTP-VERSION"><quote>+downgrade-http-version</quote></ulink>
+   <ulink url="actions-file.html#PREVENT-SETTING-COOKIES"><quote>+prevent-setting-cookies</quote></ulink>,
+   <ulink url="actions-file.html#SESSION-COOKIES-ONLY"><quote>+session-cookies-only</quote></ulink>,
+   and <ulink url="actions-file.html#DOWNGRADE-HTTP-VERSION"><quote>+downgrade-http-version</quote></ulink>
    actions.
   </para>
  </listitem> 
  <listitem>
   <para>
-   If the <ulink url="configuration.html#KILL-POPUPS"><quote>+kill-popups</quote></ulink>
+   If the <ulink url="actions-file.html#KILL-POPUPS"><quote>+kill-popups</quote></ulink>
    action applies, and it is an HTML or JavaScript document, the popup-code in the
    response is filtered on-the-fly as it is received.
   </para>
  </listitem> 
  <listitem>
   <para>
-   If a <ulink url="configuration.html#FILTER"><quote>+filter</quote></ulink>
+   If a <ulink url="actions-file.html#FILTER"><quote>+filter</quote></ulink>
    or <ulink
-   url="configuration.html#DEANIMATE-GIFS"><quote>+deanimate-gifs</quote></ulink>
+   url="actions-file.html#DEANIMATE-GIFS"><quote>+deanimate-gifs</quote></ulink>
    action applies (and the document type fits the action), the rest of the page is
    read into memory (up to a configurable limit). Then the filter rules (from
    <filename>default.filter</filename>) are processed against the buffered
@@ -5353,9 +5575,9 @@ Requests</title>
    <application>Privoxy</application> back to your browser. 
   </para>
   <para>
-   If neither <ulink url="configuration.html#FILTER"><quote>+filter</quote></ulink>
+   If neither <ulink url="actions-file.html#FILTER"><quote>+filter</quote></ulink>
    or <ulink
-   url="configuration.html#DEANIMATE-GIFS"><quote>+deanimate-gifs</quote></ulink>
+   url="actions-file.html#DEANIMATE-GIFS"><quote>+deanimate-gifs</quote></ulink>
    matches, then <application>Privoxy</application> passes the raw data through 
    to the client browser as it becomes available.
   </para>
@@ -5383,8 +5605,8 @@ Requests</title>
 
 <para>
  The way <application>Privoxy</application> applies 
- <ulink url="configuration.html#ACTIONS"><quote>actions</quote></ulink>
- and <ulink url="configuration.html#FILTER"><quote>filters</quote></ulink>
+ <ulink url="actions-file.html#ACTIONS"><quote>actions</quote></ulink>
+ and <ulink url="actions-file.html#FILTER"><quote>filters</quote></ulink>
  to any given URL can be complex, and not always so
  easy to understand what is happening. And sometimes we need to be able to
  <emphasis>see</emphasis> just what <application>Privoxy</application> is
@@ -5414,7 +5636,7 @@ Requests</title>
  <application>Privoxy</application> will tell us 
  how the current configuration will handle it. This will not
  help with filtering effects (i.e. the <ulink
- url="configuration.html#FILTER"><quote>+filter</quote></ulink> action) from
+ url="actions-file.html#FILTER"><quote>+filter</quote></ulink> action) from
  the <filename>default.filter</filename> file since this is handled very
  differently and not so easy to trap! It also will not tell you about any other
  URLs that may be embedded within the URL you are testing. For instance, images
@@ -5463,7 +5685,7 @@ Requests</title>
 
 <para>
  This tells us how we have defined our 
- <ulink url="configuration.html#ACTIONS"><quote>actions</quote></ulink>, and
+ <ulink url="actions-file.html#ACTIONS"><quote>actions</quote></ulink>, and
  which ones match for our example, <quote>google.com</quote>. The first listing
  is any matches for the <filename>standard.action</filename> file. No hits at
  all here on <quote>standard</quote>. Then next is <quote>default</quote>, or
@@ -5481,11 +5703,11 @@ Requests</title>
  apply to. Last match wins. Just below this then are two explicit matches for
  <quote>.google.com</quote>. The first is negating our previous cookie setting, 
  which was for <ulink
- url="configuration.html#SESSION-COOKIES-ONLY"><quote>+session-cookies-only</quote></ulink>
+ url="actions-file.html#SESSION-COOKIES-ONLY"><quote>+session-cookies-only</quote></ulink>
  (i.e. not persistent). So we will allow persistent cookies for google. The
  second turns <emphasis>off</emphasis> any 
  <ulink
- url="configuration.html#FAST-REDIRECTS"><quote>+fast-redirects</quote></ulink>
+ url="actions-file.html#FAST-REDIRECTS"><quote>+fast-redirects</quote></ulink>
  action, allowing this to take place unmolested. Note that there is a leading
  dot here -- <quote>.google.com</quote>. This will match any hosts and
  sub-domains, in the google.com domain also, such as
@@ -5549,7 +5771,7 @@ Requests</title>
  matched three different times. Each as an <quote>+block +handle-as-image</quote>,
  which is the expanded form of one of our aliases that had been defined as: 
  <quote>+imageblock</quote>. (<ulink
- url="configuration.html#ALIASES"><quote>Aliases</quote></ulink> are defined in
+ url="actions-file.html#ALIASES"><quote>Aliases</quote></ulink> are defined in
  the first section of the actions file and typically used to combine more 
  than one action.)
 </para>
@@ -5561,10 +5783,10 @@ Requests</title>
  though ;-) Note that if you want an ad or obnoxious 
  URL to be invisible, it should be defined as <quote>ad.doubleclick.net</quote>
  is done here -- as both a <ulink
- url="configuration.html#BLOCK"><quote>+block</quote></ulink>
+ url="actions-file.html#BLOCK"><quote>+block</quote></ulink>
  <emphasis>and</emphasis> an 
  <ulink
- url="configuration.html#HANDLE-AS-IMAGE"><quote>+handle-as-image</quote></ulink>.
+ url="actions-file.html#HANDLE-AS-IMAGE"><quote>+handle-as-image</quote></ulink>.
  The custom alias <quote>+imageblock</quote> just simplifies the process and make 
  it more readable.
 </para>
@@ -5700,6 +5922,31 @@ Requests</title>
  Temple Place - Suite 330, Boston, MA  02111-1307, USA.
 
  $Log: user-manual.sgml,v $
+ Revision 1.102  2002/05/03 17:46:00  oes
+ Further proofread & reactivated short build instructions
+
+ Revision 1.101  2002/05/03 03:58:30  hal9
+ Move the user-manual config directive to top of section. Add note about
+ Privoxy needing read permissions for configs, and write for logs.
+
+ Revision 1.100  2002/04/29 03:05:55  hal9
+ Add clarification on differences of new actions files.
+
+ Revision 1.99  2002/04/28 16:59:05  swa
+ more structure in starting section
+
+ Revision 1.98  2002/04/28 05:43:59  hal9
+ This is the break up of configuration.html into multiple files. This
+ will probably break links elsewhere :(
+
+ Revision 1.97  2002/04/27 21:04:42  hal9
+ -Rewrite of Actions File example.
+ -Add section for user-manual directive in config.
+
+ Revision 1.96  2002/04/27 05:32:00  hal9
+ -Add short section to Filter Files to tie in with +filter action.
+ -Start rewrite of examples in Actions Examples (not finished).
+
  Revision 1.95  2002/04/26 17:23:29  swa
  bookmarks cleaned, changed structure of user manual, screen and programlisting cleanups, and numerous other changes that I forgot