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                                                        /*{{{*/ 
  19 #include <apt-pkg/cachefile.h> 
  20 #include <apt-pkg/pkgcache.h> 
  25 class CacheSetHelper 
{                                                  /*{{{*/ 
  26 /** \class APT::CacheSetHelper 
  27     Simple base class with a lot of virtual methods which can be overridden 
  28     to alter the behavior or the output of the CacheSets. 
  30     This helper is passed around by the static methods in the CacheSets and 
  31     used every time they hit an error condition or something could be 
  35         CacheSetHelper(bool const &ShowError 
= true, 
  36                 GlobalError::MsgType ErrorType 
= GlobalError::ERROR
) : 
  37                         ShowError(ShowError
), ErrorType(ErrorType
) {}; 
  38         virtual ~CacheSetHelper() {}; 
  40         virtual void showTaskSelection(PackageSet 
const &pkgset
, string 
const &pattern
) {}; 
  41         virtual void showRegExSelection(PackageSet 
const &pkgset
, string 
const &pattern
) {}; 
  42         virtual void showSelectedVersion(pkgCache::PkgIterator 
const &Pkg
, pkgCache::VerIterator 
const Ver
, 
  43                                  string 
const &ver
, bool const &verIsRel
) {}; 
  45         virtual pkgCache::PkgIterator 
canNotFindPkgName(pkgCacheFile 
&Cache
, std::string 
const &str
); 
  46         virtual PackageSet 
canNotFindTask(pkgCacheFile 
&Cache
, std::string pattern
); 
  47         virtual PackageSet 
canNotFindRegEx(pkgCacheFile 
&Cache
, std::string pattern
); 
  48         virtual PackageSet 
canNotFindPackage(pkgCacheFile 
&Cache
, std::string 
const &str
); 
  49         virtual VersionSet 
canNotFindAllVer(pkgCacheFile 
&Cache
, pkgCache::PkgIterator 
const &Pkg
); 
  50         virtual VersionSet 
canNotFindInstCandVer(pkgCacheFile 
&Cache
, 
  51                                 pkgCache::PkgIterator 
const &Pkg
); 
  52         virtual VersionSet 
canNotFindCandInstVer(pkgCacheFile 
&Cache
, 
  53                                 pkgCache::PkgIterator 
const &Pkg
); 
  54         virtual pkgCache::VerIterator 
canNotFindNewestVer(pkgCacheFile 
&Cache
, 
  55                                 pkgCache::PkgIterator 
const &Pkg
); 
  56         virtual pkgCache::VerIterator 
canNotFindCandidateVer(pkgCacheFile 
&Cache
, 
  57                                 pkgCache::PkgIterator 
const &Pkg
); 
  58         virtual pkgCache::VerIterator 
canNotFindInstalledVer(pkgCacheFile 
&Cache
, 
  59                                 pkgCache::PkgIterator 
const &Pkg
); 
  61         bool showErrors() const { return ShowError
; }; 
  62         bool showErrors(bool const &newValue
) { if (ShowError 
== newValue
) return ShowError
; else return ((ShowError 
= newValue
) == false); }; 
  63         GlobalError::MsgType 
errorType() const { return ErrorType
; }; 
  64         GlobalError::MsgType 
errorType(GlobalError::MsgType 
const &newValue
) 
  66                 if (ErrorType 
== newValue
) return ErrorType
; 
  68                         GlobalError::MsgType 
const &oldValue 
= ErrorType
; 
  77         GlobalError::MsgType ErrorType
; 
  79 class PackageSet 
: public std::set
<pkgCache::PkgIterator
> {             /*{{{*/ 
  80 /** \class APT::PackageSet 
  82     Simple wrapper around a std::set to provide a similar interface to 
  83     a set of packages as to the complete set of all packages in the 
  86         /** \brief smell like a pkgCache::PkgIterator */ 
  87         class const_iterator 
: public std::set
<pkgCache::PkgIterator
>::const_iterator 
{/*{{{*/ 
  89                 const_iterator(std::set
<pkgCache::PkgIterator
>::const_iterator x
) : 
  90                          std::set
<pkgCache::PkgIterator
>::const_iterator(x
) {} 
  92                 operator pkgCache::PkgIterator(void) { return **this; } 
  94                 inline const char *Name() const {return (**this).Name(); } 
  95                 inline std::string 
FullName(bool const &Pretty
) const { return (**this).FullName(Pretty
); } 
  96                 inline std::string 
FullName() const { return (**this).FullName(); } 
  97                 inline const char *Section() const {return (**this).Section(); } 
  98                 inline bool Purge() const {return (**this).Purge(); } 
  99                 inline const char *Arch() const {return (**this).Arch(); } 
 100                 inline pkgCache::GrpIterator 
Group() const { return (**this).Group(); } 
 101                 inline pkgCache::VerIterator 
VersionList() const { return (**this).VersionList(); } 
 102                 inline pkgCache::VerIterator 
CurrentVer() const { return (**this).CurrentVer(); } 
 103                 inline pkgCache::DepIterator 
RevDependsList() const { return (**this).RevDependsList(); } 
 104                 inline pkgCache::PrvIterator 
ProvidesList() const { return (**this).ProvidesList(); } 
 105                 inline pkgCache::PkgIterator::OkState 
State() const { return (**this).State(); } 
 106                 inline const char *CandVersion() const { return (**this).CandVersion(); } 
 107                 inline const char *CurVersion() const { return (**this).CurVersion(); } 
 108                 inline pkgCache 
*Cache() const { return (**this).Cache(); }; 
 109                 inline unsigned long Index() const {return (**this).Index();}; 
 110                 // we have only valid iterators here 
 111                 inline bool end() const { return false; }; 
 113                 friend std::ostream
& operator<<(std::ostream
& out
, const_iterator i
) { return operator<<(out
, (*i
)); } 
 115                 inline pkgCache::Package 
const * operator->() const { 
 119         // 103. set::iterator is required to be modifiable, but this allows modification of keys 
 120         typedef APT::PackageSet::const_iterator iterator
; 
 123         using std::set
<pkgCache::PkgIterator
>::insert
; 
 124         inline void insert(pkgCache::PkgIterator 
const &P
) { if (P
.end() == false) std::set
<pkgCache::PkgIterator
>::insert(P
); }; 
 125         inline void insert(PackageSet 
const &pkgset
) { insert(pkgset
.begin(), pkgset
.end()); }; 
 127         /** \brief returns all packages in the cache who belong to the given task 
 129             A simple helper responsible for search for all members of a task 
 130             in the cache. Optional it prints a a notice about the 
 131             packages chosen cause of the given task. 
 132             \param Cache the packages are in 
 133             \param pattern name of the task 
 134             \param helper responsible for error and message handling */ 
 135         static APT::PackageSet 
FromTask(pkgCacheFile 
&Cache
, std::string pattern
, CacheSetHelper 
&helper
); 
 136         static APT::PackageSet 
FromTask(pkgCacheFile 
&Cache
, std::string 
const &pattern
) { 
 137                 CacheSetHelper helper
; 
 138                 return FromTask(Cache
, pattern
, helper
); 
 141         /** \brief returns all packages in the cache whose name matchs a given pattern 
 143             A simple helper responsible for executing a regular expression on all 
 144             package names in the cache. Optional it prints a a notice about the 
 145             packages chosen cause of the given package. 
 146             \param Cache the packages are in 
 147             \param pattern regular expression for package names 
 148             \param helper responsible for error and message handling */ 
 149         static APT::PackageSet 
FromRegEx(pkgCacheFile 
&Cache
, std::string pattern
, CacheSetHelper 
&helper
); 
 150         static APT::PackageSet 
FromRegEx(pkgCacheFile 
&Cache
, std::string 
const &pattern
) { 
 151                 CacheSetHelper helper
; 
 152                 return FromRegEx(Cache
, pattern
, helper
); 
 155         /** \brief returns all packages specified by a string 
 157             \param Cache the packages are in 
 158             \param string String the package name(s) should be extracted from 
 159             \param helper responsible for error and message handling */ 
 160         static APT::PackageSet 
FromString(pkgCacheFile 
&Cache
, std::string 
const &string
, CacheSetHelper 
&helper
); 
 161         static APT::PackageSet 
FromString(pkgCacheFile 
&Cache
, std::string 
const &string
) { 
 162                 CacheSetHelper helper
; 
 163                 return FromString(Cache
, string
, helper
); 
 166         /** \brief returns a package specified by a string 
 168             \param Cache the package is in 
 169             \param string String the package name should be extracted from 
 170             \param helper responsible for error and message handling */ 
 171         static pkgCache::PkgIterator 
FromName(pkgCacheFile 
&Cache
, std::string 
const &string
, CacheSetHelper 
&helper
); 
 172         static pkgCache::PkgIterator 
FromName(pkgCacheFile 
&Cache
, std::string 
const &string
) { 
 173                 CacheSetHelper helper
; 
 174                 return FromName(Cache
, string
, helper
); 
 177         /** \brief returns all packages specified on the commandline 
 179             Get all package names from the commandline and executes regex's if needed. 
 180             No special package command is supported, just plain names. 
 181             \param Cache the packages are in 
 182             \param cmdline Command line the package names should be extracted from 
 183             \param helper responsible for error and message handling */ 
 184         static APT::PackageSet 
FromCommandLine(pkgCacheFile 
&Cache
, const char **cmdline
, CacheSetHelper 
&helper
); 
 185         static APT::PackageSet 
FromCommandLine(pkgCacheFile 
&Cache
, const char **cmdline
) { 
 186                 CacheSetHelper helper
; 
 187                 return FromCommandLine(Cache
, cmdline
, helper
); 
 191                 enum Position 
{ NONE
, PREFIX
, POSTFIX 
}; 
 193                 const char * const Alias
; 
 195                 Modifier (unsigned short const &id
, const char * const alias
, Position 
const &pos
) : ID(id
), Alias(alias
), Pos(pos
) {}; 
 198         /** \brief group packages by a action modifiers 
 200             At some point it is needed to get from the same commandline 
 201             different package sets grouped by a modifier. Take 
 202                 apt-get install apt awesome- 
 204             \param Cache the packages are in 
 205             \param cmdline Command line the package names should be extracted from 
 206             \param mods list of modifiers the method should accept 
 207             \param fallback the default modifier group for a package 
 208             \param helper responsible for error and message handling */ 
 209         static std::map
<unsigned short, PackageSet
> GroupedFromCommandLine( 
 210                 pkgCacheFile 
&Cache
, const char **cmdline
, 
 211                 std::list
<PackageSet::Modifier
> const &mods
, 
 212                 unsigned short const &fallback
, CacheSetHelper 
&helper
); 
 213         static std::map
<unsigned short, PackageSet
> GroupedFromCommandLine( 
 214                 pkgCacheFile 
&Cache
, const char **cmdline
, 
 215                 std::list
<PackageSet::Modifier
> const &mods
, 
 216                 unsigned short const &fallback
) { 
 217                 CacheSetHelper helper
; 
 218                 return GroupedFromCommandLine(Cache
, cmdline
, 
 219                                 mods
, fallback
, helper
); 
 222         enum Constructor 
{ UNKNOWN
, REGEX
, TASK 
}; 
 223         Constructor 
getConstructor() const { return ConstructedBy
; }; 
 225         PackageSet() : ConstructedBy(UNKNOWN
) {}; 
 226         PackageSet(Constructor 
const &by
) : ConstructedBy(by
) {}; 
 229         Constructor ConstructedBy
; 
 232 class VersionSet 
: public std::set
<pkgCache::VerIterator
> {             /*{{{*/ 
 233 /** \class APT::VersionSet 
 235     Simple wrapper around a std::set to provide a similar interface to 
 236     a set of versions as to the complete set of all versions in the 
 239         /** \brief smell like a pkgCache::VerIterator */ 
 240         class const_iterator 
: public std::set
<pkgCache::VerIterator
>::const_iterator 
{/*{{{*/ 
 242                 const_iterator(std::set
<pkgCache::VerIterator
>::const_iterator x
) : 
 243                          std::set
<pkgCache::VerIterator
>::const_iterator(x
) {} 
 245                 operator pkgCache::VerIterator(void) { return **this; } 
 247                 inline pkgCache 
*Cache() const { return (**this).Cache(); }; 
 248                 inline unsigned long Index() const {return (**this).Index();}; 
 249                 // we have only valid iterators here 
 250                 inline bool end() const { return false; }; 
 252                 inline pkgCache::Version 
const * operator->() const { 
 256                 inline int CompareVer(const pkgCache::VerIterator 
&B
) const { return (**this).CompareVer(B
); }; 
 257                 inline const char *VerStr() const { return (**this).VerStr(); }; 
 258                 inline const char *Section() const { return (**this).Section(); }; 
 259                 inline const char *Arch() const { return (**this).Arch(); }; 
 260                 inline pkgCache::PkgIterator 
ParentPkg() const { return (**this).ParentPkg(); }; 
 261                 inline pkgCache::DescIterator 
DescriptionList() const { return (**this).DescriptionList(); }; 
 262                 inline pkgCache::DescIterator 
TranslatedDescription() const { return (**this).TranslatedDescription(); }; 
 263                 inline pkgCache::DepIterator 
DependsList() const { return (**this).DependsList(); }; 
 264                 inline pkgCache::PrvIterator 
ProvidesList() const { return (**this).ProvidesList(); }; 
 265                 inline pkgCache::VerFileIterator 
FileList() const { return (**this).FileList(); }; 
 266                 inline bool Downloadable() const { return (**this).Downloadable(); }; 
 267                 inline const char *PriorityType() const { return (**this).PriorityType(); }; 
 268                 inline string 
RelStr() const { return (**this).RelStr(); }; 
 269                 inline bool Automatic() const { return (**this).Automatic(); }; 
 270                 inline pkgCache::VerFileIterator 
NewestFile() const { return (**this).NewestFile(); }; 
 273         // 103. set::iterator is required to be modifiable, but this allows modification of keys 
 274         typedef APT::VersionSet::const_iterator iterator
; 
 276         using std::set
<pkgCache::VerIterator
>::insert
; 
 277         inline void insert(pkgCache::VerIterator 
const &V
) { if (V
.end() == false) std::set
<pkgCache::VerIterator
>::insert(V
); }; 
 278         inline void insert(VersionSet 
const &verset
) { insert(verset
.begin(), verset
.end()); }; 
 280         /** \brief specifies which version(s) will be returned if non is given */ 
 284                 /** Candidate and installed version */ 
 286                 /** Candidate version */ 
 288                 /** Installed version */ 
 290                 /** Candidate or if non installed version */ 
 292                 /** Installed or if non candidate version */ 
 294                 /** Newest version */ 
 298         /** \brief returns all versions specified on the commandline 
 300             Get all versions from the commandline, uses given default version if 
 301             non specifically requested  and executes regex's if needed on names. 
 302             \param Cache the packages and versions are in 
 303             \param cmdline Command line the versions should be extracted from 
 304             \param helper responsible for error and message handling */ 
 305         static APT::VersionSet 
FromCommandLine(pkgCacheFile 
&Cache
, const char **cmdline
, 
 306                         APT::VersionSet::Version 
const &fallback
, CacheSetHelper 
&helper
); 
 307         static APT::VersionSet 
FromCommandLine(pkgCacheFile 
&Cache
, const char **cmdline
, 
 308                         APT::VersionSet::Version 
const &fallback
) { 
 309                 CacheSetHelper helper
; 
 310                 return FromCommandLine(Cache
, cmdline
, fallback
, helper
); 
 312         static APT::VersionSet 
FromCommandLine(pkgCacheFile 
&Cache
, const char **cmdline
) { 
 313                 return FromCommandLine(Cache
, cmdline
, CANDINST
); 
 316         static APT::VersionSet 
FromString(pkgCacheFile 
&Cache
, std::string pkg
, 
 317                         APT::VersionSet::Version 
const &fallback
, CacheSetHelper 
&helper
, 
 318                         bool const &onlyFromName 
= false); 
 319         static APT::VersionSet 
FromString(pkgCacheFile 
&Cache
, std::string pkg
, 
 320                         APT::VersionSet::Version 
const &fallback
) { 
 321                 CacheSetHelper helper
; 
 322                 return FromString(Cache
, pkg
, fallback
, helper
); 
 324         static APT::VersionSet 
FromString(pkgCacheFile 
&Cache
, std::string pkg
) { 
 325                 return FromString(Cache
, pkg
, CANDINST
); 
 328         /** \brief returns all versions specified for the package 
 330             \param Cache the package and versions are in 
 331             \param P the package in question 
 332             \param fallback the version(s) you want to get 
 333             \param helper the helper used for display and error handling */ 
 334         static APT::VersionSet 
FromPackage(pkgCacheFile 
&Cache
, pkgCache::PkgIterator 
const &P
, 
 335                 VersionSet::Version 
const &fallback
, CacheSetHelper 
&helper
); 
 336         static APT::VersionSet 
FromPackage(pkgCacheFile 
&Cache
, pkgCache::PkgIterator 
const &P
, 
 337                         APT::VersionSet::Version 
const &fallback
) { 
 338                 CacheSetHelper helper
; 
 339                 return FromPackage(Cache
, P
, fallback
, helper
); 
 341         static APT::VersionSet 
FromPackage(pkgCacheFile 
&Cache
, pkgCache::PkgIterator 
const &P
) { 
 342                 return FromPackage(Cache
, P
, CANDINST
); 
 346                 enum Position 
{ NONE
, PREFIX
, POSTFIX 
}; 
 348                 const char * const Alias
; 
 350                 VersionSet::Version SelectVersion
; 
 351                 Modifier (unsigned short const &id
, const char * const alias
, Position 
const &pos
, 
 352                           VersionSet::Version 
const &select
) : ID(id
), Alias(alias
), Pos(pos
), 
 353                          SelectVersion(select
) {}; 
 356         static std::map
<unsigned short, VersionSet
> GroupedFromCommandLine( 
 357                 pkgCacheFile 
&Cache
, const char **cmdline
, 
 358                 std::list
<VersionSet::Modifier
> const &mods
, 
 359                 unsigned short const &fallback
, CacheSetHelper 
&helper
); 
 360         static std::map
<unsigned short, VersionSet
> GroupedFromCommandLine( 
 361                 pkgCacheFile 
&Cache
, const char **cmdline
, 
 362                 std::list
<VersionSet::Modifier
> const &mods
, 
 363                 unsigned short const &fallback
) { 
 364                 CacheSetHelper helper
; 
 365                 return GroupedFromCommandLine(Cache
, cmdline
, 
 366                                 mods
, fallback
, helper
); 
 371         /** \brief returns the candidate version of the package 
 373             \param Cache to be used to query for information 
 374             \param Pkg we want the candidate version from this package */ 
 375         static pkgCache::VerIterator 
getCandidateVer(pkgCacheFile 
&Cache
, 
 376                 pkgCache::PkgIterator 
const &Pkg
, CacheSetHelper 
&helper
); 
 378         /** \brief returns the installed version of the package 
 380             \param Cache to be used to query for information 
 381             \param Pkg we want the installed version from this package */ 
 382         static pkgCache::VerIterator 
getInstalledVer(pkgCacheFile 
&Cache
, 
 383                 pkgCache::PkgIterator 
const &Pkg
, CacheSetHelper 
&helper
);