#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
{
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;
}
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;
}
}
-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);
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;
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;