Imported Upstream version 16.3.2
[platform/upstream/libzypp.git] / zypp / Resolver.cc
index 6e3b9cf..8c02fac 100644 (file)
 */
 #include <iostream>
 
+#define ZYPP_USE_RESOLVER_INTERNALS
+
 #include "zypp/Resolver.h"
 #include "zypp/ZConfig.h"
 #include "zypp/TriBool.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;
 
@@ -33,9 +37,8 @@ namespace zypp
   //   METHOD TYPE : Ctor
   //
   Resolver::Resolver( const ResPool & pool )
-  {
-    _pimpl = new solver::detail::Resolver(pool);
-  }
+  : _pimpl( new solver::detail::ResolverInternal(pool) )
+  {}
 
   ///////////////////////////////////////////////////////////////////
   //
@@ -68,6 +71,9 @@ namespace zypp
   void Resolver::applySolutions( const ProblemSolutionList & solutions )
   { _pimpl->applySolutions (solutions); }
 
+  sat::Transaction Resolver::getTransaction()
+  { return _pimpl->getTransaction(); }
+
   bool Resolver::doUpgrade()
   { return _pimpl->doUpgrade(); }
 
@@ -75,15 +81,16 @@ namespace zypp
   { _pimpl->doUpdate(); }
 
   void Resolver::setForceResolve( bool yesno_r )       { _pimpl->setForceResolve( yesno_r ); }
-  bool Resolver::forceResolve()                                { return _pimpl->forceResolve(); }
+  bool Resolver::forceResolve() const                  { return _pimpl->forceResolve(); }
 
   void Resolver::setIgnoreAlreadyRecommended( bool yesno_r) { _pimpl->setIgnoreAlreadyRecommended( yesno_r ); }
-  bool Resolver::ignoreAlreadyRecommended()            { return _pimpl->ignoreAlreadyRecommended(); }
+  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()                                { return _pimpl->onlyRequires(); }
+  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 ); }
@@ -98,7 +105,29 @@ namespace zypp
   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(); }
 
@@ -107,8 +136,8 @@ namespace zypp
   void Resolver::removeRequire( const Capability & capability )        { _pimpl->removeExtraRequire( capability ); }
   void Resolver::removeConflict( const Capability & capability ){ _pimpl->removeExtraConflict( capability ); }
 
-  CapabilitySet Resolver::getRequire() { return _pimpl->extraRequires(); }
-  CapabilitySet Resolver::getConflict()        { return _pimpl->extraConflicts(); }
+  CapabilitySet Resolver::getRequire() const   { return _pimpl->extraRequires(); }
+  CapabilitySet Resolver::getConflict() const  { return _pimpl->extraConflicts(); }
 
   std::list<PoolItem> Resolver::problematicUpdateItems() const
   { return _pimpl->problematicUpdateItems(); }
@@ -134,7 +163,8 @@ namespace zypp
   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