net.ossindex.common.PackageCoordinate Maven / Gradle / Ivy
package net.ossindex.common;
import java.util.Objects;
import net.ossindex.version.IVersionRange;
import net.ossindex.version.InvalidRangeException;
import net.ossindex.version.VersionFactory;
public class PackageCoordinate
{
public final String format;
public final String namespace;
public final String name;
public final String version;
private PackageCoordinate(final Builder builder) {
format = builder.format;
namespace = builder.namespace;
name = builder.name;
version = builder.version;
}
public static Builder newBuilder() {
return new Builder();
}
public static Builder newBuilder(final PackageCoordinate copy) {
Builder builder = new Builder();
builder.format = copy.format;
builder.namespace = copy.namespace;
builder.name = copy.name;
builder.version = copy.version;
return builder;
}
public String getFormat() {
return format;
}
public String getNamespace() {
return namespace;
}
public String getName() {
return name;
}
public String getVersion() {
return version;
}
@Override
public int hashCode() {
// DIRTY HACK: Don't include version in the hash because we want to be forced to compare coordinates with
// different versions, cause if one coordinate specifies a version and the other does not then they are equivalent.
// We also need to use some custom version comparison code, since one will be a range, and the other a specific
// version and we will consider them equal if they overlap. This is a dirty misuse of the equals method.
int hashcode = Objects.hash(format, namespace, name);
return hashcode;
}
/**
* For our purposes we will allow coordinates to be equal if they overlap, even though technically they are different
* objects. This is a bit of a dirty hack to be able to force set to our will.
*/
@Override
public boolean equals(final Object obj) {
if (this == obj) {
return true;
}
if (obj == null || getClass() != obj.getClass()) {
return false;
}
final PackageCoordinate other = (PackageCoordinate) obj;
if (Objects.equals(this.format, other.format)
&& Objects.equals(this.namespace, other.namespace)
&& Objects.equals(this.name, other.name)) {
// Do versions overlap
if (other.version == null || this.version == null) {
return true;
}
try {
IVersionRange orange = VersionFactory.getVersionFactory().getRange(other.version);
IVersionRange range = VersionFactory.getVersionFactory().getRange(this.version);
if (orange.intersects(range)) {
return true;
}
}
catch (InvalidRangeException e) {
e.printStackTrace();
}
}
return false;
}
public static final class Builder
{
private String format;
private String namespace;
private String name;
private String version;
private Builder() {}
public Builder withFormat(final String val) {
format = val == null || val.trim().isEmpty() ? null : val;
return this;
}
public Builder withNamespace(final String val) {
namespace = val == null || val.trim().isEmpty() ? null : val;
return this;
}
public Builder withName(final String val) {
name = val == null || val.trim().isEmpty() ? null : val;
return this;
}
public Builder withVersion(final String val) {
version = val == null || val.trim().isEmpty() ? null : val;
return this;
}
public PackageCoordinate build() {
return new PackageCoordinate(this);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy