org.btrplace.json.model.constraint.ResourceCapacityConverter Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of scheduler-json Show documentation
Show all versions of scheduler-json Show documentation
Read and write model according to the JSON format
/*
* 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.json.model.constraint;
import net.minidev.json.JSONObject;
import org.btrplace.json.JSONConverterException;
import org.btrplace.model.Model;
import org.btrplace.model.constraint.ResourceCapacity;
import java.util.HashSet;
import static org.btrplace.json.JSONs.*;
/**
* JSON Converter for the constraint {@link ResourceCapacityConverter}.
*
* @author Fabien Hermenier
*/
public class ResourceCapacityConverter implements ConstraintConverter {
@Override
public Class getSupportedConstraint() {
return ResourceCapacity.class;
}
@Override
public String getJSONId() {
return "resourceCapacity";
}
@Override
public ResourceCapacity fromJSON(Model mo, JSONObject o) throws JSONConverterException {
checkId(o);
return new ResourceCapacity(new HashSet<>(requiredNodes(mo, o, "nodes")),
requiredString(o, "rc"),
requiredInt(o, "amount"),
requiredBoolean(o, "continuous"));
}
@Override
public JSONObject toJSON(ResourceCapacity o) {
JSONObject c = new JSONObject();
c.put("id", getJSONId());
c.put("nodes", nodesToJSON(o.getInvolvedNodes()));
c.put("rc", o.getResource());
c.put("amount", o.getAmount());
c.put("continuous", o.isContinuous());
return c;
}
}