This is a port of clzip 1.12 to MSDOS/DJGPP.

  Clzip is a lossless data compressor with a user interface similar to the one
  of gzip or bzip2. Clzip is about as fast as gzip, compresses most files more
  than bzip2, and is better than both from a data recovery perspective.  Clzip
  uses the lzip file format; the files produced by clzip are fully compatible
  with lzip-1.4 or newer, and can be rescued with lziprecover.  Clzip is in
  fact a C language version of lzip, intended for embedded devices or systems
  lacking a C++ compiler.



1.:     DJGPP specific changes.
        =======================

        If LFN support is available then simply a .lx extension is added to the
        output filename.  This will work on systems with LFN support but not on
        plain DOS.  Thus the same shema than used for the BZIP2 port has been
        implemented.  Unfortunately the original file name is not stored in the
        compressed file header so there will be no possibility to restore the
        original file name extension on SFN systems.

        For SFN systems the following rules apply for ".lz" extension:
          compressed name       uncompressed name
            filename.exl    -->   filename.ex
            filename.elz    -->   filename.e
            filename.lz     -->   filename
          uncompressed name     compressed name
            filename.ext    -->   filename.exl
            filename.ex     -->   filename.exl
            filename.e      -->   filename.elz
            filename        -->   filename.lz

        The port will detect at run time if LFN support is available or not and
        will select the method to handle the extension creation accordingly.
        For LFN and SFN systems, the ".tlz" extension is always identified as
        tar archives.  Their file name will always have a ".tar" extension.

        If only SFN support is available, the DJGPP port of clzip will always
        consume the last 5 characters of the 8 possible name characters to
        encode the volume number.  E.g.: when compressing a file with the file
        name filename.ext and splitting it into multiple volumes, the different
        volumes will become fil00001.exl, fil00002.exl, etc.  It is clear that
        neither the original filename nor the original extension can be recreated.

        A LFN environment is required to run the testsuite.

        The port has been configured and compiled on WinXP SP3 and Win98SE.
        There is no guarantee that this may be possible with any other DOS-like
        OS.  Due to the massive use of long file names it will not be possible
        to configure and compile without LFN support.

        The version of the port has been compiled using gcc346 and bnu2351b.
        The port has been configured to be build in the "_build" directory.

        The usual configuration files have been added.  They are located in the
        "djgpp" directory together with the diffs file that documents my changes
        against the original sources.
          
        For further information about clzip please read the info docs and NEWS file.


2.:     Installing the binary package.
        ==============================

2.1.:   Copy the binary distribution into the top DJGPP installation directory,
        just unzip it preserving the directory structure running *ONE* of the
        following commands:
          unzip32 clzp112b.zip      or
          djtarx clzp112b.zip       or
          pkunzip -d clzp112b.zip


3.:     Building the binaries from sources.
        ===================================

3.1.:   Create a temporary directory and copy the source package into the
        directory.  If you download the source distribution from one of the
        DJGPP sites, just unzip it preserving the directory structure
        running *ONE* of the following commands:
          unzip32 clzp112s.zip      or
          djtarx clzp112s.zip       or
          pkunzip -d clzp112s.zip

3.2.:   To build the binaries you will need the following binary packages:
          djdev205.zip (or a later but NOT a prior version)
          bsh205bbr3.zip (or a later but NOT a prior version)
          gccNNNb.zip, gppNNN.zip, bnuNNNb.zip, makNNNb.zip, filNNNb.zip,
          shlNNNb.zip, txtNNNb.zip, txiNNNb.zip, grepNNNb.zip, sedNNNb.zip,
          pcreNNNb.zip, mktmpNNb.zip and gwkNNNb.zip.

        If you want to run the check you will need also:
          difNNNb.zip and mktmpNNNb.zip

        NNN represents the latest version number of the binary packages.  All
        this packages can be found in the /v2gnu directory of any
        ftp.delorie.com mirror.
        You will need bsh205bbr3.zip or later and *NOT* a prior version or
        the build will fail.  The same applies to djdev205.zip.

3.3.:   The package has been configured to be build in a separate build directory
        under the top srcdir (aka clzip-1.12).  To build the binaries cd
        into /_build directory.  If for some reason you want to reconfigure the
        package cd into the build directory and run the
        following commands:
          del config.cache
          make clean
          ..\djgpp\config ./..

        Please note that you *MUST* delete the config.cache file in the /_build
        directory or you will not really reconfigure the sources because the
        configuration informations will be read from the cache file instead
        of being newly computed.

        config.bat, among other things, will start the configure script passing
        to it a couple of arguments.  You can control these argument passing the
        following command line arguments to config.bat:
          nls or no-nls, default nls.  NLS support enabled.
          cache or no-cache, default cache.  Cache in build directory.
          dep or no-dep, default no-dep.  No dependency tracking.
          silent or no-silent, default silent.  Controls the verbosity of the
                                                build process.
        All other configure specific options are not set by config.bat so their
        values are left as they are.  If no arguments are passed to config.bat
        then the default values are used.


        To build the programs in a directory other than where the sources are,
        you must add the parameter that specifies the source directory,
        e.g:
          x:\src\contrib\clzip-1.12\djgpp\config x:/src/contrib/clzip-1.12

        Lets assume you want to build the binaries in a directory placed on a
        different drive (z:\build in this case) from where the sources are,
        then you will run the following commands:
          z:
          md \build
          cd \build
          x:\src\contrib\clzip-1.12\djgpp\config x:/src/contrib/clzip-1.12

        The order of the options and the srcdir option does not matter.  You
        *MUST* use forward slashes to specify the source directory.

        The batch file will set same environment variables, make MSDOS specific
        modifications to the Makefile.in's and supply all other needed options
        to the configure script.

3.4.:   To compile the package run from the directory where you have configured
        the sources the command:
          make

3.5.:   Now you can run the tests if you like. From the directory where you have
        configured the sources run the command:
          make check

        No test should fail.

3.6.:   To install the binaries, header, library, catalogs, and man pages
        run the following command from the top srcdir:
          make install

        This will install the products into your DJGPP installation tree given
        by the default prefix "/dev/env/DJDIR".  If you prefer to install them
        into some other directory you will have to set prefix to the appropriate
        value:
          make install prefix=z:/some/other/place



        Send clzip specific bug reports to <lzip-bug@nongnu.org>.
        Send suggestions and bug reports concerning the DJGPP port
        to comp.os.msdos.djgpp or <djgpp@delorie.com>.


Enjoy.

          Guerrero, Juan Manuel <juan.guerrero@gmx.de>
