pkgsrc/doc/guide/files/configuring.xml

446 lines
17 KiB
XML

<!-- $NetBSD: configuring.xml,v 1.33 2009/03/05 13:08:02 imil Exp $ -->
<chapter id="configuring">
<title>Configuring pkgsrc</title>
<anchor id="mk.conf" />
<para>The whole pkgsrc system is configured in a single file, usually
called <filename>mk.conf</filename>. In which directory pkgsrc looks for
that file depends on the installation. On NetBSD, when you use
&man.make.1; from the base system, it is in the directory
<filename>/etc/</filename>. In all other cases the default location is
<literal>${PREFIX}/etc/</literal>, depending on where you told the
bootstrap program to install the binary packages.</para>
<para>During the bootstrap, an example configuration file is created. To
use that, you have to create the directory
<filename>${PREFIX}/etc</filename> and copy the example file
there.</para>
<para>The format of the configuration file is that of the usual
BSD-style <filename>Makefile</filename>s. The whole pkgsrc configuration
is done by setting variables in this file. Note that you can define all
kinds of variables, and no special error checking (for example for
spelling mistakes) takes place, so you have to try it out to see if it
works.</para>
<sect1 id="general-configuration">
<title>General configuration</title>
<para>In this section, you can find some variables that apply to all
pkgsrc packages. A complete list of the variables that can be
configured by the user is available in
<filename>mk/defaults/mk.conf</filename>, together with some
comments that describe each variable's intent.</para>
<itemizedlist>
<listitem><para><varname>LOCALBASE</varname>: Where
packages will be installed. The default is
<filename>/usr/pkg</filename>. Do not mix binary packages
with different <varname>LOCALBASE</varname>s!</para>
</listitem>
<listitem><para><varname>CROSSBASE</varname>: Where
<quote>cross</quote> category packages will be
installed. The default is
<filename>${LOCALBASE}/cross</filename>.</para>
</listitem>
<listitem><para><varname>X11BASE</varname>: Where
X11 is installed on the system. The default is
<filename>/usr/X11R6</filename>.</para>
</listitem>
<listitem><para><varname>DISTDIR</varname>: Where to store the
downloaded copies of the original source distributions used
for building pkgsrc packages. The default is
<filename>${PKGSRCDIR}/distfiles</filename>.</para>
</listitem>
<listitem><para><varname>PKG_DBDIR</varname>: Where the
database about installed packages is stored. The default is
<filename>/var/db/pkg</filename>.</para>
</listitem>
<listitem><para><varname>MASTER_SITE_OVERRIDE</varname>:
If set, override the packages'
<varname>MASTER_SITES</varname> with this value.</para>
</listitem>
<listitem><para><varname>MASTER_SITE_BACKUP</varname>:
Backup location(s) for distribution files and patch files
if not found locally or in
<filename>${MASTER_SITES}</filename> or
<filename>${PATCH_SITES}</filename> respectively.
The defaults are
<filename>ftp://ftp.NetBSD.org/pub/NetBSD/packages/distfiles/${DIST_SUBDIR}/</filename>
and
<filename>ftp://ftp.freebsd.org/pub/FreeBSD/distfiles/${DIST_SUBDIR}/</filename>.</para>
</listitem>
<listitem><para><varname>BINPKG_SITES</varname>:
List of sites carrying binary pkgs. <replaceable>rel</replaceable> and
<replaceable>arch</replaceable> are replaced with OS
release (<quote>2.0</quote>, etc.) and architecture
(<quote>mipsel</quote>, etc.).</para>
</listitem>
<listitem><para><varname>ACCEPTABLE_LICENSES</varname>:
List of acceptable licenses. Whenever you try to build a package
whose license is not in this list, you will get an error message
that includes instructions on how to change this variable.</para>
</listitem>
</itemizedlist>
</sect1>
<sect1 id="variables-affecting-build">
<title>Variables affecting the build process</title>
<para>XXX
<itemizedlist>
<listitem><para><varname>PACKAGES</varname>: The top level
directory for the binary packages. The default is
<filename>${PKGSRCDIR}/packages</filename>.</para>
</listitem>
<listitem><para><varname>WRKOBJDIR</varname>:
The top level directory where, if defined, the separate
working directories will get created, and symbolically
linked to from <filename>${WRKDIR}</filename> (see below).
This is useful for building packages on several
architectures, then <filename>${PKGSRCDIR}</filename>
can be NFS-mounted while <filename>${WRKOBJDIR}</filename>
is local to every architecture. (It should be noted that
<varname>PKGSRCDIR</varname> should not be set by the user
&mdash; it is an internal definition which refers to the
root of the pkgsrc tree. It is possible to have many
pkgsrc tree instances.)</para>
</listitem>
<listitem><para><varname>LOCALPATCHES</varname>:
Directory for local patches that aren't part of pkgsrc.
See <xref linkend="components.patches" /> for more
information.</para>
</listitem>
<listitem><para><varname>PKGMAKECONF</varname>: Location of
the &mk.conf; file used by a package's
BSD-style Makefile. If this is not set,
<varname>MAKECONF</varname> is set to
<filename>/dev/null</filename> to avoid picking up
settings used by builds in <filename>/usr/src</filename>.</para>
</listitem>
<listitem><para><varname>DEPENDS_TARGET</varname>:
By default, dependencies are only installed, and no binary
package is created for them. You can set this variable to
<literal>package</literal> to automatically create binary
packages after installing dependencies.</para>
</listitem>
<!-- DISTDIR -->
<!-- FAILOVER_FETCH -->
</itemizedlist></para>
</sect1>
<sect1 id="variables-affecting-installation">
<title>Variables affecting the installation process</title>
<para>A growing number of packages support installation into a
subdirectory of <varname>WRKDIR</varname>. This allows a package
to be built, before the actual filesystem is touched. DESTDIR
support exists in two variations:</para>
<itemizedlist>
<listitem><para>Basic DESTDIR support means that the package
installation and packaging is still run as
root.</para></listitem>
<listitem><para>Full DESTDIR support can run the complete build,
installation and packaging as normal user. Root privileges are
only needed to add packages.</para></listitem>
</itemizedlist>
<para>To use the DESTDIR support, set either
<varname>USE_DESTDIR=yes</varname> to use the basic support for
packages that offer it or <varname>USE_DESTDIR=full</varname> to
get the full support with fallback to basic
support. <varname>USE_DESTDIR=full</varname> needs <filename
role="pkg">pkgtools/pkg_install</filename> version 20070802 (or
newer). It might become the default DESTDIR support later.</para>
<para>DESTDIR support changes the behaviour of various targets
slightly. To install a package after building it, use
<literal>package-install</literal>. <literal>package</literal> and
<literal>install</literal> don't do that any
longer. <literal>package-install</literal> can be used as
<varname>DEPENDS_TARGET</varname>. <literal>bin-install</literal>
will ask for the root password to install the package and fail,
<literal>package-install</literal> will ask again.</para>
<para>With basic DESTDIR support, <userinput>make
clean</userinput> needs to be run as root.</para>
<para>Considering the <filename>foo/bar</filename> package,
DESTDIR full support can be tested using the following commands
<programlisting>
&uprompt; id
uid=1000(myusername) gid=100(users) groups=100(users),0(wheel)
&uprompt; mkdir $HOME/packages
&uprompt; cd $PKGSRCDIR/foo/bar
</programlisting>
Verify <varname>DESTDIR</varname> full support, no root privileges
should be needed
<programlisting>
&uprompt; make USE_DESTDIR=full install
</programlisting>
Create a package without root privileges
<programlisting>
&uprompt; make USE_DESTDIR=full PACKAGES=$HOME/packages package
</programlisting>
For the following command, you must be able to gain root
privileges using &man.su.1;
<programlisting>
&uprompt; make USE_DESTDIR=full PACKAGES=$HOME/packages package-install
</programlisting>
Then, as a simple user
<programlisting>
&uprompt; make clean
</programlisting>
</para>
</sect1>
<sect1 id="conf.compiler">
<title>Selecting and configuring the compiler</title>
<sect2 id="selecting-the-compiler">
<title>Selecting the compiler</title>
<para>By default, pkgsrc will use GCC to build packages. This may be
overridden by setting the following variables in /etc/mk.conf:</para>
<variablelist>
<varlistentry>
<term><varname>PKGSRC_COMPILER</varname>:</term>
<listitem>
<para>This is a list of values specifying the chain of
compilers to invoke when building packages. Valid values
are:</para>
<!-- TODO: update this list after jlam's changes in May 2005 -->
<itemizedlist>
<listitem><para><varname>distcc</varname>:
distributed C/C++ (chainable)</para>
</listitem>
<listitem><para><varname>ccache</varname>:
compiler cache (chainable)</para>
</listitem>
<listitem><para><varname>gcc</varname>:
GNU C/C++ Compiler</para>
</listitem>
<listitem><para><varname>mipspro</varname>:
Silicon Graphics, Inc. MIPSpro (n32/n64)</para>
</listitem>
<listitem><para><varname>mipspro</varname>:
Silicon Graphics, Inc. MIPSpro (o32)</para>
</listitem>
<listitem><para><varname>sunpro</varname>:
Sun Microsystems, Inc. WorkShip/Forte/Sun ONE Studio</para>
</listitem>
</itemizedlist>
<para>The default is
<quote><varname>gcc</varname></quote>. You can use
<varname>ccache</varname> and/or
<varname>distcc</varname> with an appropriate
<varname>PKGSRC_COMPILER</varname> setting,
e.g. <quote><varname>ccache gcc</varname></quote>. This
variable should always be terminated with a value for
a real compiler. Note that only one real compiler
should be listed (e.g. <quote><varname>sunpro gcc</varname></quote>
is not allowed).</para>
</listitem>
</varlistentry>
<varlistentry>
<term><varname>GCC_REQD</varname>:</term>
<!--
TODO: what are the effects of setting GCC_REQD if PKGSRC_COMPILER
is not gcc?
-->
<listitem>
<para>This specifies the minimum version of GCC to use
when building packages. If the system GCC doesn't
satisfy this requirement, then pkgsrc will build and
install one of the GCC packages to use instead.</para>
</listitem>
</varlistentry>
</variablelist>
</sect2>
<sect2 id="conf.cflags">
<title>Additional flags to the compiler (<varname>CFLAGS</varname>)</title>
<para>If you wish to set the <varname>CFLAGS</varname> variable,
please make sure to use the <literal>+=</literal> operator
instead of the <literal>=</literal> operator:</para>
<programlisting>
CFLAGS+= -your -flags
</programlisting>
<para>Using <varname>CFLAGS=</varname> (i.e. without the
<quote>+</quote>) may lead to problems with packages that
need to add their own flags. You may want to take a look
at the <filename role="pkg">devel/cpuflags</filename>
package if you're interested in optimization for the current
CPU. Setting <varname>USE_CPUFLAGS</varname> to yes in
&mk.conf; will cause pkgsrc to automatically use cpuflags.</para>
</sect2>
<sect2 id="conf.ldflags">
<title>Additional flags to the linker (<varname>LDFLAGS</varname>)</title>
<para>If you want to pass flags to the linker, both in the configure
step and the build step, you can do this in two ways. Either set
<varname>LDFLAGS</varname> or <varname>LIBS</varname>. The difference
between the two is that <varname>LIBS</varname> will be appended to
the command line, while <varname>LDFLAGS</varname> come earlier.
<varname>LDFLAGS</varname> is pre-loaded with rpath settings for ELF
machines depending on the setting of <varname>USE_IMAKE</varname> or
the inclusion of <filename>mk/x11.buildlink3.mk</filename>. As with
<varname>CFLAGS</varname>, if you do not wish to override these
settings, use the <literal>+=</literal> operator:</para>
<programlisting>
LDFLAGS+= -your -linkerflags
</programlisting>
</sect2>
</sect1>
<!-- Configuration files -->
<!-- PKG_SYSCONFBASE -->
<!-- PKG_SYSCONFDIR.foobar -->
<!-- Security -->
<!-- PKGVULNDIR -->
<sect1 id="developer-advanced-settings">
<title>Developer/advanced settings</title>
<!-- USE_ABI_DEPENDS -->
<para>XXX
<itemizedlist>
<listitem><para><varname>PKG_DEVELOPER</varname>:
Run some sanity checks that package developers want:
<itemizedlist>
<listitem><para>make sure patches apply with zero
fuzz</para></listitem>
<listitem><para>run check-shlibs to see that all
binaries will find their shared libs.</para>
<!-- XXX: some more stuff -->
</listitem>
</itemizedlist>
</para>
</listitem>
<listitem><para><varname>PKG_DEBUG_LEVEL</varname>: The level
of debugging output which is displayed whilst making and
installing the package. The default value for this is 0,
which will not display the commands as they are executed
(normal, default, quiet operation); the value 1 will display
all shell commands before their invocation, and the value 2
will display both the shell commands before their invocation,
and their actual execution progress with <command>set
-x</command> will be displayed.</para></listitem>
</itemizedlist>
</para>
</sect1>
<!-- pkginstall-related variables -->
<!-- PKG_REGISTER_SHELLS -->
<!-- PKG_RCD_SCRIPTS -->
<sect1 id="selecting-build-options">
<title>Selecting Build Options</title>
<para>Some packages have build time options, usually to select
between different dependencies, enable optional support for big
dependencies or enable experimental features.</para>
<para>To see which options, if any, a package supports, and which
options are mutually exclusive, run <command>make
show-options</command>, for example:</para>
<programlisting>
The following options are supported by this package:
ssl Enable SSL support.
Exactly one of the following gecko options is required:
firefox Use firefox as gecko rendering engine.
mozilla Use mozilla as gecko rendering engine.
At most one of the following database options may be selected:
mysql Enable support for MySQL database.
pgsql Enable support for PostgreSQL database.
These options are enabled by default: firefox
These options are currently enabled: mozilla ssl
</programlisting>
<para>The following variables can be defined in
&mk.conf; to select which options to
enable for a package: <varname>PKG_DEFAULT_OPTIONS</varname>,
which can be used to select or disable options for all packages
that support them, and
<varname>PKG_OPTIONS.<replaceable>pkgbase</replaceable></varname>,
which can be used to select or disable options specifically for
package <replaceable>pkgbase</replaceable>. Options listed in
these variables are selected, options preceded by <quote>-</quote>
are disabled. A few examples:</para>
<screen>
&uprompt; <command>grep "PKG.*OPTION" &mk.conf;</command>
PKG_DEFAULT_OPTIONS= -arts -dvdread -esound
PKG_OPTIONS.kdebase= debug -sasl
PKG_OPTIONS.apache= suexec </screen>
<para>It is important to note that options that were specifically
suggested by the package maintainer must be explicitely removed if
you do not wish to include the option. If you are unsure you can view
the current state with <command>make show-options</command>.</para>
<para>The following settings are consulted in the order given, and
the last setting that selects or disables an option is
used:</para>
<orderedlist>
<listitem><para>the default options as suggested by the package
maintainer</para></listitem>
<listitem><para>the options implied by the settings of legacy
variables (see below)</para></listitem>
<listitem><para><varname>PKG_DEFAULT_OPTIONS</varname></para></listitem>
<listitem><para><varname>PKG_OPTIONS.<replaceable>pkgbase</replaceable></varname></para></listitem>
</orderedlist>
<para>For groups of mutually exclusive options, the last option
selected is used, all others are automatically disabled. If an
option of the group is explicitly disabled, the previously
selected option, if any, is used. It is an error if no option
from a required group of options is selected, and building the
package will fail.</para>
<para>Before the options framework was introduced, build options
were selected by setting a variable (often named
<varname>USE_<replaceable>FOO</replaceable></varname>) in
&mk.conf; for each option. To ease
transition to the options framework for the user, these legacy
variables are converted to the appropriate options setting
(<varname>PKG_OPTIONS.<replaceable>pkgbase</replaceable></varname>)
automatically. A warning is issued to prompt the user to update
&mk.conf; to use the options framework
directly. Support for the legacy variables will be removed
eventually.</para>
</sect1>
</chapter>