Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance. Project price only 1 $
You can buy this project and download/modify it how often you want.
package org.opentripplanner.common;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.io.InputStream;
import java.io.Serializable;
import java.util.Properties;
public class MavenVersion implements Serializable {
private static final Logger LOG = LoggerFactory.getLogger(MavenVersion.class);
public static final MavenVersion VERSION = fromProperties();
private static final long serialVersionUID = VERSION.getUID();
/* Info derived from version string */
public final String version;
public final int major;
public final int minor;
public final int incremental;
public final String qualifier;
/* Other info from git-commit-id-plugin via maven-version.properties */
public final String commit;
public final String describe;
public final String commit_time;
public final String build_time;
private static MavenVersion fromProperties() {
final String FILE = "maven-version.properties";
try {
Properties props = new java.util.Properties();
InputStream in = MavenVersion.class.getClassLoader().getResourceAsStream(FILE);
props.load(in);
MavenVersion version = new MavenVersion(props.getProperty("project.version"),
props.getProperty("git.commit.id"),
props.getProperty("git.commit.id.describe"),
props.getProperty("git.commit.time"),
props.getProperty("git.build.time"));
LOG.debug("Parsed Maven artifact version: {}", version.toStringVerbose());
return version;
} catch (Exception e) {
LOG.error("Error reading version from properties file: {}", e.getMessage());
return new MavenVersion();
}
}
private MavenVersion () {
// JAXB Marshalling requires classes to have a 0-arg constructor and mutable fields.
// otherwise it throws a com.sun.xml.bind.v2.runtime.IllegalAnnotationsException.
// It is protecting you against yourself, since you might someday want to
// unmarshal that same object in Java.
// The 'proper' way of handling this is to make a mutable equivalent of your class,
// plus another adapter class that converts between the mutable and immutable
// versions. It would be absurd to produce so much boilerplate and verbosity in this
// situation, so I am providing a 0-arg constructor with a totally different role:
// generating a default version when OTP encounters a problem parsing the
// maven-version.properties file.
this("0.0.0-ParseFailure", "UNKNOWN", "UNKNOWN", "UNKNOWN", "UNKNOWN");
}
public MavenVersion (String version, String commit, String describe, String commit_time, String build_time) {
this.version = version;
String [] fields = version.split("\\-");
if (fields.length > 1)
qualifier = fields[1];
else
qualifier = "";
fields = fields[0].split("\\.");
if (fields.length > 0)
major = Integer.parseInt(fields[0]);
else
major = 0;
if (fields.length > 1)
minor = Integer.parseInt(fields[1]);
else
minor = 0;
if (fields.length > 2)
incremental = Integer.parseInt(fields[2]);
else
incremental = 0;
this.commit = commit;
this.describe = describe;
this.commit_time = commit_time;
this.build_time = build_time;
}
public long getUID() {
return (long) hashCode();
}
public String toString() {
return String.format("MavenVersion(%d, %d, %d, %s, %s)",
major, minor, incremental, qualifier, commit);
}
public String toStringVerbose() {
return String.format("%s => %s UID=%d", version, this.toString(), getUID());
}
public String getShortVersionString() {
return "OpenTripPlanner " + version + " " + commit;
}
public String getLongVersionString() {
String format = "version: %s\nmajor: %s\nminor: %s\npatch: %s\nqualifier: %s\ncommit: %s\n";
return String.format(format, version, major, minor, incremental, qualifier, commit);
}
public int hashCode () {
return (qualifier.equals("SNAPSHOT") ? -1 : +1) *
(1000000 * major + 1000 * minor + incremental);
}
public boolean equals (Object other) {
if ( ! (other instanceof MavenVersion))
return false;
MavenVersion that = (MavenVersion) other;
return this.major == that.major &&
this.minor == that.minor &&
this.incremental == that.incremental &&
this.qualifier.equals(that.qualifier);
}
}