]> err.no Git - dpkg/commitdiff
dpkg (1.3.6) experimental; urgency=low (HIGH for new source format)
authorIan Jackson <ian@chiark.chu.cam.ac.uk>
Tue, 20 Aug 1996 14:39:58 +0000 (15:39 +0100)
committerIan Jackson <ian@chiark.chu.cam.ac.uk>
Tue, 20 Aug 1996 14:39:58 +0000 (15:39 +0100)
  * dpkg-source now has broken argument unparsing for tar.  (Bug#4195.)

  * dpkg-gencontrol writes to debian/tmp/DEBIAN/control by default.
  * dpkg-shlibdeps script added.

  * Back to old sh update-rc.d, and removed manpage, because new Perl
    version and the manpage have different syntax and semantics.
  * update-rc.d prints usage message for missing terminal `.'.  (Bug#4122.)

  * Use rm -rf instead of just rm -r in dpkg-deb --info &c.  (Bug#4200.)

  * Added support for Installed-Size to dpkg-gencontrol, and documented.
  * Source packaging substitution variables and name syntax rationalised.
  * dpkg-source scripts' usage messages improved slightly.
  * dpkg-source works with non-empty second (orig dir) argument.

  * Added rationale for copyright policy to manual.
  * More developers' PGP keys.
  * Control database handling cleanups (usu. Source field blanked).

 -- Ian Jackson <ian@chiark.chu.cam.ac.uk>  Tue, 20 Aug 1996 15:39:58 +0100

31 files changed:
debian/changelog
debian/control
debian/rules
debian/shlibs.default.i386 [new file with mode: 0644]
debian/substvars [new file with mode: 0644]
doc/developer-keys.bak [deleted file]
doc/developer-keys.pgp
doc/policy.sgml
doc/policy.sgml.orig [deleted file]
doc/programmer.sgml
dpkg-deb/info.c
include/dpkg-db.h
lib/database.c
lib/parse.c
main/processarc.c
main/remove.c
scripts/Makefile.in
scripts/controllib.pl
scripts/dpkg-buildpackage.sh
scripts/dpkg-distaddfile.pl
scripts/dpkg-genchanges.pl
scripts/dpkg-gencontrol.pl
scripts/dpkg-parsechangelog.pl
scripts/dpkg-shlibdeps.pl [new file with mode: 0644]
scripts/dpkg-source.1
scripts/dpkg-source.8 [deleted file]
scripts/dpkg-source.pl
scripts/update-rc.d.new-pl [new file with mode: 0644]
scripts/update-rc.d.pl
scripts/update-rc.d.sh [moved from scripts/update-rc.d.old-sh with 93% similarity]
version.h

index 04292326638b8a2fe9d02fa57e63e2bf108480c5..76bd8a1b7f263e9491a9e2cebab7624de3f9f8aa 100644 (file)
@@ -1,3 +1,27 @@
+dpkg (1.3.6) experimental; urgency=low (HIGH for new source format)
+
+  * dpkg-source now has broken argument unparsing for tar.  (Bug#4195.)
+
+  * dpkg-gencontrol writes to debian/tmp/DEBIAN/control by default.
+  * dpkg-shlibdeps script added.
+
+  * Back to old sh update-rc.d, and removed manpage, because new Perl
+    version and the manpage have different syntax and semantics.
+  * update-rc.d prints usage message for missing terminal `.'.  (Bug#4122.)
+
+  * Use rm -rf instead of just rm -r in dpkg-deb --info &c.  (Bug#4200.)
+
+  * Added support for Installed-Size to dpkg-gencontrol, and documented.
+  * Source packaging substitution variables and name syntax rationalised.
+  * dpkg-source scripts' usage messages improved slightly.
+  * dpkg-source works with non-empty second (orig dir) argument.
+
+  * Added rationale for copyright policy to manual.
+  * More developers' PGP keys.
+  * Control database handling cleanups (usu. Source field blanked).
+
+ -- Ian Jackson <ian@chiark.chu.cam.ac.uk>  Tue, 20 Aug 1996 15:39:58 +0100
+
 dpkg (1.3.5) experimental; urgency=low (high for debian-changelog-mode)
 
   * 822-date script included.  (Bug#4136.)
index b55ec8b1303260726eb5bce0ae98c185437f8c3f..398698e1c97be4d0981eab613c3b9b21011695e0 100644 (file)
@@ -7,7 +7,7 @@ Standards-Version: 0.1
 Package: dpkg
 Architecture: any
 Essential: yes
-Pre-Depends: libc5${libcver}, ncurses3.0
+Pre-Depends: ${shlibs:Pre-Depends}
 Conflicts: dpkgname
 Replaces: dpkgname
 Description: Package maintenance system for Debian Linux
index 4fa109626183b972c1eb64ab472f59408dd74cff..8dd1658fae29d52aae31e42da82eae0c85cf4b79 100755 (executable)
@@ -21,17 +21,19 @@ clean:
 
 binary:        checkroot build
        -rm -rf debian/tmp
-       install -d debian/tmp debian/tmp/DEBIAN
+       install -d debian/tmp debian/tmp/DEBIAN debian/tmp/etc/dpkg
        install -d debian/tmp/usr/doc/{copyright,dpkg}
        set -e; if [ $(arch) = i386 ]; then \
-               dpkg-gencontrol -Vlibcver=' (>= 5.2.18-2)' >$(cidir)/control ; \
                sed -e 's/^# i386elf: //' <debian/preinst >$(cidir)/preinst ; \
        else \
-               dpkg-gencontrol -Vlibcver='' >$(cidir)/control ; \
                sed -e '/^# i386elf: /d' debian/preinst >$(cidir)/preinst ; \
        fi
-       cp debian/{prerm,postinst} debian/tmp/DEBIAN/.
-       chmod +x debian/tmp/DEBIAN/{postinst,prerm,preinst}
+       set -e; if [ -f debian/shlibs.default.$(arch) ]; then \
+               echo /etc/dpkg/shlibs.default >$(cidir)/conffiles ; \
+               cp debian/shlibs.default.$(arch) debian/tmp/etc/dpkg/shlibs.default ; \
+       fi
+       cp debian/{prerm,postinst} $(cidir)/.
+       chmod +x $(cidir)/{postinst,prerm,preinst}
        $(MAKE) prefix=$(DIR)/debian/tmp/usr \
                datadir=$(DIR)/debian/tmp/var/lib/dpkg \
                etcdir=$(DIR)/debian/tmp/etc \
@@ -39,8 +41,10 @@ binary:      checkroot build
        cp debian/copyright debian/tmp/usr/doc/copyright/dpkg
        cp TODO debian/tmp/usr/doc/dpkg/WISHLIST
        touch debian/tmp/var/lib/dpkg/{status,available}
+       dpkg-shlibdeps -dPre-Depends main/dpkg dselect/dselect
+       dpkg-gencontrol
        chown -R root.root debian/tmp
-       chmod -R g-ws debian/tmp
+       chmod -R g-ws,a+r,u+w debian/tmp
        set -e; cd debian/tmp; \
         version=`sed -n 's/^Version: //p' DEBIAN/control`; \
         file=dpkg_$${version}_$(arch).nondebbin.tar; \
diff --git a/debian/shlibs.default.i386 b/debian/shlibs.default.i386
new file mode 100644 (file)
index 0000000..602cb89
--- /dev/null
@@ -0,0 +1,2 @@
+libc 5         libc5 (>= 5.2.18)
+libncurses 3.0 ncurses3.0
diff --git a/debian/substvars b/debian/substvars
new file mode 100644 (file)
index 0000000..915d7d5
--- /dev/null
@@ -0,0 +1 @@
+shlibs:Pre-Depends=libc5 (>= 5.2.18), ncurses3.0
diff --git a/doc/developer-keys.bak b/doc/developer-keys.bak
deleted file mode 100644 (file)
index dfbf9df..0000000
Binary files a/doc/developer-keys.bak and /dev/null differ
index 10692b2c5b5cbf74bfda0cf7272d80708d0bb4b2..5ad9b5aec037e26c186787ff98cbcb7b1cb7a1a0 100644 (file)
Binary files a/doc/developer-keys.pgp and b/doc/developer-keys.pgp differ
index 2994a9a88ee5f7b0504e8ec24187019df797b533..998b3696dee73707f7a89af8d00cd074e8d28905 100644 (file)
@@ -77,6 +77,20 @@ understand it before proceeding.  If you have doubts or questions,
 please ask.
 <p>
 
+The aims of the policy detailed below are:
+<list compact>
+<item>
+That any user be able to rebuild any package in the official Debian
+distribution from the original source plus our patches.
+<item>
+That we make available in our packaging formats as much software as we
+can.
+<item>
+That it be easy for people to make CDROMs of our distribution without
+violating copyrights.
+</list>
+<p>
+
 All packages in the Debian distribution proper must be freely useable,
 modifiable and redistributable in both source and binary form.  It
 must be possible for anyone to distribute and use modified source code
diff --git a/doc/policy.sgml.orig b/doc/policy.sgml.orig
deleted file mode 100644 (file)
index e15c939..0000000
+++ /dev/null
@@ -1,1222 +0,0 @@
-<!doctype debiandoc system>
-
-<!--
- Debian Linux package policy manual.
- Copyright (C)1996 Ian Jackson; released under the terms of the GNU
- General Public License, version 2 or (at your option) any later.
- -->
-
-<book>
-
-<title>Debian policy manual
-<author>Ian Jackson <email/ijackson@gnu.ai.mit.edu/
-<version>version 0.1, <date>
-
-<abstract>
-This manual describes the policy requirements which must be satisfied
-for a package to be included in the Debian distribution.  This
-includes details of the permissions and ownerships of files in
-packages and other technical requirements as well as information like
-the upload procedure.
-</abstract>
-
-<copyright>Copyright &copy;1996 Ian Jackson.
-<p>
-
-This manual is free software; you may redistribute it and/or modify it
-under the terms of the GNU General Public License as published by the
-Free Software Foundation; either version 2, or (at your option) any
-later version.
-<p>
-
-This is distributed in the hope that it will be useful, but
-<em>without any warranty</em>; without even the implied warranty of
-merchantability or fitness for a particular purpose.  See the GNU
-General Public License for more details.
-<p>
-
-You should have received a copy of the GNU General Public License with
-your Debian GNU/Linux system, in <tt>/usr/doc/copyright/GPL</tt>, or
-with the <prgn/dpkg/ source package as the file <tt>COPYING</tt>.  If
-not, write to the Free Software Foundation, Inc., 675 Mass Ave,
-Cambridge, MA 02139, USA.
-
-<toc sect>
-
-<chapt id="scope">Introduction and scope of this manual
-<p>
-
-This manual describes the criteria that a Debian-format package must
-satisfy to be included in the Debian distribution.
-<p>
-
-Much of this information will be useful even when building a package
-which is to be distributed in some other way or is for local use.
-<p>
-
-This manual does <em/not/ describe the technical mechanisms involved
-in package creation, installation and removal.  This information can
-be found in the <prgn/dpkg/ programmers' manual and the <prgn/dpkg/ system
-administrators' manual.
-<p>
-
-This document assumes familiarity with these other two manuals.
-<p>
-
-The Debian version of the FSF's GNU <prgn/hello/ program is provided
-as an example for people wishing to create Debian packages.
-<p>
-
-<em>Note that this document is still a draft!</em>
-
-<chapt id="pkgcopyright">Package copyright
-<p>
-
-Please study the copyright of your submission <em/carefully/ and
-understand it before proceeding.  If you have doubts or questions,
-please ask.
-<p>
-
-All packages in the Debian distribution proper must be freely useable,
-modifiable and redistributable in both source and binary form.  It
-must be possible for anyone to distribute and use modified source code
-and their own own compiled binaries, at least when they do so as part
-of a Debian distribution.
-<p>
-
-Packages whose copyright permission notices (or patent problems) do
-not allow distribution and copying for profit, without restriction on
-the amount charged, or where distribution is restricted according to
-the medium used, or where the distributor must ask any kind of special
-permission of the authors, or with other onerous conditions, may only
-be placed in the semi-supported non-free section of the Debian FTP
-archives.  This is important so that CDROM manufacturers can
-distribute Debian without having to check the copyright of each
-package individually, simply by leaving out the contents of the
-non-free area; CDROM distributors are encouraged, though, to check the
-copyrights on programs in non-free individually and include as many as
-they can.
-<p>
-
-Packages whose copyright permission notices (or patent problems) allow
-only distribution of compiled binaries (and thus of which only
-binaries are available), or where the source code which may be
-distributed is not the complete source code required to compile the
-program (ie, the program cannot be compiled using only packages in the
-main Debian distribution), or which depend for their use on non-free
-or contrib packages, or allow free use only for a trial period
-(shareware), or are demonstration programs lacking vital functionality
-(crippleware), or are only installer-packages which require the user
-to supply a separate file to be installed, or which fail to meet some
-other policy requirements, may only be placed in the semi-supported
-contrib section of the Debian FTP archives (unless they need to be in
-non-free - see above).
-<p>
-
-Programs whose authors encourage the user to make donations are fine
-for the main distribution, provided that the authors do not claim that
-not donating is immoral, unethical, illegal or something similar;
-otherwise they must go in contrib (or non-free, if even distribution
-is restricted by such statements).
-<p>
-
-Packages whose copyright permission notices (or patent problems) do
-not allow redistribution even of only binaries, and where no special
-permission has been obtained, cannot placed on the Debian FTP site and
-its mirrors at all.
-<p>
-
-Note that under international copyright law<footnote>This applies in
-the United States, too.</footnote> <em/no/ distribution or modification
-of a work is allowed without an explicit notice saying so.  Therefore
-a program without a copyright notice <em/is/ copyrighted and you may
-not do anything to it without risking being sued!  Likewise if a
-program has a copyright notice but no statement saying what is
-permitted then nothing is permitted.
-<p>
-
-Many authors are unaware of the problems that restrictive copyrights
-(or lack of copyright notices) can cause for the users of their
-supposedly-free software.  It is often worthwhile contacting such
-authors diplomatically to ask them to modify their terms generally, or
-specially for Debian.  However, this is a politically difficult thing
-to do and you should ask for advice on <prgn/debian-devel/ first.
-<p>
-
-When in doubt, send mail to <email/debian-devel@lists.debian.org/.  Be
-prepared to provide us with the copyright statement.  Software covered
-by the GPL, public domain software and BSD-like copyrights are safe;
-be wary of the phrases `commercial use prohibited' and `distribution
-restricted'.
-<p>
-
-Every package submission <em/must/ be accompanied by verbatim copy of
-its copyright (with the exceptions of public domain packages and those
-covered by the UCB BSD licence or the GNU GPL or LGPL; in these cases
-simply indicate which is appropriate).  This information must be
-included in a file installed by the binary package - see <ref
-id="copyrightfile">.
-
-<chapt id="binarypkg">Contents of the binary package
-
-<sect>Control file requirements
-
-<sect1><tt/Maintainer/ information
-<p>
-
-All packages must have a <tt/Maintainer/ field with the correct name
-and a working email address for the Debian maintainer of the package.
-If one person maintains several packages they should try to avoid
-having different forms of their name and address in different
-<tt/Maintainer/ fields.
-
-<sect1>Dependencies and virtual packages
-<p>
-
-Add a dependency for any shared libraries required by
-dynamically-linked executable binaries in your package.  Almost every
-package containing compiled C code should therefore include a
-<tt/Depends/ field which mentions the shared C library required for
-the program to run.  For ELF binaries linked against <tt/libc.so.5/
-the relevant package name is <tt/libc5/.
-<p>
-
-All packages must use virtual package names where appropriate, and
-arrange to create new ones if necessary.  They must not use virtual
-package names (except privately, amongst a cooperating group of
-packages) unless they have been agreed upon and appear in the list of
-virtual package names.
-<p>
-
-The latest version of the authoritative list of virtual package names
-can be found on <ftpsite>ftp.debian.org</> in
-<ftppath>/debian/doc/package-developer/virtual-package-names-list.text</>
-or your local mirror.  The procedure for updating it is described at
-the top of the file.
-
-<sect1><tt/Section/ and <tt/Priority/
-<p>
-
-Decide whether your package can go in <tt/non-free/, <tt/contrib/ or
-the main distribution - see <ref id="pkgcopyright">, and put
-an appropriate value for the distribution in the
-<tt>debian/changelog</> file.
-<p>
-
-The <tt/Priority/ and <tt/Section/ control file fields give
-information for classifying the package in <prgn/dselect/ and say
-which directory to place it in the FTP archive.
-<p>
-
-They are ultimately the responsibility of the distribution
-maintainers; however, you should suggest values for them in your
-<tt/.changes/ information when you upload a package.  You do this by
-including appropriate information in the <tt>debian/control</tt> file
-before building the packages.
-<p>
-
-For a list of the currently in-use sections, please see the FTP
-archive.  Packages in the non-free and contrib areas should have
-section <tt/non-free/ and <tt/contrib/, respectively.
-
-<sect2><tt/Priority/ values
-<p>
-
-<taglist>
-<tag><tt/required/
-<item>
-<tt/required/ packages are necessary for the proper functioning of the
-system.  You must not remove these packages or your system may become
-totally broken and you may probably not even be able to use
-<prgn/dpkg/ to put things back.  Systems with only the <tt/required/
-packages are probably unuseable, but they do have enough functionality
-to allow the sysadmin to boot and install more software.
-
-<tag><tt/important/
-<item>
-Important programs, including those which one would expect to find on
-any Unix-like system.  If the expectation is that an experienced Unix
-person who found it missing would go `What the F*!@&lt;+ is going on,
-where is <prgn/foo/', it should be in <tt/important/.  This is an
-important criterion because we are trying to produce, amongst other
-things, a free Unix.  Other packages without which the system will not
-run well or be useable should also be here.  This does <em/not/
-include Emacs or X11 or TeX or any other large applications.  The
-<tt/important/ packages are just a bare minimum of commonly-expected
-and necessary tools.
-
-<tag><tt/standard/
-<item>
-These packages provide a reasonably small but not too limited
-character-mode system.  This is what will install by default if the
-user doesn't select anything else.  It doesn't include many large
-applications, but it does include Emacs (this is more of a piece of
-infrastructure than an application) and a reasonable subset of TeX and
-LaTeX (if this is possible without X).
-
-<tag><tt/optional/<footnote>In a sense everything is optional that
-isn't required, but that's not what is meant here.</footnote>
-<item>
-This is all the software that you might reasonably want to install if
-you didn't know what it was or don't have specialised requirements.
-This is a much larger system and includes X11, a full TeX
-distribution, and lots of applications.
-
-<tag><tt/extra/
-<item>
-This contains packages that conflict with others with higher
-priorities, or are only likely to be useful if you already know what
-they are or have specialised requirements.
-
-</taglist>
-<p>
-
-Priority values are not case-sensitive.
-
-<sect2>Base packages
-<p>
-
-Some packages have <tt/Section: base/ and are in the <tt/base/
-subdirectory on the FTP archives.  These are the packages that are
-supplied on the base disks.  They are the minimum sensible set for
-installing new packages (perhaps via a network).
-<p>
-
-Most of these packages should have <tt/Priority: required/ or at least
-<tt/Priority: important/.
-
-<sect1>The <tt/Essential/ flag
-<p>
-
-The <tt/Essential: yes/ control file field should not be used unless
-removing a package really will completely hose the system; nor should
-it be used for a shared library package - the dependencies will
-prevent its premature removal, and we need to be able to remove it
-when it has been superseded.
-
-<sect1>Including <tt/Priority/ and <tt/Section/ in the <tt/.deb/
-control file
-<p>
-
-If a user installs a package which is not part of the standard
-distribution, or without downloading and updating from a new
-<prgn/Packages/ file, the information about the priority and section
-of a package will be absent, and the <prgn/dselect/ package listing
-will have the package listed under `unclassified'.  In order to
-improve this it is permissible to use the <tt/-is/, <tt/-isp/ or
-<tt/-ip/ option to <prgn/dpkg-gencontrol/, so that the <tt/Section/
-and/or <tt/Priority/ is copied into the actual control information in
-the <tt/.deb/ file.  However, if you do this you should make sure you
-keep the information up to date so that users are not shown
-conflicting information.
-
-
-<sect1>Formatting of the <tt/Description/ control file field
-<p>
-
-Every Debian package should have an extended description.
-<p>
-
-The description should be written so that it tells the user what they
-need to know to decide whether to install the package.  This
-description should not just be copied from the blurb for the program.
-Instructions for configuring or using the package should not be
-included - that is what installation scripts, manpages, Info files and
-<tt>/usr/doc/<var/package/</> are for.  Copyright statements and other
-administrivia should not be included - that is what
-<tt>/usr/doc/copyright</> is for.
-<p>
-
-If you wish to include a list in your extended with entries which are
-a line or more each you must indent each entry by one space to make
-sure that it doesn't get wordwrapped.  The start of each list entry
-should be marked with an asterisk, followed by a single space.  You
-must wrap the list entries yourself to 75 columns, and should start
-continuation lines indented by three spaces so that they line up with
-the start of the text on the first line of each list entry.
-<p>
-
-See the programmers' manual for further requirements and pitfalls.
-
-<sect>Locations of files
-<p>
-
-The location of all installed files and directories must comply fully
-with the Linux File System Standard (FSSTND).  The latest version of
-this document can be found alongside this manual or on
-<ftpsite/tsx-11.mit.edu/ in
-<ftppath>/pub/linux/docs/linux-standards/fsstnd/</>.  Specific questions
-about following the standard may be asked on <prgn/debian-devel/, or
-referred to Daniel Quinlan, the FSSTND coordinator, at
-<email/quinlan@yggdrasil.com/.
-<p>
-
-<sect1>Manpages
-<p>
-
-You must install manpages in <prgn/nroff/ source form, in appropriate
-places under <tt>/usr/man</tt>.  You should only use sections 1 to 9
-(see the FSSTND for more details).  You must <em/not/ install a
-preformatted `cat page'.
-<p>
-
-If no manual page is available for a particular program, utility or
-function and this is reported as a bug on debian-bugs, a symbolic link
-from the requested manual page to the <manref name=undocumented
-section=7> manual page should be provided.  This symbolic link can be
-created from <tt>debian/rules</> like this:
-<example>
-ln -s ../man7/undocumented.7 \
- debian/tmp/usr/man/man[1-9]/the_requested_manpage.[1-9]
-</example>
-This manpage claims that the lack of a manpage has been reported as a
-bug, so you may only do this if it really has (you can report it
-yourself, if you like).  Do not close the bug report until a proper
-manpage is available.
-<p>
-
-You may forward a complaint about a missing manpage to the upstream
-authors, and mark the bug as forwarded in the Debian bug tracking
-system.  Even though the GNU Project do not in general consider the
-lack of a manpage to be a bug, we do - if they tell you that they
-don't consider it a bug you should leave the bug in our bug tracking
-system open anyway.
-<p>
-
-Manpages should be installed uncompressed.
-<p>
-
-If one manpage needs to be accesssible via several names it is better
-to use a symbolic link than the <tt/.so/ feature, but there is no need
-to fiddle with the relevant parts of the upstream source to change
-from <tt/.so/ to symlinks - don't do it unless it's easy.  Do not
-create hard links in the manual page directories, and do not put
-absolute filenames in <tt/.so/ directives.  The filename in a
-<tt/.so/ in a manpage should be relative to the base of the manpage
-tree (usually <tt>/usr/man</tt>).
-
-<sect1>Info documents
-<p>
-
-Info documents should be installed in <tt>/usr/info</tt>.  They should
-be compressed with <tt/gzip -9/.
-<p>
-
-Your package must call <prgn/install-info/ to update the Info <tt/dir/
-file, in its post-installation script:
-<example>
-install-info --quiet --section Development Development \
-  /usr/info/foobar.info
-</example>
-<p>
-
-It is a good idea to specify a section for the location of your
-program; this is done with the <tt/--section/ switch.  To determine
-which section to use, you should use look at <tt>/usr/info/dir</> on
-your system and choose the most relevant (or create a new section if
-none of the current sections are relevant).  Note that the
-<tt/--section/ flag takes two arguments; the first is a regular
-expression to match (case-insensitively) against an existing section,
-the second is used when creating a new one.
-<p>
-
-You must remove the entries in the pre-removal script:
-<example>
-install-info --quiet --remove /usr/info/foobar.info
-</example>
-<p>
-
-If <prgn/install-info/ cannot find a description entry in the Info file
-you will have to supply one.  See <manref name=install-info section=8>
-for details.
-
-<sect1>Additional documentation
-<p>
-
-Any additional documentation that comes with the package can be
-installed at the discretion of the package maintainer.  Text
-documentation should be installed in a directory
-<tt>/usr/doc/<var/package/</tt><footnote>Where <var/package/ is the
-name of the package.</footnote> and compressed with <tt/gzip -9/
-unless it is small.
-<p>
-
-If a package comes with large amounts of documentation which many
-users of the package will not require you should create a separate
-binary package to contain it, so that it does not take up disk space
-on the machines of users who do not need or want it installed.
-<p>
-
-It is often a good idea to put text information files that come with
-the source package in <tt>/usr/doc/<var/package/</> in the binary
-package.  However, don't install the instructions for building and
-installing the package, of course!
-
-<sect1>Preferred documentation formats
-<p>
-
-The unification of Debian documentation is being carried out via HTML.
-<p>
-
-If your package comes with extensive documentation in a markup format
-that can be converted to various other formats you should if possible
-ship HTML versions in the binary package, in the directory
-<tt>/usr/doc/<var/package/</> or its subdirectories.
-<p>
-
-Other formats such as PostScript may be provided at your option.
-
-<sect2>Examples
-<p>
-
-Any examples (configurations, source files, whatever), should be
-installed in a directory <tt>/usr/doc/<var/package//examples</tt>.
-These files should not be referenced by any program - they're there
-for the benefit of the system administrator and users, as
-documentation only.
-
-<sect1 id="copyrightfile"><tt>/usr/doc/copyright/<var/package/</tt>
-<p>
-
-This file must contain details of the authorship and copyright of the
-package.  It must say where the upstream sources (if any) were
-obtained, and explain briefly what modifications were made in the
-Debian version of the package compared to the upstream one.  It must
-name the original authors of the package and the Debian maintainer(s)
-who were involved with its creation.
-<p>
-
-It must contain the full text of the copyright notice and any
-acknowledgements for the program and the licence terms under which the
-program is distributed.  If the package is distributed under the GNU
-General Public Licence, the GNU Library General Public Licence, the
-Regents of the University of California at Berkeley (BSD) licence or
-Larry Wall's Artistic Licence please say so instead of including a
-copy of the licence.  The files <tt/BSD/, <tt/GPL/, <tt/LGPL/ and
-<tt/Artistic/ are be available in <tt>/usr/doc/copyright</tt> for you
-to refer to.  The package's copyright file should not be compressed.
-<p>
-
-Do not use the copyright file as a general <tt/README/ file.  If your
-package has such a file it should be installed in
-<tt>/usr/doc/<var/package//README</> or <tt/README.Debian/ or some
-other appropriate place.  Do not make links between
-<tt>/usr/doc/<var/package/</> and the <tt/copyright/ directory.
-
-<sect1>Symbolic links
-<p>
-
-Most symbolic links should be relative, not absolute.  Absolute links,
-in general, cause problems when a file system is not mounted where it
-"normally" resides (for example, when mounted via NFS).
-<p>
-
-In particular, symlinks from one part of <tt>/usr</tt> to another
-should be relative.
-<p>
-
-In certain cases, however, relative links may cause more problems.
-For example, links into <tt>/etc</tt> and <tt>/var</tt> should be
-absolute.
-<p>
-
-Note that when creating a relative link using <prgn/ln/ it is not
-necessary for the target of the link to exist relative to the working
-directory you're running <prgn/ln/ from; nor is it necessary to change
-directory to the directory where the link is to be made.  Simply
-include the string that should appear as the target of the link (this
-will be a pathname relative to the directory in which the link
-resides) as the first argument to <prgn/ln/.
-<p>
-
-For example, in your <prgn/Makefile/ or <tt>debian/rules</>, do things
-like:
-<example>
-ln -fs gcc $(prefix)/bin/cc
-ln -fs gcc debian/tmp/usr/bin/cc
-ln -fs ../sbin/sendmail $(prefix)/bin/runq
-ln -fs ../sbin/sendmail debian/tmp/usr/bin/runq
-</example>
-
-<sect1>Logfiles
-<p>
-
-Logfiles should usually be named
-<tt>/var/log/<var/package/.log</tt>.  If you have many logfiles,
-or need a separate directory for permissions reasons
-(<tt>/var/log</tt> is writeable only by <tt/root/), you should usually
-create a directory named <tt>/var/log/<var/package/</tt>.
-<p>
-
-Make sure that any logfiles are rotated occasionally using so that
-they don't grow indefinitely; the best way to do this is to use
-<prgn/savelog/ program in an <tt>/etc/cron.daily</>,
-<tt>/etc/cron.weekly</> or <tt>/etc/cron.monthly</> script.
-<p>
-
-Make sure that any logfiles are removed when the package is purged
-(but not when it is only removed), by checking the argument to the
-postrm script (see the programmer's manual for details).
-
-<sect1><tt>/usr/local</> - for the use of the system administrator
-<p>
-
-As mandated by the FSSTND no package should place any files in
-<tt>/usr/local</>, either by putting them in the filesystem archive to
-be unpacked by <prgn/dpkg/ or by manipulating them in their maintainer
-scripts.
-<p>
-
-Every package that searches a number of directories or files for
-something (for example, looking for shared libraries in <tt>/lib</> or
-<tt>/usr/lib</>) should search an appropriate directory in
-<tt>/usr/local</> too.
-<p>
-
-In order that the system administrator may know where to place
-additional files a package should create an empty directory in the
-appropriate place in <tt>/usr/local</> by supplying it in the
-filesystem archive for unpacking by <prgn/dpkg/.  The
-<tt>/usr/local</> directory itself and all the subdirectories created
-by the package should have permissions 2775 (group-writeable and
-set-group-id) and be owned by <tt/root.staff/.
-<p>
-
-In the future it will be possible to tell <prgn/dpkg/ not to unpack
-files matching certain patterns, so that system administrators who do
-not wish these directories in <tt>/usr/local</> do not need to have
-them.
-
-<sect>Permissions and ownerships
-<p>
-
-The rules in this section are guidelines for general use.  If
-necessary you may deviate from the details below.  However, if you do
-so you must make sure that what is done is secure and you must try to
-be as consistent as possible with the rest of the system.  You should
-probably also discuss it on <prgn/debian-devel/ first.
-<p>
-
-Files should be owned by <tt/root.root/, and made writeable only by
-the owner and universally readable (and executable, if appropriate).
-<p>
-
-Directories should be mode 755 or (for group-writability) mode 2775.
-The ownership of the directory should be consistent with its mode -
-if a directory is mode 2775, it should be owned by the group that
-needs write access to it.
-<p>
-
-Setuid and setgid executables should be mode 4755 or 2755
-respectively, and owned by the appropriate user or group.  They should
-not be made unreadable (modes like 4711 or 2711 or even 4111); doing
-so achieves no extra security, because anyone can find the binary in
-the freely available Debian package - it is merely inconvenient.  For
-the same reason you should not restrict read or execute permissions on
-non-set-id executables.
-<p>
-
-Some setuid programs need to be restricted to particular sets of
-users, using file permissions.  In this case they should be owned by
-the uid to which they are set-id, and by the group which should be
-allowed to execute them.  They should have mode 4754; there is no
-point in making them unreadable to those users who must not be allowed
-to execute them.
-<p>
-
-Do not arrange that the system administrator can only reconfigure the
-package to correspond to their local security policy by changing the
-permissions on a binary.  Ordinary files installed by <prgn/dpkg/ (as
-opposed to conffiles and other similar objects) have their permissions
-reset to the distributed permissions when the package is reinstalled.
-Instead you should consider (for example) creating a group for people
-allowed to use the program(s) and making any setuid executables
-executable only by that group.
-<p>
-
-Shared libraries should be installed executable.
-
-<sect>Configuration files
-<p>
-
-Any configuration files created or used by your package should reside
-in <tt>/etc</tt>.  If there are several you should consider creating a
-subdirectory named after your package.
-<p>
-
-It is almost certain that any file in <tt>/etc</tt> that is in your
-package's filesystem archive should be listed in <prgn/dpkg/'s
-<tt/conffiles/ control area file.  (See the <prgn/dpkg/ programmers'
-manual).
-
-<sect>Maintainer scripts
-<p>
-
-The package installation scripts should avoid producing output which
-it is unnecessary for the user to see and should rely on <prgn/dpkg/ to
-stave off boredom on the part of a user installing many packages.
-This means, amongst other things, using the <tt/--quiet/ option on
-<prgn/install-info/.
-<p>
-
-Packages should try to minimise the amount of prompting they need to
-do, and they should ensure that the user will only every be asked each
-question once.  This means that packages should try to use appropriate
-shared configuration files (such as <tt>/etc/papersize</> and
-<tt>/etc/news/server</>, rather than each prompting for their own
-list of required pieces of information.
-<p>
-
-It also means that an upgrade should not ask the same questions again,
-unless the user has used <tt/dpkg --purge/ to remove the package's
-configuration.  The answers to configuration questions should be
-stored in an appropriate place in <tt>/etc</> so that the user can
-modify them, and how this has been done should be documented.
-<p>
-
-If a package has a vitally important piece of information to pass to
-the user (such as "don't run me as I am, you must edit the following
-configuration files first or you risk your system emitting
-badly-formatted messages"), it should display this in the
-<prgn/postinst/ script and prompt the user to hit return to
-acknowledge the message.  Copyright messages do not count as vitally
-important (they belong in <tt>/usr/doc/copyright</>); neither do
-instructions on how to use a program (these should be in on line
-documentation, where all the users can see them).
-<p>
-
-Any necessary prompting should almost always be confined to the
-post-installation script, and should be protected with a conditional
-so that unnecssary prompting doesn't happen if a package's
-installation fails and the <prgn/postinst/ is called with
-<tt/abort-upgrade/, <tt/abort-remove/ or <tt/abort-deconfigure/.
-<p>
-
-Errors which occur during the execution of an installation script
-<em/must/ be checked and the installation <em/must not/ continue after
-an error.
-<p>
-
-The section below on scripts in general applies to package maintainer
-scripts too.
-
-<sect>Scripts in general
-<p>
-
-All command scripts, including the package maintainer scripts inside
-the package and used by <prgn/dpkg/, should have a <tt/#!/ line naming
-the shell to be used to interpret them.
-<p>
-
-In the case of Perl scripts this should be <tt>#!/usr/bin/perl</tt>.
-<p>
-
-Shell scripts (<prgn/sh/ and <prgn/bash/) should almost certainly
-start with <tt>set -e</> so that errors are detected.  Every script
-<em/must/ use <tt/set -e/ or check the exit status of <em/every/
-command.
-<p>
-
-Perl scripts should check for errors when making any system calls,
-including <tt/open/, <tt/print/, <tt/close/, <tt/rename/ and
-<tt/system/.
-<p>
-
-<prgn/csh/ and <prgn/tcsh/ should be avoided as scripting languages.  See
-Csh Programming Considered Harmful, one of the <tt/comp.unix.*/ FAQs.
-If an upstream package comes with <prgn/csh/ scripts then you must make
-sure that they start with <tt>#!/bin/csh</tt> and make your package
-depend on <prgn/csh/.
-<p>
-
-<sect>Compilation options
-<p>
-
-Generally the following compilation parameters should be used:
-<example>
-CC = gcc
-CFLAGS = -O2 -g -Wall # sane warning options vary between programs
-LDFLAGS = # none
-install -s # (or use strip on the files in debian/tmp)
-</example>
-<p>
-
-Note that all installed binaries should be stripped, either by using
-the <tt/-s/ flag to <prgn/install/, or by calling <prgn/strip/ on the
-binaries after they have been copied into <tt>debian/tmp</> but
-before the tree is made into a package.
-<p>
-
-Make sure that you do not link with <tt/-g/, as this makes a.out
-compilers produce huge statically linked binaries.  The <tt/-g/ flag
-is useful on compilation so that you have available a full set of
-debugging symbols in your built source tree, in case anyone should
-file a bug report involving (for example) a core dump.
-<p>
-
-The <tt/-N/ flag should not be used.  On a.out systems it may have
-been useful for some very small binaries, but for ELF it has no good
-effect.
-<p>
-
-It is up to the package maintainer to decide what compilation options
-are best for the package.  Certain binaries (such as
-computationally-intensive programs) may function better with certain
-flags (<tt/-O3/, for example); feel free to use them.  Please use good
-judgment here.  Don't use flags for the sake of it; only use them if
-there is good reason to do so.  Feel free to override the upstream
-author's ideas about which compilation options are best - they are
-often inappropriate for our environment.
-<p>
-
-Please make sure that you use only released versions of shared
-libraries to build your packages; otherwise other users will not be
-able to run your binaries properly.  Producing source packages that
-depend on unreleased compilers is also usually a bad idea.
-
-<sect>Shared library packages
-<p>
-
-Packages involving shared libraries should be split up into several
-binary packages.
-<p>
-
-For a straightforward library which has a development environment and
-a runtime kit including just shared libraries you need to create two
-packages: <tt/<var/libraryname/<var/soname//<footnote><var/soname/ is
-the shared object name of the shared library - it's the thing that has
-to match exactly between building an executable and running it for the
-dynamic linker to be able run the program.  Usually the <var/soname/
-is the major number of the library.</footnote> and
-<tt/<var/libraryname/<var/soname/-dev/.
-<p>
-
-If you prefer only to support one development version time you may
-name the development package <tt/<var/libraryname/-dev/; otherwise you
-may wish to use <prgn/dpkg/'s conflicts mechanism to ensure that the
-user only installs one development version at a time (after all,
-different development versions are likely to have the same header
-files in them, causing a filename clash if both are installed).
-Typically the development version will also need an exact version
-dependency on the runtime library, to make sure that compilation and
-linking happens correctly.
-<p>
-
-Packages which use the shared library should have a dependency on the
-name of the shared library package,
-<tt/<var/libraryname/<var/soname//.  When the <var/soname/ changes you
-can have both versions of the library installed while moving from the
-old library to the new.
-<p>
-
-If your package has some run-time support programs which use the
-shared library you must <em/not/ put them in the shared library
-package.  If you do that then you won't be able to install several
-versions of the shared library without getting filename clashes.
-Instead, either create a third package for the runtime binaries (this
-package might typically be named <tt/<var/libraryname/-runtime/ - note
-the absence of the <var/soname/ in the package name) or if the
-development package is small include them in there.
-<p>
-
-If you have several shared libraries built from the same source tree
-you can lump them all togther into a single shared library package,
-provided that you change all their <var/soname/s at once (so that you
-don't get filename clashes if you try to install different versions of
-the combined shared libraries package).
-<p>
-
-Follow the directions in the <prgn/dpkg/ programmers' manual for
-putting the shared library in its package.
-
-<sect>Application configuration files, dotfiles and <tt>/etc/skel</>
-<p>
-
-Files in <tt>/etc/skel</> will automatically be copied into new user
-accounts by <prgn/adduser/.  They should not be referenced there by
-any program.
-<p>
-
-Therefore, if a program needs a dotfile to exist in advance in
-<tt/$HOME/ to work sensibly that dotfile should be installed in
-<tt>/etc/skel</> (and listed in conffiles, if it is not generated and
-modified dynamically by the package's installation scripts).
-<p>
-
-However, programs that require dotfiles in order to operate sensibly
-(dotfiles that they do not create themselves automatically, that is)
-are a bad thing, and programs should be configured by the Debian
-default installation as close to normal as possible.
-<p>
-
-Therefore, if a program in a Debian package needs to be configured in
-some way in order to operate sensibly that configuration should be
-done in a site-wide global configuration file elsewhere in
-<tt>/etc</>.  Only if the program doesn't support a site-wide default
-configuration and the package maintainer doesn't have time to add it
-should a default per-user file be placed in <tt>/etc/skel</>.
-<p>
-
-<tt>/etc/skel</> should be as empty as we can make it.  This is
-particularly true because there is no easy mechanism for ensuring that
-the appropriate dotfiles are copied into the accounts of existing
-users when a package is installed.
-<p>
-
-Ideally the sysadmin should ideally not have to do any configuration
-other than that done (semi-)automatically by the postinst script.
-
-<sect id="mail">Mail processing on Debian systems
-<p>
-
-Debian packages which process electronic mail, whether
-mail-user-agents (MUAs) or mail-transport-agents (MTAs), <em/must/
-make sure that they are compatible with the configuration decisions
-below.  Failure to do this may result in lost mail, broken <tt/From:/
-lines, and other serious brain damage!
-<p>
-
-The mail spool is <tt>/var/spool/mail</> and the interface to send a
-mail message is <tt>/usr/sbin/sendmail</> (as per the FSSTND).  The
-mail spool is part of the base system and not part of the MTA package.
-<p>
-
-Mailboxes are locked using the <tt/<var/username/.lock/ lockfile
-convention, rather than <prgn/fcntl/, <prgn/flock/ or <prgn/lockf/.
-<p>
-
-Mailboxes are generally 660 <tt/<var/user/.mail/ unless the user has
-chosen otherwise.  A MUA may remove a mailbox (unless it has
-nonstandard permissions) in which case the MTA or another MUA must
-recreate it if needed.  Mailboxes must be writeable by group mail.
-<p>
-
-The mail spool is 2775 <tt/mail.mail/, and MUA's need to be setgid
-mail to do the locking mentioned above (and obviously need to avoid
-accessing other users' mailboxes using this privilege).
-<p>
-
-<tt>/etc/aliases</> is the source file for the system mail aliases
-(e.g.  postmaster, usenet, etc.) - it is the one which the sysadmin
-and postinst scripts may edit.  After <tt>/etc/aliases</> is edited
-the program or human editing it must call <prgn/newaliases/.  All MTA
-packages should come with a <prgn/newaliases/ program, even if it does
-nothing, but older MTA packages do not do this so programs should not
-fail if <prgn/newaliases/ cannot be found.
-<p>
-
-The convention of writing <tt/forward to <var/address// in the mailbox
-itself is not supported.  Use a <tt/.forward/ file instead.
-<p>
-
-The location for the <prgn/rmail/ program used by UUCP for incoming
-mail is <tt>/usr/sbin/rmail</>, as per the FSSTND.  Likewise,
-<prgn/rsmtp/, for receiving batch-SMTP-over-UUCP, is in
-<tt>/usr/sbin/rsmtp</> if it is supported.
-<p>
-
-Smail is not using HoneyDanBer UUCP, whose <prgn/uux/ apparently
-accepts <tt/-a/ and <tt/-g/ options.
-<p>
-
-If you need to know what name to use (for example) on outgoing news
-and mail messages which are generated locally, you should use the file
-<tt>/etc/mailname</>.  It will contain the portion after the username
-and <tt/@/ (at) sign for email addresses of users on the machine
-(followed by a newline).
-<p>
-
-A package should check for the existence of this file.  If it exists
-it should use it without comment.<footnote>An MTA's prompting
-configuration script may wish to prompt the user even if it finds this
-file exists.</footnote> If it does not exist it should prompt the user
-for the value and store it in <tt>/etc/mailname</> as well as using it
-in the package's configuration.  The prompt should make it clear that
-the name will not just be used by that package.  E.g., in this
-situation the INN package says:
-<example>
-Please enter the `mail name' of your system.  This is the hostname
-portion of the address to be shown on outgoing news and mail messages.
-The default is <var/syshostname/, your system's host name.
-Mail name [`<var/syshostname/']:
-</example>
-where <var/syshostname/ is the output of <tt/hostname -fqdn/.
-
-
-<sect>Packages which can use the X shared libraries
-<p>
-
-Some programs can be configured with or without support for X Windows.
-Typically these binaries produced when configured for X will need the
-X shared libraries to run.
-<p>
-
-Such programs should be configured <em/with/ X support, and should
-declare a dependency on <tt/elf-x11r6lib/ (for the X11R6 libraries).
-Users who wish to use the program can install just the relatively
-small <tt/xlib/ package, and do not need to install the whole of X.
-<p>
-
-Do not create two versions (one with X support and one without) of
-your package.
-
-
-<sect>Games
-<p>
-
-The permissions on /var/lib/games are 755 <tt/root.root/.
-<p>
-
-Each game decides on its own security policy.
-<p>
-
-Games which require protected, privileged access to high-score files,
-savegames, &amp;c, must be made set-<em/group/-id (mode 2755) and
-owned by <tt/root.games/, and use files and directories with
-appropriate permissions (770 <tt/root.games/, for example).  They must
-<em/not/ be made set-<em/user/-id, as this causes security
-problems.<footnote>If an attacker can subvert any set-user-id game
-they can overwrite the executable of any other, causing other players
-of these cames to run a trojan.  With a set-group-id game the attacker
-only gets access to less important game data, and if they can get at
-the other players' accounts at all it will take considerably more
-effort.</footnote>
-<p>
-
-Some packages, for example some fortune cookie programs, are
-configured by the upstream authors to install with their data files or
-other static information made unreadable so that they can only be
-accessed through set-id programs provided.  Do not do this in a Debian
-package: anyone can download the <tt/.deb/ file and read the data from
-it, so there is no point making the files unreadable.  Not making the
-files unreadable also means that you don't have to make so many
-programs set-id, which reduces the risk of a security hole.
-
-<sect>Allocating package-specific users and groups
-<p>
-
-If you need to create a new user or group for your package there are
-two possibilities.  Firstly, you may need to make some files in the
-binary package be owned by this user or group, or you may need to
-compile the user or group id (rather than just the name) into the
-binary (though this latter should be avoided if possible).  In this
-case you need a statically allocated id.
-<p>
-
-You must ask for a user or group id from the base system maintainer,
-and must not release the package until you have been allocated one.
-Once you have been allocated one you must make the package depend
-on a version of the base system with the id present in
-<tt>/etc/passwd</tt> or <tt>/etc/group</tt>, or alternatively arrange
-for your package to create the user or group itself with the correct
-id (using <tt/adduser/) in its pre- or post-installation script (the
-latter is to be preferred if it is possible).
-<p>
-
-On the other hand, the program may able to determine the uid or gid
-from the group name at runtime, so that a dynamic id can be used.  In
-this case you must choose an appropriate user or group name,
-discussing this on <prgn/debian-devel/ and checking with the base system
-maintainer that it is unique and that they do not wish you to use a
-statically allocated id instead.  When this has been checked you must
-arrange for your package to create the user or group if necessary
-using <prgn/adduser/ in the pre- or post-installation script (again, the
-latter is to be preferred if it is possible).
-<p>
-
-Note that changing the numeric value of an id associated with a name
-is very difficult, and involves searching the filesystem for all
-appropriate files.  You need to think carefully whether a static or
-dynamic id is required, since changing your mind later will cause
-problems.
-
-<chapt id="sourcepkg">Source package
-
-<sect>Documentation and the <tt/changelog/
-<p>
-
-Document your changes and updates to the source package properly in
-the <tt>debian/changelog</tt> file.
-<p>
-
-A copy of the file which will be installed in
-<tt>/usr/doc/copyright/<var/package/</tt> should be in
-<tt>debian/copyright</tt>.
-<p>
-
-In non-experimental packages you may only use a format for
-<tt>debian/changelog</> which is supported by the most recent released
-version of <prgn/dpkg/.  If your format is not supported and there is
-general support for it you should contact the <prgn/dpkg/ maintainer
-to have the parser script for your format included in the <prgn/dpkg/
-package.<footnote>You will need to agree that the parser and its
-manpage may be distributed under the GNU GPL, just as the rest of
-<prgn/dpkg/ is.</footnote>
-
-<sect>Changes to the upstream sources
-<p>
-
-If you need to edit a <prgn/Makefile/ where GNU-style <prgn/configure/
-scripts are used, you should edit the <tt/.in/ files rather than
-editing the <prgn/Makefile/ directly.  This allows the user to
-reconfigure the package if necessary.  You should <em/not/ configure
-the package and edit the generated <prgn/Makefile/!  This makes it
-impossible for someone else to later reconfigure the package.
-<p>
-
-If changes to the source code are made that are generally applicable
-please try to get them included in the upstream version of the package
-by supplying the upstream authors with the changes in whatever form
-they prefer.
-<p>
-
-If you need to configure the package differently for Debian or for
-Linux, and the upstream source doesn't provide a way to configure it
-the way you need to, please add such configuration facilities (for
-example, a new <prgn/autoconf/ test or <tt/#define/) and send the
-patch to the upstream authors, with the default set to the way they
-originally had it.  You can then easily override the default in your
-<tt>debian/rules</tt> or wherever is appropriate.
-
-<sect>Error trapping in makefiles
-<p>
-
-When <prgn/make/ invokes a command in a makefile (including your
-package's upstream makefiles and the <tt>debian/rules</>) it does so
-using <tt/sh/.  This means that <tt/sh/'s usual bad error handling
-properties apply: if you include a miniature script as one of the
-commands in your makefile you'll find that if you don't do anything
-about it then errors are not detected and <prgn/make/ will blithely
-continue after problems.
-<p>
-
-Every time you put more than one shell command (this includes using a
-loop) in a makefile command you <em/must/ make sure that errors are
-trapped.  For simple compound commands, such as changing directory and
-then running a program, using <tt/&amp;&amp;/ rather than semicolon as
-a command separator is sufficient.  For more complex commands
-including most loops and conditionals you must include a separate
-<tt/set -e/ command at the start of every makefile command that's
-actually one of these miniature shellscripts.
-
-<sect>Permissions
-<p>
-
-All the files in the source package should be world-readable and
-user-writeable.  Directories and executable programs should be
-world-exectuable.  None of the files should be world-writeable.  The
-files may or may not be group-writeable, and directories may or may
-not be setgid.  Pipes should not be world-readable and should be
-either both group readable and writeable or neither (and they should
-not be executable).
-<p>
-
-In summary: data files may be <tt/664/, <tt/644/.  Executable files
-may be <tt/775/ or <tt/755/.  Directories may be <tt/775/, <tt/755/,
-<tt/2775/ or <tt/2755/.  Pipes may be <tt/660/ or <tt/600/.
-
-<chapt id="developer">How to become a Debian developer
-
-<sect>Before you start work
-<p>
-
-So, you've read all the documentation, you understand what everything
-in the <prgn/hello/ example package is for, and you're about to
-Debianise your favourite package.  How do you actually become a Debian
-developer so that your work can be incorporated into the Project?
-<p>
-
-Firstly, subscribe to <prgn/debian-devel/ if you haven't already.
-Send the word <tt/subscribe/ in the <em/Subject/ of a mail to
-<email/debian-devel-REQUEST@lists.debian.org/.  In case of problems
-contact the list administrator, Anders Chrigstrom <email/ac@netg.se/.
-<p>
-
-You should to subscribe and lurk for a bit before doing any coding,
-and you should post about your intentions to work on something to
-avoid duplicated effort.
-<p>
-
-If you do not have a PGP key yet generate one.  You should probably
-read the PGP manual, as it has much important information which is
-critical to its security.  Many more security failures are due to
-human error than to software failure or high-powered spy techniques.
-
-<sect>When you have a package to upload
-<p>
-
-When you have your package ready to be uploaded you must send a
-message to the project leader, Bruce Perens <email/bruce@pixar.com/,
-the administrator of <tt/master.debian.org/, Simon Shapiro
-<email/shimon@i-connect.net/, the mailing list administrator, Anders
-Chrigstrom <email/ac@netg.se/ and the <prgn/dpkg/ maintainer, Ian
-Jackson <email/ijackson@gnu.ai.mit.edu/.
-<p>
-
-The message should say what you've done and who you are, and should
-ask for an account on <prgn/master/ and to be subscribed to
-<prgn/debian-private/ (the developers-only mailing list).  It should
-contain your PGP key (extracted using <tt/pgp -kxa/) for the database
-of keys which is shipped with <prgn/dpkg/.
-
-When you have your personal account on <prgn/master/ log in and
-transfer the files to
-<tt>/home/Debian/ftp/private/project/Incoming</>.  You cannot upload
-to <prgn/Incoming/ on <prgn/master/ using anonymous FTP.
-<p>
-
-You can also upload files to <prgn/Incoming/ via a <prgn/cron/-driven
-upload queue in Europe on <ftpsite/chiark.chu.cam.ac.uk/.  For details
-connect to <prgn/chiark/ using anonymous FTP and read
-<ftppath>/pub/debian/private/project/README.how-to-upload</ftppath>.
-
-<sect id="changesfiles">Upload handling - <tt/.changes/ files
-<p>
-
-When a package is uploaded to the Debian FTP archive, it must be
-accompanied by a <tt/.changes/ file which gives directions for its
-handling.  This is usually generated by <prgn/dpkg-genchanges/.
-<p>
-
-This file is a control file with the following fields:
-<list compact>
-<item><tt/Format/
-<item><tt/Date/
-<item><tt/Source/
-<item><tt/Binary/
-<item><tt/Architecture/
-<item><tt/Version/
-<item><tt/Distribution/
-<item><tt/Urgency/
-<item><tt/Maintainer/
-<item><tt/Description/
-<item><tt/Changes/
-<item><tt/Files/
-</list>
-<p>
-
-All of them are mandatory for a Debian upload.  See the list of
-control fields in the <prgn/dpkg/ programmers' manual for the contents
-of these fields.
-
-
-<chapt id="mailinglists">The Debian mailing lists
-<p>
-
-The mailing list server is at <tt/lists.debian.org/.  Mail
-<tt/debian-<var/foo/-REQUEST@lists.debian.org/<footnote>where
-<tt/debian-<var/foo// is the name of the list</footnote> with the word
-<tt/subscribe/ in the Subject to subscribe or <tt/unsubscribe/ to
-unsubscribe.
-<p>
-
-When replying to messages on the mailing list, please do not send a
-carbon copy (<tt/CC/ - this does not mean `courtesy copy') to the
-original poster.  Anyone who posts to a mailing list should read it to
-see the responses.
-<p>
-
-As ever on the net, please trim down the quoting of articles you're
-replying to.
-
-</book>
index 6360d245ce47010e334bc9e2d06afa3b0cbc5b46..509e715910bc7235302bc7a79ccad61592f5c310 100644 (file)
@@ -259,6 +259,49 @@ This file contains a list of configuration files which are to be
 handled automatically by <prgn/dpkg/ (see <ref id="conffiles">).  Note
 that not necessarily every configuration file should be listed here.
 
+<tag><tt/shlibs/
+<item>
+
+This file contains a list of the shared libraries supplied by the
+package, with dependency details for each.  This is used by
+<prgn/dpkg-shlibdeps/ when it determines what dependencies are
+required in a package control file.
+<p>
+
+Each line is of the form:
+<example>
+<var/library-name/ <var/version-or-soname/ <var/dependencies .../
+</example>
+<p>
+
+<var/library-name/ is the name of the shared library, for example
+<tt/libc5/.
+<p>
+
+<var/version-or-soname/ is the soname of the library - ie, the thing
+that must exactly match for the library to be recognised by
+<prgn/ld.so/.  Usually this is major version number of the library.
+<p>
+
+<var/dependencies/ has the same syntax as a dependency field in a
+binary package control file.  It should give details of which
+package(s) are required to satisfy a binary built against the version
+of the library contained in the package.  See <ref id="depsyntax">.
+<p>
+
+For example, if the package <tt/foo/ contains <tt/libfoo.so.1.2.3/,
+where the soname of the library is <tt/libfoo.so.1/, and the first
+version of the package which contained a minor number of at least
+<tt/2.3/ was <var/1.2.3-1/, then the package's <var/shlibs/ could
+say:
+<example>
+libfoo 1       foo (>= 1.2.3-1)
+</example>
+<p>
+
+The version-specific dependency is to avoid warnings from <prgn/ld.so/
+about using older shared libraries with newer binaries.
+
 </taglist>
 
 <sect id="controlfile">The main control information file: <tt/control/
@@ -292,6 +335,7 @@ installed.</footnote>
 <item><qref id="f-classification"><tt/Section/, <tt/Priority/</>
 <item><qref id="f-Source"><tt/Source/</>
 <item><qref id="descriptions"><tt/Description/</>
+<item><qref id="f-Installed-Size"><tt/Installed-Size/</>
 
 </list>
 <p>
@@ -1152,6 +1196,16 @@ commas.<footnote>A space after each comma is conventional.</footnote>
 Currently the packages must be separated using only spaces in the
 <tt/.changes/ file.
 
+<sect1 id="f-Installed-Size"><tt/Installed-Size/
+<p>
+
+This field appears in the control files of binary packages, and in the
+<tt/Packages/ files.  It gives the total amount of disk space
+required to install the named package.
+<p>
+
+The disk space is represented in kilobytes as a simple decimal number.
+
 <sect1 id="f-Files"><tt/Files/
 <p>
 
@@ -1989,7 +2043,7 @@ This is done using the <tt/Depends/, <tt/Recommends/, <tt/Suggests/,
 <tt/Conflicts/, <tt/Provides/ and <tt/Replaces/ control file fields.
 <p>
 
-<sect>Syntax of relationship fields
+<sect id="depsyntax">Syntax of relationship fields
 <p>
 
 These fields all have a uniform syntax.  They are a list of package
index 987a05bdd5d2a517381b9453ea3055952b369ed9..a3ddbc29b5c0b2bb81cb5f16c0a6caf3dd070f9b 100644 (file)
@@ -48,7 +48,7 @@ static void cu_info_prepare(int argc, void **argv) {
   if (lstat(directory,&stab) && errno==ENOENT) return;
   if ((c1= fork()) == -1) { perror("failed to fork for cleanup"); return; }
   if (!c1) {
-    execlp(RM,"rm","-r",directory,(char*)0);
+    execlp(RM,"rm","-rf",directory,(char*)0);
     perror("failed to exec " RM " for cleanup"); _exit(1);
   }
   if (waitpid(c1,&status,0) != c1) { perror("failed to wait for rm cleanup"); return; }
index b2de971cf82c38e0707589ef0405bf051e3e12b0..e84745d7bc3fc7c9867aa5b10d3c8d6f34670800 100644 (file)
@@ -90,7 +90,7 @@ struct pkginfoperfile { /* pif */
   struct dependency *depends;
   struct deppossi *depended;
   int essential; /* The `essential' flag, 1=yes, 0=no (absent) */
-  char *description, *maintainer, *source, *architecture;
+  char *description, *maintainer, *source, *architecture, *installedsize;
   struct versionrevision version;
   struct conffile *conffiles;
   struct arbitraryfield *arbs;
index 02c3c3cf90aeec3dc93c1e58ebf0c7b7bbff95f5..e2043116126d78348a730882a469c589db436c51 100644 (file)
@@ -129,7 +129,7 @@ void blankpackageperfile(struct pkginfoperfile *pifp) {
   pifp->essential= 0;
   pifp->depends= 0;
   pifp->depended= 0;
-  pifp->description= pifp->maintainer= pifp->source= 0;
+  pifp->description= pifp->maintainer= pifp->source= pifp->installedsize= 0;
   pifp->architecture= 0;
   blankversion(&pifp->version);
   pifp->conffiles= 0;
@@ -155,6 +155,7 @@ int informative(struct pkginfo *pkg, struct pkginfoperfile *info) {
   if (info->depends ||
       nes(info->description) ||
       nes(info->maintainer) ||
+      nes(info->installedsize) ||
       nes(info->source) ||
       nes(info->architecture) ||
       informativeversion(&info->version) ||
index 499dddfc3cad0a4cefeb5d1fecec37d2162b5ae9..728756aeb172cd93f5fd7c33d447b7596af67d1b 100644 (file)
 
 const struct fieldinfo fieldinfos[]= {
   /* NB: capitalisation of these strings is important. */
-  { "Package",          f_name,            w_name                                    },
-  { "Essential",        f_boolean,         w_booleandefno,   PKGIFPOFF(essential)    },
-  { "Status",           f_status,          w_status                                  },
-  { "Priority",         f_priority,        w_priority                                },
-  { "Section",          f_section,         w_section                                 },
-  { "Maintainer",       f_charfield,       w_charfield,      PKGIFPOFF(maintainer)   },
-  { "Architecture",     f_charfield,       w_charfield,      PKGIFPOFF(architecture) },
-  { "Source",           f_charfield,       w_charfield,      PKGIFPOFF(source)       },
-  { "Version",          f_version,         w_version                                 },
-  { "Revision",         f_revision,        w_null                                    },
-  { "Config-Version",   f_configversion,   w_configversion                           },
-  { "Replaces",         f_dependency,      w_dependency,     dep_replaces            },
-  { "Provides",         f_dependency,      w_dependency,     dep_provides            },
-  { "Depends",          f_dependency,      w_dependency,     dep_depends             },
-  { "Pre-Depends",      f_dependency,      w_dependency,     dep_predepends          },
-  { "Recommends",       f_dependency,      w_dependency,     dep_recommends          },
-  { "Suggests",         f_dependency,      w_dependency,     dep_suggests            },
-  { "Conflicts",        f_dependency,      w_dependency,     dep_conflicts           },
-  { "Conffiles",        f_conffiles,       w_conffiles                               },
-  { "Filename",         f_filecharf,       w_filecharf,      FILEFOFF(name)          },
-  { "Size",             f_filecharf,       w_filecharf,      FILEFOFF(size)          },
-  { "MD5sum",           f_filecharf,       w_filecharf,      FILEFOFF(md5sum)        },
-  { "MSDOS-Filename",   f_filecharf,       w_filecharf,      FILEFOFF(msdosname)     },
-  { "Description",      f_charfield,       w_charfield,      PKGIFPOFF(description)  },
+  { "Package",          f_name,            w_name                                     },
+  { "Essential",        f_boolean,         w_booleandefno,   PKGIFPOFF(essential)     },
+  { "Status",           f_status,          w_status                                   },
+  { "Priority",         f_priority,        w_priority                                 },
+  { "Section",          f_section,         w_section                                  },
+  { "Installed-Size",   f_charfield,       w_charfield,      PKGIFPOFF(installedsize) },
+  { "Maintainer",       f_charfield,       w_charfield,      PKGIFPOFF(maintainer)    },
+  { "Architecture",     f_charfield,       w_charfield,      PKGIFPOFF(architecture)  },
+  { "Source",           f_charfield,       w_charfield,      PKGIFPOFF(source)        },
+  { "Version",          f_version,         w_version                                  },
+  { "Revision",         f_revision,        w_null                                     },
+  { "Config-Version",   f_configversion,   w_configversion                            },
+  { "Replaces",         f_dependency,      w_dependency,     dep_replaces             },
+  { "Provides",         f_dependency,      w_dependency,     dep_provides             },
+  { "Depends",          f_dependency,      w_dependency,     dep_depends              },
+  { "Pre-Depends",      f_dependency,      w_dependency,     dep_predepends           },
+  { "Recommends",       f_dependency,      w_dependency,     dep_recommends           },
+  { "Suggests",         f_dependency,      w_dependency,     dep_suggests             },
+  { "Conflicts",        f_dependency,      w_dependency,     dep_conflicts            },
+  { "Conffiles",        f_conffiles,       w_conffiles                                },
+  { "Filename",         f_filecharf,       w_filecharf,      FILEFOFF(name)           },
+  { "Size",             f_filecharf,       w_filecharf,      FILEFOFF(size)           },
+  { "MD5sum",           f_filecharf,       w_filecharf,      FILEFOFF(md5sum)         },
+  { "MSDOS-Filename",   f_filecharf,       w_filecharf,      FILEFOFF(msdosname)      },
+  { "Description",      f_charfield,       w_charfield,      PKGIFPOFF(description)   },
   /* Note that aliases are added to the nicknames table in parsehelp.c. */
-  {  0   /* sentinel - tells code that list is ended */                              }
+  {  0   /* sentinel - tells code that list is ended */                               }
 };
 #define NFIELDS (sizeof(fieldinfos)/sizeof(struct fieldinfo))
 const int nfields= NFIELDS;
index 8f77b542f3d415070d1fdafb3cfd730761549988..ca542793b4909e64e39c4ef2dd6c90471b7cd3c2 100644 (file)
@@ -751,6 +751,7 @@ void process_archive(const char *filename) {
   pkg->installed.maintainer= pkg->available.maintainer;
   pkg->installed.source= pkg->available.source;
   pkg->installed.architecture= 0; /* This is irrelevant in the status file. */
+  pkg->installed.installedsize= pkg->available.installedsize;
   pkg->installed.version= pkg->available.version;
 
   /* We have to generate our own conffiles structure. */
@@ -887,6 +888,7 @@ void process_archive(const char *filename) {
     otherpkg->installed.depends= 0;
     otherpkg->installed.essential= 0;
     otherpkg->installed.description= otherpkg->installed.maintainer= 0;
+    otherpkg->installed.installedsize= otherpkg->installed.source= 0;
     otherpkg->installed.conffiles= 0;
     blankversion(&otherpkg->installed.version);
     otherpkg->installed.arbs= 0;
index 86bc81e31b6794119010023784d11e781e6bdc2e..993588d82e917d70cf42b122883eaf4132733cda 100644 (file)
@@ -457,6 +457,7 @@ void removal_bulk(struct pkginfo *pkg) {
     pkg->installed.depends= 0;
     pkg->installed.essential= 0;
     pkg->installed.description= pkg->installed.maintainer= 0;
+    pkg->installed.source= pkg->installed.installedsize= 0;
     blankversion(&pkg->installed.version);
     pkg->installed.arbs= 0;
   }
index a6d8678198e3e23129b365190842713746ef77e6..fb60808d23ba9f04751d06fc3fa9e208b235e002 100644 (file)
@@ -39,8 +39,8 @@ perlpath = @perlpath@
 MAN1 =  dpkg-name dpkg-source 822-date
 LSMAN = dpkg-source.$(man1)
 LSMANL=        dpkg-gencontrol dpkg-genchanges dpkg-buildpackage \
-       dpkg-distaddfile dpkg-parsechangelog
-EXC =   dpkg-name dpkg-source dpkg-genchanges dpkg-gencontrol \
+       dpkg-distaddfile dpkg-parsechangelog dpkg-shlibdeps
+EXC =   dpkg-name dpkg-source dpkg-genchanges dpkg-gencontrol dpkg-shlibdeps \
        dpkg-buildpackage dpkg-parsechangelog dpkg-distaddfile 822-date
 MAN8 = update-rc.d start-stop-daemon update-alternatives install-info \
        dpkg-scanpackages
index 151a56e78ebb4ffc1a9a7dd822f33a55c983cc70..f662b6f83e4d675e508cea08f8bd4dbcfbd61965 100644 (file)
@@ -1,11 +1,12 @@
 $parsechangelog= 'dpkg-parsechangelog';
 
-grep($capit{lc $_}=$_, qw(Pre-Depends Standards-Version));
+grep($capit{lc $_}=$_, qw(Pre-Depends Standards-Version Installed-Size));
 
 $substvar{'Format'}= 1.5;
-$substvar{'newline'}= "\n";
-$substvar{'space'}= " ";
-$substvar{'tab'}= "\t";
+$substvar{'Newline'}= "\n";
+$substvar{'Space'}= " ";
+$substvar{'Tab'}= "\t";
+$maxsubsts=50;
 
 $progname= $0; $progname= $& if $progname =~ m,[^/]+$,;
 
@@ -18,16 +19,20 @@ sub findarch {
     $arch=`dpkg --print-architecture`;
     $? && &subprocerr("dpkg --print-archictecture");
     $arch =~ s/\n$//;
-    $substvar{'arch'}= $arch;
+    $substvar{'Arch'}= $arch;
 }
 
 sub substvars {
     my ($v) = @_;
-    my $lhs,$vn,$rhs;
+    my $lhs,$vn,$rhs,$count;
+    $count=0;
     while ($v =~ m/\$\{([-:0-9a-z]+)\}/i) {
+        $count < $maxsubsts ||
+            &error("too many substitutions - recursive ? - in \`$v'");
         $lhs=$`; $vn=$1; $rhs=$';
         if (defined($substvar{$vn})) {
             $v= $lhs.$substvar{$vn}.$rhs;
+            $count++;
         } else {
             &warn("unknown substitution variable \${$vn}");
             $v= $lhs.$rhs;
@@ -37,14 +42,14 @@ sub substvars {
 }
 
 sub outputclose {
-    for $f (keys %f) { $substvar{"f:$f"}= $f{$f}; }
+    for $f (keys %f) { $substvar{"F:$f"}= $f{$f}; }
     if (length($varlistfile)) {
         $varlistfile="./$varlistfile" if $varlistfile =~ m/\s/;
         if (open(SV,"< $varlistfile")) {
             while (<SV>) {
                 next if m/^\#/ || !m/\S/;
                 s/\s*\n$//;
-                m/^(\w+)\=/ ||
+                m/^(\w[-:0-9A-Za-z]*)\=/ ||
                     &error("bad line in substvars file $varlistfile at line $.");
                 $substvar{$1}= $';
             }
@@ -56,6 +61,7 @@ sub outputclose {
     for $f (sort { $fieldimps{$b} <=> $fieldimps{$a} } keys %f) {
         $v= $f{$f};
         $v= &substvars($v);
+        $v =~ m/\S/ || next; # delete whitespace-only fields
         $v =~ m/\n\S/ && &internerr("field $f has newline then non whitespace >$v<");
         $v =~ m/\n[ \t]*\n/ && &internerr("field $f has blank lines >$v<");
         $v =~ m/\n$/ && &internerr("field $f has trailing newline >$v<");
@@ -91,7 +97,7 @@ sub parsechangelog {
     }
     &parsecdata('L',0,"parsed version of changelog");
     close(CDATA); $? && &subprocerr("parse changelog");
-    $substvar{'sourceversion'}= $fi{"L Version"};
+    $substvar{'Source-Version'}= $fi{"L Version"};
 }
 
 
index 024419bc3d6823bb8f343ce5d5fa49e755d9e919..7b4d4402a803adce45983afb943a29830a17929b 100644 (file)
@@ -18,6 +18,7 @@ Options:  -r<gain-root-command>
           -B         (binary-only, no arch-indep files)
           -us        (unsigned source)
           -uc        (unsigned changes)
+          -h         print this message
 END
 }
 
index ddbdb345345a1fb8630ab38ae98b56caed661e9f..6bbfebcaf5d436390e1d3f3f253aeec7a293c8d8 100644 (file)
@@ -18,8 +18,9 @@ Ian Jackson.  This is free software; see the GNU General Public Licence
 version 2 or later for copying conditions.  There is NO warranty.
 
 Usage:
-  dpkg-addfile <filename> <section> <priority>
+  dpkg-distaddfile <filename> <section> <priority>
 Options:  -f<fileslistfile>      write files here instead of debian/files
+          -h                     print this message
 ";
 }
 
index 53d0ee3c8878099605a7bc7f59f650e6a1375707..44a7bc9ff554c98255615d6fc26bfdf89286a529 100644 (file)
@@ -37,6 +37,7 @@ Options:  -b                     binary-only build - no source files
           -T<varlistfile>        read variables here, not debian/substvars
           -D<field>=<value>      override or add a field and value
           -U<field>              remove a field
+          -h                     print this message
 ";
 }
 
@@ -70,7 +71,7 @@ while (@ARGV) {
         $override{$1}= $';
     } elsif (m/^-U([^\=:]+)$/) {
         $remove{$1}= 1;
-    } elsif (m/^-V(\w+)[=:]/) {
+    } elsif (m/^-V(\w[-:0-9A-Za-z]*)[=:]/) {
         $substvar{$1}= $';
     } elsif (m/^-h$/) {
         &usageversion; exit(0);
index e2176b2e4552f9f7618a260750563bb041dd6f12..4a8c28f62102497934524a8fb9597d4c8772e8e6 100644 (file)
@@ -7,6 +7,7 @@ $controlfile= 'debian/control';
 $changelogfile= 'debian/changelog';
 $fileslistfile= 'debian/files';
 $varlistfile= 'debian/substvars';
+$packagebuilddir= 'debian/tmp';
 
 use POSIX;
 use POSIX qw(:errno_h);
@@ -28,6 +29,8 @@ Options:  -p<package>            print control file for package
           -F<changelogformat>    force change log format
           -v<forceversion>       set version of binary package
           -f<fileslistfile>      write files here instead of debian/files
+          -P<packagebuilddir>    temporary build dir instead of debian/tmp
+          -O                     write to stdout, not .../DEBIAN/control
           -is                    include section field
           -ip                    include priority field
           -isp|-ips              include both section and priority
@@ -35,13 +38,14 @@ Options:  -p<package>            print control file for package
           -U<field>              remove a field
           -V<name>=<value>       set a substitution variable
           -T<varlistfile>        read variables here, not debian/substvars
+          -h                     print this message
 ";
 }
 
 $i=100;grep($fieldimps{$_}=$i--,
           qw(Package Version Section Priority Architecture Essential
              Pre-Depends Depends Recommends Suggests Optional Conflicts Replaces
-             Provides Maintainer Source Description));
+             Provides Installed-Size Maintainer Source Description));
 
 while (@ARGV) {
     $_=shift(@ARGV);
@@ -51,10 +55,14 @@ while (@ARGV) {
         $controlfile= $';
     } elsif (m/^-l/) {
         $changelogfile= $';
+    } elsif (m/^-P/) {
+        $packagebuilddir= $';
     } elsif (m/^-f/) {
         $fileslistfile= $';
     } elsif (m/^-v(.+)$/) {
         $forceversion= $1;
+    } elsif (m/^-O$/) {
+        $stdout= 1;
     } elsif (m/^-is$/) {
         $spinclude{'Section'}=1;
     } elsif (m/^-ip$/) {
@@ -68,7 +76,7 @@ while (@ARGV) {
         $override{$1}= $';
     } elsif (m/^-U([^\=:]+)$/) {
         $remove{$1}= 1;
-    } elsif (m/^-V(\w+)[=:]/) {
+    } elsif (m/^-V(\w[-:0-9A-Za-z]*)[=:]/) {
         $substvar{$1}= $';
     } elsif (m/^-T/) {
         $varlistfile= $';
@@ -173,6 +181,24 @@ if ($oppackage ne $sourcepackage || $verdiff) {
     $f{'Source'}.= " ($sourceversion)" if $verdiff;
 }
 
+if (!defined($substvar{'Installed-Size'})) {
+    defined($c= open(DU,"-|")) || &syserr("fork for du");
+    if (!$c) {
+        chdir("$packagebuilddir") || &syserr("chdir for du to \`$packagebuilddir'");
+        exec("du","-k","-s","."); &syserr("exec du");
+    }
+    $duo=''; while (<DU>) { $duo.=$_; }
+    close(DU); $? && &subprocerr("du in \`$packagebuilddir'");
+    $duo =~ m/^(\d+)\s+\.$/ || &failure("du gave unexpected output \`$duo'");
+    $substvar{'Installed-Size'}= $1;
+}
+if (defined($substvar{'Extra-Size'})) {
+    $substvar{'Installed-Size'} += $substvar{'Extra-Size'};
+}
+if (length($substvar{'Installed-Size'})) {
+    $f{'Installed-Size'}= $substvar{'Installed-Size'};
+}
+
 $fileslistfile="./$fileslistfile" if $fileslistfile =~ m/^\s/;
 open(Y,"> $fileslistfile.new") || &syserr("open new files list file");
 if (open(X,"< $fileslistfile")) {
@@ -194,7 +220,16 @@ rename("$fileslistfile.new",$fileslistfile) || &syserr("install new files list f
 for $f (keys %override) { $f{&capit($f)}= $override{$f}; }
 for $f (keys %remove) { delete $f{&capit($f)}; }
 
+if (!$stdout) {
+    $cf= "$packagebuilddir/DEBIAN/control";
+    $cf= "./$cf" if $cf =~ m/^\s/;
+    open(STDOUT,"> $cf.new") ||
+        &syserr("cannot open new output control file \`$cf.new'");
+}
 &outputclose;
+if (!$stdout) {
+    rename("$cf.new","$cf") || &syserr("cannot install output control file \`$cf'");
+}
 
 sub spfileslistvalue {
     $r= $spvalue{$_[0]};
index a663cd32513cd62589f1a4e53714a806f8a89999..f5eeb5eab5df32081db0b73e252dc5912ad49762 100644 (file)
@@ -20,8 +20,12 @@ sub usageversion {
 Ian Jackson.  This is free software; see the GNU General Public Licence
 version 2 or later for copying conditions.  There is NO warranty.
 
-Usage: dpkg-parsechangelog [-L<libdir>] [-F<format>] [-v<version>]
-                           [-lchangelogfile]
+Usage: dpkg-parsechangelog [<option> ...]
+Options:  -l<changelogfile>      get per-version info from this file
+          -v<sinceversion>       include all changes later than version
+          -F<changelogformat>    force change log format
+          -L<libdir>             look for change log parsers in <libdir>
+          -h                     print this message
 ";
 }
 
diff --git a/scripts/dpkg-shlibdeps.pl b/scripts/dpkg-shlibdeps.pl
new file mode 100644 (file)
index 0000000..9a655ce
--- /dev/null
@@ -0,0 +1,198 @@
+#!/usr/bin/perl
+
+$dpkglibdir= ".";
+$version= '1.3.6'; # This line modified by Makefile
+
+use POSIX;
+use POSIX qw(:errno_h :signal_h);
+
+$shlibsoverride= '/etc/dpkg/shlibs.override';
+$shlibsdefault= '/etc/dpkg/shlibs.default';
+$shlibsppdir= '/var/lib/dpkg/info';
+$shlibsppext= '.shlibs';
+$varnameprefix= 'shlibs';
+$dependencyfield= 'Depends';
+$varlistfile= 'debian/substvars';
+
+@depfields= qw(Suggests Recommends Depends Pre-Depends);
+
+push(@INC,$dpkglibdir);
+require 'controllib.pl';
+
+sub usageversion {
+    print STDERR
+"Debian GNU/Linux dpkg-shlibdeps $version.  Copyright (C) 1996
+Ian Jackson.  This is free software; see the GNU General Public Licence
+version 2 or later for copying conditions.  There is NO warranty.
+
+Usage:
+  dpkg-shlibdeps [<option> ...] <executable>|-e<executable> [<option>] ...
+Positional arguments/options (order is significant):
+          <executable>           } include dependencies for <executable>
+          -e<executable>         }  (use -e if <executable> starts with \`-')
+          -d<dependencyfield>    next executable(s) set shlibs:<dependencyfield>
+Overall options (have global effect no matter where placed):
+          -p<varnameprefix>      set <varnameprefix>:* instead of shlibs:*.
+          -O                     print variable settings to stdout
+          -T<varlistfile>        update variables here, not debian/substvars
+Dependency fields recognised are ".join("/",@depfields)."
+";
+}
+
+$i=0; grep($depstrength{$_}= ++$i, @depfields);
+
+while (@ARGV) {
+    $_=shift(@ARGV);
+    if (m/^-T/) {
+        $varlistfile= $';
+    } elsif (m/^-p(\w[-:0-9A-Za-z]*)$/) {
+        $varnameprefix= $1;
+    } elsif (m/^-O$/) {
+        $stdout= 1;
+    } elsif (m/^-h$/) {
+        usageversion; exit(0);
+    } elsif (m/^-d/) {
+        $dependencyfield= capit($');
+        defined($depstrength{$dependencyfield}) ||
+            &warn("unrecognised dependency field \`$dependencyfield'");
+    } elsif (m/^-e/) {
+        push(@exec,$'); push(@execf,$dependencyfield);
+    } elsif (m/^-/) {
+        usageerr("unknown option \`$_'");
+    } else {
+        push(@exec,$_); push(@execf,$dependencyfield);
+    }
+}
+
+@exec || usageerr("need at least one executable");
+
+for ($i=0;$i<=$#exec;$i++) {
+    defined($c= open(P,"-|")) || syserr("cannot fork for ldd");
+    if (!$c) { exec("ldd","--",$exec[$i]); syserr("cannot exec ldd"); }
+    $nthisldd=0;
+    while (<P>) {
+        s/\n$//;
+        if (m,^\t(\S+)\.so\.(\S+) \=\> (/\S+)$,) {
+            push(@libname,$1); push(@libsoname,$2); push(@libpath,$3);
+            push(@libf,$execf[$i]);
+            push(@libpaths,$3) if !$libpathadded{$3}++;
+            $nthisldd++;
+        } else {
+            &warn("unknown output from ldd on \`$exec[$i]': \`$_'");
+        }
+    }
+    close(P); $? && subprocerr("ldd on \`$exec[$i]'");
+    $nthisldd || &warn("ldd on \`$exec[$i]' gave nothing on standard output");
+}
+
+grep(s/\[\?\*/\\$&/g, @libpaths);
+defined($c= open(P,"-|")) || syserr("cannot fork for dpkg --search");
+if (!$c) { exec("dpkg","--search","--",@libpaths); syserr("cannot exec dpkg"); }
+while (<P>) {
+    s/\n$//;
+    if (m/^local diversion |^diversion by/) {
+        &warn("diversions involved - output may be incorrect");
+        print(STDERR " $_\n") || syserr("write diversion info to stderr");
+    } elsif (m=^(\S+(, \S+)*): (/.+)$=) {
+        $pathpackages{$+}= $1;
+    } else {
+        &warn("unknown output from dpkg --search: \`$_'");
+    }
+}
+close(P); $? && subprocerr("dpkg --search");
+
+for ($i=0;$i<=$#libname;$i++) {
+    scanshlibsfile($shlibsoverride,$libname[$i],$libsoname[$i],$libf[$i]) && next;
+    if (!defined($pathpackages{$libpath[$i]})) {
+        &warn("could not find any packages for $libpath[$i]".
+              " ($libname[$i].so.$libsoname[$i])");
+    } else {
+        @packages= split(/, /,$pathpackages{$libpath[$i]});
+        for $p (@packages) {
+            scanshlibsfile("$shlibsppdir/$p$shlibsppext",
+                           $libname[$i],$libsoname[$i],$libf[$i]) && next;
+        }
+    }
+    scanshlibsfile($shlibsdefault,$libname[$i],$libsoname[$i],$libf[$i]) && next;
+    &warn("unable to find dependency information for ".
+          "shared library $libname[$i] (soname $libsoname[$i], path $libpath[$i], ".
+          "dependency field $libf[$i])");
+}
+
+sub scanshlibsfile {
+    my ($fn,$ln,$lsn,$lf) = @_;
+    my ($da,$dv,$dk);
+    $fn= "./$fn" if $fn =~ m/^\s/;
+    if (!open(SLF,"< $fn")) {
+        $! == ENOENT || syserr("unable to open shared libs info file \`$fn'");
+#print STDERR "scanshlibsfile($fn,$ln,$lsn,$lf) ... ENOENT\n";
+        return 0;
+    }
+#print STDERR "scanshlibsfile($fn,$ln,$lsn,$lf) ...\n";
+    while (<SLF>) {
+        s/\s*\n$//; next if m/^\#/;
+        if (!m/^\s*(\S+)\s+(\S+)/) {
+            &warn("shared libs info file \`$fn' line $.: bad line \`$_'");
+            next;
+        }
+        next if $1 ne $ln || $2 ne $lsn;
+        $da= $';
+        for $dv (split(/,/,$da)) {
+            $dv =~ s/^\s+//; $dv =~ s/\s+$//;
+            if (defined($depstrength{$lf})) {
+                if (!defined($predefdepfdep{$dv}) ||
+                    $depstrength{$predefdepfdep{$dv}} < $depstrength{$lf}) {
+                    $predefdepfdep{$dv}= $lf;
+                }
+            } else {
+                $dk= "$lf: $dv";
+                if (!defined($unkdepfdone{$dk})) {
+                    $unkdepfdone{$dk}= 1;
+                    $unkdepf{$lf}.= ', ' if length($unkdepf{$lf});
+                    $unkdepf{$lf}.= $dv;
+                }
+            }
+        }
+        return 1;
+    }
+    close(SLF);
+    return 0;
+}
+
+if (!$stdout) {
+    $varlistfile="./$varlistfile" if $fileslistfile =~ m/^\s/;
+    open(Y,"> $varlistfile.new") ||
+        syserr("open new substvars file \`$varlistfile.new'");
+    if (open(X,"< $varlistfile")) {
+        while (<X>) {
+            s/\n$//;
+            next if m/^(\w[-:0-9A-Za-z]*):/ && $1 eq $varnameprefix;
+            print(Y "$_\n") ||
+                syserr("copy old entry to new varlist file \`$varlistfile.new'");
+        }
+    } elsif ($! != ENOENT) {
+        syserr("open old varlist file \`$varlistfile' for reading");
+    }
+    $fh= 'Y';
+} else {
+    $fh= 'STDOUT';
+}
+for $dv (sort keys %predefdepfdep) {
+    $lf= $predefdepfdep{$dv};
+    $defdepf{$lf}.= ', ' if length($defdepf{$lf});
+    $defdepf{$lf}.= $dv;
+}
+for $lf (reverse @depfields) {
+    next unless defined($defdepf{$lf});
+    print($fh "$varnameprefix:$lf=$defdepf{$lf}\n")
+        || syserr("write output entry");
+}
+for $lf (sort keys %unkdepf) {
+    print($fh "$varnameprefix:$lf=$unkdepf{$lf}\n")
+        || syserr("write userdef output entry");
+}
+close($fh) || syserr("close output");
+if (!$stdout) {
+    rename("$varlistfile.new",$varlistfile) ||
+        syserr("install new varlist file \`$varlistfile'");
+}
index fe9f73ae80e021fe4650839f51224b37bc864c3d..bc548a8ee5ba691813e9d14c61eb02b42863c31f 100644 (file)
@@ -15,6 +15,9 @@ dpkg\-buildpackage, dpkg\-distaddfile, dpkg\-parsechangelog
 .B dpkg-gencontrol
 .RI [ options ]
 .br
+.B dpkg-shlibdeps
+.IR options
+.br
 .B dpkg-genchanges
 .RI [ options ]
 .br
@@ -36,6 +39,19 @@ binary package control file on standard output; it also adds an entry
 for the binary package to
 .BR debian/files .
 
+.B dpkg-shlibdeps
+calculates shared library dependencies for executables named in its
+arguments.  The dependencies are added to the substitution
+variables file
+.B debian/substvars
+as variable names
+.BI shlibs: dependencyfield
+where
+.I dependencyfield
+is a dependency field name.  Any other variables starting
+.I shlibs:
+are removed from the file.
+
 .B dpkg-genchanges
 reads information from an unpacked and built Debian source tree and
 from the files it has generated and generates a Debian upload control
@@ -43,7 +59,7 @@ file
 .RB ( .changes " file)."
 
 .B dpkg-buildpackage
-Is a control script which can be used to help automate the building of
+is a control script which can be used to help automate the building of
 a package.
 
 .B dpkg-distaddfile
@@ -87,12 +103,14 @@ This option is understood by
 See below for a discussion of output substitution.
 .TP
 .BI -T substvarsfile
-Read substitution variables from
+Read (or, for
+.BR dpkg-shlibdeps ,
+write) substitution variables in
 .IR substvarsfile ;
 the default is
 .BR debian/substvars .
 This option is understood by
-.BR dpkg-source ", " dpkg-gencontrol " and " dpkg-genchanges .
+.BR dpkg-source ", " dpkg-gencontrol ", " dpkg-shlibdeps " and " dpkg-genchanges .
 .TP
 .BI -D field = value
 Override or add an output control file field.
@@ -196,6 +214,79 @@ file.
 .B -isp
 includes both fields,
 .BR -is " only the " Section " and " -ip " only the " Priority .
+.TP
+.BI -P packagebuilddir
+Tells
+.B dpkg-source
+that the package is being built in
+.I packagebuilddir
+instead of
+.BR debian/tmp .
+This value is used to find the default value of the
+.B Installed-Size
+substitution variable and control file field (using
+.BR du ),
+and for the default location of the output file.
+.TP
+.B -O
+Causes the control file to be printed to standard output, rather than
+to
+.B debian/tmp/DEBIAN/control
+(or
+.IB packagebuilddir /DEBIAN/control
+if
+.B -P
+was used).
+.SH DPKG-SHLIBDEPS OPTIONS
+.B dpkg-shlibdeps
+interprets non-option arguments as executable names, just as if they'd
+been supplied as
+.BI -e executable\fR.
+.TP
+.BI -e executable
+Include dependencies appropriate for the shared libraries required by
+.IR executable .
+.TP
+.BI -d dependencyfield
+Add dependencies to be added to the control file dependency field
+.IR dependencyfield .
+(The dependencies for this field are placed in the variable
+.BI shlibs: dependencyfield\fR.)
+
+The
+.BI -d dependencyfield
+option takes effect for all executables after the option, until the
+next
+.BI -d dependencyfield\fR.
+The default
+.I dependencyfield
+is
+.BR Depends .
+
+If the same dependency entry (or set of alternatives) appears in more
+than one of the recognised dependency field names
+.BR Pre-Depends ", " Depends ", " Recommends " or " Suggests
+then
+.B dpkg-shlibdeps
+will automatically remove the dependency from all fields except the
+one representing the most important dependencies.
+.TP
+.BI -p varnameprefix
+Causes substitution variables to start with
+.IB varnameprefix :
+instead of
+.BR shlib: .
+Likewise, any existing substitution variables starting with
+.IB varnameprefix :
+(rather than
+.BR shlib: )
+are removed from the the substitution variables file.
+.TP
+.B -O
+Causes the substitution variable settings to be printed to standard
+output, rather than being added to the substitution variables file
+.RB ( debian/substvars
+by default).
 .SH DPKG-GENCHANGES OPTIONS
 .B dpkg-gencontrol
 does not take any non-option arguments.
@@ -293,9 +384,10 @@ they perform some variable substitutions on the output file.
 
 A variable substitution has the form
 .BI ${ variable-name }\fR.
-Variable substitutions are performed repeatedly until none are left;
-the full text of the field after the substitution is rescanned to look
-for more substitutions.
+Variable names consist of alphanumerics, hyphens and colons and start
+with an alphanumeric.  Variable substitutions are performed repeatedly
+until none are left; the full text of the field after the substitution
+is rescanned to look for more substitutions.
 
 After all the substitutions have been done each occurence of the
 string
@@ -304,36 +396,52 @@ string
 .B $
 sign.
 
-Variables whose names consist entirely of alphanumerics can be set
-using the
+Variables can be set using the
 .B -V
-common option.
-
-They can be also specified in the file
+common option.  They can be also specified in the file
 .B debian/substvars
 (or whatever other file is specified using the
 .B -T
 option).  This file consists of lines of the form
-.IB name = value
-(where
-.B name
-is a string of alphanumerics).  Trailing whitespace on each line,
-blank lines, and lines starting with a
+.IB name = value\fR.
+Trailing whitespace on each line, blank lines, and
+lines starting with a
 .B #
 symbol (comments) are ignored.
 
 Additionally, the following standard variables are available:
 .TP
-.BI arch
+.BI Arch
 The current build architecture (from
 .BR "dpkg \-\-print-architecture" ).
 .TP
-.B sourceversion
+.B Source-Version
 The source package version (from the changelog file).
 .TP
-.BI f: fieldname
+.B Installed-Size
+The total size of the package's installed files.  This value is copied
+into the corresponding control file field; setting it will modify the
+value of that field.  If this variable isn't set
+.B dpkg-gencontrol
+will use
+.B du -k debian/tmp
+to find the default value.
+.TP
+.B Extra-Size
+Additional disk space used when the package is installed.  If this
+variable is set its value is added to that of the
+.B Installed-Size
+variable (whether set explicitly or using the default value) before it
+is copied into the
+.B Installed-Size
+control file field.
+.TP
+.BI F: fieldname
 The value of the output field
-.IR fieldname .
+.IR fieldname
+(which must be given in the canonical capitalisation).  Setting these
+variables has no effect other than on places where they are expanded
+explicitly.
 .TP
 .B Format
 The
@@ -345,9 +453,14 @@ field in the
 .B .changes
 file will change too.
 .TP
-.BR newline ", " space ", " tab
+.BR Newline ", " Space ", " Tab
 These variables each hold the corresponding character.
-
+.TP
+.BI shlibs: dependencyfield
+Variable settings with names of this form are generated by
+.B dpkg-shlibdeps
+- see above.
+.LP
 If a variable is referred to but not defined it generates a warning
 and an empty value is assumed.
 .SH FILES
diff --git a/scripts/dpkg-source.8 b/scripts/dpkg-source.8
deleted file mode 100644 (file)
index c7d6951..0000000
+++ /dev/null
@@ -1,249 +0,0 @@
-.\" Hey, Emacs!  This is an -*- nroff -*- source file.
-.\" Authors: Ian Jackson
-.TH DPKG\-SOURCE 8 "7th Auguest" "Debian Project" "Debian GNU/Linux manual"
-.SH NAME 
-dpkg\-source, dpkg\-genchanges, dpkg\-gencontrol,
-dpkg\-buildpackage, dpkg\-distaddfile, dpkg\-parsechangelog
-\- Debian source packaging tools
-.SH SYNOPSIS
-.B dpkg-deb
-.BR -b | --build
-.IR directory " [" archive | directory ]
-.br
-.B dpkg-deb
-.BR -I | --info
-.IR archive " [" control\-file\-name " ..]"
-.br
-.B dpkg-deb
-.BR -f | --field
-.IR archive " [" control\-field\-name " ...]"
-.br
-.B dpkg-deb
-.BR -c | --contents
-.I archive
-.br
-.B dpkg-deb
-.BR -x | --extract | -X | --vextract
-.I archive directory
-.br
-.B dpkg-deb --fsys-tarfile
-.I archive
-.br
-.B dpkg-deb --control
-.I archive directory
-.SH DESCRIPTION
-.B dpkg-deb
-packs, unpacks and provides information about Debian archives.
-
-Use
-.B dpkg
-to install and remove packages from your system.
-
-You can also invoke
-.B dpkg\-deb
-by calling
-.B dpkg
-with whatever options you want to pass to
-.BR dpkg\-deb ".  " dpkg
-will spot that you wanted
-.B dpkg\-deb
-and run it for you.
-.SH ACTION OPTIONS
-.TP
-.BR --build ", " -b
-Creates a debian archive from the filesystem tree stored in
-.IR directory ".  " directory
-must have a
-.B DEBIAN
-subdirectory, which contains the control information files such
-as the control file itself.  This directory will
-.I not
-appear in the binary package's filesystem archive, but instead
-the files in it will be put in the binary package's control
-information area.
-
-Unless you specify
-.BR \-\-no\-check ", " dpkg\-deb "
-will read
-.B DEBIAN/control
-and parse it.  It will check it for syntax errors and other problems,
-and display the name of the binary package being built.
-.B dpkg\-deb
-will also check the permissions of the maintainer scripts and other
-files found in the
-.B DEBIAN
-control information directory.
-
-If no
-.I archive
-is specified then
-.B dpkg\-deb
-will write the package into the file
-.IR directory \fB.deb\fR.
-
-If the archive to be created already exists it will be overwritten.
-
-If the second argument is a directory then
-.B dpkg\-deb
-will write to the file
-.IB package _ version _ arch .deb\fR,
-or
-.IB package _ version .deb
-if no
-.B Architecture
-field is present in the package control file.  When a target directory
-is specified, rather than a file, the
-.B \-\-no\-check
-option may not be used (since
-.B dpkg\-deb
-needs to read and parse the package control file to determine which
-filename to use).
-.TP
-.BR \-\-info ", " -I
-Provides information about a binary package archive.
-
-If no
-.IR control\-file\-name s
-are specified then it will print a summary of the contents of the
-package as well as its control file.
-
-If any
-.IR control\-file\-name s
-are specified then
-.B dpkg\-deb
-will print them in the order they were specified; if any of the
-components weren't present it will print an error message to stderr
-about each one and exit with status 2.
-.TP
-.BR \-\-field ", " -f
-Extracts control file information from a binary package archive.
-
-If no
-.BR control\-file\-field s
-are specified then it will print the whole control file.
-
-If any are specified then
-.B dpkg\-deb
-will print their contents, in the order in which they appear in the
-control file.  If more than one
-.BR control\-file\-field
-is specified then
-.B dpkg\-deb
-will precede each with its field name (and a colon and space).
-
-No errors are reported for fields requested but not found.
-.TP
-.BR --contents ", " -c
-Lists the contents of the filesystem tree archive portion of the
-package archive.  It is currently produced in the format generated by
-.BR tar 's
-verbose listing.
-.TP
-.BR --extract ", " -x ", " \-\-vextract ", " -X
-Extracts the filesystem tree from a package archive into the specified
-directory.
-
-.BR \-\-vextract " (" -X ")"
-prints a listing of the files extracted as it goes, while
-.BR \-\-extract " (" -x ")"
-is silent unless an error occurs.
-
-Note that extracting a package to the root directory will
-.I not
-result in a correct installation !  Use
-.B dpkg
-to install packages.
-
-.I directory
-(but not its parents) will be created if necessary.
-.TP
-.BR --fsys-tarfile
-Extracts the filesystem tree data from a binary package and sends it
-to standard output in
-.B tar
-format.  Together with
-.B tar
-this can be used to extract a particular file from a package archive.
-.TP
-.BR --control ", " -e
-Extracs the control information files from a package archive into the
-specified directory.
-
-If no directory is specified then a subdirectory
-.B DEBIAN
-in the current directory is used.
-
-The target directory (but not its parents) will be created if
-necessary.
-.TP
-.BR --help ", " -h
-Prints
-.BR dpkg\-deb 's
-usage message, giving a summary of its options and their uses.
-.TP
-.BR --version
-Prints
-.BR dpkg\-deb 's
-version number.
-.TP
-.BR --licence
-Prints information about
-.BR dpkg\-deb 's
-copyright licensing and lack of warranty.  (The American spelling
-.B \-\-license
-is also supported.)
-.SH OTHER OPTIONS
-.TP
-.BR --new
-Ensures that
-.B dpkg\-deb
-builds a `new' format archive.  This is the default.
-.TP
-.BR --old
-Forces
-.B dpkg\-deb
-to build an `old' format archive.  This old archive format is less
-easily parsed by non-Debian tools and is now obsolete; its only use is
-when building packages to be parsed by versions of dpkg older than
-0.93.76 (September 1995), which was released as i386 a.out only.
-.TP
-.BR --no-check
-Inhibit's
-.BR "dpkg\-deb \-\-build" 's
-usual checks on the proposed contents of an archive.  You can build
-any archive you want, no matter how broken, this way.
-.TP
-.BR --debug ", " -D
-Enables debugging output.  This is not very interesting.
-.SH BUGS
-.B dpkg-deb -I 
-.IB package1 .deb
-.IB package2 .deb
-does the wrong thing.
-
-There is no authentication on
-.B .deb
-files; in fact, there isn't even a straightforward checksum.
-
-Do not attempt to use just
-.B dpkg\-deb
-to install software !  You must use
-.B dpkg
-proper to ensure that all the files are correctly placed and the
-package's scripts run and its status and contents recorded.
-.SH SEE ALSO
-.BR deb (5),
-.BR deb-control (5),
-.BR dpkg (5),
-.BR dpkg (8),
-.BR dselect (8).
-.SH AUTHOR
-.B dpkg\-deb
-and this manpage were written by Ian Jackson.  They are
-Copyright (C)1995-1996
-by him and released under the GNU General Public Licence; there is NO
-WARRANTY.  See
-.B /usr/doc/copyright/dpkg
-and
-.B /usr/doc/copyright/GPL
-for details.
index 46110e8c357f013c1dc93436f1ae2185f0f7c2c5..f3250a10c30b51401bb4d730e9421dcf6d4dd9ee 100644 (file)
@@ -52,7 +52,7 @@ while (@ARGV && $ARGV[0] =~ m/^-/) {
         $override{$1}= $';
     } elsif (m/^-U([^\=:]+)$/) {
         $remove{$1}= 1;
-    } elsif (m/^-V(\w+)[=:]/) {
+    } elsif (m/^-V(\w[-:0-9A-Za-z]*)[=:]/) {
         $substvar{$1}= $';
     } elsif (m/^-T/) {
         $varlistfile= $';
@@ -76,9 +76,10 @@ if ($opmode eq 'build') {
     stat($dir) || &error("cannot stat directory $dir: $!");
     -d $dir || &error("directory argument $dir is not a directory");
 
-    $!=0; if (@ARGV) {
+    if (@ARGV) {
         $origdir= shift(@ARGV);
         if (length($origdir)) {
+            $origdir= "./$origdir" unless $origdir =~ m:^/:;
             stat($origdir) || &error("cannot find orig directory $origdir: $!");
             -d $origdir || &error("orig directory argument $origdir is not a directory");
         }
@@ -90,6 +91,7 @@ if ($opmode eq 'build') {
     } else {
         &error("tentative orig directory $dir.orig is not a directory");
     }
+print STDERR ">$dir|$origdir<\n";
 
     $changelogfile= "$dir/debian/changelog" unless defined($changelogfile);
     $controlfile= "$dir/debian/control" unless defined($controlfile);
@@ -204,7 +206,8 @@ if ($opmode eq 'build') {
     if (!$c2) {
         chdir($tardirbase) || &syserr("chdir to above (orig) source $tardirbase");
         open(STDOUT,">&GZIP") || &syserr("reopen gzip for tar");
-        exec('tar','-cO','--',$tardirname); &syserr("exec tar");
+        # FIXME: put `--' argument back when tar is fixed
+        exec('tar','-cO',$tardirname); &syserr("exec tar");
     }
     close(GZIP);
     &reapgzip;
diff --git a/scripts/update-rc.d.new-pl b/scripts/update-rc.d.new-pl
new file mode 100644 (file)
index 0000000..7c8c911
--- /dev/null
@@ -0,0 +1,166 @@
+#! /usr/bin/perl
+#
+# update-rc.d  Perl script to update links in /etc/rc?.d
+#
+# Usage:
+#              update-rc.d [-f] <basename> remove
+#              update-rc.d <basename> [options]
+#
+# Options are:
+#              start <codenumber> <runlevel> <runlevel> <runlevel> .
+#              stop  <codenumber> <runlevel> <runlevel> <runlevel> .
+#
+#              defaults [<codenumber> | <startcode> <stopcode>]
+#              (means       start <startcode> 2 3 4 5
+#               as well as  stop  <stopcode>  0 1 2 3 4 5 6
+#              <codenumber> defaults to 20)
+#
+# Version:     @(#)update-rc.d  1.02  11-Jul-1996  miquels@cistron.nl
+#
+# Changes:      1.00 Wrote perl version directly derived from shell version.
+#              1.01 Fixed problem when dangling symlinks are found in
+#                   /etc/rc?.d/. The shell version just exits silently!
+#              1.02 More misc bugs fixed caused by sh -> perl translation
+#
+
+$version= '1.3.2'; # This line modified by Makefile
+
+chdir('/etc') || die "chdir /etc: $!\n";
+
+$initd='init.d';
+
+sub usage {
+  print STDERR <<EOF;
+Debian GNU/Linux update-rc.d $version.  Copyright (C) 1996 Miquel van
+Smoorenburg.  This is free software; see the GNU General Public Licence
+version 2 or later for copying conditions.  There is NO warranty.
+
+update-rc.d: error: @_
+usage: update-rc.d [-f] <basename> remove
+       update-rc.d <basename> defaults [<cn> | <scn> <kcn>]
+       update-rc.d <basename> start|stop <cn> <r> <r> .  ...
+EOF
+  &leave(1);
+}
+
+
+sub getinode {
+       local @tmp;
+
+       unless (@tmp = stat($_[0])) {
+               print STDERR "stat($_[0]): $!\n";
+               $tmp[1] = 0;
+       }
+       $tmp[1];
+}
+
+sub leave {
+       eval $atexit if ($atexit ne '');
+       exit($_[0]);
+}
+
+$force = 0;
+if ($ARGV[0] eq '-f') {
+       shift @ARGV;
+       $force = 1;
+}
+
+&usage("too few arguments") if ($#ARGV < 1);
+
+$bn = shift @ARGV;
+$action = shift @ARGV;
+
+if ($action eq 'remove') {
+       &usage("remove must be only action") if ($#ARGV > 0);
+       if (-f "$initd/$bn") {
+               unless ($force) {
+                       print STDERR "update-rc.d: error: /etc/$initd/$bn exists during rc.d purge (use -f to force).\n";
+                       &leave(1);
+               }
+       } else {
+               $atexit = "unlink('$initd/$bn');";
+       }
+       print  " Removing any system startup links to /etc/$initd/$bn ...\n";
+       open(FD, ">>$initd/$bn");
+       close FD;
+       $own = &getinode("$initd/$bn");
+       @files = split(/\s+/, `echo rc?.d/[SK]*`);
+       foreach $f (@files) {
+               $inode = &getinode($f);
+               if ($inode == $own) {
+                       unless (unlink($f))  {
+                               print STDERR "unlink($f): $!\n";
+                               &leave(1);
+                       }
+                       print "   $f\n";
+               }
+       }
+       &leave(0);
+} elsif ($action eq 'defaults') {
+       if ($#ARGV < 0) {
+               $sn = $kn = 20;
+       } elsif ($#ARGV == 0) {
+               $sn = $kn = $ARGV[0];
+       } elsif ($#ARGV == 1) {
+               $sn = $ARGV[0];
+               $kn = $ARGV[1];
+       } else {
+               &usage("defaults takes only one or two codenumbers");
+       }
+       @ARGV = ('start', "$sn", '2', '3', '4', '5', 'stop',
+                         "$kn", '0', '1', '6');
+} elsif ($action ne 'start' && $action ne 'stop') {
+       &usage("unknown mode or add action $action");
+}
+
+unless (-f "$initd/$bn") {
+       print STDERR "update-rc.d: warning /etc/$initd/$bn doesn't exist during rc.d setup.\n";
+       exit(0);
+}
+
+$own = &getinode("$initd/$bn");
+
+@files = split(/\s+/, `echo rc?.d/[SK]*`);
+foreach $f (@files) {
+       $inode = &getinode($f);
+       if ($inode == $own) {
+               print STDERR " System startup links pointing to /etc/$initd/$bn already exist.\n";
+               exit(0);
+       }
+}
+
+
+print " Adding system startup links pointing to /etc/$initd/$bn ...\n";
+while ($#ARGV >= 1) {
+       if ($ARGV[0] eq 'start') {
+               $ks = 'S';
+       } elsif ($ARGV[0] eq 'stop') {
+               $ks = 'K';
+       } else {
+               &usage("unknown action $1");
+       }
+       shift @ARGV;
+       $number = shift @ARGV;
+       while ($#ARGV >= 0) {
+               $_ = $ARGV[0];
+               if (/^\.$/) {
+                       shift @ARGV;
+                       last;
+               } elsif (/^.$/) {
+                       symlink("../$initd/$bn", "rc$_.d/$ks$number$bn") ||
+                               die "symlink: $!\n";
+                       print "   rc$_.d/$ks$number$bn -> ../$initd/$bn\n";
+                       shift @ARGV;
+                       next;
+               } elsif (/^(start|stop)$/) {
+                       last;
+               }
+               &usage('runlevel is more than one character\n');
+       }
+}
+
+if ($#ARGV >= 0) {
+       &usage("surplus arguments, but not enough for an add action: @ARGV\n");
+}
+
+0;
index 7c8c9116c39afec738236d4139492302954daf14..2a38f9cf4e12118ea6c0f1654b7e37683f465d01 100644 (file)
@@ -129,7 +129,6 @@ foreach $f (@files) {
        }
 }
 
-
 print " Adding system startup links pointing to /etc/$initd/$bn ...\n";
 while ($#ARGV >= 1) {
        if ($ARGV[0] eq 'start') {
similarity index 93%
rename from scripts/update-rc.d.old-sh
rename to scripts/update-rc.d.sh
index d471cc177ebc3017191fe6b1234d4df8f89d0e41..bc51d150010080ea729e69c604e64d0c91527e33 100755 (executable)
@@ -91,9 +91,13 @@ while [ $# -ge 3 ]; do
                        shift
                        continue
                        ;;
+               *)
+                       usage "runlevel is more than one character (forgotten \`.' ?)"
                esac
-               usage 'runlevel is more than one character (forgotten . ?)'
        done
+       if [ $# -eq 0 ]; then
+               usage "action with list of runlevels not terminated by \`.'"
+       fi
        shift
 done
 
index 85d37bc955d811190fa5e7663aeddfe6f179ea99..24361f988b53fe71f5668a02bc0dfffc8c9f04f7 100644 (file)
--- a/version.h
+++ b/version.h
@@ -1 +1 @@
-#define DPKG_VERSION "1.3.3" /* This line modified by Makefile */
+#define DPKG_VERSION "1.3.6" /* This line modified by Makefile */