*/
#include <iostream>
+#define ZYPP_USE_RESOLVER_INTERNALS
+
#include "zypp/Resolver.h"
#include "zypp/ZConfig.h"
#include "zypp/TriBool.h"
-#include "zypp/UpgradeStatistics.h"
#include "zypp/solver/detail/Resolver.h"
#include "zypp/solver/detail/Testcase.h"
+#include "zypp/solver/detail/ItemCapKind.h"
+#include "zypp/sat/Transaction.h"
using namespace std;
{ /////////////////////////////////////////////////////////////////
using namespace solver;
-
+
IMPL_PTR_TYPE(Resolver);
-#if 0
- Resolver_Ptr Resolver::_resolver = NULL;
- Resolver_Ptr Resolver::resolver()
- {
- if (_resolver == NULL) {
- _resolver = new Resolver();
- }
- return _resolver;
- }
-#endif
+
///////////////////////////////////////////////////////////////////
//
// METHOD NAME : Resolver::Resolver
// METHOD TYPE : Ctor
//
Resolver::Resolver( const ResPool & pool )
- {
- _pimpl = new solver::detail::Resolver(pool);
- }
+ : _pimpl( new solver::detail::ResolverInternal(pool) )
+ {}
///////////////////////////////////////////////////////////////////
//
///////////////////////////////////////////////////////////////////
bool Resolver::verifySystem ()
{ return _pimpl->verifySystem(); }
+
bool Resolver::resolvePool ()
{ return _pimpl->resolvePool(); }
- bool Resolver::resolveQueue (zypp::solver::detail::SolverQueueItemList & queue)
- { return _pimpl->resolveQueue(queue); }
+
+ bool Resolver::resolveQueue( solver::detail::SolverQueueItemList & queue )
+ { return _pimpl->resolveQueue(queue); }
+
void Resolver::undo()
{ _pimpl->undo(); }
+
ResolverProblemList Resolver::problems ()
{ return _pimpl->problems (); }
+
void Resolver::applySolutions( const ProblemSolutionList & solutions )
- { _pimpl->applySolutions (solutions); }
- bool Resolver::doUpgrade( UpgradeStatistics & opt_stats_r )
- { return _pimpl->doUpgrade(opt_stats_r); }
+ { _pimpl->applySolutions (solutions); }
+
+ sat::Transaction Resolver::getTransaction()
+ { return _pimpl->getTransaction(); }
+
+ bool Resolver::doUpgrade()
+ { return _pimpl->doUpgrade(); }
+
void Resolver::doUpdate()
- { _pimpl->doUpdate(); }
- void Resolver::setForceResolve( const bool force )
- { _pimpl->setForceResolve( force ); }
- bool Resolver::forceResolve()
- { return _pimpl->forceResolve(); }
- void Resolver::setIgnoreAlreadyRecommended
- (const bool ignoreAlreadyRecommended)
- { _pimpl->setIgnorealreadyrecommended (ignoreAlreadyRecommended); }
- bool Resolver::ignoreAlreadyRecommended()
- { return _pimpl->ignorealreadyrecommended(); }
- void Resolver::setOnlyRequires( const bool onlyRequires )
- { onlyRequires ? _pimpl->setOnlyRequires( true ) : _pimpl->setOnlyRequires( false ); }
- void Resolver::resetOnlyRequires()
- { _pimpl->setOnlyRequires( indeterminate ); }
- bool Resolver::onlyRequires()
+ { _pimpl->doUpdate(); }
+
+ void Resolver::setForceResolve( bool yesno_r ) { _pimpl->setForceResolve( yesno_r ); }
+ bool Resolver::forceResolve() const { return _pimpl->forceResolve(); }
+
+ void Resolver::setIgnoreAlreadyRecommended( bool yesno_r) { _pimpl->setIgnoreAlreadyRecommended( yesno_r ); }
+ bool Resolver::ignoreAlreadyRecommended() const { return _pimpl->ignoreAlreadyRecommended(); }
+
+ void Resolver::setOnlyRequires( bool yesno_r ) { _pimpl->setOnlyRequires( yesno_r ); }
+ void Resolver::resetOnlyRequires() { _pimpl->setOnlyRequires( indeterminate ); }
+ bool Resolver::onlyRequires() const { return _pimpl->onlyRequires(); }
+
+ void Resolver::setUpgradeMode( bool yesno_r ) { return _pimpl->setUpgradeMode( yesno_r ); }
+ bool Resolver::upgradeMode() const { return _pimpl->isUpgradeMode(); }
+
+ void Resolver::setAllowVendorChange( bool yesno_r ) { _pimpl->setAllowVendorChange( yesno_r ); }
+ void Resolver::setDefaultAllowVendorChange() { _pimpl->setAllowVendorChange( indeterminate ); }
+ bool Resolver::allowVendorChange() const { return _pimpl->allowVendorChange(); }
+
+ void Resolver::setSystemVerification( bool yesno_r ) { _pimpl->setVerifyingMode( yesno_r ); }
+ void Resolver::setDefaultSystemVerification() { _pimpl->setVerifyingMode( indeterminate ); }
+ bool Resolver::systemVerification() const { return _pimpl->isVerifyingMode(); }
+
+ void Resolver::setSolveSrcPackages( bool yesno_r ) { _pimpl->setSolveSrcPackages( yesno_r ); }
+ void Resolver::setDefaultSolveSrcPackages() { _pimpl->setSolveSrcPackages( indeterminate ); }
+ bool Resolver::solveSrcPackages() const { return _pimpl->solveSrcPackages(); }
+
+ void Resolver::setCleandepsOnRemove( bool yesno_r ) { _pimpl->setCleandepsOnRemove( yesno_r ); }
+ void Resolver::setDefaultCleandepsOnRemove() { _pimpl->setCleandepsOnRemove( indeterminate ); }
+ bool Resolver::cleandepsOnRemove() const { return _pimpl->cleandepsOnRemove(); }
+
+#define ZOLV_FLAG_BOOL( ZSETTER, ZGETTER ) \
+ void Resolver::ZSETTER( bool yesno_r ){ _pimpl->ZSETTER( yesno_r ); } \
+ bool Resolver::ZGETTER() const { return _pimpl->ZGETTER(); } \
+
+#define ZOLV_FLAG_TRIBOOL( ZSETTER, ZDEFAULT, ZGETTER ) \
+ ZOLV_FLAG_BOOL( ZSETTER , ZGETTER ) \
+ void Resolver::ZDEFAULT() { _pimpl->ZSETTER( indeterminate ); } \
+
+ ZOLV_FLAG_TRIBOOL( dupSetAllowDowngrade, dupSetDefaultAllowDowngrade, dupAllowDowngrade )
+ ZOLV_FLAG_TRIBOOL( dupSetAllowNameChange, dupSetDefaultAllowNameChange, dupAllowNameChange )
+ ZOLV_FLAG_TRIBOOL( dupSetAllowArchChange, dupSetDefaultAllowArchChange, dupAllowArchChange )
+ ZOLV_FLAG_TRIBOOL( dupSetAllowVendorChange, dupSetDefaultAllowVendorChange, dupAllowVendorChange )
+
+#undef ZOLV_FLAG_BOOL
+#undef ZOLV_FLAG_TRIBOOL
+
+ void Resolver::addUpgradeRepo( Repository repo_r ) { _pimpl->addUpgradeRepo( repo_r ); }
+ bool Resolver::upgradingRepos() const { return !_pimpl->upgradeRepos().empty(); }
+ bool Resolver::upgradingRepo( Repository repo_r ) const { return _pimpl->upgradingRepo( repo_r ); }
+ void Resolver::removeUpgradeRepo( Repository repo_r ) { _pimpl->removeUpgradeRepo( repo_r ); }
+ void Resolver::removeUpgradeRepos() { _pimpl->removeUpgradeRepos(); }
+
+ void Resolver::addRequire( const Capability & capability ) { _pimpl->addExtraRequire( capability ); }
+ void Resolver::addConflict( const Capability & capability ) { _pimpl->addExtraConflict( capability ); }
+ void Resolver::removeRequire( const Capability & capability ) { _pimpl->removeExtraRequire( capability ); }
+ void Resolver::removeConflict( const Capability & capability ){ _pimpl->removeExtraConflict( capability ); }
+
+ CapabilitySet Resolver::getRequire() const { return _pimpl->extraRequires(); }
+ CapabilitySet Resolver::getConflict() const { return _pimpl->extraConflicts(); }
+
+ std::list<PoolItem> Resolver::problematicUpdateItems() const
+ { return _pimpl->problematicUpdateItems(); }
+
+ bool Resolver::createSolverTestcase( const std::string & dumpPath, bool runSolver )
{
- if (_pimpl->onlyRequires() == indeterminate)
- return ZConfig::instance().solver_onlyRequires();
- else
- return _pimpl->onlyRequires();
+ solver::detail::Testcase testcase (dumpPath);
+ return testcase.createTestcase(*_pimpl, true, runSolver);
}
- void Resolver::addNoObsoletesCapability (const Capability & capability)
- { _pimpl->addNoObsoletesCapability (capability); }
- void Resolver::removeNoObsoletesCapability (const Capability & capability)
- { _pimpl->removeNoObsoletesCapability (capability); }
- CapabilitySet Resolver::noObsoletesCapability()
- { return _pimpl->noObsoletesCapability(); }
- void Resolver::addNoObsoletesItem (const PoolItem & item)
- { _pimpl->addNoObsoletesItem (item); }
- void Resolver::removeNoObsoletesItem (const PoolItem & item)
- { _pimpl->removeNoObsoletesItem (item); }
- solver::detail::PoolItemSet Resolver::noObsoletesItem()
- { return _pimpl->noObsoletesItem(); }
- void Resolver::addNoObsoletesName (const std::string & name)
- { _pimpl->addNoObsoletesName (name); }
- void Resolver::removeNoObsoletesName (const std::string & name)
- { _pimpl->removeNoObsoletesName (name); }
- solver::detail::ObsoleteStrings Resolver::noObsoletesString ()
- { return _pimpl->noObsoletesString (); }
-
- void Resolver::addRequire (const Capability & capability)
- { _pimpl->addExtraRequire( capability ); }
- void Resolver::addConflict (const Capability & capability)
- { _pimpl->addExtraConflict( capability ); }
- void Resolver::removeRequire (const Capability & capability)
- { _pimpl->removeExtraRequire( capability ); }
- void Resolver::removeConflict (const Capability & capability)
- { _pimpl->removeExtraConflict( capability ); }
- const CapabilitySet Resolver::getRequire ()
- { return _pimpl->extraRequires();}
- const CapabilitySet Resolver::getConflict ()
- { return _pimpl->extraConflicts();}
- std::list<PoolItem> Resolver::problematicUpdateItems( void ) const
- { return _pimpl->problematicUpdateItems(); }
- bool Resolver::createSolverTestcase (const std::string & dumpPath)
- { solver::detail::Testcase testcase (dumpPath);
- return testcase.createTestcase(*_pimpl);}
- const solver::detail::ItemCapKindList Resolver::isInstalledBy (const PoolItem item)
+ solver::detail::ItemCapKindList Resolver::isInstalledBy( const PoolItem & item )
{ return _pimpl->isInstalledBy (item); }
- const solver::detail::ItemCapKindList Resolver::installs (const PoolItem item)
+
+ solver::detail::ItemCapKindList Resolver::installs( const PoolItem & item )
{ return _pimpl->installs (item); }
- const solver::detail::ItemCapKindList Resolver::satifiedByInstalled (const PoolItem item)
+
+ solver::detail::ItemCapKindList Resolver::satifiedByInstalled( const PoolItem & item )
{ return _pimpl->satifiedByInstalled (item); }
- const solver::detail::ItemCapKindList Resolver::installedSatisfied (const PoolItem item)
- { return _pimpl->installedSatisfied (item); }
-
+ solver::detail::ItemCapKindList Resolver::installedSatisfied( const PoolItem & item )
+ { return _pimpl->installedSatisfied (item); }
+
+ void Resolver::reset()
+ { _pimpl->reset( false ); /* Do not keep extra requires/conflicts */ }
+
+ std::ostream & operator<<( std::ostream & str, const Resolver & obj )
+ { return str << *obj._pimpl; }
/////////////////////////////////////////////////////////////////
} // namespace zypp