
org.btrplace.model.constraint.Root Maven / Gradle / Ivy
/*
* Copyright (c) 2016 University Nice Sophia Antipolis
*
* This file is part of btrplace.
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 3 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this program. If not, see .
*/
package org.btrplace.model.constraint;
import org.btrplace.model.VM;
import java.util.Collection;
import java.util.Collections;
import java.util.List;
import java.util.Objects;
import java.util.stream.Collectors;
/**
* A constraint to avoid VM relocation to another host.
*
* The restriction provided by the constraint is only continuous. The running
* VMs will stay on their current node for the whole duration of the reconfiguration
* process.
*
* @author Fabien Hermenier
*/
public class Root implements SatConstraint {
private VM vm;
/**
* Make a new constraint.
*
* @param vm the VM to disallow to move
*/
public Root(VM vm) {
this.vm = vm;
}
@Override
public String toString() {
return "root(vm=" + vm + ", continuous)";
}
@Override
public Collection getInvolvedVMs() {
return Collections.singleton(vm);
}
@Override
public boolean setContinuous(boolean b) {
return b;
}
@Override
public RootChecker getChecker() {
return new RootChecker(this);
}
@Override
public boolean equals(Object o) {
if (this == o) {
return true;
}
if (o == null || getClass() != o.getClass()) {
return false;
}
Root root = (Root) o;
return Objects.equals(vm, root.vm);
}
@Override
public int hashCode() {
return Objects.hash(vm);
}
@Override
public boolean isContinuous() {
return true;
}
/**
* Instantiate constraints for a collection of VMs.
*
* @param vms the VMs to integrate
* @return the associated list of constraints
*/
public static List newRoots(Collection vms) {
return vms.stream().map(Root::new).collect(Collectors.toList());
}
}