mirror of
				https://git.tukaani.org/xz.git
				synced 2025-10-25 10:32:52 +00:00 
			
		
		
		
	Also add a note that packagers should check the licensing of the Doxygen output. (cherry picked from commit 541406bee3f09e9813103c6406b10fc6ab2e0d30)
		
			
				
	
	
		
			246 lines
		
	
	
		
			8.8 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			246 lines
		
	
	
		
			8.8 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| 
 | |
| Information to packagers of XZ Utils
 | |
| ====================================
 | |
| 
 | |
|     0. Preface
 | |
|     1. Package naming
 | |
|     2. Package description
 | |
|     3. License
 | |
|     4. configure options
 | |
|     5. Additional documentation
 | |
|     6. Extra files
 | |
|     7. Installing XZ Utils and LZMA Utils in parallel
 | |
|     8. Example
 | |
| 
 | |
| 
 | |
| 0. Preface
 | |
| ----------
 | |
| 
 | |
|     This document is meant for people who create and maintain XZ Utils
 | |
|     packages for operating system distributions. The focus is on GNU/Linux
 | |
|     systems, but most things apply to other systems too.
 | |
| 
 | |
|     While the standard "configure && make DESTDIR=$PKG install" should
 | |
|     give a pretty good package, there are some details which packagers
 | |
|     may want to tweak.
 | |
| 
 | |
|     Packagers should also read the INSTALL file.
 | |
| 
 | |
| 
 | |
| 1. Package naming
 | |
| -----------------
 | |
| 
 | |
|     The preferred name for the XZ Utils package is "xz", because that's
 | |
|     the name of the upstream tarball. Naturally you may have good reasons
 | |
|     to use some other name; I won't get angry about it. ;-) It's just nice
 | |
|     to be able to point people to the correct package name without asking
 | |
|     what distro they have.
 | |
| 
 | |
|     If your distro policy is to split things into small pieces, here is
 | |
|     one suggestion:
 | |
| 
 | |
|         xz              xz, xzdec, scripts (xzdiff, xzgrep, etc.), docs
 | |
|         xz-lzma         lzma, unlzma, lzcat, lzgrep etc. symlinks and
 | |
|                         lzmadec binary for compatibility with LZMA Utils
 | |
|         liblzma         liblzma.so.*
 | |
|         liblzma-devel   liblzma.so, liblzma.a, API headers
 | |
|         liblzma-doc     Example programs and, if enabled at build time,
 | |
|                         Doxygen-generated liblzma API docs (HTML)
 | |
| 
 | |
| 
 | |
| 2. Package description
 | |
| ----------------------
 | |
| 
 | |
|     Here is a suggestion which you may use as the package description.
 | |
|     If you can use only one-line description, pick only the first line.
 | |
|     Naturally, feel free to use some other description if you find it
 | |
|     better, and maybe send it to me too.
 | |
| 
 | |
|         Library and command line tools for XZ and LZMA compressed files
 | |
| 
 | |
|         XZ Utils provide a general purpose data compression library
 | |
|         and command line tools. The native file format is the .xz
 | |
|         format, but also the legacy .lzma format is supported. The .xz
 | |
|         format supports multiple compression algorithms, of which LZMA2
 | |
|         is currently the primary algorithm. With typical files, XZ Utils
 | |
|         create about 30 % smaller files than gzip.
 | |
| 
 | |
|     If you are splitting XZ Utils into multiple packages, here are some
 | |
|     suggestions for package descriptions:
 | |
| 
 | |
|     xz:
 | |
| 
 | |
|         Command line tools for XZ and LZMA compressed files
 | |
| 
 | |
|         This package includes the xz compression tool and other command
 | |
|         line tools from XZ Utils. xz has command line syntax similar to
 | |
|         that of gzip. The native file format is the .xz format, but also
 | |
|         the legacy .lzma format is supported. The .xz format supports
 | |
|         multiple compression algorithms, of which LZMA2 is currently the
 | |
|         primary algorithm. With typical files, XZ Utils create about 30 %
 | |
|         smaller files than gzip.
 | |
| 
 | |
|         Note that this package doesn't include the files needed for
 | |
|         LZMA Utils 4.32.x compatibility. Install also the xz-lzma
 | |
|         package to make XZ Utils emulate LZMA Utils 4.32.x.
 | |
| 
 | |
|     xz-lzma:
 | |
| 
 | |
|         LZMA Utils emulation with XZ Utils
 | |
| 
 | |
|         This package includes executables and symlinks to make
 | |
|         XZ Utils emulate lzma, unlzma, lzcat, and other command
 | |
|         line tools found from the legacy LZMA Utils 4.32.x package.
 | |
| 
 | |
|     liblzma:
 | |
| 
 | |
|         Library for XZ and LZMA compressed files
 | |
| 
 | |
|         liblzma is a general purpose data compression library with
 | |
|         an API similar to that of zlib. liblzma supports multiple
 | |
|         algorithms, of which LZMA2 is currently the primary algorithm.
 | |
|         The native file format is .xz, but also the legacy .lzma
 | |
|         format and raw streams (no headers at all) are supported.
 | |
| 
 | |
|         This package includes the shared library.
 | |
| 
 | |
|     liblzma-devel:
 | |
| 
 | |
|         Library for XZ and LZMA compressed files
 | |
| 
 | |
|         This package includes the API headers, static library, and
 | |
|         other development files related to liblzma.
 | |
| 
 | |
|     liblzma-doc:
 | |
| 
 | |
|         liblzma API documentation in HTML and example usage
 | |
| 
 | |
|         This package includes the Doxygen-generated liblzma API
 | |
|         HTML docs and example programs showing how to use liblzma.
 | |
| 
 | |
| 
 | |
| 3. License
 | |
| ----------
 | |
| 
 | |
|     If the package manager supports a license field, you probably should
 | |
|     put GPLv2+ there (GNU GPL v2 or later). The interesting parts of
 | |
|     XZ Utils are under the BSD Zero Clause License (0BSD), but some less
 | |
|     important files ending up into the binary package are under GPLv2+.
 | |
|     So it is simplest to just say GPLv2+ if you cannot specify
 | |
|     "BSD0 and GPLv2+".
 | |
| 
 | |
|     If you split XZ Utils into multiple packages as described earlier
 | |
|     in this file, liblzma and liblzma-dev packages will contain only
 | |
|     0BSD-licensed code from XZ Utils (compiler or linker may add some
 | |
|     third-party code which may have other licenses).
 | |
| 
 | |
| 
 | |
| 4. configure options
 | |
| --------------------
 | |
| 
 | |
|     Unless you are building a package for a distribution that is meant
 | |
|     only for embedded systems, don't use the following configure options:
 | |
| 
 | |
|         --enable-debug
 | |
|         --enable-encoders (*)
 | |
|         --enable-decoders
 | |
|         --enable-match-finders
 | |
|         --enable-checks
 | |
|         --enable-small (*)
 | |
|         --disable-threads (*)
 | |
|         --disable-microlzma (*)
 | |
|         --disable-lzip-decoder (*)
 | |
| 
 | |
|     (*) These are OK when building xzdec and lzmadec as described
 | |
|         in INSTALL.
 | |
| 
 | |
|     xzdec and lzmadec don't provide any functionality that isn't already
 | |
|     available in the xz tool. Shipping xzdec and lzmadec without size
 | |
|     optimization and statically-linked liblzma isn't very useful. Doing
 | |
|     that would give users the xzdec man page, which may make it easier
 | |
|     for people to find out that such tools exists, but the executables
 | |
|     wouldn't have any advantage over the full-featured xz.
 | |
| 
 | |
| 
 | |
| 5. Additional documentation
 | |
| ---------------------------
 | |
| 
 | |
|     "make install" copies some additional documentation to $docdir
 | |
|     (--docdir in configure). There is a copy of the GNU GPL v2, which
 | |
|     can be replaced with a symlink if your distro ships with shared
 | |
|     copies of the common license texts.
 | |
| 
 | |
|     The Doxygen-generated liblzma API documentation (HTML) is built and
 | |
|     installed if the configure option --enable-doxygen is used (it's
 | |
|     disabled by default). This requires that Doxygen is available. The
 | |
|     API documentation is installed by "make install" to $docdir/api.
 | |
| 
 | |
|         NOTE: The files generated by Doxygen include content from
 | |
|         Doxygen itself. Check the license info before distributing
 | |
|         the Doxygen-generated files.
 | |
| 
 | |
| 
 | |
| 6. Extra files
 | |
| --------------
 | |
| 
 | |
|     The "extra" directory contains some small extra tools or other files.
 | |
|     The exact set of extra files can vary between XZ Utils releases. The
 | |
|     extra files have only limited use or they are too dangerous to be
 | |
|     put directly to $bindir (7z2lzma.sh is a good example, since it can
 | |
|     silently create corrupt output if certain conditions are not met).
 | |
| 
 | |
|     If you feel like it, you may copy the extra directory under the doc
 | |
|     directory (e.g. /usr/share/doc/xz/extra). Maybe some people will find
 | |
|     them useful. However, most people needing these tools probably are
 | |
|     able to find them from the source package too.
 | |
| 
 | |
|     The "debug" directory contains some tools that are useful only when
 | |
|     hacking on XZ Utils. Don't package these tools.
 | |
| 
 | |
| 
 | |
| 7. Installing XZ Utils and LZMA Utils in parallel
 | |
| -------------------------------------------------
 | |
| 
 | |
|     XZ Utils and LZMA Utils 4.32.x can be installed in parallel by
 | |
|     omitting the compatibility symlinks (lzma, unlzma, lzcat, lzgrep etc.)
 | |
|     from the XZ Utils package. It's probably a good idea to still package
 | |
|     the symlinks into a separate package so that users may choose if they
 | |
|     want to use XZ Utils or LZMA Utils for handling .lzma files.
 | |
| 
 | |
| 
 | |
| 8. Example
 | |
| ----------
 | |
| 
 | |
|     Here is an example for i686 GNU/Linux that
 | |
|       - links xz and lzmainfo against shared liblzma;
 | |
|       - links size-optimized xzdec and lzmadec against static liblzma
 | |
|         while avoiding libpthread dependency;
 | |
|       - includes only shared liblzma in the final package; and
 | |
|       - copies also the "extra" directory to the package.
 | |
| 
 | |
|     PKG=/tmp/xz-pkg
 | |
|     tar xf xz-x.y.z.tar.gz
 | |
|     cd xz-x.y.z
 | |
|     ./configure \
 | |
|             --prefix=/usr \
 | |
|             --disable-static \
 | |
|             --disable-xzdec \
 | |
|             --disable-lzmadec \
 | |
|             CFLAGS='-march=i686 -mtune=generic -O2'
 | |
|     make
 | |
|     make DESTDIR=$PKG install-strip
 | |
|     make clean
 | |
|     ./configure \
 | |
|             --prefix=/usr \
 | |
|             --disable-shared \
 | |
|             --disable-nls \
 | |
|             --disable-encoders \
 | |
|             --enable-small \
 | |
|             --disable-threads \
 | |
|             CFLAGS='-march=i686 -mtune=generic -Os'
 | |
|     make -C src/liblzma
 | |
|     make -C src/xzdec
 | |
|     make -C src/xzdec DESTDIR=$PKG install-strip
 | |
|     cp -a extra $PKG/usr/share/doc/xz
 | |
| 
 |