| 
      pkg_add - install software package distributions
      pkg_add [-Inv] [-A arch]  [-B  pkg-destdir]  [-f  keys]  [-L
localbase] [-P
             type] pkg-name [...]
     The pkg_add command is used to install packages created with
the
     pkg_create(1) command.  Selected  packages  containing  precompiled applications
 from the /usr/ports tree can be found on the OpenBSD
FTP site or
     on the official OpenBSD CD.
           Note:  System  distribution  files,  e.g.  base28.tgz,
comp28.tgz, etc.,
           are  not  packages  and  may  not  be  installed using
pkg_add.
     Each package name may be specified as a filename (which normally consists
     of  the  package name itself plus the ``.tgz'' suffix) or an
URL referring
     to FTP, HTTP, or SCP locations.  For example, the  following
is valid:
     pkg_add                                                   -v
ftp://ftp.openbsd.org/pub/OpenBSD/2.7/packages/i386/m4-1.4.tgz
     If the given package names are  not  found  in  the  current
working directory,
  pkg_add will search for them in each directory named by
the PKG_PATH
     environment variable.  Specifying  `-'  as  a  package  name
causes pkg_add to
     read from the standard input.
     Some  packages may depend on other packages.  When resolving
dependencies
     pkg_add will first look at already installed packages,  then
match dependencies
  with the list of packages left to install, then install default
     packages that satisfy the dependencies.
     Alternatively, it is possible to add packages  interactively
from within
     the  ftp  client,  in  which case setting PKG_PATH correctly
will be necessary
 for any dependency to be found out  and  retrieved  the
same way.  For
     example, the following works:
             $   ftp  ftp://ftp.openbsd.org/pub/OpenBSD/2.7/pack-
ages/i386/
             250 CWD command successful
             ftp> ls m*
             227 Entering Passive Mode (129,128,5,191,164,73)
             150 Opening ASCII mode data connection for m*.
             m4-1.4.tgz
             metamail-2.7.tgz
             mh-6.8.4.tgz
             mm-1.0.12.tgz
             mpeg_lib-1.2.1.tgz
             mpeg_play-2.4.tgz
             mpg123-0.59q.tgz
             mutt-0.95.7i.tgz
             226 Transfer complete.
             ftp> get m4-1.4.tgz "|pkg_add -v -"
     Warning: Since the pkg_add command may  execute  scripts  or
programs contained
 within a package file, your system may be susceptible
to ``trojan
     horses'' or other subtle attacks from miscreants who  create
dangerous
     packages.  Be sure the specified package(s) are from trusted
sources.
     The options are as follows:
     -v       Turn on verbose output.
     -I       If an installation script exists for a given  package, do not execute
 it.
     -n        Don't  actually install a package, just report the
steps that
              would be taken if it was.
     -A arch  Assume arch as current machine architecture for any
package
              tests.
     -B pkg-destdir
              Set pkg-destdir as the prefix to prepend to any object extracted
              from the package.
     -f keys  Force installation of the package.  keys is a  comma-separated
              list  of  keywords that state what failsafes should
be waived.
              These include:
              arch     architecture recorded in package  may  not
match.
              conflicts
                       package  may conflict with other packages.
              installed
                       reinstall an existing package.
              libdepends
                       library specifications  may  not  be  fulfilled.
              nonroot  install even if not running as root.
              scripts  install scripts may fail.
     -L localbase
              Install  a  package  under  localbase.  By default,
localbase equals
              /usr/local, and specifying  it  is  not  necessary.
However, packages
  can  be  created  using a different localbase
(see
              pkg_create(1)), and those packages can only be  installed by using
  the  same localbase.  See bsd.port.mk(5) for a
description of
              LOCALBASE.
     -P type  Check permissions for distribution, where type  can
be `cdrom' or
              `ftp'.
     By default, when adding packages via FTP, the ftp(1) program
operates in
     ``passive'' mode.  If you wish to use active  mode  instead,
set the
     FTPMODE  environment  variable to "active".  If pkg_add consistently fails
     to fetch a package from a site known to work, it may be  because the site
     does  not  support passive mode ftp correctly.  This is very
rare since
     pkg_add will try active mode ftp if  the  server  refuses  a
passive mode
     connection.
   Technical details    [Toc]    [Back]
     pkg_add extracts each package's ``packing information'' (the
packing
     list, description, and installation/deinstallation  scripts)
into a special
  staging  directory in /var/tmp (or PKG_TMPDIR if set -
see CAVEATS
     section) and then runs through  the  following  sequence  to
fully extract
     the contents of the package:
     1.    A check is made to determine if the package is already
recorded as
          installed.  If it is, installation is terminated.
     2.   A check is made to determine if the  package  conflicts
(from @pkgcfl
          directives, see pkg_create(1)) with an already recorded
as installed
          package.  If it is, installation is terminated.
     3.   For  packages  tagged  with  architecture  constraints,
pkg_add verifies
          that  the  current machine architecture agrees with the
constraints.
     4.   All package dependencies (from @pkgdep, @libdepend, and
@newdepend
          directives,  see pkg_create(1)) are read from the packing list.  If
          any of these dependencies are not currently  fulfilled,
an attempt is
          made  to find a package that meets them and install it,
looking first
          in the list of packages to install passed  to  pkg_add;
if no adequate
          package can be found and installed, the installation is
terminated.
     5.   pkg_add  checks  for  collisions  with  installed  file
names, read-only
          file systems, and enough space to store files.
     6.    If the package contains a require script (see pkg_create(1)), it is
          executed with the following arguments:
          pkg-name      The name of the package being installed
          INSTALL       Keyword denoting to the script that it is
to run an
                        installation requirements check (the keyword is useful
                        only  to  scripts  which  serve  multiple
functions).
          If  the  require  script  exits  with a non-zero status
code, the installation
 is terminated.
     7.   If the package contains an install script, it  is  executed with the
          following arguments:
          pkg-name       The name of the package being installed.
          PRE-INSTALL   Keyword denoting that the  script  is  to
perform any actions
  needed  before  the package is installed.
          If the install script  exits  with  a  non-zero  status
code, the installation
 is terminated.
     8.    The  packing  list  is  used as a guide for extracting
files from the
          package into their final locations.
     9.   If an install script exists for the package, it is executed with the
          following arguments:
          pkg_name       The name of the package being installed.
          POST-INSTALL  Keyword denoting that the  script  is  to
perform any actions
  needed  after the package has been
installed.
     10.  After installation is complete, a copy of  the  packing
list,
          deinstall  script,  description,  and display files are
copied into
          /var/db/pkg/<pkg-name> for subsequent possible  use  by
pkg_delete(1).
          Any  package  dependencies  are  recorded  in the other
packages'
          /var/db/pkg/<other-pkg>/+REQUIRED_BY file (if the environment variable
  PKG_DBDIR is set, this overrides the /var/db/pkg/
path shown
          above).
     11.  Finally, the staging area is deleted  and  the  program
terminates.
     Note that it is safe to interrupt pkg_add through SIGINT, as
it will
     safely record an interrupted install as borked.n.
     PKG_PATH     If a given package name cannot  be  found,  the
directories
                  named by PKG_PATH are searched.  It should contain a series
                  of entries separated  by  colons.   Each  entry
consists of a
                  directory  name.   The current directory may be
indicated implicitly
 by an empty directory name, or explicitly by a single
 period (`.').
     PKG_DBDIR      Where   to   register   packages  instead  of
/var/db/pkg.
     PKG_DESTDIR  Value for pkg-destdir, if no -B option is specified; value
                  passed to any INSTALL or REQUIRE script invoked
from the
                  package.
     PKG_TMPDIR   Temporary area where package information  files
will be extracted,
 instead of /var/tmp.
     pkg_create(1),   pkg_delete(1),   pkg_info(1),   mkdtemp(3),
sysconf(3),
     mtree(8)
     Jordan Hubbard
             Initial design.
     Marc Espie
             Complete rewrite.
     Package extraction does need a temporary area that can  hold
executable
     scripts.
     pkg_add  looks  through  ${PKG_TMPDIR}, ${TMPDIR}, /var/tmp,
/tmp, /usr/tmp
     for such an area, in sequence.
     If ${TMPDIR} and /var/tmp are mounted noexec, you must  currently set
     PKG_TMPDIR to a suitable area, as pkg_add does not check for
noexec status
 except by failing to run installation scripts.
OpenBSD     3.6                        November     25,      1994
[ Back ] |