com.prezi.pride.ivyversions.ExactVersionMatcher Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of gradle-pride-plugin Show documentation
Show all versions of gradle-pride-plugin Show documentation
Pride manages multiple Gradle modules as a single Gradle project
The newest version!
package com.prezi.pride.ivyversions;
import com.google.common.collect.ImmutableMap;
import java.util.Locale;
import java.util.Map;
/**
* Version matcher for "static" version selectors (1.0, 1.2.3, etc.).
*/
public class ExactVersionMatcher implements VersionMatcher {
private static final Map SPECIAL_MEANINGS =
ImmutableMap.of("dev", new Integer(-1), "rc", new Integer(1), "final", new Integer(2));
@Override
public boolean canHandle(String selector) {
return true;
}
@Override
public boolean accept(String selector, String candidate) {
return selector.equals(candidate);
}
/**
* Compares a static selector with a candidate version. Algorithm is inspired
* by PHP version_compare one.
*
* TODO: compare() is inconsistent with accept(), because not everything
* that compares equal is accepted (e.g. 1.0 vs. 1_0). Can this cause problems?
*/
@Override
public int compare(String selector, String candidate) {
if (selector.equals(candidate)) {
return 0;
}
selector = selector.replaceAll("([a-zA-Z])(\\d)", "$1.$2");
selector = selector.replaceAll("(\\d)([a-zA-Z])", "$1.$2");
candidate = candidate.replaceAll("([a-zA-Z])(\\d)", "$1.$2");
candidate = candidate.replaceAll("(\\d)([a-zA-Z])", "$1.$2");
String[] parts1 = selector.split("[\\._\\-\\+]");
String[] parts2 = candidate.split("[\\._\\-\\+]");
int i = 0;
for (; i < parts1.length && i < parts2.length; i++) {
if (parts1[i].equals(parts2[i])) {
continue;
}
boolean is1Number = isNumber(parts1[i]);
boolean is2Number = isNumber(parts2[i]);
if (is1Number && !is2Number) {
return 1;
}
if (is2Number && !is1Number) {
return -1;
}
if (is1Number && is2Number) {
return Long.valueOf(parts1[i]).compareTo(Long.valueOf(parts2[i]));
}
// both are strings, we compare them taking into account special meaning
Integer sm1 = SPECIAL_MEANINGS.get(parts1[i].toLowerCase(Locale.US));
Integer sm2 = SPECIAL_MEANINGS.get(parts2[i].toLowerCase(Locale.US));
if (sm1 != null) {
sm2 = sm2 == null ? 0 : sm2;
return sm1 - sm2;
}
if (sm2 != null) {
return -sm2;
}
return parts1[i].compareTo(parts2[i]);
}
if (i < parts1.length) {
return isNumber(parts1[i]) ? 1 : -1;
}
if (i < parts2.length) {
return isNumber(parts2[i]) ? -1 : 1;
}
return 0;
}
private boolean isNumber(String str) {
return str.matches("\\d+");
}
}