Imported Upstream version 14.45.0
[platform/upstream/libzypp.git] / zypp / solver / detail / SolutionAction.cc
index e21a250..77d3b39 100644 (file)
 
 #include "zypp/solver/detail/Resolver.h"
 #include "zypp/solver/detail/SolutionAction.h"
-#include "zypp/CapSet.h"
+#include "zypp/Capabilities.h"
 #include "zypp/base/Logger.h"
-#include "zypp/Dependencies.h"
-
 
 /////////////////////////////////////////////////////////////////////////
 namespace zypp
@@ -63,17 +61,16 @@ TransactionSolutionAction::dumpOn( ostream& os) const
 {
     os << "TransactionSolutionAction: ";
     switch (_action) {
-       case KEEP:      os << "Keep"; break;
-       case INSTALL:   os << "Install"; break;
-       case REMOVE:    os << "Remove"; break;
-       case UNLOCK:    os << "Unlock"; break;
-       case ALLBRANCHES_ON:    os << "All branches on"; break;
-       case ALLBRANCHES_OFF:   os << "All branches off"; break;            
-       case DOUBLETIMEOUT:     os << "Double timeout"; break;
+       case KEEP:                      os << "Keep " << _item; break;
+       case INSTALL:                   os << "Install " << _item; break;
+       case REMOVE:                    os << "Remove " << _item; break;
+       case UNLOCK:                    os << "Unlock " << _item; break;
+       case LOCK:                      os << "Lock " << _item; break;
+       case REMOVE_EXTRA_REQUIRE:      os << "Remove require " << _capability; break;
+       case REMOVE_EXTRA_CONFLICT:     os << "Remove conflict " << _capability; break;
+       case ADD_SOLVE_QUEUE_ITEM:      os << "Add SolveQueueItem " <<  _solverQueueItem; break;
+       case REMOVE_SOLVE_QUEUE_ITEM:   os << "Remove SolveQueueItem " <<  _solverQueueItem; break;
     }
-    os << " ";
-    os << _item;
-    os << endl;
     return os;
 }
 
@@ -105,20 +102,12 @@ ostream &
 InjectSolutionAction::dumpOn( ostream& os ) const
 {
     os << "InjectSolutionAction: ";
-    os << _capability;
-    os << ", ";
     switch (_kind) {
-       case REQUIRES:  os << "Requires"; break;
-       case CONFLICTS: os << "Conflicts"; break;
-       case OBSOLETES: os << "Obsoletes"; break;
-       case INSTALLED: os << "Installed"; break;
-       case ARCHITECTURE: os << "Architecture"; break;
-       case VENDOR: os << "Vendor"; break;                 
+       case WEAK:      os << "Weak"; break;
        default: os << "Wrong kind"; break;
     }
     os << " ";
-    os << _item;           
-    os << endl;
+    os << _item;
     return os;
 }
 
@@ -135,14 +124,15 @@ SolutionAction::dumpOn( std::ostream & os ) const
 }
 
 
-bool 
+bool
 TransactionSolutionAction::execute(Resolver & resolver) const
 {
     bool ret = true;
     switch (action()) {
        case KEEP:
-           resolver.addIgnoreInstalledItem( _item );
-           /*FALLTHRU*/
+           _item.status().resetTransact (ResStatus::USER);
+           ret = _item.status().setTransact (false, ResStatus::APPL_HIGH); // APPL_HIGH: Locking should not be saved permanently
+           break;
        case INSTALL:
            if (_item.status().isToBeUninstalled())
                ret = _item.status().setTransact (false, ResStatus::USER);
@@ -152,25 +142,33 @@ TransactionSolutionAction::execute(Resolver & resolver) const
        case REMOVE:
            if (_item.status().isToBeInstalled()) {
                _item.status().setTransact (false,ResStatus::USER);
-               _item.status().setLock (true,ResStatus::USER); // no other dependency can set it again          
+               _item.status().setLock (true,ResStatus::USER); // no other dependency can set it again
            } else if (_item.status().isInstalled())
                _item.status().setToBeUninstalled (ResStatus::USER);
            else
-               _item.status().setLock (true,ResStatus::USER); // no other dependency can set it again          
+               _item.status().setLock (true,ResStatus::USER); // no other dependency can set it again
            break;
        case UNLOCK:
            ret = _item.status().setLock (false, ResStatus::USER);
            if (!ret) ERR << "Cannot unlock " << _item << endl;
            break;
-       case ALLBRANCHES_ON:
-           resolver.setTryAllPossibilities (true);
+       case LOCK:
+           _item.status().resetTransact (ResStatus::USER);
+           ret = _item.status().setLock (true, ResStatus::APPL_HIGH); // APPL_HIGH: Locking should not be saved permanently
+           if (!ret) ERR << "Cannot lock " << _item << endl;
+           break;
+       case REMOVE_EXTRA_REQUIRE:
+           resolver.removeExtraRequire (_capability);
            break;
-       case ALLBRANCHES_OFF:
-           resolver.setTryAllPossibilities (false);
+       case REMOVE_EXTRA_CONFLICT:
+           resolver.removeExtraConflict (_capability);
+           break;
+       case ADD_SOLVE_QUEUE_ITEM:
+           resolver.addQueueItem(_solverQueueItem);
+           break;
+       case REMOVE_SOLVE_QUEUE_ITEM:
+           resolver.removeQueueItem(_solverQueueItem);
            break;
-       case DOUBLETIMEOUT:
-           resolver.setTimeout (resolver.timeout()*2);
-           break;          
        default:
            ERR << "Wrong TransactionKind" << endl;
            ret = false;
@@ -181,75 +179,11 @@ TransactionSolutionAction::execute(Resolver & resolver) const
 bool
 InjectSolutionAction::execute(Resolver & resolver) const
 {
-    Dependencies dependencies;
-    CapSet depList;
-    if (_item != PoolItem_Ref()) {    
-       dependencies = _item.resolvable()->deps();
-       depList = dependencies[Dep::CONFLICTS];
-    }
     switch (_kind) {
-        case CONFLICTS:
-           // removing conflict in both resolvables
-           for (CapSet::const_iterator iter = depList.begin(); iter != depList.end(); iter++) {
-               if (iter->matches (_capability) == CapMatch::yes )
-               {
-                   resolver.addIgnoreConflict (_item, _capability);
-               }
-           }
-           // Obsoletes are conflicts too
-           depList = dependencies[Dep::OBSOLETES];
-           for (CapSet::const_iterator iter = depList.begin(); iter != depList.end(); iter++) {
-               if (iter->matches (_capability) == CapMatch::yes )
-               {
-                   resolver.addIgnoreConflict (_otherItem, _capability);
-               }
-           }
-           
-           dependencies = _otherItem.resolvable()->deps();
-           depList = dependencies[Dep::CONFLICTS];
-           for (CapSet::const_iterator iter = depList.begin(); iter != depList.end(); iter++) {
-               if (iter->matches (_capability) == CapMatch::yes )
-               {
-                   resolver.addIgnoreConflict (_otherItem, _capability);
-               }
-           }
-           // Obsoletes are conflicts too          
-           depList = dependencies[Dep::OBSOLETES];
-           for (CapSet::const_iterator iter = depList.begin(); iter != depList.end(); iter++) {
-               if (iter->matches (_capability) == CapMatch::yes )
-               {
-                   resolver.addIgnoreConflict (_otherItem, _capability);
-               }
-           }
-           
-           break;
-        case REQUIRES:
-           // removing the requires dependency from the item
-           if (_item == PoolItem_Ref()) {
-               // this was a requirement via Resolver::addExtraCapability
-               // so we have to delete it.
-               resolver.removeExtraCapability (_capability);
-           } else {
-               resolver.addIgnoreRequires (_item, _capability);
-           }
-           break;
-        case ARCHITECTURE:
-           // This item is for ALL architectures available
-           resolver.addIgnoreArchitectureItem (_item);
-           break;
-        case VENDOR:
-           // This item is for ALL vendor available
-           resolver.addIgnoreVendorItem (_item);
-           break;                  
-        case OBSOLETES:
-           // removing the obsoletes dependency from the item
-           resolver.addIgnoreObsoletes (_otherItem, _capability);
-           break;          
-        case INSTALLED:
-           // ignoring already installed items
-           resolver.addIgnoreInstalledItem (_item);
-           resolver.addIgnoreInstalledItem (_otherItem);
-           break;
+        case WEAK:
+           // set item dependencies to weak
+           resolver.addWeak (_item);
+            break;
         default:
            ERR << "No valid InjectSolutionAction kind found" << endl;
            return false;