libzypp  17.2.0
PoolQuery.h
Go to the documentation of this file.
1 /*---------------------------------------------------------------------\
2 | ____ _ __ __ ___ |
3 | |__ / \ / / . \ . \ |
4 | / / \ V /| _/ _/ |
5 | / /__ | | | | | | |
6 | /_____||_| |_| |_| |
7 | |
8 \---------------------------------------------------------------------*/
12 #ifndef ZYPP_POOLQUERY_H
13 #define ZYPP_POOLQUERY_H
14 
15 #include <iosfwd>
16 #include <set>
17 #include <map>
18 
19 #include "zypp/base/Regex.h"
20 #include "zypp/base/PtrTypes.h"
21 #include "zypp/base/Function.h"
22 
23 #include "zypp/sat/SolvIterMixin.h"
24 #include "zypp/sat/LookupAttr.h"
25 #include "zypp/base/StrMatcher.h"
26 #include "zypp/sat/Pool.h"
27 
29 namespace zypp
30 {
31 
32  namespace detail
33  {
34  class PoolQueryIterator;
35  }
36 
38  //
39  // CLASS NAME : PoolQuery
40  //
90  class PoolQuery : public sat::SolvIterMixin<PoolQuery, detail::PoolQueryIterator>
91  {
92  public:
93  typedef std::set<ResKind> Kinds;
94  typedef std::set<std::string> StrContainer;
95  typedef std::map<sat::SolvAttr, StrContainer> AttrRawStrMap;
96 
98  typedef unsigned int size_type;
99 
100  public:
101  typedef function<bool( const sat::Solvable & )> ProcessResolvable;
102 
103  PoolQuery();
104  ~PoolQuery();
105 
120  const_iterator begin() const;
121 
123  const_iterator end() const;
124 
126  bool empty() const;
127 
129  size_type size() const;
131 
136  void execute(ProcessResolvable fnc);
137 
153  void addKind(const ResKind & kind);
154 
161  void addRepo(const std::string &repoalias);
162 
165 
170  ALL = 0, // both install filter and uninstall filter bits are 0
173  };
174 
176  void setInstalledOnly();
178  void setUninstalledOnly();
181 
183 
195  void addString(const std::string & value);
196 
224  void addAttribute( const sat::SolvAttr & attr, const std::string & value = "" );
225 
287  void addDependency( const sat::SolvAttr & attr, const std::string & name, const Rel & op, const Edition & edition );
289  void addDependency( const sat::SolvAttr & attr, const std::string & name, const Rel & op, const Edition & edition, const Arch & arch );
290 
292  void addDependency( const sat::SolvAttr & attr, const std::string & name, const Edition & edition )
293  { addDependency( attr, name, Rel::EQ, edition ); }
295  void addDependency( const sat::SolvAttr & attr, const std::string & name, const Edition & edition, const Arch & arch )
296  { addDependency( attr, name, Rel::EQ, edition, arch ); }
297 
299  void addDependency( const sat::SolvAttr & attr, const std::string & name )
300  { addDependency( attr, name, Rel::ANY, Edition() ); }
302  void addDependency( const sat::SolvAttr & attr, const std::string & name, const Arch & arch )
303  { addDependency( attr, name, Rel::ANY, Edition(), arch ); }
304 
306  void addDependency( const sat::SolvAttr & attr, const Rel & op, const Edition & edition )
307  { addDependency( attr, std::string(), op, edition ); }
309  void addDependency( const sat::SolvAttr & attr, const Rel & op, const Edition & edition, const Arch & arch )
310  { addDependency( attr, std::string(), op, edition, arch ); }
311 
313  void addDependency( const sat::SolvAttr & attr, const Edition & edition )
314  { addDependency( attr, std::string(), Rel::EQ, edition ); }
316  void addDependency( const sat::SolvAttr & attr, const Edition & edition, const Arch & arch )
317  { addDependency( attr, std::string(), Rel::EQ, edition, arch ); }
318 
321  { addDependency( attr, std::string(), Rel::ANY, Edition() ); }
323  void addDependency( const sat::SolvAttr & attr, const Arch & arch )
324  { addDependency( attr, std::string(), Rel::ANY, Edition(), arch ); }
325 
330  void addDependency( const sat::SolvAttr & attr, Capability cap_r );
332 
340  void setEdition(const Edition & edition, const Rel & op = Rel::EQ);
341 
355  void setCaseSensitive( bool value = true );
356 
362  void setFilesMatchFullPath( bool value = true );
364  void setFilesMatchBasename( bool value = true )
365  { setFilesMatchFullPath( !value ); }
366 
368  void setMatchExact();
370  void setMatchSubstring();
372  void setMatchGlob();
374  void setMatchRegex();
376  void setMatchWord();
377  //void setLocale(const Locale & locale);
379 
386  void setRequireAll( bool require_all = true );
387 
388 
391 
393  const StrContainer & strings() const;
397  const AttrRawStrMap & attributes() const;
398 
399  const StrContainer & attribute(const sat::SolvAttr & attr) const;
400 
401  const Kinds & kinds() const;
402 
403  const StrContainer & repos() const;
404 
405  const Edition edition() const;
406  const Rel editionRel() const;
407 
411  bool caseSensitive() const;
412 
414  bool filesMatchFullPath() const;
416  bool filesMatchBasename() const
417  { return !filesMatchFullPath(); }
418 
419  bool matchExact() const;
420  bool matchSubstring() const;
421  bool matchGlob() const;
422  bool matchRegex() const;
423  bool matchWord() const;
424 
429  { return flags().mode(); }
430 
435  bool requireAll() const;
436 
439 
450  bool recover( std::istream &str, char delim = '\n' );
451 
461  void serialize( std::ostream &str, char delim = '\n' ) const;
462 
464  std::string asString() const;
465 
466  bool operator<(const PoolQuery& b) const;
467  bool operator==(const PoolQuery& b) const;
468  bool operator!=(const PoolQuery& b) const { return !(*this == b ); }
469 
470  // low level API
471 
478  Match flags() const;
479 
486  void setFlags( const Match & flags );
487 
488  public:
489  class Impl;
490  private:
493  };
495 
497  std::ostream & operator<<( std::ostream & str, const PoolQuery & obj );
498 
500  std::ostream & dumpOn( std::ostream & str, const PoolQuery & obj );
501 
503  namespace detail
504  {
505 
506  class PoolQueryMatcher;
507 
509  //
510  // CLASS NAME : PoolQuery::PoolQueryIterator
511  //
519  class PoolQueryIterator : public boost::iterator_adaptor<
520  PoolQueryIterator // Derived
521  , sat::LookupAttr::iterator // Base
522  , const sat::Solvable // Value
523  , boost::forward_traversal_tag // CategoryOrTraversal
524  , const sat::Solvable // Reference
525  >
526  {
527  typedef std::vector<sat::LookupAttr::iterator> Matches;
528  public:
530  typedef Matches::const_iterator matches_iterator;
531  public:
534  {}
535 
537  PoolQueryIterator( const shared_ptr<PoolQueryMatcher> & matcher_r )
538  : _matcher( matcher_r )
539  { increment(); }
540 
587  bool matchesEmpty() const { return ! _matcher; }
589  size_type matchesSize() const { return matches().size(); }
591  matches_iterator matchesBegin() const { return matches().begin(); }
593  matches_iterator matchesEnd() const { return matches().end(); }
595 
596  private:
598 
600  { return base_reference().inSolvable(); }
601 
602  void increment();
603 
604  private:
605  const Matches & matches() const;
606 
607  private:
608  shared_ptr<PoolQueryMatcher> _matcher;
609  mutable shared_ptr<Matches> _matches;
610  };
612 
614  inline std::ostream & operator<<( std::ostream & str, const PoolQueryIterator & obj )
615  { return str << obj.base(); }
616 
618  std::ostream & dumpOn( std::ostream & str, const PoolQueryIterator & obj );
619 
621  } //namespace detail
623 
625  { return detail::PoolQueryIterator(); }
626 
628 } // namespace zypp
630 
631 #endif // ZYPP_POOLQUERY_H
PoolQueryIterator(const shared_ptr< PoolQueryMatcher > &matcher_r)
PoolQuery ctor.
Definition: PoolQuery.h:537
bool matchExact() const
Definition: PoolQuery.cc:1028
A Solvable object within the sat Pool.
Definition: Solvable.h:53
std::ostream & operator<<(std::ostream &str, const PoolQueryIterator &obj)
Definition: PoolQuery.h:614
void setUninstalledOnly()
Return only packages from repos other than .
Definition: PoolQuery.cc:977
StatusFilter
Installed status filter setters.
Definition: PoolQuery.h:169
const AttrRawStrMap & attributes() const
Map (map<SolvAttr, StrContainer>) of attribute values added via addAttribute(), addDep in string form...
Definition: PoolQuery.cc:992
void addAttribute(const sat::SolvAttr &attr, const std::string &value="")
Filter by the value of the specified attr attribute.
Definition: PoolQuery.cc:887
void addDependency(const sat::SolvAttr &attr, const Rel &op, const Edition &edition, const Arch &arch)
Definition: PoolQuery.h:309
std::set< ResKind > Kinds
Definition: PoolQuery.h:93
String matching option flags as used e.g.
Definition: StrMatcher.h:32
void addDependency(const sat::SolvAttr &attr, const std::string &name)
Definition: PoolQuery.h:299
std::ostream & dumpOn(std::ostream &str, const PoolQueryIterator &obj)
Definition: PoolQuery.cc:1786
void addDependency(const sat::SolvAttr &attr, const std::string &name, const Arch &arch)
Definition: PoolQuery.h:302
Architecture.
Definition: Arch.h:36
PoolQuery iterator as returned by PoolQuery::begin.
Definition: PoolQuery.h:519
void setFlags(const Match &flags)
Free function to set libsolv repo search flags.
Definition: PoolQuery.cc:971
Relational operators.
Definition: Rel.h:43
void execute(ProcessResolvable fnc)
Executes the query with the current settings.
Definition: PoolQuery.cc:1062
void addString(const std::string &value)
Add a global query string.
Definition: PoolQuery.cc:884
void setFilesMatchBasename(bool value=true)
Definition: PoolQuery.h:364
static const Rel EQ
Definition: Rel.h:50
const StrContainer & strings() const
Search strings added via addString()
Definition: PoolQuery.cc:988
sat::SolvAttr attr
Definition: PoolQuery.cc:314
Match::Mode matchMode() const
Returns string matching mode as enum.
Definition: PoolQuery.h:428
const Matches & matches() const
Definition: PoolQuery.cc:1769
void setMatchGlob()
Set to match globs.
Definition: PoolQuery.cc:962
void setMatchRegex()
Set to use the query strings as regexes.
Definition: PoolQuery.cc:961
String related utilities and Regular expression matching.
detail::PoolQueryIterator const_iterator
Definition: PoolQuery.h:97
bool operator<(const PoolQuery &b) const
Definition: PoolQuery.cc:1457
bool matchesEmpty() const
False unless this is the end iterator.
Definition: PoolQuery.h:587
void addDependency(const sat::SolvAttr &attr, const std::string &name, const Rel &op, const Edition &edition)
Query "name|global op edition".
Definition: PoolQuery.cc:890
void setCaseSensitive(bool value=true)
Turn case sentitivity on or off (unsets or sets SEARCH_NOCASE flag).
Definition: PoolQuery.cc:1020
void addDependency(const sat::SolvAttr &attr, const std::string &name, const Edition &edition)
Definition: PoolQuery.h:292
void addKind(const ResKind &kind)
Filter by selectable kind.
Definition: PoolQuery.cc:881
Edition represents [epoch:]version[-release]
Definition: Edition.h:60
static const Rel ANY
Definition: Rel.h:56
Mode mode() const
Return the mode part.
Definition: StrMatcher.cc:52
bool operator!=(const PoolQuery &b) const
Definition: PoolQuery.h:468
const Kinds & kinds() const
Definition: PoolQuery.cc:1010
void addDependency(const sat::SolvAttr &attr)
Definition: PoolQuery.h:320
Matches::size_type size_type
Definition: PoolQuery.h:529
size_type size() const
Number of solvables in the query result.
Definition: PoolQuery.cc:1049
bool operator==(const PoolQuery &b) const
Definition: PoolQuery.cc:1454
void serialize(std::ostream &str, char delim='\n') const
Writes a machine-readable string representation of the query to stream.
Definition: PoolQuery.cc:1336
const StrContainer & attribute(const sat::SolvAttr &attr) const
Definition: PoolQuery.cc:996
std::vector< sat::LookupAttr::iterator > Matches
Definition: PoolQuery.h:527
Base class providing common iterator types based on a Solvable iterator.
bool caseSensitive() const
returns true if search is case sensitive
Definition: PoolQuery.cc:1018
unsigned int size_type
Definition: PoolQuery.h:98
Solvable attribute keys.
Definition: SolvAttr.h:40
bool filesMatchFullPath() const
Whether searching in filelists looks at the full path or just at the basenames.
Definition: PoolQuery.cc:1023
std::set< std::string > StrContainer
Definition: PoolQuery.h:94
void setStatusFilterFlags(StatusFilter flags)
Set status filter directly.
Definition: PoolQuery.cc:979
std::ostream & operator<<(std::ostream &str, const Exception &obj)
Definition: Exception.cc:147
const StrContainer & repos() const
Definition: PoolQuery.cc:1014
void addRepo(const std::string &repoalias)
Filter by repo.
Definition: PoolQuery.cc:871
void setMatchWord()
Set to match words (uses regex)
Definition: PoolQuery.cc:963
const_iterator begin() const
Query result accessers.
Definition: PoolQuery.cc:1803
matches_iterator matchesEnd() const
End of matches.
Definition: PoolQuery.h:593
friend class boost::iterator_core_access
Definition: PoolQuery.h:597
const Rel editionRel() const
Definition: PoolQuery.cc:1005
std::ostream & dumpOn(std::ostream &str, const Capability &obj)
Definition: Capability.cc:444
void setInstalledOnly()
Return only repo packages.
Definition: PoolQuery.cc:975
bool recover(std::istream &str, char delim='\n')
Reads from stream query.
Definition: PoolQuery.cc:1153
Mode
Mode flags (mutual exclusive).
Definition: StrMatcher.h:40
void addDependency(const sat::SolvAttr &attr, const std::string &name, const Edition &edition, const Arch &arch)
Definition: PoolQuery.h:295
const_iterator end() const
An iterator pointing to the end of the query result.
Definition: PoolQuery.h:624
SolvableIdType size_type
Definition: PoolMember.h:126
const Edition edition() const
Definition: PoolQuery.cc:1003
Matches::const_iterator matches_iterator
Definition: PoolQuery.h:530
void setMatchSubstring()
Set to substring (the default).
Definition: PoolQuery.cc:959
std::map< sat::SolvAttr, StrContainer > AttrRawStrMap
Definition: PoolQuery.h:95
Meta-data query API.
Definition: PoolQuery.h:90
bool matchWord() const
Definition: PoolQuery.cc:1033
void setEdition(const Edition &edition, const Rel &op=Rel::EQ)
Set version condition.
Definition: PoolQuery.cc:953
void setMatchExact()
Set to match exact string instead of substring.
Definition: PoolQuery.cc:960
A sat capability.
Definition: Capability.h:59
shared_ptr< PoolQueryMatcher > _matcher
Definition: PoolQuery.h:608
StatusFilter statusFilterFlags() const
Definition: PoolQuery.cc:1039
bool matchSubstring() const
Definition: PoolQuery.cc:1029
matches_iterator matchesBegin() const
Begin of matches.
Definition: PoolQuery.h:591
bool empty() const
Whether the result is empty.
Definition: PoolQuery.cc:1042
shared_ptr< Matches > _matches
Definition: PoolQuery.h:609
void addDependency(const sat::SolvAttr &attr, const Edition &edition, const Arch &arch)
Definition: PoolQuery.h:316
sat::Solvable dereference() const
Definition: PoolQuery.h:599
Match flags() const
Free function to get libsolv repo search flags.
Definition: PoolQuery.cc:969
void setFilesMatchFullPath(bool value=true)
If set (default), look at the full path when searching in filelists.
Definition: PoolQuery.cc:1025
RW_pointer< Impl > _pimpl
Pointer to implementation.
Definition: PoolQuery.h:489
void addDependency(const sat::SolvAttr &attr, const Arch &arch)
Definition: PoolQuery.h:323
std::string asString() const
Return a human-readable description of the query.
Definition: PoolQuery.cc:1445
Resolvable kinds.
Definition: ResKind.h:32
Easy-to use interface to the ZYPP dependency resolver.
Definition: CodePitfalls.doc:1
size_type matchesSize() const
Number of attribute matches.
Definition: PoolQuery.h:589
function< bool(const sat::Solvable &)> ProcessResolvable
Definition: PoolQuery.h:101
bool matchGlob() const
Definition: PoolQuery.cc:1030
bool requireAll() const
Whether all values added via addString() or addAttribute() are required to match the values of the re...
Definition: PoolQuery.cc:1036
void addDependency(const sat::SolvAttr &attr, const Rel &op, const Edition &edition)
Definition: PoolQuery.h:306
PoolQueryIterator()
Default ctor is also end.
Definition: PoolQuery.h:533
bool matchRegex() const
Definition: PoolQuery.cc:1031
bool filesMatchBasename() const
Definition: PoolQuery.h:416
void addDependency(const sat::SolvAttr &attr, const Edition &edition)
Definition: PoolQuery.h:313
void setRequireAll(bool require_all=true)
Require that all of the values set by addString or addAttribute match the values of respective attrib...
Definition: PoolQuery.cc:983