# phpman > man > DEBC(1)

[DEBC(1)](https://www.chedong.com/phpMan.php/man/DEBC/1/markdown)                                General Commands Manual                               [DEBC(1)](https://www.chedong.com/phpMan.php/man/DEBC/1/markdown)



## NAME
       debc - view contents of a generated Debian package

## SYNOPSIS
       **debc** [_options_] [_changes_ _file_] [_package_ ...]

## DESCRIPTION
       **debc** figures out the current version of a package and displays information about the _.deb_ and
       _.udeb_ files which have been generated in the current build process.  If a  _.changes_  file  is
       specified  on  the command line, the filename must end with _.changes_, as this is how the pro‐
       gram distinguishes it from package names.  If not, then **debc** has to be called from within the
       source  code  directory tree.  In this case, it will look for the _.changes_ file corresponding
       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)](https://www.chedong.com/phpMan.php/man/dpkg-buildpackage/1/markdown) does).  It then runs
       **dpkg-deb** **-I** and **dpkg-deb** **-c** on every _.deb_ and _.udeb_ archive listed in the  _.changes_  file  to
       display  information about the contents of the _.deb_ / _.udeb_ files.  It precedes every _.deb_ or
       _.udeb_ file with the name of the file.  It assumes that all of the _.deb_ / _.udeb_ archives  live
       in  the  same  directory  as  the _.changes_ file.  It is useful for ensuring that the expected
       files have ended up in the Debian package.

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

### Directory name checking
       In common with several other scripts in the **devscripts** package, **debc** will climb the directory
       tree until it finds a _debian/changelog_ file.  As a safeguard against stray files causing  po‐
       tential  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.  Pre‐
       cisely   how   it   does   this  is  controlled  by  two  configuration  file  variables  **DE**‐‐
       **VSCRIPTS**___**CHECK**___**DIRNAME**___**LEVEL** and **DEVSCRIPTS**___**CHECK**___**DIRNAME**___**REGEX**, and their corresponding com‐
       mand-line options **--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 _de__‐
              _bian/changelog_.  This is the default behaviour.

       **2**      Always check the directory name.

       The directory name is checked by testing whether the current directory name (as determined by
       [**pwd**(1)](https://www.chedong.com/phpMan.php/man/pwd/1/markdown))    matches    the    regex    given    by   the   configuration   file   option   **DE**‐‐
       **VSCRIPTS**___**CHECK**___**DIRNAME**___**REGEX** or by the command line option **--check-dirname-regex** _regex_.  Here
       _regex_  is  a  Perl regex (see [**perlre**(3perl)](https://www.chedong.com/phpMan.php/man/perlre/3perl/markdown)), 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 re‐
       placed 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-ver‐
       sion.

## OPTIONS
### -a -t
              See [**dpkg-architecture**(1)](https://www.chedong.com/phpMan.php/man/dpkg-architecture/1/markdown) 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_, _.deb_ and _.udeb_ files in _directory_ instead of the parent of  the
              source  directory.   This  should either be an absolute path or relative to the top of
              the source directory.

       **--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.

### --list-changes
              List the filename of the .changes file, and do not display anything else. This  option
              only makes sense if a .changes file is NOT passed explicitly in the command line. This
              can be used for example in a script that needs to reference the .changes file, without
              having to duplicate the heuristics for finding it that debc already implements.

### --list-debs
              List the filenames of the .deb packages, and do not display their contents.

       **--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 options can be used to override configuration
       file settings.  Environment variable settings are ignored for this  purpose.   The  currently
       recognised variables are:

       **DEBRELEASE**___**DEBS**___**DIR**
              This  specifies the directory in which to look for the _.changes_, _.deb_ and _.udeb_ files,
              and is either an absolute path or relative to the top of the source tree.  This corre‐
              sponds to the **--debs-dir** command line option.  This directive could be used, for exam‐
              ple, if you always use **pbuilder** or **svn-buildpackage** to build your packages.  Note that
              it also affects [**debrelease**(1)](https://www.chedong.com/phpMan.php/man/debrelease/1/markdown) 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 configuration variables, and  will  therefore  affect
              all  **devscripts** scripts which check their value, as described in their respective man‐
              pages and in [**devscripts.conf**(5)](https://www.chedong.com/phpMan.php/man/devscripts.conf/5/markdown).

## SEE ALSO
       [**debdiff**(1)](https://www.chedong.com/phpMan.php/man/debdiff/1/markdown), [**dpkg-deb**(1)](https://www.chedong.com/phpMan.php/man/dpkg-deb/1/markdown), [**devscripts.conf**(5)](https://www.chedong.com/phpMan.php/man/devscripts.conf/5/markdown)

## AUTHOR
       Julian Gilbey <<jdg@debian.org>>, based on an original  script  by  Christoph  Lameter  <clame‐
       <ter@debian.org>>.



DEBIAN                                    Debian Utilities                                   [DEBC(1)](https://www.chedong.com/phpMan.php/man/DEBC/1/markdown)
