1 // -*- mode: cpp; mode: fold -*- 
   4    Wrappers around std::set to have set::iterators which behave 
   5    similar to the Iterators of the cache structures. 
   7    Provides also a few helper methods which work with these sets */ 
  10 #define APT_CACHESET_H 
  11 // Include Files                                                        /*{{{*/ 
  21 #include <apt-pkg/error.h> 
  22 #include <apt-pkg/pkgcache.h> 
  24 #ifndef APT_8_CLEANER_HEADERS 
  25 #include <apt-pkg/cachefile.h> 
  32 class PackageContainerInterface
; 
  33 class VersionContainerInterface
; 
  35 class CacheSetHelper 
{                                                  /*{{{*/ 
  36 /** \class APT::CacheSetHelper 
  37     Simple base class with a lot of virtual methods which can be overridden 
  38     to alter the behavior or the output of the CacheSets. 
  40     This helper is passed around by the static methods in the CacheSets and 
  41     used every time they hit an error condition or something could be 
  45         CacheSetHelper(bool const ShowError 
= true, 
  46                 GlobalError::MsgType ErrorType 
= GlobalError::ERROR
) : 
  47                         ShowError(ShowError
), ErrorType(ErrorType
) {}; 
  48         virtual ~CacheSetHelper() {}; 
  50         virtual void showTaskSelection(pkgCache::PkgIterator 
const &pkg
, std::string 
const &pattern
); 
  51         virtual void showRegExSelection(pkgCache::PkgIterator 
const &pkg
, std::string 
const &pattern
); 
  52         virtual void showSelectedVersion(pkgCache::PkgIterator 
const &Pkg
, pkgCache::VerIterator 
const Ver
, 
  53                                  std::string 
const &ver
, bool const verIsRel
); 
  55         virtual void canNotFindTask(PackageContainerInterface 
* const pci
, pkgCacheFile 
&Cache
, std::string pattern
); 
  56         virtual void canNotFindRegEx(PackageContainerInterface 
* const pci
, pkgCacheFile 
&Cache
, std::string pattern
); 
  57         virtual void canNotFindPackage(PackageContainerInterface 
* const pci
, pkgCacheFile 
&Cache
, std::string 
const &str
); 
  59         virtual void canNotFindAllVer(VersionContainerInterface 
* const vci
, pkgCacheFile 
&Cache
, pkgCache::PkgIterator 
const &Pkg
); 
  60         virtual void canNotFindInstCandVer(VersionContainerInterface 
* const vci
, pkgCacheFile 
&Cache
, 
  61                                 pkgCache::PkgIterator 
const &Pkg
); 
  62         virtual void canNotFindCandInstVer(VersionContainerInterface 
* const vci
, 
  64                                 pkgCache::PkgIterator 
const &Pkg
); 
  66         virtual pkgCache::PkgIterator 
canNotFindPkgName(pkgCacheFile 
&Cache
, std::string 
const &str
); 
  67         virtual pkgCache::VerIterator 
canNotFindNewestVer(pkgCacheFile 
&Cache
, 
  68                                 pkgCache::PkgIterator 
const &Pkg
); 
  69         virtual pkgCache::VerIterator 
canNotFindCandidateVer(pkgCacheFile 
&Cache
, 
  70                                 pkgCache::PkgIterator 
const &Pkg
); 
  71         virtual pkgCache::VerIterator 
canNotFindInstalledVer(pkgCacheFile 
&Cache
, 
  72                                 pkgCache::PkgIterator 
const &Pkg
); 
  74         bool showErrors() const { return ShowError
; }; 
  75         bool showErrors(bool const newValue
) { if (ShowError 
== newValue
) return ShowError
; else return ((ShowError 
= newValue
) == false); }; 
  76         GlobalError::MsgType 
errorType() const { return ErrorType
; }; 
  77         GlobalError::MsgType 
errorType(GlobalError::MsgType 
const &newValue
) 
  79                 if (ErrorType 
== newValue
) return ErrorType
; 
  81                         GlobalError::MsgType 
const &oldValue 
= ErrorType
; 
  90         GlobalError::MsgType ErrorType
; 
  92 class PackageContainerInterface 
{                                       /*{{{*/ 
  93 /** \class PackageContainerInterface 
  95  * Interface ensuring that all operations can be executed on the yet to 
  96  * define concrete PackageContainer - access to all methods is possible, 
  97  * but in general the wrappers provided by the PackageContainer template 
 100  * This class mostly protects use from the need to write all implementation 
 101  * of the methods working on containers in the template */ 
 103         class const_iterator 
{                                          /*{{{*/ 
 105                 virtual pkgCache::PkgIterator 
getPkg() const = 0; 
 106                 operator pkgCache::PkgIterator(void) const { return getPkg(); } 
 108                 inline const char *Name() const {return getPkg().Name(); } 
 109                 inline std::string 
FullName(bool const Pretty
) const { return getPkg().FullName(Pretty
); } 
 110                 inline std::string 
FullName() const { return getPkg().FullName(); } 
 111                 inline const char *Section() const {return getPkg().Section(); } 
 112                 inline bool Purge() const {return getPkg().Purge(); } 
 113                 inline const char *Arch() const {return getPkg().Arch(); } 
 114                 inline pkgCache::GrpIterator 
Group() const { return getPkg().Group(); } 
 115                 inline pkgCache::VerIterator 
VersionList() const { return getPkg().VersionList(); } 
 116                 inline pkgCache::VerIterator 
CurrentVer() const { return getPkg().CurrentVer(); } 
 117                 inline pkgCache::DepIterator 
RevDependsList() const { return getPkg().RevDependsList(); } 
 118                 inline pkgCache::PrvIterator 
ProvidesList() const { return getPkg().ProvidesList(); } 
 119                 inline pkgCache::PkgIterator::OkState 
State() const { return getPkg().State(); } 
 120                 inline const char *CandVersion() const { return getPkg().CandVersion(); } 
 121                 inline const char *CurVersion() const { return getPkg().CurVersion(); } 
 122                 inline pkgCache 
*Cache() const { return getPkg().Cache(); }; 
 123                 inline unsigned long Index() const {return getPkg().Index();}; 
 124                 // we have only valid iterators here 
 125                 inline bool end() const { return false; }; 
 127                 inline pkgCache::Package 
const * operator->() const {return &*getPkg();}; 
 131         virtual bool insert(pkgCache::PkgIterator 
const &P
) = 0; 
 132         virtual bool empty() const = 0; 
 133         virtual void clear() = 0; 
 135         enum Constructor 
{ UNKNOWN
, REGEX
, TASK 
}; 
 136         virtual void setConstructor(Constructor 
const &con
) = 0; 
 137         virtual Constructor 
getConstructor() const = 0; 
 139         static bool FromTask(PackageContainerInterface 
* const pci
, pkgCacheFile 
&Cache
, std::string pattern
, CacheSetHelper 
&helper
); 
 140         static bool FromRegEx(PackageContainerInterface 
* const pci
, pkgCacheFile 
&Cache
, std::string pattern
, CacheSetHelper 
&helper
); 
 141         static pkgCache::PkgIterator 
FromName(pkgCacheFile 
&Cache
, std::string 
const &pattern
, CacheSetHelper 
&helper
); 
 142         static bool FromString(PackageContainerInterface 
* const pci
, pkgCacheFile 
&Cache
, std::string 
const &pattern
, CacheSetHelper 
&helper
); 
 143         static bool FromCommandLine(PackageContainerInterface 
* const pci
, pkgCacheFile 
&Cache
, const char **cmdline
, CacheSetHelper 
&helper
); 
 146                 enum Position 
{ NONE
, PREFIX
, POSTFIX 
}; 
 148                 const char * const Alias
; 
 150                 Modifier (unsigned short const &id
, const char * const alias
, Position 
const &pos
) : ID(id
), Alias(alias
), Pos(pos
) {}; 
 153         static bool FromModifierCommandLine(unsigned short &modID
, PackageContainerInterface 
* const pci
, 
 154                                             pkgCacheFile 
&Cache
, const char * cmdline
, 
 155                                             std::list
<Modifier
> const &mods
, CacheSetHelper 
&helper
); 
 158 template<class Container
> class PackageContainer 
: public PackageContainerInterface 
{/*{{{*/ 
 159 /** \class APT::PackageContainer 
 161     Simple wrapper around a container class like std::set to provide a similar 
 162     interface to a set of packages as to the complete set of all packages in the 
 166         /** \brief smell like a pkgCache::PkgIterator */ 
 167         class const_iterator 
: public PackageContainerInterface::const_iterator
,/*{{{*/ 
 168                                public std::iterator
<std::forward_iterator_tag
, typename 
Container::const_iterator
> { 
 169                 typename 
Container::const_iterator _iter
; 
 171                 const_iterator(typename 
Container::const_iterator i
) : _iter(i
) {} 
 172                 pkgCache::PkgIterator 
getPkg(void) const { return *_iter
; } 
 173                 inline pkgCache::PkgIterator 
operator*(void) const { return *_iter
; }; 
 174                 operator typename 
Container::const_iterator(void) const { return _iter
; } 
 175                 inline const_iterator
& operator++() { ++_iter
; return *this; } 
 176                 inline const_iterator 
operator++(int) { const_iterator 
tmp(*this); operator++(); return tmp
; } 
 177                 inline bool operator!=(const_iterator 
const &i
) const { return _iter 
!= i
._iter
; }; 
 178                 inline bool operator==(const_iterator 
const &i
) const { return _iter 
== i
._iter
; }; 
 179                 friend std::ostream
& operator<<(std::ostream
& out
, const_iterator i
) { return operator<<(out
, *i
); } 
 181         class iterator 
: public PackageContainerInterface::const_iterator
, 
 182                          public std::iterator
<std::forward_iterator_tag
, typename 
Container::iterator
> { 
 183                 typename 
Container::iterator _iter
; 
 185                 iterator(typename 
Container::iterator i
) : _iter(i
) {} 
 186                 pkgCache::PkgIterator 
getPkg(void) const { return *_iter
; } 
 187                 inline pkgCache::PkgIterator 
operator*(void) const { return *_iter
; }; 
 188                 operator typename 
Container::iterator(void) const { return _iter
; } 
 189                 operator typename PackageContainer
<Container
>::const_iterator() { return PackageContainer
<Container
>::const_iterator(_iter
); } 
 190                 inline iterator
& operator++() { ++_iter
; return *this; } 
 191                 inline iterator 
operator++(int) { iterator 
tmp(*this); operator++(); return tmp
; } 
 192                 inline bool operator!=(iterator 
const &i
) const { return _iter 
!= i
._iter
; }; 
 193                 inline bool operator==(iterator 
const &i
) const { return _iter 
== i
._iter
; }; 
 194                 friend std::ostream
& operator<<(std::ostream
& out
, iterator i
) { return operator<<(out
, *i
); } 
 198         bool insert(pkgCache::PkgIterator 
const &P
) { if (P
.end() == true) return false; _cont
.insert(P
); return true; }; 
 199         template<class Cont
> void insert(PackageContainer
<Cont
> const &pkgcont
) { _cont
.insert((typename 
Cont::const_iterator
)pkgcont
.begin(), (typename 
Cont::const_iterator
)pkgcont
.end()); }; 
 200         void insert(const_iterator begin
, const_iterator end
) { _cont
.insert(begin
, end
); }; 
 202         bool empty() const { return _cont
.empty(); }; 
 203         void clear() { return _cont
.clear(); }; 
 204         void erase(iterator position
) { _cont
.erase((typename 
Container::iterator
)position
); }; 
 205         size_t erase(const pkgCache::PkgIterator x
) { return _cont
.erase(x
); }; 
 206         void erase(iterator first
, iterator last
) { _cont
.erase(first
, last
); }; 
 207         size_t size() const { return _cont
.size(); }; 
 209         const_iterator 
begin() const { return const_iterator(_cont
.begin()); }; 
 210         const_iterator 
end() const { return const_iterator(_cont
.end()); }; 
 211         iterator 
begin() { return iterator(_cont
.begin()); }; 
 212         iterator 
end() { return iterator(_cont
.end()); }; 
 213         const_iterator 
find(pkgCache::PkgIterator 
const &P
) const { return const_iterator(_cont
.find(P
)); }; 
 215         void setConstructor(Constructor 
const &by
) { ConstructedBy 
= by
; }; 
 216         Constructor 
getConstructor() const { return ConstructedBy
; }; 
 218         PackageContainer() : ConstructedBy(UNKNOWN
) {}; 
 219         PackageContainer(Constructor 
const &by
) : ConstructedBy(by
) {}; 
 221         /** \brief returns all packages in the cache who belong to the given task 
 223             A simple helper responsible for search for all members of a task 
 224             in the cache. Optional it prints a a notice about the 
 225             packages chosen cause of the given task. 
 226             \param Cache the packages are in 
 227             \param pattern name of the task 
 228             \param helper responsible for error and message handling */ 
 229         static PackageContainer 
FromTask(pkgCacheFile 
&Cache
, std::string 
const &pattern
, CacheSetHelper 
&helper
) { 
 230                 PackageContainer 
cont(TASK
); 
 231                 PackageContainerInterface::FromTask(&cont
, Cache
, pattern
, helper
); 
 234         static PackageContainer 
FromTask(pkgCacheFile 
&Cache
, std::string 
const &pattern
) { 
 235                 CacheSetHelper helper
; 
 236                 return FromTask(Cache
, pattern
, helper
); 
 239         /** \brief returns all packages in the cache whose name matchs a given pattern 
 241             A simple helper responsible for executing a regular expression on all 
 242             package names in the cache. Optional it prints a a notice about the 
 243             packages chosen cause of the given package. 
 244             \param Cache the packages are in 
 245             \param pattern regular expression for package names 
 246             \param helper responsible for error and message handling */ 
 247         static PackageContainer 
FromRegEx(pkgCacheFile 
&Cache
, std::string pattern
, CacheSetHelper 
&helper
) { 
 248                 PackageContainer 
cont(REGEX
); 
 249                 PackageContainerInterface::FromRegEx(&cont
, Cache
, pattern
, helper
); 
 253         static PackageContainer 
FromRegEx(pkgCacheFile 
&Cache
, std::string 
const &pattern
) { 
 254                 CacheSetHelper helper
; 
 255                 return FromRegEx(Cache
, pattern
, helper
); 
 258         /** \brief returns a package specified by a string 
 260             \param Cache the package is in 
 261             \param pattern String the package name should be extracted from 
 262             \param helper responsible for error and message handling */ 
 263         static pkgCache::PkgIterator 
FromName(pkgCacheFile 
&Cache
, std::string 
const &pattern
, CacheSetHelper 
&helper
) { 
 264                 return PackageContainerInterface::FromName(Cache
, pattern
, helper
); 
 266         static pkgCache::PkgIterator 
FromName(pkgCacheFile 
&Cache
, std::string 
const &pattern
) { 
 267                 CacheSetHelper helper
; 
 268                 return PackageContainerInterface::FromName(Cache
, pattern
, helper
); 
 271         /** \brief returns all packages specified by a string 
 273             \param Cache the packages are in 
 274             \param pattern String the package name(s) should be extracted from 
 275             \param helper responsible for error and message handling */ 
 276         static PackageContainer 
FromString(pkgCacheFile 
&Cache
, std::string 
const &pattern
, CacheSetHelper 
&helper
) { 
 277                 PackageContainer cont
; 
 278                 PackageContainerInterface::FromString(&cont
, Cache
, pattern
, helper
); 
 281         static PackageContainer 
FromString(pkgCacheFile 
&Cache
, std::string 
const &pattern
) { 
 282                 CacheSetHelper helper
; 
 283                 return FromString(Cache
, pattern
, helper
); 
 286         /** \brief returns all packages specified on the commandline 
 288             Get all package names from the commandline and executes regex's if needed. 
 289             No special package command is supported, just plain names. 
 290             \param Cache the packages are in 
 291             \param cmdline Command line the package names should be extracted from 
 292             \param helper responsible for error and message handling */ 
 293         static PackageContainer 
FromCommandLine(pkgCacheFile 
&Cache
, const char **cmdline
, CacheSetHelper 
&helper
) { 
 294                 PackageContainer cont
; 
 295                 PackageContainerInterface::FromCommandLine(&cont
, Cache
, cmdline
, helper
); 
 298         static PackageContainer 
FromCommandLine(pkgCacheFile 
&Cache
, const char **cmdline
) { 
 299                 CacheSetHelper helper
; 
 300                 return FromCommandLine(Cache
, cmdline
, helper
); 
 303         /** \brief group packages by a action modifiers 
 305             At some point it is needed to get from the same commandline 
 306             different package sets grouped by a modifier. Take 
 307                 apt-get install apt awesome- 
 309             \param Cache the packages are in 
 310             \param cmdline Command line the package names should be extracted from 
 311             \param mods list of modifiers the method should accept 
 312             \param fallback the default modifier group for a package 
 313             \param helper responsible for error and message handling */ 
 314         static std::map
<unsigned short, PackageContainer
> GroupedFromCommandLine( 
 316                                                                                  const char **cmdline
, 
 317                                                                                  std::list
<Modifier
> const &mods
, 
 318                                                                                  unsigned short const &fallback
, 
 319                                                                                  CacheSetHelper 
&helper
) { 
 320                 std::map
<unsigned short, PackageContainer
> pkgsets
; 
 321                 for (const char **I 
= cmdline
; *I 
!= 0; ++I
) { 
 322                         unsigned short modID 
= fallback
; 
 323                         PackageContainer pkgset
; 
 324                         PackageContainerInterface::FromModifierCommandLine(modID
, &pkgset
, Cache
, *I
, mods
, helper
); 
 325                         pkgsets
[modID
].insert(pkgset
); 
 329         static std::map
<unsigned short, PackageContainer
> GroupedFromCommandLine( 
 331                                                                                  const char **cmdline
, 
 332                                                                                  std::list
<Modifier
> const &mods
, 
 333                                                                                  unsigned short const &fallback
) { 
 334                 CacheSetHelper helper
; 
 335                 return GroupedFromCommandLine(Cache
, cmdline
, 
 336                                 mods
, fallback
, helper
); 
 340         Constructor ConstructedBy
; 
 344 template<> template<class Cont
> void PackageContainer
<std::list
<pkgCache::PkgIterator
> >::insert(PackageContainer
<Cont
> const &pkgcont
) { 
 345         for (typename PackageContainer
<Cont
>::const_iterator p 
= pkgcont
.begin(); p 
!= pkgcont
.end(); ++p
) 
 348 // these two are 'inline' as otherwise the linker has problems with seeing these untemplated 
 349 // specializations again and again - but we need to see them, so that library users can use them 
 350 template<> inline bool PackageContainer
<std::list
<pkgCache::PkgIterator
> >::insert(pkgCache::PkgIterator 
const &P
) { 
 356 template<> inline void PackageContainer
<std::list
<pkgCache::PkgIterator
> >::insert(const_iterator begin
, const_iterator end
) { 
 357         for (const_iterator p 
= begin
; p 
!= end
; ++p
) 
 360 typedef PackageContainer
<std::set
<pkgCache::PkgIterator
> > PackageSet
; 
 361 typedef PackageContainer
<std::list
<pkgCache::PkgIterator
> > PackageList
; 
 363 class VersionContainerInterface 
{                                       /*{{{*/ 
 364 /** \class APT::VersionContainerInterface 
 366     Same as APT::PackageContainerInterface, just for Versions */ 
 368         /** \brief smell like a pkgCache::VerIterator */ 
 369         class const_iterator 
{                                          /*{{{*/ 
 371                 virtual pkgCache::VerIterator 
getVer() const = 0; 
 372                 operator pkgCache::VerIterator(void) { return getVer(); } 
 374                 inline pkgCache 
*Cache() const { return getVer().Cache(); }; 
 375                 inline unsigned long Index() const {return getVer().Index();}; 
 376                 inline int CompareVer(const pkgCache::VerIterator 
&B
) const { return getVer().CompareVer(B
); }; 
 377                 inline const char *VerStr() const { return getVer().VerStr(); }; 
 378                 inline const char *Section() const { return getVer().Section(); }; 
 379                 inline const char *Arch() const { return getVer().Arch(); }; 
 380                 inline pkgCache::PkgIterator 
ParentPkg() const { return getVer().ParentPkg(); }; 
 381                 inline pkgCache::DescIterator 
DescriptionList() const { return getVer().DescriptionList(); }; 
 382                 inline pkgCache::DescIterator 
TranslatedDescription() const { return getVer().TranslatedDescription(); }; 
 383                 inline pkgCache::DepIterator 
DependsList() const { return getVer().DependsList(); }; 
 384                 inline pkgCache::PrvIterator 
ProvidesList() const { return getVer().ProvidesList(); }; 
 385                 inline pkgCache::VerFileIterator 
FileList() const { return getVer().FileList(); }; 
 386                 inline bool Downloadable() const { return getVer().Downloadable(); }; 
 387                 inline const char *PriorityType() const { return getVer().PriorityType(); }; 
 388                 inline std::string 
RelStr() const { return getVer().RelStr(); }; 
 389                 inline bool Automatic() const { return getVer().Automatic(); }; 
 390                 inline pkgCache::VerFileIterator 
NewestFile() const { return getVer().NewestFile(); }; 
 391                 // we have only valid iterators here 
 392                 inline bool end() const { return false; }; 
 394                 inline pkgCache::Version 
const * operator->() const { return &*getVer(); }; 
 398         virtual bool insert(pkgCache::VerIterator 
const &V
) = 0; 
 399         virtual bool empty() const = 0; 
 400         virtual void clear() = 0; 
 402         /** \brief specifies which version(s) will be returned if non is given */ 
 406                 /** Candidate and installed version */ 
 408                 /** Candidate version */ 
 410                 /** Installed version */ 
 412                 /** Candidate or if non installed version */ 
 414                 /** Installed or if non candidate version */ 
 416                 /** Newest version */ 
 421                 enum Position 
{ NONE
, PREFIX
, POSTFIX 
}; 
 423                 const char * const Alias
; 
 425                 Version SelectVersion
; 
 426                 Modifier (unsigned short const &id
, const char * const alias
, Position 
const &pos
, 
 427                           Version 
const &select
) : ID(id
), Alias(alias
), Pos(pos
), 
 428                          SelectVersion(select
) {}; 
 431         static bool FromCommandLine(VersionContainerInterface 
* const vci
, pkgCacheFile 
&Cache
, 
 432                                     const char **cmdline
, Version 
const &fallback
, 
 433                                     CacheSetHelper 
&helper
); 
 435         static bool FromString(VersionContainerInterface 
* const vci
, pkgCacheFile 
&Cache
, 
 436                                std::string pkg
, Version 
const &fallback
, CacheSetHelper 
&helper
, 
 437                                bool const onlyFromName 
= false); 
 439         static bool FromPackage(VersionContainerInterface 
* const vci
, pkgCacheFile 
&Cache
, 
 440                                 pkgCache::PkgIterator 
const &P
, Version 
const &fallback
, 
 441                                 CacheSetHelper 
&helper
); 
 443         static bool FromModifierCommandLine(unsigned short &modID
, 
 444                                             VersionContainerInterface 
* const vci
, 
 445                                             pkgCacheFile 
&Cache
, const char * cmdline
, 
 446                                             std::list
<Modifier
> const &mods
, 
 447                                             CacheSetHelper 
&helper
); 
 450         static bool FromDependency(VersionContainerInterface 
* const vci
, 
 452                                    pkgCache::DepIterator 
const &D
, 
 453                                    Version 
const &selector
, 
 454                                    CacheSetHelper 
&helper
); 
 458         /** \brief returns the candidate version of the package 
 460             \param Cache to be used to query for information 
 461             \param Pkg we want the candidate version from this package */ 
 462         static pkgCache::VerIterator 
getCandidateVer(pkgCacheFile 
&Cache
, 
 463                 pkgCache::PkgIterator 
const &Pkg
, CacheSetHelper 
&helper
); 
 465         /** \brief returns the installed version of the package 
 467             \param Cache to be used to query for information 
 468             \param Pkg we want the installed version from this package */ 
 469         static pkgCache::VerIterator 
getInstalledVer(pkgCacheFile 
&Cache
, 
 470                 pkgCache::PkgIterator 
const &Pkg
, CacheSetHelper 
&helper
); 
 474 template<class Container
> class VersionContainer 
: public VersionContainerInterface 
{/*{{{*/ 
 475 /** \class APT::VersionContainer 
 477     Simple wrapper around a container class like std::set to provide a similar 
 478     interface to a set of versions as to the complete set of all versions in the 
 482         /** \brief smell like a pkgCache::VerIterator */ 
 483         class const_iterator 
: public VersionContainerInterface::const_iterator
, 
 484                                public std::iterator
<std::forward_iterator_tag
, typename 
Container::const_iterator
> {/*{{{*/ 
 485                 typename 
Container::const_iterator _iter
; 
 487                 const_iterator(typename 
Container::const_iterator i
) : _iter(i
) {} 
 488                 pkgCache::VerIterator 
getVer(void) const { return *_iter
; } 
 489                 inline pkgCache::VerIterator 
operator*(void) const { return *_iter
; }; 
 490                 operator typename 
Container::const_iterator(void) const { return _iter
; } 
 491                 inline const_iterator
& operator++() { ++_iter
; return *this; } 
 492                 inline const_iterator 
operator++(int) { const_iterator 
tmp(*this); operator++(); return tmp
; } 
 493                 inline bool operator!=(const_iterator 
const &i
) const { return _iter 
!= i
._iter
; }; 
 494                 inline bool operator==(const_iterator 
const &i
) const { return _iter 
== i
._iter
; }; 
 495                 friend std::ostream
& operator<<(std::ostream
& out
, const_iterator i
) { return operator<<(out
, *i
); } 
 497         class iterator 
: public VersionContainerInterface::const_iterator
, 
 498                          public std::iterator
<std::forward_iterator_tag
, typename 
Container::iterator
> { 
 499                 typename 
Container::iterator _iter
; 
 501                 iterator(typename 
Container::iterator i
) : _iter(i
) {} 
 502                 pkgCache::VerIterator 
getVer(void) const { return *_iter
; } 
 503                 inline pkgCache::VerIterator 
operator*(void) const { return *_iter
; }; 
 504                 operator typename 
Container::iterator(void) const { return _iter
; } 
 505                 operator typename VersionContainer
<Container
>::const_iterator() { return VersionContainer
<Container
>::const_iterator(_iter
); } 
 506                 inline iterator
& operator++() { ++_iter
; return *this; } 
 507                 inline iterator 
operator++(int) { iterator 
tmp(*this); operator++(); return tmp
; } 
 508                 inline bool operator!=(iterator 
const &i
) const { return _iter 
!= i
._iter
; }; 
 509                 inline bool operator==(iterator 
const &i
) const { return _iter 
== i
._iter
; }; 
 510                 friend std::ostream
& operator<<(std::ostream
& out
, iterator i
) { return operator<<(out
, *i
); } 
 514         bool insert(pkgCache::VerIterator 
const &V
) { if (V
.end() == true) return false; _cont
.insert(V
); return true; }; 
 515         template<class Cont
> void insert(VersionContainer
<Cont
> const &vercont
) { _cont
.insert((typename 
Cont::const_iterator
)vercont
.begin(), (typename 
Cont::const_iterator
)vercont
.end()); }; 
 516         void insert(const_iterator begin
, const_iterator end
) { _cont
.insert(begin
, end
); }; 
 517         bool empty() const { return _cont
.empty(); }; 
 518         void clear() { return _cont
.clear(); }; 
 519         void erase(iterator position
) { _cont
.erase((typename 
Container::iterator
)position
); }; 
 520         size_t erase(const pkgCache::VerIterator x
) { return _cont
.erase(x
); }; 
 521         void erase(iterator first
, iterator last
) { _cont
.erase(first
, last
); }; 
 522         size_t size() const { return _cont
.size(); }; 
 524         const_iterator 
begin() const { return const_iterator(_cont
.begin()); }; 
 525         const_iterator 
end() const { return const_iterator(_cont
.end()); }; 
 526         iterator 
begin() { return iterator(_cont
.begin()); }; 
 527         iterator 
end() { return iterator(_cont
.end()); }; 
 528         const_iterator 
find(pkgCache::VerIterator 
const &V
) const { return const_iterator(_cont
.find(V
)); }; 
 530         /** \brief returns all versions specified on the commandline 
 532             Get all versions from the commandline, uses given default version if 
 533             non specifically requested  and executes regex's if needed on names. 
 534             \param Cache the packages and versions are in 
 535             \param cmdline Command line the versions should be extracted from 
 536             \param helper responsible for error and message handling */ 
 537         static VersionContainer 
FromCommandLine(pkgCacheFile 
&Cache
, const char **cmdline
, 
 538                         Version 
const &fallback
, CacheSetHelper 
&helper
) { 
 539                 VersionContainer vercon
; 
 540                 VersionContainerInterface::FromCommandLine(&vercon
, Cache
, cmdline
, fallback
, helper
); 
 543         static VersionContainer 
FromCommandLine(pkgCacheFile 
&Cache
, const char **cmdline
, 
 544                         Version 
const &fallback
) { 
 545                 CacheSetHelper helper
; 
 546                 return FromCommandLine(Cache
, cmdline
, fallback
, helper
); 
 548         static VersionContainer 
FromCommandLine(pkgCacheFile 
&Cache
, const char **cmdline
) { 
 549                 return FromCommandLine(Cache
, cmdline
, CANDINST
); 
 552         static VersionContainer 
FromString(pkgCacheFile 
&Cache
, std::string 
const &pkg
, 
 553                         Version 
const &fallback
, CacheSetHelper 
&helper
, 
 554                         bool const onlyFromName 
= false) { 
 555                 VersionContainer vercon
; 
 556                 VersionContainerInterface::FromString(&vercon
, Cache
, pkg
, fallback
, helper
); 
 559         static VersionContainer 
FromString(pkgCacheFile 
&Cache
, std::string pkg
, 
 560                         Version 
const &fallback
) { 
 561                 CacheSetHelper helper
; 
 562                 return FromString(Cache
, pkg
, fallback
, helper
); 
 564         static VersionContainer 
FromString(pkgCacheFile 
&Cache
, std::string pkg
) { 
 565                 return FromString(Cache
, pkg
, CANDINST
); 
 568         /** \brief returns all versions specified for the package 
 570             \param Cache the package and versions are in 
 571             \param P the package in question 
 572             \param fallback the version(s) you want to get 
 573             \param helper the helper used for display and error handling */ 
 574         static VersionContainer 
FromPackage(pkgCacheFile 
&Cache
, pkgCache::PkgIterator 
const &P
, 
 575                 Version 
const &fallback
, CacheSetHelper 
&helper
) { 
 576                 VersionContainer vercon
; 
 577                 VersionContainerInterface::FromPackage(&vercon
, Cache
, P
, fallback
, helper
); 
 580         static VersionContainer 
FromPackage(pkgCacheFile 
&Cache
, pkgCache::PkgIterator 
const &P
, 
 581                                             Version 
const &fallback
) { 
 582                 CacheSetHelper helper
; 
 583                 return FromPackage(Cache
, P
, fallback
, helper
); 
 585         static VersionContainer 
FromPackage(pkgCacheFile 
&Cache
, pkgCache::PkgIterator 
const &P
) { 
 586                 return FromPackage(Cache
, P
, CANDIDATE
); 
 589         static std::map
<unsigned short, VersionContainer
> GroupedFromCommandLine( 
 591                                                                                  const char **cmdline
, 
 592                                                                                  std::list
<Modifier
> const &mods
, 
 593                                                                                  unsigned short const fallback
, 
 594                                                                                  CacheSetHelper 
&helper
) { 
 595                 std::map
<unsigned short, VersionContainer
> versets
; 
 596                 for (const char **I 
= cmdline
; *I 
!= 0; ++I
) { 
 597                         unsigned short modID 
= fallback
; 
 598                         VersionContainer verset
; 
 599                         VersionContainerInterface::FromModifierCommandLine(modID
, &verset
, Cache
, *I
, mods
, helper
); 
 600                         versets
[modID
].insert(verset
); 
 605         static std::map
<unsigned short, VersionContainer
> GroupedFromCommandLine( 
 606                 pkgCacheFile 
&Cache
, const char **cmdline
, 
 607                 std::list
<Modifier
> const &mods
, 
 608                 unsigned short const fallback
) { 
 609                 CacheSetHelper helper
; 
 610                 return GroupedFromCommandLine(Cache
, cmdline
, 
 611                                 mods
, fallback
, helper
); 
 614         static VersionContainer 
FromDependency(pkgCacheFile 
&Cache
, pkgCache::DepIterator 
const &D
, 
 615                                                Version 
const &selector
, CacheSetHelper 
&helper
) { 
 616                 VersionContainer vercon
; 
 617                 VersionContainerInterface::FromDependency(&vercon
, Cache
, D
, selector
, helper
); 
 620         static VersionContainer 
FromDependency(pkgCacheFile 
&Cache
, pkgCache::DepIterator 
const &D
, 
 621                                                Version 
const &selector
) { 
 622                 CacheSetHelper helper
; 
 623                 return FromPackage(Cache
, D
, selector
, helper
); 
 625         static VersionContainer 
FromDependency(pkgCacheFile 
&Cache
, pkgCache::DepIterator 
const &D
) { 
 626                 return FromPackage(Cache
, D
, CANDIDATE
); 
 631 template<> template<class Cont
> void VersionContainer
<std::list
<pkgCache::VerIterator
> >::insert(VersionContainer
<Cont
> const &vercont
) { 
 632         for (typename VersionContainer
<Cont
>::const_iterator v 
= vercont
.begin(); v 
!= vercont
.end(); ++v
) 
 635 // these two are 'inline' as otherwise the linker has problems with seeing these untemplated 
 636 // specializations again and again - but we need to see them, so that library users can use them 
 637 template<> inline bool VersionContainer
<std::list
<pkgCache::VerIterator
> >::insert(pkgCache::VerIterator 
const &V
) { 
 643 template<> inline void VersionContainer
<std::list
<pkgCache::VerIterator
> >::insert(const_iterator begin
, const_iterator end
) { 
 644         for (const_iterator v 
= begin
; v 
!= end
; ++v
) 
 647 typedef VersionContainer
<std::set
<pkgCache::VerIterator
> > VersionSet
; 
 648 typedef VersionContainer
<std::list
<pkgCache::VerIterator
> > VersionList
;