One solution would be to set up your personal APT repository and install the package with APT from there.
Another possibility is to extract the dependencies from the package description. This script pulls the Recommends:
line from the description in the .deb
file and removes versions and keeps only the first alternative when there are several.
apt-get install $(dpkg-deb -I foo.deb |
sed -n 's/^ *\(Depends\|Recommends\)://p' |
tr , $'\n' |
sed 's/[|(].*//')
With aptitude, you can install the set of packages matched by a pattern. If there are alternatives, install the one you want first.
aptitude install '?reverse-recommends(foo)'
From the aptitude full-screen interface, highlight the package, press Enter, navigate to “Recommends” and press + then g.
Actually gdebi
is just a front-end to the dpkg
with added functionality that it can check for dependency packages in the repositories and can install them in one-operation, while dpkg -i
requires two operations manually (later being apt-get -f install
).
Question 1:
1) How gdebi do this? install .deb Packages with Dependencies without using Apt PPA links added manually in configuration files?
Being a dpkg
front-end, it can use all of the functionality of dpkg
. Since every .deb
package file contains (provided that they are not corrupt) metadata about that deb file (like package name, maintainer, dependencies etc), it can easily check this file's dependency.
For example, you can check a .deb file's metadata using dpkg --info package-name.deb
And then it uses these information to construct dependency map and mark the locally available .deb files as already downloaded and download other .deb
files from Internet.
Take note that, those needed extra packages must be available (with proper version) in at least one of the repositories, which are configured in the system.
Then it proceed to like a normal apt installation. The difference is it doesn't re-download the main .deb file
Question 2:
(2) Can I use same gdebi command ( sudo su -c gdebi my.deb
)to install all other deb packages without adding a PPA? or do I have to change format sudo su -c myn.deb
where n is version of software etc?
The PPAs exists for a reason. The main reason is they provide latest versions of packages . And these higher versioned package usually depends on higher versions of sub-packages also, which are also normally served from the PPA, not from standard Ubuntu repository.
Example Scenario:
Suppose, A package named mother-package has the highest version of 2.0
in Standard Ubuntu repositories, and this mother-package depends on a package named child-package of version 2. Also suppose, some PPA provides mother-package of version 3.0
which requires on child-package
of 3.0
, both of them are available via that PPA repository.
The problem is, if you now download mother-package-3.0.deb from the repository page and try to install it with gdebi
, you'll (or gdebi
) fail.
Because, checking the mother-package-3.0.deb file, gdebi
knew that this mother-package needs child-package of version 3.0
or higher, but It only knows the location of version 2.0
. It doesn't know where to fetch the version 3.0
of child-package from. This is expected because, You didn't tell the system where you get this latest mother-package. In other words, You didn't configured the repository list to include that PPA.
So, the Obvious answer is of this question is It depends. If the necessary dependencies can be found in already configured repositories, the installation will be successful. But if not, then it'll fail to install this highered versioned package. That's why you still need PPAs and that is the easiest way without manually doing all these.
The second part of the second question didn't make sense to me.
Best Answer
The
-o
option ofgdebi
is not meant to pass command-line options toapt-get
, but configuration options. Thus, to install recommended packages, you should use:Since,
man apt-get
says:From How to not install recommended and suggested packages?,
And comment #7 on this Launchpad question says: