Imported Upstream version 16.3.2
[platform/upstream/libzypp.git] / zypp / Resolver.cc
index 055dcc1..8c02fac 100644 (file)
 */
 #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;
 
@@ -34,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) )
+  {}
 
   ///////////////////////////////////////////////////////////////////
   //
@@ -69,21 +71,27 @@ namespace zypp
   void Resolver::applySolutions( const ProblemSolutionList & solutions )
   { _pimpl->applySolutions (solutions); }
 
-  bool Resolver::doUpgrade( UpgradeStatistics & opt_stats_r )
-  { return _pimpl->doUpgrade(opt_stats_r); }
+  sat::Transaction Resolver::getTransaction()
+  { return _pimpl->getTransaction(); }
+
+  bool Resolver::doUpgrade()
+  { return _pimpl->doUpgrade(); }
 
   void Resolver::doUpdate()
   { _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 ); }
   void Resolver::setDefaultAllowVendorChange()         { _pimpl->setAllowVendorChange( indeterminate ); }
@@ -97,22 +105,47 @@ 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(); }
 
   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() { 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(); }
 
-  bool Resolver::createSolverTestcase( const std::string & dumpPath )
+  bool Resolver::createSolverTestcase( const std::string & dumpPath, bool runSolver )
   {
     solver::detail::Testcase testcase (dumpPath);
-    return testcase.createTestcase(*_pimpl);
+    return testcase.createTestcase(*_pimpl, true, runSolver);
   }
 
   solver::detail::ItemCapKindList Resolver::isInstalledBy( const PoolItem & item )
@@ -130,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