libzypp 17.37.17
Resolver.cc
Go to the documentation of this file.
1/*---------------------------------------------------------------------\
2| ____ _ __ __ ___ |
3| |__ / \ / / . \ . \ |
4| / / \ V /| _/ _/ |
5| / /__ | | | | | | |
6| /_____||_| |_| |_| |
7| |
8\---------------------------------------------------------------------*/
12#include <iostream>
13
14#define ZYPP_USE_RESOLVER_INTERNALS
15
16#include <zypp/Resolver.h>
21
22
24namespace zypp
25{
26
27 using namespace solver;
28
30
32 //
33 // METHOD NAME : Resolver::Resolver
34 // METHOD TYPE : Ctor
35 //
37 : _pimpl( new solver::detail::ResolverInternal(pool) )
38 {}
39
41 //
42 // METHOD NAME : Resolver::~Resolver
43 // METHOD TYPE : Dtor
44 //
47
49 //
50 // Resolver interface forwarded to implementation
51 //
54 { return _pimpl->setDefaultSolverFlags( all_r ); }
55
57 { return _pimpl->get(); }
58
60 { return _pimpl->verifySystem(); }
61
63 { return _pimpl->resolvePool(); }
64
66 { return _pimpl->resolveQueue(queue); }
67
69 { _pimpl->undo(); }
70
72 { return _pimpl->problems (); }
73
75 { _pimpl->applySolutions (solutions); }
76
78 { return _pimpl->getTransaction(); }
79
81 { return _pimpl->doUpgrade(); }
82
84 { _pimpl->doUpdate(); }
85
86 void Resolver::setFocus( ResolverFocus focus_r ) { _pimpl->setFocus( focus_r ); }
87 ResolverFocus Resolver::focus() const { return _pimpl->focus(); }
88
89 void Resolver::setForceResolve( bool yesno_r ) { _pimpl->setForceResolve( yesno_r ); }
90 bool Resolver::forceResolve() const { return _pimpl->forceResolve(); }
91
92 void Resolver::setIgnoreAlreadyRecommended( bool yesno_r) { _pimpl->setIgnoreAlreadyRecommended( yesno_r ); }
93 bool Resolver::ignoreAlreadyRecommended() const { return _pimpl->ignoreAlreadyRecommended(); }
94
95 void Resolver::setOnlyRequires( bool yesno_r ) { _pimpl->setOnlyRequires( yesno_r ); }
96 void Resolver::resetOnlyRequires() { _pimpl->setOnlyRequires( indeterminate ); }
97 bool Resolver::onlyRequires() const { return _pimpl->onlyRequires(); }
98
99 void Resolver::setUpgradeMode( bool yesno_r ) { return _pimpl->setUpgradeMode( yesno_r ); }
100 bool Resolver::upgradeMode() const { return _pimpl->isUpgradeMode(); }
101
102 void Resolver::setUpdateMode( bool yesno_r ) { return _pimpl->setUpdateMode( yesno_r ); }
103 bool Resolver::updateMode() const { return _pimpl->isUpdateMode(); }
104
105 void Resolver::setRemoveOrphaned( bool yesno_r ) { return _pimpl->setRemoveOrphaned( yesno_r ); }
106 bool Resolver::removeOrphaned() const { return _pimpl->removeOrphaned(); }
107
108 void Resolver::setRemoveUnneeded( bool yesno_r ) { return _pimpl->setRemoveUnneeded( yesno_r ); }
109 bool Resolver::removeUnneeded() const { return _pimpl->removeUnneeded(); }
110
111 void Resolver::setSystemVerification( bool yesno_r ) { _pimpl->setVerifyingMode( yesno_r ); }
112 void Resolver::setDefaultSystemVerification() { _pimpl->setVerifyingMode( indeterminate ); }
113 bool Resolver::systemVerification() const { return _pimpl->isVerifyingMode(); }
114
115 void Resolver::setSolveSrcPackages( bool yesno_r ) { _pimpl->setSolveSrcPackages( yesno_r ); }
116 void Resolver::setDefaultSolveSrcPackages() { _pimpl->setSolveSrcPackages( indeterminate ); }
117 bool Resolver::solveSrcPackages() const { return _pimpl->solveSrcPackages(); }
118
119 void Resolver::setCleandepsOnRemove( bool yesno_r ) { _pimpl->setCleandepsOnRemove( yesno_r ); }
120 void Resolver::setDefaultCleandepsOnRemove() { _pimpl->setCleandepsOnRemove( indeterminate ); }
121 bool Resolver::cleandepsOnRemove() const { return _pimpl->cleandepsOnRemove(); }
122
123#define ZOLV_FLAG_BOOL( ZSETTER, ZGETTER ) \
124 void Resolver::ZSETTER( bool yesno_r ){ _pimpl->ZSETTER( yesno_r ); } \
125 bool Resolver::ZGETTER() const { return _pimpl->ZGETTER(); } \
126
127#define ZOLV_FLAG_TRIBOOL( ZSETTER, ZDEFAULT, ZGETTER ) \
128 ZOLV_FLAG_BOOL( ZSETTER , ZGETTER ) \
129 void Resolver::ZDEFAULT() { _pimpl->ZSETTER( indeterminate ); } \
130
131 ZOLV_FLAG_TRIBOOL( setAllowDowngrade, setDefaultAllowDowngrade, allowDowngrade )
132 ZOLV_FLAG_TRIBOOL( setAllowNameChange, setDefaultAllowNameChange, allowNameChange )
133 ZOLV_FLAG_TRIBOOL( setAllowArchChange, setDefaultAllowArchChange, allowArchChange )
134 ZOLV_FLAG_TRIBOOL( setAllowVendorChange, setDefaultAllowVendorChange, allowVendorChange )
135
136 ZOLV_FLAG_TRIBOOL( dupSetAllowDowngrade, dupSetDefaultAllowDowngrade, dupAllowDowngrade )
137 ZOLV_FLAG_TRIBOOL( dupSetAllowNameChange, dupSetDefaultAllowNameChange, dupAllowNameChange )
138 ZOLV_FLAG_TRIBOOL( dupSetAllowArchChange, dupSetDefaultAllowArchChange, dupAllowArchChange )
139 ZOLV_FLAG_TRIBOOL( dupSetAllowVendorChange, dupSetDefaultAllowVendorChange, dupAllowVendorChange )
140
141#undef ZOLV_FLAG_BOOL
142#undef ZOLV_FLAG_TRIBOOL
143
144 void Resolver::addUpgradeRepo( Repository repo_r ) { _pimpl->addUpgradeRepo( repo_r ); }
145 bool Resolver::upgradingRepos() const { return !_pimpl->upgradeRepos().empty(); }
146 bool Resolver::upgradingRepo( Repository repo_r ) const { return _pimpl->upgradingRepo( repo_r ); }
147 void Resolver::removeUpgradeRepo( Repository repo_r ) { _pimpl->removeUpgradeRepo( repo_r ); }
148 void Resolver::removeUpgradeRepos() { _pimpl->removeUpgradeRepos(); }
149
150 void Resolver::addRequire( const Capability & capability ) { _pimpl->addExtraRequire( capability ); }
151 void Resolver::addConflict( const Capability & capability ) { _pimpl->addExtraConflict( capability ); }
152 void Resolver::removeRequire( const Capability & capability ) { _pimpl->removeExtraRequire( capability ); }
153 void Resolver::removeConflict( const Capability & capability ){ _pimpl->removeExtraConflict( capability ); }
154
155 CapabilitySet Resolver::getRequire() const { return _pimpl->extraRequires(); }
156 CapabilitySet Resolver::getConflict() const { return _pimpl->extraConflicts(); }
157
158 std::list<PoolItem> Resolver::problematicUpdateItems() const
159 { return _pimpl->problematicUpdateItems(); }
160
161 bool Resolver::createSolverTestcase( const std::string & dumpPath, bool runSolver )
162 {
163 solver::detail::Testcase testcase (dumpPath);
164 return testcase.createTestcase(*_pimpl, true, runSolver);
165 }
166
168 { return _pimpl->isInstalledBy (item); }
169
171 { return _pimpl->installs (item); }
172
174 { return _pimpl->satifiedByInstalled (item); }
175
177 { return _pimpl->installedSatisfied (item); }
178
180 { _pimpl->reset( false ); /* Do not keep extra requires/conflicts */ }
181
182 std::ostream & operator<<( std::ostream & str, const Resolver & obj )
183 { return str << *obj._pimpl; }
184
186} // namespace zypp
#define ZOLV_FLAG_TRIBOOL(ZSETTER, ZDEFAULT, ZGETTER)
Definition Resolver.cc:127
A sat capability.
Definition Capability.h:63
Combining sat::Solvable and ResStatus.
Definition PoolItem.h:51
Global ResObject pool.
Definition ResPool.h:62
Dependency resolver interface.
Definition Resolver.h:45
void setDefaultCleandepsOnRemove()
Definition Resolver.cc:120
void setSolveSrcPackages(bool yesno_r)
Set whether to solve source packages build dependencies per default.
Definition Resolver.cc:115
bool cleandepsOnRemove() const
Definition Resolver.cc:121
bool resolveQueue(solver::detail::SolverQueueItemList &queue)
Resolve package dependencies:
Definition Resolver.cc:65
sat::detail::CSolver * get() const
Expert backdoor.
Definition Resolver.cc:56
void setCleandepsOnRemove(bool yesno_r)
Cleanup when deleting packages.
Definition Resolver.cc:119
void setRemoveOrphaned(bool yesno_r)
Set whether to remove unused orphans in 'upgrade' mode.
Definition Resolver.cc:105
void setDefaultSolverFlags(bool all_r=true)
Reset all solver flags to the systems default (e.g.
Definition Resolver.cc:53
ResolverProblemList problems()
Return the dependency problems found by the last call to resolveDependencies().
Definition Resolver.cc:71
bool forceResolve() const
Definition Resolver.cc:90
void setOnlyRequires(bool yesno_r)
Setting whether required packages are installed ONLY So recommended packages, language packages and p...
Definition Resolver.cc:95
sat::Transaction getTransaction()
Return the Transaction computed by the last solver run.
Definition Resolver.cc:77
void addRequire(const Capability &capability)
Adding additional requirement.
Definition Resolver.cc:150
void doUpdate()
Update to newest package.
Definition Resolver.cc:83
void addUpgradeRepo(Repository repo_r)
Adding request to perform a dist upgrade restricted to this repository.
Definition Resolver.cc:144
std::list< PoolItem > problematicUpdateItems() const
Unmaintained packages which does not fit to the updated system (broken dependencies) will be deleted.
Definition Resolver.cc:158
bool upgradingRepo(Repository repo_r) const
Whether there is an UpgradeRepo request pending for this repo.
Definition Resolver.cc:146
void applySolutions(const ProblemSolutionList &solutions)
Apply problem solutions.
Definition Resolver.cc:74
Resolver(const ResPool &pool)
Ctor.
Definition Resolver.cc:36
solver::detail::ItemCapKindList isInstalledBy(const PoolItem &item)
Gives information about WHO has pused an installation of an given item.
Definition Resolver.cc:167
bool ignoreAlreadyRecommended() const
Definition Resolver.cc:93
solver::detail::ItemCapKindList installs(const PoolItem &item)
Gives information about WHICH additional items will be installed due the installation of an item.
Definition Resolver.cc:170
bool resolvePool()
Resolve package dependencies:
Definition Resolver.cc:62
void setFocus(ResolverFocus focus_r)
Define the resolver's general attitude when resolving jobs.
Definition Resolver.cc:86
void resetOnlyRequires()
Definition Resolver.cc:96
void removeUpgradeRepos()
Remove all upgrade repo requests.
Definition Resolver.cc:148
bool upgradeMode() const
Definition Resolver.cc:100
void setRemoveUnneeded(bool yesno_r)
File weak remove jobs for unneeded installed packages.
Definition Resolver.cc:108
bool removeOrphaned() const
Definition Resolver.cc:106
bool systemVerification() const
Definition Resolver.cc:113
bool verifySystem()
Resolve package dependencies:
Definition Resolver.cc:59
CapabilitySet getConflict() const
Get all the additional conflicts set by addConflict(Capability).
Definition Resolver.cc:156
void removeUpgradeRepo(Repository repo_r)
Remove an upgrade request for this repo.
Definition Resolver.cc:147
~Resolver() override
Dtor.
Definition Resolver.cc:45
void setIgnoreAlreadyRecommended(bool yesno_r)
Ignore recommended packages that were already recommended by the installed packages.
Definition Resolver.cc:92
bool solveSrcPackages() const
Definition Resolver.cc:117
bool createSolverTestcase(const std::string &dumpPath="/var/log/YaST2/solverTestcase", bool runSolver=true)
Generates a solver Testcase of the current state.
Definition Resolver.cc:161
void addConflict(const Capability &capability)
Adding additional conflict.
Definition Resolver.cc:151
bool doUpgrade()
Do an distribution upgrade (DUP)
Definition Resolver.cc:80
void setForceResolve(bool force)
Remove resolvables which are conflicts with others or have unfulfilled requirements.
Definition Resolver.cc:89
void removeRequire(const Capability &capability)
Remove the additional requirement set by addRequire(Capability).
Definition Resolver.cc:152
void removeConflict(const Capability &capability)
Remove the additional conflict set by addConflict(Capability).
Definition Resolver.cc:153
bool upgradingRepos() const
Whether there is at least one UpgradeRepo request pending.
Definition Resolver.cc:145
ResolverFocus focus() const
Definition Resolver.cc:87
bool removeUnneeded() const
Definition Resolver.cc:109
bool updateMode() const
Definition Resolver.cc:103
solver::detail::ItemCapKindList installedSatisfied(const PoolItem &item)
Gives information about WHICH items require an already installed item.
Definition Resolver.cc:176
void setDefaultSolveSrcPackages()
Definition Resolver.cc:116
zypp::RW_pointer< solver::detail::ResolverInternal > _pimpl
Definition Resolver.h:491
void setUpgradeMode(bool yesno_r)
Setting whether the solver should perform in 'upgrade' mode or not.
Definition Resolver.cc:99
CapabilitySet getRequire() const
Get all the additional requirements set by addRequire(Capability).
Definition Resolver.cc:155
void setDefaultSystemVerification()
Definition Resolver.cc:112
void setUpdateMode(bool yesno_r)
Setting whether the solver should perform in 'update' mode or not.
Definition Resolver.cc:102
solver::detail::ItemCapKindList satifiedByInstalled(const PoolItem &item)
Gives information about WHICH installed items are requested by the installation of an item.
Definition Resolver.cc:173
bool onlyRequires() const
Definition Resolver.cc:97
void setSystemVerification(bool yesno_r)
System verification mode also monitors and repairs dependencies of already installed packages.
Definition Resolver.cc:111
Libsolv transaction wrapper.
Definition Transaction.h:52
String related utilities and Regular expression matching.
::s_Solver CSolver
Wrapped libsolv C data type exposed as backdoor.
Definition PoolMember.h:65
std::list< SolverQueueItem_Ptr > SolverQueueItemList
Definition Types.h:45
std::list< ItemCapKind > ItemCapKindList
Definition Types.h:42
Easy-to use interface to the ZYPP dependency resolver.
std::list< ProblemSolution_Ptr > ProblemSolutionList
ResolverFocus
The resolver's general attitude.
std::list< ResolverProblem_Ptr > ResolverProblemList
std::ostream & operator<<(std::ostream &str, const SerialNumber &obj)
std::unordered_set< Capability > CapabilitySet
Definition Capability.h:35
#define IMPL_PTR_TYPE(NAME)