Scroll to navigation

DEBGET(1p) User Contributed Perl Documentation DEBGET(1p)

NAME

debget - download source and binary Debian packages

SYNOPSIS

debget [switch]... { package | section/package | file.dsc | file.deb }...

DESCRIPTION

debget downloads source and binary Debian packages by name and optionally unpacks, compiles and installs them. The default behavior is to download the source for packages, to unpack and build *.dsc files and to install *.deb files. For detailed defaults on FTP server names and such run "debget --help".

debget doesn't require a local copy of the Packages files, instead it lists directories on the FTP site to find out what versions are available.

Non-switch arguments are *.dsc files, *.deb files, and package names or section/package, eg base/dpkg or non-free/games/quake2. There are two cases in which you've got to specify the section:

  • Information about the package isn't in the local available file (as shown by "dpkg --print-avail"), or the information there is wrong.
  • You're downloading a source package which doesn't generate a binary package of the same name. Normally debget infers the correct source package to download based on the "dpkg --print-avail" output. (Eg, if you say to download the source for perl-base, it will really download the perl sources.) This isn't possible if the source package doesn't have an available file entry (which is the case when the source package doesn't generate a binary package of the same name). In this case debget will use the section for the package which you specified (perl-base in this case). If the section for that package isn't available, or if it's not the same as the section for the source package, you have to specify the section yourself.

To handle either of these cases, specify the package with the section prepended, as it would appear in the available file. Eg, base/dpkg or non-free/games/quake2.

OPTIONS

Specify the installation architecture (used to find binary packages). The default is the output of "dpkg --print-architecture".
Download binary packages. The default is not to download them.
Don't download binary packages. This is the default.
Build downloaded source packages. This implies --unpack. --build is turned off by default, but it is turned on if you specify any *.dsc or *.deb files on the command line.
Turn debugging on. Specify multiple times for more detail.
Specify the path to the top of the Debian hierarchy on the primary FTP server.
Specify the distribution from which to download packages. The default is unstable. You can use the name of any subdirectory in the dists directory in the Debian archive, or experimental (which is special-cased).
Show the usage message and die.
Specify the host name of the primary FTP server.
Install binary packages. This turns on --unpack and --build, so specifying it will cause debget to install just about everything you mention on the command line. Packages will be downloaded, unpacked, built, and installed, *.dsc files will be unpacked, built, and installed, and *.deb files will be installed.
Go through the motions, but don't actually download any packages.
Don't process either /etc/debget.rc or ~/.debget.rc.
Don't download files whose name match the Perl regexp re. This option can be specified multiple times.
Don't download *.tar.gz files. This is normally used when downloading sources, when specified you'll just fetch the *.diff.gz and *.dsc files.
Don't run dscverify before unpacking sources. dscverify checks that the .dsc file is signed by a Debian developer and that the MD5 sums and file sizes given in it match the files about to be unpacked. These are good things, so debget will try to run dscverify by default. The dscverify program is in the devscripts package.
Don't process ~/.debget.rc.
Specify the path to the top of the Debian hierarchy for non-US packages.
Specify the host name of the non-US FTP server.
Use cmd to become root when building a package from source. The default is the first of fakeroot, sudo, super, or su which is present on the system.
Use cmd to become root when installing a package. The default is what you gave for --root-build if you specified anything, otherwise the first of sudo, super, or su which is present on the system.
Download source packages. This is the default.
Don't download source packages. The default is to download them.
Unpack downloaded source packages.
Be verbose.
Print the version number and exit.

CONFIGURATION FILES

The default behavior of debget can be modified by the configuration files /etc/debget.rc and ~/.debget.rc (unless modified by the -f or -F switches). These files are processed as Perl code. They can set these variables to control the program (with their corresponding switches):

$O{'arch'}
--arch
$O{'binary'}
--binary, boolean
"{$O{'build'}"
--build, boolean
$O{'debug'}
--debug, integer
$O{'dir'}
--dir
$O{'dist'}
--dist
$O{'host'}
--host
$O{'install'}
--install, boolean
$O{'no'}
--no, boolean
$O{'no-config'}
--no-config, boolean
$O{'no-download-re'}
--no-download-re, array reference
$O{'no-download-tar'}
--no-download-tar, boolean
$O{'no-dscverify'}
--no-dscverify, boolean
$O{'no-user-config'}
--no-user-config, boolean
$O{'non-us-dir'}
--non-us-dir
$O{'non-us-host'}
--non-us-host
$O{'root-build'}
--root-build
$O{'root-install'}
--root-install
$O{'source'}
--source, boolean
$O{'unpack'}
--unpack, boolean
$O{'verbose'}
--verbose, boolean

Here's an example configuration file:

    $O{'host'} = 'debian.terrabox.com';
    $O{'verbose'} = 1;

BUGS

If you specify --install all produced binary packages will be installed, even ones you didn't specify on the command line. Eg, if you run "debget --install ssh" it will install both ssh and ssh-askpass.

I'd like to add a --clean switch which will make the program remove intermediate files.

See /usr/share/doc/debget/README.Debian if your transfers are failing because you need to use passive FTP or a proxy.

SEE ALSO

dselect(8), apt-get(8)

AVAILABILITY

The code is licensed under the GNU GPL and distributed as part of Debian.

AUTHOR

Roderick Schertler <roderick@argon.org>

2022-11-10 perl v5.36.0