diff options
Diffstat (limited to 'doc/guide')
-rw-r--r-- | doc/guide/files/components.xml | 793 |
1 files changed, 422 insertions, 371 deletions
diff --git a/doc/guide/files/components.xml b/doc/guide/files/components.xml index 0d4cca769b1..906b426e001 100644 --- a/doc/guide/files/components.xml +++ b/doc/guide/files/components.xml @@ -1,260 +1,290 @@ -<!-- $NetBSD: components.xml,v 1.28 2006/09/03 00:20:49 wiz Exp $ --> +<!-- $NetBSD: components.xml,v 1.29 2006/09/10 19:11:15 wiz Exp $ --> <chapter id="components"> <?dbhtml filename="components.html"?> - <title>Package components - files, directories and contents</title> - - <para> Whenever you're preparing a package, there are a number of - files involved which are described in the following - sections. </para> - - <sect1 id="components.Makefile"> - <title><filename>Makefile</filename></title> - - <para>Building, installation and creation of a binary package are all - controlled by the package's <filename>Makefile</filename>. - The <filename>Makefile</filename> describes various things about - a package, for example from where to get it, how to configure, - build, and install it. - </para> - - <para>A package <filename>Makefile</filename> contains several - sections that describe the package.</para> - - <para>In the first section there are the following variables, which - should appear exactly in the order given here. The ordering and - grouping of variables is mostly historical and has no further - meaning.</para> - - <itemizedlist> - - <listitem><para><varname>DISTNAME</varname> is the basename of the - distribution file to be downloaded from the package's - website.</para></listitem> - - <listitem><para><varname>PKGNAME</varname> is the name of the - package, as used by pkgsrc. You only need to provide it if it - differs from <varname>DISTNAME</varname>. Usually it is the directory name together - with the version number. It must match the regular expression - <varname>^[A-Za-z0-9][A-Za-z0-9-_.+]*$</varname>, that is, it - starts with a letter or digit, and contains only letters, digits, - dashes, underscores, dots and plus signs.</para></listitem> - - <listitem><para><varname>CATEGORIES</varname> is a list of categories - which the package fits in. You can choose any of the top-level - directories of pkgsrc for it.</para> - - <para>Currently the following values are available for - <varname>CATEGORIES</varname>. If more than - one is used, they need to be separated by spaces:</para> - -<programlisting> - archivers cross geography meta-pkgs security - audio databases graphics misc shells - benchmarks devel ham multimedia sysutils - biology editors inputmethod net textproc - cad emulators lang news time - chat finance mail parallel wm - comms fonts math pkgtools www - converters games mbone print x11 -</programlisting> - </listitem> - - <listitem><para><varname>MASTER_SITES</varname>, - <varname>DYNAMIC_MASTER_SITES</varname>, - <varname>DIST_SUBDIR</varname>, <varname>EXTRACT_SUFX</varname> - and <varname>DISTFILES</varname> are discussed in detail in - <xref linkend="build.fetch"/>.</para></listitem> - - </itemizedlist> - - <para>The second section contains information about separately - downloaded patches, if any. - <itemizedlist> - <listitem><para><varname>PATCHFILES:</varname> - Name(s) of additional files that contain distribution patches. - There is no default. pkgsrc will look for them at - <varname>PATCH_SITES</varname>. - They will automatically be uncompressed before patching if - the names end with <filename>.gz</filename> or - <filename>.Z</filename>.</para> - </listitem> - <listitem><para><varname>PATCH_SITES</varname>: - Primary location(s) for distribution patch files (see - <varname>PATCHFILES</varname> below) if not found locally.</para> - </listitem> - </itemizedlist> - </para> - <para>The third section contains the following variables. - <itemizedlist> - - <listitem><para><varname>MAINTAINER</varname> is the email address - of the person who feels responsible for this package, and who is - most likely to look at problems or questions regarding this - package which have been reported with &man.send-pr.1;. Other - developers should contact the <varname>MAINTAINER</varname> before - making major changes to the package. When packaging a new program, - set <varname>MAINTAINER</varname> to yourself. If you really can't - maintain the package for future updates, set it to - <email>pkgsrc-users@NetBSD.org</email>.</para></listitem> - - <listitem><para><varname>HOMEPAGE</varname> is a URL where users can - find more information about the package.</para></listitem> - - <listitem><para><varname>COMMENT</varname> is a one-line - description of the package (should not include the package - name).</para></listitem> - </itemizedlist> - </para> - - <para>Other variables that affect the build: - <itemizedlist> - - <listitem> - - <para><varname>WRKSRC</varname>: The directory where the - interesting distribution files of the package are found. The - default is <filename>${WRKDIR}/${DISTNAME}</filename>, which - works for most packages.</para> - - <para>If a package doesn't create a subdirectory for itself - (most GNU software does, for instance), but extracts itself in - the current directory, you should set <varname>WRKSRC= - ${WRKDIR}</varname>.</para> - - <para>If a package doesn't create a subdirectory with the name - of <varname>DISTNAME</varname> but some different name, set - <varname>WRKSRC</varname> to point to the proper name in - <filename>${WRKDIR}</filename>, for example <varname>WRKSRC= - ${WRKDIR}/${DISTNAME}/unix</varname>. See <filename - role="pkg">lang/tcl</filename> and <filename - role="pkg">x11/tk</filename> for other examples.</para> - - <para>The name of the working directory created by pkgsrc is - taken from the <varname>WRKDIR_BASENAME</varname> variable. By - default, its value is <filename>work</filename>. If you want - to use the same pkgsrc tree for building different kinds of - binary packages, you can change the variable according to your - needs. Two other variables handle common cases of setting - <varname>WRKDIR_BASENAME</varname> individually. If - <varname>OBJHOSTNAME</varname> is defined in - <filename>/etc/mk.conf</filename>, the first component of the - host's name is attached to the directory name. If - <varname>OBJMACHINE</varname> is defined, the platform name is - attached, which might look like <filename>work.i386</filename> - or <filename>work.sparc</filename>.</para> - - </listitem> - </itemizedlist> - </para> - <para>Please pay attention to the following gotchas:</para> - - <itemizedlist> - <listitem> - <para>Add <varname>MANCOMPRESSED</varname> if man pages are installed in - compressed form by the package; see comment in - <filename>bsd.pkg.mk</filename>.</para> - </listitem> - - <listitem> - <para>Replace <filename>/usr/local</filename> with - <quote>${PREFIX}</quote> in all files (see patches, below).</para> - </listitem> - - <listitem> - <para>If the package installs any info files, see - <xref linkend="faq.info-files"/>.</para> - </listitem> - - </itemizedlist> - </sect1> +<title>Package components - files, directories and contents</title> + +<para>Whenever you're preparing a package, there are a number of +files involved which are described in the following +sections.</para> + +<sect1 id="components.Makefile"> + <title><filename>Makefile</filename></title> + + <para>Building, installation and creation of a binary package are all + controlled by the package's <filename>Makefile</filename>. + The <filename>Makefile</filename> describes various things about + a package, for example from where to get it, how to configure, + build, and install it.</para> + + <para>A package <filename>Makefile</filename> contains several + sections that describe the package.</para> + + <para>In the first section there are the following variables, which + should appear exactly in the order given here. The order and + grouping of the variables is mostly historical and has no further + meaning.</para> + <itemizedlist> + + <listitem><para><varname>DISTNAME</varname> is the basename of the + distribution file to be downloaded from the package's + website.</para></listitem> + + <listitem><para><varname>PKGNAME</varname> is the name of the + package, as used by pkgsrc. You only need to provide it if + <varname>DISTNAME</varname> (which is the default) is not a good + name for the package in pkgsrc. Usually it is the pkgsrc + directory name together with the version number. It must match the + regular expression + <varname>^[A-Za-z0-9][A-Za-z0-9-_.+]*$</varname>, that is, it + starts with a letter or digit, and contains only letters, digits, + dashes, underscores, dots and plus signs.</para></listitem> + + <listitem><para><varname>SVR4_PKGNAME</varname> is the name of + the package file to create if the <varname>PKGNAME</varname> + isn't unique on a SVR4 system. The default is + <varname>PKGNAME</varname>, which may be shortened when you use + <filename role="pkg">pkgtools/gensolpkg</filename>. Only add + <varname>SVR4_PKGNAME</varname> if <varname>PKGNAME</varname> + does not produce an unique package name on a SVR4 system. + The length of <varname>SVR4_PKGNAME</varname> is limited to 5 + characters.</para></listitem> + + <listitem><para><varname>CATEGORIES</varname> is a list of categories + which the package fits in. You can choose any of the top-level + directories of pkgsrc for it.</para> + + <para>Currently the following values are available for + <varname>CATEGORIES</varname>. If more than + one is used, they need to be separated by spaces:</para> + + <programlisting> + archivers cross geography meta-pkgs security + audio databases graphics misc shells + benchmarks devel ham multimedia sysutils + biology editors inputmethod net textproc + cad emulators lang news time + chat finance mail parallel wm + comms fonts math pkgtools www + converters games mbone print x11 + </programlisting> + </listitem> + + <listitem><para><varname>MASTER_SITES</varname>, + <varname>DYNAMIC_MASTER_SITES</varname>, + <varname>DIST_SUBDIR</varname>, <varname>EXTRACT_SUFX</varname> + and <varname>DISTFILES</varname> are discussed in detail in + <xref linkend="build.fetch"/>.</para></listitem> + + </itemizedlist> + + <para>The second section contains information about separately + downloaded patches, if any. + <itemizedlist> + <listitem><para><varname>PATCHFILES:</varname> + Name(s) of additional files that contain distribution patches. + There is no default. pkgsrc will look for them at + <varname>PATCH_SITES</varname>. + They will automatically be uncompressed before patching if + the names end with <filename>.gz</filename> or + <filename>.Z</filename>.</para> + </listitem> + <listitem><para><varname>PATCH_SITES</varname>: + Primary location(s) for distribution patch files (see + <varname>PATCHFILES</varname> below) if not found locally.</para> + </listitem> + </itemizedlist></para> + <para>The third section contains the following variables. + <itemizedlist> + + <listitem><para><varname>MAINTAINER</varname> is the email address + of the person who feels responsible for this package, and who is + most likely to look at problems or questions regarding this + package which have been reported with &man.send-pr.1;. Other + developers should contact the <varname>MAINTAINER</varname> before + making major changes to the package. When packaging a new program, + set <varname>MAINTAINER</varname> to yourself. If you really can't + maintain the package for future updates, set it to + <email>pkgsrc-users@NetBSD.org</email>.</para></listitem> + + <listitem><para><varname>HOMEPAGE</varname> is a URL where users can + find more information about the package.</para></listitem> + + <listitem><para><varname>COMMENT</varname> is a one-line + description of the package (should not include the package + name).</para></listitem> + </itemizedlist></para> + + <para>Other variables that affect the build: + <itemizedlist> + + <listitem> + <para><varname>WRKSRC</varname>: The directory where the + interesting distribution files of the package are found. The + default is <filename>${WRKDIR}/${DISTNAME}</filename>, which + works for most packages.</para> + + <para>If a package doesn't create a subdirectory for itself + (most GNU software does, for instance), but extracts itself in + the current directory, you should set + <varname>WRKSRC=${WRKDIR}</varname>.</para> + + <para>If a package doesn't create a subdirectory with the + name of <varname>DISTNAME</varname> but some different name, + set <varname>WRKSRC</varname> to point to the proper name in + <filename>${WRKDIR}</filename>, for example + <varname>WRKSRC=${WRKDIR}/${DISTNAME}/unix</varname>. See + <filename role="pkg">lang/tcl</filename> and <filename + role="pkg">x11/tk</filename> for other examples.</para> + + <para>The name of the working directory created by pkgsrc is + taken from the <varname>WRKDIR_BASENAME</varname> + variable. By default, its value is + <filename>work</filename>. If you want to use the same + pkgsrc tree for building different kinds of binary packages, + you can change the variable according to your needs. Two + other variables handle common cases of setting + <varname>WRKDIR_BASENAME</varname> individually. If + <varname>OBJHOSTNAME</varname> is defined in + <filename>/etc/mk.conf</filename>, the first component of + the host's name is attached to the directory name. If + <varname>OBJMACHINE</varname> is defined, the platform name + is attached, which might look like + <filename>work.i386</filename> or + <filename>work.sparc</filename>.</para> + + </listitem> + + </itemizedlist></para> + + <para>Please pay attention to the following gotchas:</para> + <itemizedlist> + <listitem> + <para>Add <varname>MANCOMPRESSED</varname> if man pages are + installed in compressed form by the package; see comment in + <filename>bsd.pkg.mk</filename>.</para> + </listitem> + + <listitem> + <para>Replace <filename>/usr/local</filename> with + <quote>${PREFIX}</quote> in all files (see patches, below).</para> + </listitem> + + <listitem> + <para>If the package installs any info files, see + <xref linkend="faq.info-files"/>.</para> + </listitem> + + </itemizedlist> +</sect1> - <sect1 id="components.distinfo"> - <title><filename>distinfo</filename></title> - - <para>The <filename>distinfo</filename> file contains the message - digest, or checksum, of each distfile needed for the package. This - ensures that the distfiles retrieved from the Internet have not been - corrupted during transfer or altered by a malign force to introduce - a security hole. Due to recent rumor about weaknesses of digest - algorithms, all distfiles are protected using both SHA1 and RMD160 - message digests, as well as the file size.</para> - - <para>The <filename>distinfo</filename> file also contains the - checksums for all the patches found in the - <filename>patches</filename> directory (see <xref - linkend="components.patches"/>).</para> - - <para>To regenerate the <filename>distinfo</filename> file, use the - <command>make makedistinfo</command> or <command>make mdi</command> - command.</para> - - <para>Some packages have different sets of distfiles depending on - the platform, for example <filename - role="pkg">www/navigator</filename>). These are kept in the same - <filename>distinfo</filename> file and care should be taken when - upgrading such a package to ensure distfile information is not - lost.</para> +<sect1 id="components.distinfo"> + <title><filename>distinfo</filename></title> + + <para>The <filename>distinfo</filename> file contains the message + digest, or checksum, of each distfile needed for the package. This + ensures that the distfiles retrieved from the Internet have not been + corrupted during transfer or altered by a malign force to introduce + a security hole. Due to recent rumor about weaknesses of digest + algorithms, all distfiles are protected using both SHA1 and RMD160 + message digests, as well as the file size.</para> + + <para>The <filename>distinfo</filename> file also contains the + checksums for all the patches found in the + <filename>patches</filename> directory (see <xref + linkend="components.patches"/>).</para> + + <para>To regenerate the <filename>distinfo</filename> file, use the + <command>make makedistinfo</command> or <command>make mdi</command> + command.</para> + + <para>Some packages have different sets of distfiles depending on + the platform, for example <filename + role="pkg">www/navigator</filename>). These are kept in the same + <filename>distinfo</filename> file and care should be taken when + upgrading such a package to ensure distfile information is not + lost.</para> - </sect1> +</sect1> - <sect1 id="components.patches"> - <title>patches/*</title> - - <para>This directory contains files that are used by the - &man.patch.1; command to - modify the sources as distributed in the distribution file into a form - that will compile and run perfectly on &os;. The files are applied - successively in alphabetic order (as returned by a shell - <quote>patches/patch-*</quote> glob expansion), so - <filename>patch-aa</filename> is applied before - <filename>patch-ab</filename>, etc.</para> - - <para>The <filename>patch-*</filename> files should be in - <command>diff -bu</command> format, and apply without a fuzz to avoid - problems. (To force patches to apply - with fuzz you can set <varname>PATCH_FUZZ_FACTOR=-F2</varname>). - Furthermore, do not put changes for more than one file into a single - patch file, as this will make future modifications more difficult.</para> - - <para>Similar, a file should be patched at most once, not several times by - several different patches. If a file needs several patches, they should - be combined into one file.</para> - - <para>One important thing to mention is to pay attention that no RCS IDs - get stored in the patch files, as these will cause problems when - later checked into the &os; CVS tree. Use the - <command>pkgdiff</command> from the - <filename role="pkg">pkgtools/pkgdiff</filename> package to avoid - these problems.</para> - - <para>For even more automation, we recommend using <command>mkpatches</command> from the same - package to make a whole set of patches. You just have to backup files - before you edit them to <filename>filename.orig</filename>, e.g. with - <command>cp -p filename filename.orig</command> or, easier, by using - <command>pkgvi</command> again from the same package. If you upgrade a package - this way, you can easily compare the new set of patches with the - previously existing one with <command>patchdiff</command>.</para> - - <para>When you have finished a package, remember to generate the checksums - for the patch files by using the <command>make makepatchsum</command> - command, see <xref linkend="components.distinfo"/>.</para> +<sect1 id="components.patches"> + <title>patches/*</title> + + <para>This directory contains files that are used by the + &man.patch.1; command to + modify the sources as distributed in the distribution file into a form + that will compile and run perfectly on &os;. The files are applied + successively in alphabetic order (as returned by a shell + <quote>patches/patch-*</quote> glob expansion), so + <filename>patch-aa</filename> is applied before + <filename>patch-ab</filename>, etc.</para> + + <para>The <filename>patch-*</filename> files should be in + <command>diff -bu</command> format, and apply without a fuzz to avoid + problems. (To force patches to apply + with fuzz you can set <varname>PATCH_FUZZ_FACTOR=-F2</varname>). + Furthermore, do not put changes for more than one file into a single + patch file, as this will make future modifications more difficult.</para> + + <para>Similar, a file should be patched at most once, not several times by + several different patches. If a file needs several patches, they should + be combined into one file.</para> + + <para>One important thing to mention is to pay attention that no RCS IDs + get stored in the patch files, as these will cause problems when + later checked into the &os; CVS tree. Use the + <command>pkgdiff</command> from the + <filename role="pkg">pkgtools/pkgdiff</filename> package to avoid + these problems.</para> + + <para>For even more automation, we recommend using + <command>mkpatches</command> from the same package to make a + whole set of patches. You just have to backup files before you + edit them to <filename>filename.orig</filename>, e.g. with + <command>cp -p filename filename.orig</command> or, easier, by + using <command>pkgvi</command> again from the same package. If + you upgrade a package this way, you can easily compare the new + set of patches with the previously existing one with + <command>patchdiff</command>. Copy the patches you want to use + or update from the <filename>work/.newpatches</filename> + directory to <filename>patches/</filename>.</para> + + <para>When you have finished a package, remember to generate + the checksums for the patch files by using the <command>make + makepatchsum</command> command, see <xref + linkend="components.distinfo"/>.</para> + + <para>When adding a patch that corrects a problem in the + distfile (rather than e.g. enforcing pkgsrc's view of where + man pages should go), send the patch as a bug report to the + maintainer. This benefits non-pkgsrc users of the package, + and usually makes it possible to remove the patch in future + version.</para> + + <para>If you want to share patches between multiple packages + in pkgsrc, e.g. because they use the same distfiles, set + <varname>PATCHDIR</varname> to the path where the patch files + can be found, e.g.:</para> + <programlisting> + PATCHDIR= ${.CURDIR}/../xemacs/patches + </programlisting>> <para>Patch files that are distributed by the author or other - maintainers can be listed in - <varname>$PATCHFILES</varname>. </para> - - <para>If it is desired to store any patches that should not be committed into - pkgsrc, they can be kept outside the pkgsrc tree in the - <filename>$LOCALPATCHES</filename> - directory. The directory tree there is expected to have the same - <quote>category/package</quote> structure as pkgsrc, and patches are - expected to be stored inside these dirs (also known as - <filename>$LOCALPATCHES/$PKGPATH</filename>). For - example, if you want to keep a private patch for - <filename>pkgsrc/graphics/png</filename>, keep - it in <filename>$LOCALPATCHES/graphics/png/mypatch</filename>. All - files in the named directory are expected to be patch files, and - <emphasis>they are applied after pkgsrc patches are applied</emphasis>.</para> + maintainers can be listed in + <varname>PATCHFILES</varname>.</para> + + <para>If it is desired to store any patches that should not be + committed into pkgsrc, they can be kept outside the pkgsrc + tree in the <filename>$LOCALPATCHES</filename> directory. The + directory tree there is expected to have the same + <quote>category/package</quote> structure as pkgsrc, and + patches are expected to be stored inside these dirs (also + known as <filename>$LOCALPATCHES/$PKGPATH</filename>). For + example, if you want to keep a private patch for + <filename>pkgsrc/graphics/png</filename>, keep it in + <filename>$LOCALPATCHES/graphics/png/mypatch</filename>. All + files in the named directory are expected to be patch files, + and <emphasis>they are applied after pkgsrc patches are + applied</emphasis>.</para> <sect2 id="components.patches.guidelines"> <title>Patching guidelines</title> @@ -302,9 +332,9 @@ <entry>configure script</entry> <entry> <programlisting>case ${target_os} in - netbsd*) have_kvm=yes ;; - *) have_kvm=no ;; - esac</programlisting> + netbsd*) have_kvm=yes ;; + *) have_kvm=no ;; + esac</programlisting> </entry> <entry> @@ -316,40 +346,40 @@ <entry>C source file</entry> <entry> <programlisting>#if defined(__NetBSD__) - # include <sys/event.h> - #endif</programlisting> + # include <sys/event.h> + #endif</programlisting> </entry> <entry> <programlisting>#if defined(HAVE_SYS_EVENT_H) - # include <sys/event.h> - #endif</programlisting> + # include <sys/event.h> + #endif</programlisting> </entry> </row> <row> <entry>C source file</entry> <entry><programlisting>int - monitor_file(...) - { - #if defined(__NetBSD__) - int fd = kqueue(); - ... - #else - ... - #endif - }</programlisting> + monitor_file(...) + { + #if defined(__NetBSD__) + int fd = kqueue(); + ... + #else + ... + #endif + }</programlisting> </entry> <entry> <programlisting>int - monitor_file(...) - { - #if defined(HAVE_KQUEUE) - int fd = kqueue(); - ... - #else - ... - #endif - }</programlisting> + monitor_file(...) + { + #if defined(HAVE_KQUEUE) + int fd = kqueue(); + ... + #else + ... + #endif + }</programlisting> </entry> </row> </tbody> @@ -399,27 +429,27 @@ <variablelist> <varlistentry> - <term><filename>DESCR</filename></term> - - <listitem> - <para>A multi-line description of the piece of software. This should include - any credits where they are due. Please bear in mind that others do not - share your sense of humour (or spelling idiosyncrasies), and that others - will read everything that you write here.</para> - </listitem> + <term><filename>DESCR</filename></term> + + <listitem> + <para>A multi-line description of the piece of software. This should include + any credits where they are due. Please bear in mind that others do not + share your sense of humour (or spelling idiosyncrasies), and that others + will read everything that you write here.</para> + </listitem> </varlistentry> <varlistentry> - <term><filename>PLIST</filename></term> - - <listitem> - <para> - This file governs the files that are installed on your system: all the - binaries, manual pages, etc. There are other directives which may be - entered in this file, to control the creation and deletion of - directories, and the location of inserted files. - See <xref linkend="plist"/> for more information. </para> - </listitem> + <term><filename>PLIST</filename></term> + + <listitem> + <para>This file governs the files that are installed on your + system: all the binaries, manual pages, etc. There are other + directives which may be entered in this file, to control the + creation and deletion of directories, and the location of + inserted files. See <xref linkend="plist"/> for more + information.</para> + </listitem> </varlistentry> </variablelist> </sect1> @@ -427,69 +457,82 @@ <sect1 id="components.optional"> <title>Optional files</title> -<sect2 id="components.optional.bin"> -<title>Files affecting the binary package</title> - - <variablelist> - <varlistentry> - <term><filename>INSTALL</filename></term> - - <listitem> - <para>This shell script is invoked twice by &man.pkg.add.1;. - First time after package - extraction and before files are moved in place, the second time after - the files to install are moved in place. This can be used to do any - custom procedures not possible with @exec commands in - <filename>PLIST</filename>. See - &man.pkg.add.1; and &man.pkg.create.1; for more information.</para> - </listitem> - </varlistentry> - - <varlistentry> - <term><filename>DEINSTALL</filename></term> - - <listitem> - <para>This script is executed before and after any files are removed. It is - this script's responsibility to clean up any additional messy details - around the package's installation, since all pkg_delete knows is how to - delete the files created in the original distribution. - See &man.pkg.delete.1; - and &man.pkg.create.1; for more information.</para> - </listitem> - </varlistentry> - - <varlistentry> - <term><filename>MESSAGE</filename></term> - - <listitem> - <para>This file is displayed after installation of the package. - Useful for things like legal notices on almost-free - software and hints for updating config files after - installing modules for apache, PHP etc. - Please note that you can modify variables in it easily by using - <varname>MESSAGE_SUBST</varname> in the package's - <filename>Makefile</filename>:</para> - -<programlisting> - MESSAGE_SUBST+= SOMEVAR="somevalue" -</programlisting> - - <para>replaces "${SOMEVAR}" with <quote>somevalue</quote> in - <filename>MESSAGE</filename>.</para> - </listitem> - </varlistentry> + <sect2 id="components.optional.bin"> + <title>Files affecting the binary package</title> + + <variablelist> + <varlistentry> + <term><filename>INSTALL</filename></term> + + <listitem> + <para>This shell script is invoked twice by &man.pkg.add.1;. + First time after package extraction and before files are + moved in place, the second time after the files to install + are moved in place. This can be used to do any custom + procedures not possible with @exec commands in + <filename>PLIST</filename>. See &man.pkg.add.1; and + &man.pkg.create.1; for more information. See also <xref + linkend="files-and-dirs-outside-prefix" />.</para> + </listitem> + </varlistentry> + + <varlistentry> + <term><filename>DEINSTALL</filename></term> + + <listitem> + <para>This script is executed before and after any files are removed. It is + this script's responsibility to clean up any additional messy details + around the package's installation, since all pkg_delete knows is how to + delete the files created in the original distribution. + See &man.pkg.delete.1; + and &man.pkg.create.1; for more information.</para> + </listitem> + </varlistentry> + + <varlistentry> + <term><filename>MESSAGE</filename></term> + + <listitem> + <para>This file is displayed after installation of the package. + Useful for things like legal notices on almost-free + software and hints for updating config files after + installing modules for apache, PHP etc. + Please note that you can modify variables in it easily by using + <varname>MESSAGE_SUBST</varname> in the package's + <filename>Makefile</filename>:</para> + + <programlisting> + MESSAGE_SUBST+= SOMEVAR="somevalue" + </programlisting> + + <para>replaces "${SOMEVAR}" with <quote>somevalue</quote> in + <filename>MESSAGE</filename>. By default, substitution is + performed for <varname>PKGNAME</varname>, + <varname>PKGBASE</varname>, <varname>PREFIX</varname>, + <varname>LOCALBASE</varname>, <varname>X11PREFIX</varname>, + <varname>X11BASE</varname>, + <varname>PKG_SYSCONFDIR</varname>, + <varname>ROOT_GROUP</varname>, and + <varname>ROOT_GROUP</varname>.</para> + + <para>You can display a different or additional files by + setting the <varname>MESSAGE_SRC</varname> variable. Its + default is <filename>MESSAGE</filename>, if the file + exists.</para> + </listitem> + </varlistentry> <varlistentry><term><filename>ALTERNATIVES</filename></term> <listitem><para>FIXME: There is no documentation on the alternatives framework.</para></listitem></varlistentry> - </variablelist> + </variablelist> -</sect2> -<sect2 id="components.optional.build"> -<title>Files affecting the build process</title> + </sect2> + <sect2 id="components.optional.build"> + <title>Files affecting the build process</title> - <variablelist> + <variablelist> <varlistentry><term><filename>Makefile.common</filename></term> <listitem><para>This file contains arbitrary things that could @@ -519,13 +562,13 @@ it is equally acceptable to put the code directly into the <filename>Makefile</filename>.</para></listitem></varlistentry> - </variablelist> + </variablelist> -</sect2> -<sect2 id="components.optional.none"> -<title>Files affecting nothing at all</title> + </sect2> + <sect2 id="components.optional.none"> + <title>Files affecting nothing at all</title> - <variablelist> + <variablelist> <varlistentry><term><filename>README*</filename></term> <listitem><para>These files do not take place in the creation of @@ -537,34 +580,42 @@ to make the package even better.</para></listitem></varlistentry> - </variablelist> + </variablelist> -</sect2> -</sect1> + </sect2> + </sect1> <sect1 id="work-dir"> <title><filename>work*</filename></title> <para>When you type <command>make</command>, the distribution files are - unpacked into the directory denoted by - <varname>WRKDIR</varname>. It can be removed by running - <command>make clean</command>. Besides the sources, this - directory is also used to keep various timestamp files. - The directory gets <emphasis>removed completely</emphasis> on clean. - The default is <filename>${.CURDIR}/work</filename> - or <filename>${.CURDIR}/work.${MACHINE_ARCH}</filename> - if <varname>OBJMACHINE</varname> is set.</para> + unpacked into the directory denoted by + <varname>WRKDIR</varname>. It can be removed by running + <command>make clean</command>. Besides the sources, this + directory is also used to keep various timestamp files. + The directory gets <emphasis>removed completely</emphasis> on clean. + The default is <filename>${.CURDIR}/work</filename> + or <filename>${.CURDIR}/work.${MACHINE_ARCH}</filename> + if <varname>OBJMACHINE</varname> is set.</para> </sect1> <sect1 id="files-dir"> <title><filename>files/*</filename></title> <para>If you have any files that you wish to be placed in the package prior - to configuration or building, you could place these files here and use - a <quote>${CP}</quote> command in the - <quote>pre-configure</quote> target to achieve - this. Alternatively, you could simply diff the file against - <filename>/dev/null</filename> and use the patch mechanism to manage - the creation of this file.</para> + to configuration or building, you could place these files here and use + a <command>${CP}</command> command in the + <quote>pre-configure</quote> target to achieve + this. Alternatively, you could simply diff the file against + <filename>/dev/null</filename> and use the patch mechanism to manage + the creation of this file.</para> + + <para>If you want to share files in this way with other + packages, set the <varname>FILESDIR</varname> variable to point + to the other package's <filename>files</filename> directory, + e.g.:</para> + <programlisting> + FILESDIR=${.CURDIR}/../xemacs/files + </programlisting> </sect1> </chapter> |