Skip to content

Commit b382e24

Browse files
committed
Create VersionUtils class
Added a new utility class for looking up versions of classes.
1 parent c62d5d3 commit b382e24

File tree

1 file changed

+101
-0
lines changed

1 file changed

+101
-0
lines changed
Lines changed: 101 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,101 @@
1+
/*
2+
* #%L
3+
* SciJava Common shared library for SciJava software.
4+
* %%
5+
* Copyright (C) 2009 - 2014 Board of Regents of the University of
6+
* Wisconsin-Madison, Broad Institute of MIT and Harvard, and Max Planck
7+
* Institute of Molecular Cell Biology and Genetics.
8+
* %%
9+
* Redistribution and use in source and binary forms, with or without
10+
* modification, are permitted provided that the following conditions are met:
11+
*
12+
* 1. Redistributions of source code must retain the above copyright notice,
13+
* this list of conditions and the following disclaimer.
14+
* 2. Redistributions in binary form must reproduce the above copyright notice,
15+
* this list of conditions and the following disclaimer in the documentation
16+
* and/or other materials provided with the distribution.
17+
*
18+
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
19+
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
20+
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
21+
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE
22+
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
23+
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
24+
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
25+
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
26+
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
27+
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
28+
* POSSIBILITY OF SUCH DAMAGE.
29+
* #L%
30+
*/
31+
32+
package org.scijava.util;
33+
34+
/**
35+
* Useful methods for retrieving versions from JARs and POMs associated with
36+
* {@link Class} objects.
37+
*
38+
* @author Curtis Rueden
39+
* @author Mark Hiner
40+
*/
41+
public class VersionUtils {
42+
43+
/**
44+
* Looks up the version of the specified class using any means available. Will
45+
* only search POMs in the base directory.
46+
*
47+
* @param c - Look up this Class's version
48+
* @return Version of specified {@link Class} or null if not found.
49+
*/
50+
public static String getVersion(Class<?> c) {
51+
return getVersion(c, null, null);
52+
}
53+
54+
/**
55+
* Looks up the version of the specified class using any means available.
56+
* {@code groupId} and {@code artifactId} allow specification of the POM
57+
* lookup path.
58+
*
59+
* @param c - Look up this Class's version
60+
* @param groupId - GroupID containing class
61+
* @param artifactId - ArtifactID containing class
62+
* @return Version of specified {@link Class} or null if not found.
63+
*/
64+
public static String
65+
getVersion(Class<?> c, String groupId, String artifactId)
66+
{
67+
final String pomVersion = getVersionFromPOM(c, groupId, artifactId);
68+
return pomVersion != null ? pomVersion : getVersionFromManifest(c);
69+
}
70+
71+
/**
72+
* Looks up the version of the specified class using a JAR manifest if
73+
* available.
74+
*
75+
* @param c - Look up this Class's version
76+
* @return Version of specified {@link Class} or null if not found.
77+
*/
78+
public static String getVersionFromManifest(Class<?> c) {
79+
final Manifest m = Manifest.getManifest(c);
80+
if (m == null) return null;
81+
final String manifestVersion = m.getImplementationVersion();
82+
return manifestVersion == null ? null : m.getSpecificationVersion();
83+
}
84+
85+
/**
86+
* Looks up the version of the specified class using the specified POM, or
87+
* base POM directory if {@code groupId} and {@code artifactId} are
88+
* {@code null}.
89+
*
90+
* @param c - Look up this Class's version
91+
* @param groupId - GroupID containing class
92+
* @param artifactId - ArtifactID containing class
93+
* @return Version of specified {@link Class} or null if not found.
94+
*/
95+
public static String getVersionFromPOM(Class<?> c, String groupId,
96+
String artifactId)
97+
{
98+
final POM pom = POM.getPOM(c, groupId, artifactId);
99+
return pom == null ? null : pom.getVersion();
100+
}
101+
}

0 commit comments

Comments
 (0)