debi

DEBI(1)                     General Commands Manual                    DEBI(1)

NAME
       debi - install current version of generated Debian package

SYNOPSIS
       debi [options] [changes file] [package ...]

DESCRIPTION
       debi  figures out the current version of a package and installs it.  If
       a .changes file is specified on the command line, the filename must end
       with .changes, as this is how the program distinguishes it from package
       names.  If not, then debi has to be called from within the source  code
       directory  tree.  In this case, it will look for the .changes file cor-
       responding to the current package version (by determining the name  and
       version number from the changelog, and the architecture in the same way
       as dpkg-buildpackage(1) does).  It then runs debpkg -i  on  every  .deb
       archive  listed in the .changes file to install them, assuming that all
       of the .deb archives live in the same directory as the  .changes  file.
       Note  that  you  probably  don't want to run this program on a .changes
       file relating to a different  architecture  after  cross-compiling  the
       package!

       If  a  list  of  packages is given on the command line, then only those
       debs with names in this list of packages will be installed.

       Since installing a package requires root privileges, debi calls  debpkg
       rather  than dpkg directly.  Thus debi will only be useful if it is ei-
       ther being run as root or debpkg can be run as root.  See debpkg(1) for
       more details.

Directory name checking
       In  common  with  several other scripts in the devscripts package, debi
       will climb the directory tree until it finds a  debian/changelog  file.
       As  a safeguard against stray files causing potential problems, it will
       examine the name  of  the  parent  directory  once  it  finds  the  de-
       bian/changelog  file,  and check that the directory name corresponds to
       the package name.  Precisely how it does this is controlled by two con-
       figuration   file   variables  DEVSCRIPTS_CHECK_DIRNAME_LEVEL  and  DE-
       VSCRIPTS_CHECK_DIRNAME_REGEX, and their corresponding command-line  op-
       tions --check-dirname-level and --check-dirname-regex.

       DEVSCRIPTS_CHECK_DIRNAME_LEVEL can take the following values:

       0      Never check the directory name.

       1      Only check the directory name if we have had to change directory
              in our search for debian/changelog.  This is the default  behav-
              iour.

       2      Always check the directory name.

       The  directory name is checked by testing whether the current directory
       name (as determined by pwd(1)) matches the regex given by the  configu-
       ration  file  option  DEVSCRIPTS_CHECK_DIRNAME_REGEX  or by the command
       line option --check-dirname-regex regex.  Here regex is  a  Perl  regex
       (see  perlre(3perl)),  which  will be anchored at the beginning and the
       end.  If regex contains a '/', then it must match  the  full  directory
       path.   If  not,  then it must match the full directory name.  If regex
       contains the string 'PACKAGE', this will  be  replaced  by  the  source
       package  name, as determined from the changelog.  The default value for
       the regex is: 'PACKAGE(-.+)?', thus matching directory  names  such  as
       PACKAGE and PACKAGE-version.

OPTIONS
       -adebian-architecture, -tGNU-system-type
              See  dpkg-architecture(1)  for  a  description of these options.
              They affect the search for the .changes file.  They are provided
              to mimic the behaviour of dpkg-buildpackage when determining the
              name of the .changes file.

       --debs-dir directory
              Look for the .changes and .deb files in directory instead of the
              parent  of the source directory.  This should either be an abso-
              lute path or relative to the top of the source directory.

       -m, --multi
              Search for a multiarch .changes file, as created by dpkg-cross.

       -u, --upgrade
              Only upgrade packages already installed on  the  system,  rather
              than  installing all packages listed in the .changes file.  Use-
              ful for multi-binary packages when you don't want  to  have  all
              the binaries installed at once.

       --check-dirname-level N
              See the above section Directory name checking for an explanation
              of this option.

       --check-dirname-regex regex
              See the above section Directory name checking for an explanation
              of this option.

       --with-depends
              Attempt to satisfy the Depends of a package when installing it.

       --tool tool
              Use  the  specified  tool for installing the dependencies of the
              package(s) to be installed.  By default, apt-get is used.

       --no-conf, --noconf
              Do not read any configuration files.  This can only be  used  as
              the first option given on the command-line.

       --help, --version
              Show help message and version information respectively.

CONFIGURATION VARIABLES
       The  two configuration files /etc/devscripts.conf and ~/.devscripts are
       sourced in that order to set configuration variables.  Command line op-
       tions can be used to override configuration file settings.  Environment
       variable settings are ignored for this purpose.  The  currently  recog-
       nised variables are:

       DEBRELEASE_DEBS_DIR
              This  specifies  the directory in which to look for the .changes
              and .deb files, and is either an absolute path  or  relative  to
              the  top of the source tree.  This corresponds to the --debs-dir
              command line option.  This directive could be used, for example,
              if  you  always  use  pbuilder or svn-buildpackage to build your
              packages.  Note that it also affects debrelease(1) in  the  same
              way, hence the strange name of the option.

       DEVSCRIPTS_CHECK_DIRNAME_LEVEL, DEVSCRIPTS_CHECK_DIRNAME_REGEX
              See the above section Directory name checking for an explanation
              of these variables.  Note that these are package-wide configura-
              tion variables, and will therefore affect all devscripts scripts
              which check their value, as described in their  respective  man-
              pages and in devscripts.conf(5).

SEE ALSO
       debpkg(1), devscripts.conf(5)

AUTHOR
       debi was originally written by Christoph Lameter <clameter@debian.org>.
       The now-defunct script debit was originally written  by  James  R.  Van
       Zandt  <jrv@vanzandt.mv.com>.   They  have been moulded into one script
       together with debc(1) and parts extensively modified by  Julian  Gilbey
       <jdg@debian.org>.

DEBIAN                         Debian Utilities                        DEBI(1)
Man Pages Copyright Respective Owners. Site Copyright (C) 1994 - 2025 Hurricane Electric. All Rights Reserved.