FILTER-DEFLATE(2)                               FILTER-DEFLATE(2)

     NAME
          deflate, inflate - data compression filters

     SYNOPSIS
          include "filter.m";

          deflate := load Filter Filter->DEFLATEPATH;
          inflate := load Filter Filter->INFLATEPATH;

          init:  fn();
          start: fn(param: string): chan of ref Rq;

     DESCRIPTION
          These implementation modules conform to the Filter module
          interface for data-processing filters.  For details of the
          interface, see filter(2).

          Deflate implements gzip-compatible stream compression.  The
          param string argument to start can contain one or more of
          the following option characters:

                    `d'  Enable debugging output. Each line of debug-
                         ging output is provided in an Rq.Info mes-
                         sage.

                    `v'  Enable verbose mode. Each line of verbose
                         output is provided in an Rq.Info message.

                    `h'  Add a gzip header and footer to the data.
                         With this flag, the data after filtering will
                         be in exactly the same format as a gzip file,
                         with accompanying checksum.

                    `z'  Add a zlib header and footer to the data.
                         The footer contains a checksum.

                    `0' to `9'
                         Specifies the level of compression to be used
                         (9 highest). See gzip(1).

          Inflate performs the inverse operation to deflate.  If the
          param argument to start begins with the character `h' then
          the input to the filter is assumed to be in the standard
          gzip file format; if it starts with the character `z' it is
          assumed to be in zlib format; the output will be checked for
          integrity in both cases. While processing a gzip stream, the
          Rq.Info message is used to transmit some information; the
          type of information is determined by the first word of msg,
          as follows:

     Page 1                       Plan 9              (printed 1/2/25)

     FILTER-DEFLATE(2)                               FILTER-DEFLATE(2)

               file The rest of msg (after a following space) is the
                    name of the original filename before compression.

               mtime
                    The rest of msg (after a following space) is the
                    modification time of the original file before com-
                    pression.

     SOURCE
          /appl/lib/deflate.b
          /appl/lib/inflate.b

     SEE ALSO
          gzip(1), filter(2)
          Internet RFCs RFC1950, RFC1951, and RFC1952.

     Page 2                       Plan 9              (printed 1/2/25)