/** * Copyright (C) 2001-2017 by RapidMiner and the contributors * * Complete list of developers available at our web site: * * http://rapidminer.com * * This program is free software: you can redistribute it and/or modify it under the terms of the * GNU Affero General Public License as published by the Free Software Foundation, either version 3 * of the License, or (at your option) any later version. * * This program 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 * Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License along with this program. * If not, see http://www.gnu.org/licenses/. */ package com.rapidminer.tools.plugin; import java.util.Collection; import java.util.Collections; import java.util.Iterator; import java.util.LinkedList; import java.util.List; /** * A plugin dependency defines the name and version of a desired plugin. * * @author Ingo Mierswa */ public class Dependency { /** The name of the desired plugin. */ private String extensionId; /** The version of the desired plugin. */ private String version; /** Create a new plugin dependency. */ public Dependency(String name, String version) { this.extensionId = name; this.version = version; } /** * Returns true if the set contains a extension with the desired name and version. */ public boolean isFulfilled(Collection<Plugin> plugins) { Iterator<Plugin> i = plugins.iterator(); while (i.hasNext()) { Plugin plugin = i.next(); if (plugin.getExtensionId().equals(this.extensionId) && ManagedExtension.normalizeVersion(plugin.getVersion()) .compareTo(ManagedExtension.normalizeVersion(this.version)) >= 0) { return true; } } return false; } public String getPluginExtensionId() { return extensionId; } public String getPluginVersion() { return version; } @Override public String toString() { return extensionId + " (" + version + ")"; } public static List<Dependency> parse(String dependencyString) { if (dependencyString == null || dependencyString.isEmpty()) { return Collections.emptyList(); } List<Dependency> result = new LinkedList<Dependency>(); String[] singleDependencies = dependencyString.trim().split(";"); for (int i = 0; i < singleDependencies.length; i++) { if (singleDependencies[i].trim().length() > 0) { String dependencyName = singleDependencies[i].trim(); String dependencyVersion = "0"; if (singleDependencies[i].trim().indexOf("[") >= 0) { dependencyName = singleDependencies[i].trim().substring(0, singleDependencies[i].trim().indexOf("[")) .trim(); dependencyVersion = singleDependencies[i].trim().substring(singleDependencies[i].trim().indexOf("[") + 1, singleDependencies[i].trim().indexOf("]")).trim(); } result.add(new Dependency(dependencyName, dependencyVersion)); } } return result; } }