Imported Upstream version 17.8.0
[platform/upstream/libzypp.git] / zypp / Resolver.cc
index 1b7243a..07f90d8 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;
@@ -34,7 +37,7 @@ namespace zypp
   //   METHOD TYPE : Ctor
   //
   Resolver::Resolver( const ResPool & pool )
-  : _pimpl( new Impl(pool) )
+  : _pimpl( new solver::detail::ResolverInternal(pool) )
   {}
 
   ///////////////////////////////////////////////////////////////////
@@ -83,6 +86,10 @@ namespace zypp
   void Resolver::setIgnoreAlreadyRecommended( bool yesno_r) { _pimpl->setIgnoreAlreadyRecommended( yesno_r ); }
   bool Resolver::ignoreAlreadyRecommended() const      { return _pimpl->ignoreAlreadyRecommended(); }
 
+  void Resolver::setInr( ResolverNamespaces namespaces_r ) { _pimpl->setInr( namespaces_r ); }
+  void Resolver::resetInr()                            { setInr( ResolverNamespaces() ); }
+  ResolverNamespaces Resolver::inr() const             { return _pimpl->inr(); }
+
   void Resolver::setOnlyRequires( bool yesno_r )       { _pimpl->setOnlyRequires( yesno_r ); }
   void Resolver::resetOnlyRequires()                   { _pimpl->setOnlyRequires( indeterminate ); }
   bool Resolver::onlyRequires() const                  { return _pimpl->onlyRequires(); }
@@ -90,9 +97,8 @@ namespace zypp
   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::setUpdateMode( bool yesno_r )         { return _pimpl->setUpdateMode( yesno_r ); }
+  bool Resolver::updateMode() const                    { return _pimpl->isUpdateMode(); }
 
   void Resolver::setSystemVerification( bool yesno_r ) { _pimpl->setVerifyingMode( yesno_r ); }
   void Resolver::setDefaultSystemVerification()                { _pimpl->setVerifyingMode( indeterminate ); }
@@ -106,7 +112,29 @@ namespace zypp
   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( setAllowDowngrade,                setDefaultAllowDowngrade,       allowDowngrade )
+  ZOLV_FLAG_TRIBOOL( setAllowNameChange,       setDefaultAllowNameChange,      allowNameChange )
+  ZOLV_FLAG_TRIBOOL( setAllowArchChange,       setDefaultAllowArchChange,      allowArchChange )
+  ZOLV_FLAG_TRIBOOL( setAllowVendorChange,     setDefaultAllowVendorChange,    allowVendorChange )
+
+  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(); }