diff options
author | Michael Vogt <mvo@debian.org> | 2014-04-11 14:40:08 +0200 |
---|---|---|
committer | Michael Vogt <mvo@debian.org> | 2014-04-11 14:40:08 +0200 |
commit | 23fc5ecaa01bc41d582640dd5950be73987a8b4b (patch) | |
tree | df6884ffed553a9e501560d8c3129f7acff89de6 /apt-private | |
parent | 473ccfb9454e2707c2145ec49e671b78dc775e0c (diff) | |
parent | d6570f8577a955a6950ef9fe1ee9def401759336 (diff) |
Merge remote-tracking branch 'mvo/feature/helpful-apt-list' into debian/sid
Conflicts:
test/integration/test-apt-cli-list
Diffstat (limited to 'apt-private')
-rw-r--r-- | apt-private/private-list.cc | 15 |
1 files changed, 14 insertions, 1 deletions
diff --git a/apt-private/private-list.cc b/apt-private/private-list.cc index b053cbcbe..b69002103 100644 --- a/apt-private/private-list.cc +++ b/apt-private/private-list.cc @@ -130,10 +130,11 @@ bool DoList(CommandLine &Cmd) Cache->Head().PackageCount, _("Listing")); GetLocalitySortedVersionSet(CacheFile, bag, matcher, progress); + bool ShowAllVersions = _config->FindB("APT::Cmd::All-Versions", false); for (LocalitySortedVersionSet::iterator V = bag.begin(); V != bag.end(); ++V) { std::stringstream outs; - if(_config->FindB("APT::Cmd::All-Versions", false) == true) + if(ShowAllVersions == true) { ListAllVersions(CacheFile, records, V.ParentPkg(), outs, includeSummary); output_map.insert(std::make_pair<std::string, std::string>( @@ -151,6 +152,18 @@ bool DoList(CommandLine &Cmd) std::cout << (*K).second << std::endl; + // be nice and tell the user if there is more to see + if (bag.size() == 1 && ShowAllVersions == false) + { + // start with -1 as we already displayed one version + int versions = -1; + pkgCache::VerIterator Ver = *bag.begin(); + for ( ; Ver.end() == false; Ver++) + versions++; + if (versions > 0) + _error->Notice(P_("There is %i additional version. Please use the '-a' switch to see it", "There are %i additional versions. Please use the '-a' switch to see them.", versions), versions); + } + return true; } |