Process fragments directly instead of maven2-depmap.xml
Fragments are also expected in /usr/share/maven-fragments where they should be moved (backward compat preserved for now). Big changes are due to reformatting to use spaces (sorry, cleaner log/diff in separate resolver repo)
This commit is contained in:
parent
70f23c4306
commit
bdbc16d2c1
@ -11,16 +11,12 @@ import org.sonatype.aether.repository.WorkspaceReader;
|
||||
import org.sonatype.aether.repository.WorkspaceRepository;
|
||||
import org.sonatype.aether.artifact.Artifact;
|
||||
|
||||
|
||||
public class JavadirWorkspaceReader
|
||||
implements WorkspaceReader
|
||||
{
|
||||
public class JavadirWorkspaceReader implements WorkspaceReader {
|
||||
private WorkspaceRepository workspaceRepository;
|
||||
|
||||
private static final char GROUP_SEPARATOR = '.';
|
||||
private static final char PATH_SEPARATOR = '/';
|
||||
|
||||
|
||||
public JavadirWorkspaceReader() {
|
||||
workspaceRepository = new WorkspaceRepository("javadir-workspace");
|
||||
}
|
||||
@ -29,8 +25,9 @@ public class JavadirWorkspaceReader
|
||||
return workspaceRepository;
|
||||
}
|
||||
|
||||
public File findArtifact( Artifact artifact ) {
|
||||
MavenJPackageDepmap.debug("=============JAVADIRREADER-FIND_ARTIFACT: " + artifact.getArtifactId());
|
||||
public File findArtifact(Artifact artifact) {
|
||||
MavenJPackageDepmap.debug("=============JAVADIRREADER-FIND_ARTIFACT: "
|
||||
+ artifact.getArtifactId());
|
||||
StringBuffer path = new StringBuffer();
|
||||
|
||||
String artifactId = artifact.getArtifactId();
|
||||
@ -42,7 +39,8 @@ public class JavadirWorkspaceReader
|
||||
|
||||
if (!groupId.startsWith("JPP")) {
|
||||
MavenJPackageDepmap map = MavenJPackageDepmap.getInstance();
|
||||
Hashtable<String,String> newInfo = map.getMappedInfo(groupId, artifactId, version);
|
||||
Hashtable<String, String> newInfo = map.getMappedInfo(groupId,
|
||||
artifactId, version);
|
||||
|
||||
groupId = (String) newInfo.get("group");
|
||||
artifactId = (String) newInfo.get("artifact");
|
||||
@ -54,32 +52,33 @@ public class JavadirWorkspaceReader
|
||||
path = getPOMPath(groupId, artifactId);
|
||||
} else if (artifact.getExtension().equals("signature")) {
|
||||
path.append("/usr/share/maven/repository/");
|
||||
path.append( groupId ).append( '/' );
|
||||
path.append( artifactId ).append( ".signature" );
|
||||
path.append(groupId).append('/');
|
||||
path.append(artifactId).append(".signature");
|
||||
} else if (artifact.getExtension().equals("zip")) {
|
||||
path.append("/usr/share/maven/repository/");
|
||||
path.append( groupId ).append( '/' );
|
||||
path.append( artifactId ).append( ".zip" );
|
||||
path.append(groupId).append('/');
|
||||
path.append(artifactId).append(".zip");
|
||||
} else {
|
||||
path.append("/usr/share/maven/repository/");
|
||||
path.append( groupId ).append( '/' );
|
||||
path.append( artifactId ).append( ".jar" );
|
||||
path.append(groupId).append('/');
|
||||
path.append(artifactId).append(".jar");
|
||||
}
|
||||
|
||||
MavenJPackageDepmap.debug("Returning " + path.toString());
|
||||
File ret = new File(path.toString());
|
||||
// if file doesn't exist return null to delegate to other
|
||||
// resolvers (reactor/local repo)
|
||||
if ( ret.isFile() ) {
|
||||
if (ret.isFile()) {
|
||||
MavenJPackageDepmap.debug("Returning " + path.toString());
|
||||
return ret;
|
||||
} else {
|
||||
MavenJPackageDepmap.debug("Returning null for gid:aid =>" + groupId + ":" + artifactId);
|
||||
MavenJPackageDepmap.debug("Returning null for gid:aid =>" + groupId
|
||||
+ ":" + artifactId);
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
||||
public List<String> findVersions( Artifact artifact ) {
|
||||
public List<String> findVersions(Artifact artifact) {
|
||||
List<String> ret = new LinkedList<String>();
|
||||
ret.add("latest");
|
||||
return ret;
|
||||
@ -87,25 +86,30 @@ public class JavadirWorkspaceReader
|
||||
|
||||
private StringBuffer getPOMPath(String groupId, String artifactId) {
|
||||
|
||||
String fName = groupId.replace(PATH_SEPARATOR, GROUP_SEPARATOR) + "-" + artifactId + ".pom";
|
||||
String m2path = System.getProperty("maven2.local.pom.path", "JPP/maven2/poms") + "/" + fName;
|
||||
String m3path = System.getProperty("maven.local.pom.path", "JPP/maven/poms") + "/" + fName;
|
||||
String fName = groupId.replace(PATH_SEPARATOR, GROUP_SEPARATOR) + "-"
|
||||
+ artifactId + ".pom";
|
||||
String m2path = System.getProperty("maven2.local.pom.path",
|
||||
"JPP/maven2/poms") + "/" + fName;
|
||||
String m3path = System.getProperty("maven.local.pom.path",
|
||||
"JPP/maven/poms") + "/" + fName;
|
||||
File f;
|
||||
|
||||
// let's try maven 2 repo first
|
||||
f = new File(System.getProperty("maven2.local.default.repo", "/usr/share/maven2/repository") + "/" + m2path);
|
||||
if ( f.exists() ) {
|
||||
f = new File(System.getProperty("maven2.local.default.repo",
|
||||
"/usr/share/maven2/repository") + "/" + m2path);
|
||||
if (f.exists()) {
|
||||
return new StringBuffer(f.getPath());
|
||||
}
|
||||
|
||||
f = new File(System.getProperty("maven.local.default.repo", "/usr/share/maven/repository") + "/" + m3path);
|
||||
if ( f.exists() ) {
|
||||
f = new File(System.getProperty("maven.local.default.repo",
|
||||
"/usr/share/maven/repository") + "/" + m3path);
|
||||
if (f.exists()) {
|
||||
return new StringBuffer(f.getPath());
|
||||
}
|
||||
|
||||
// final fallback to m2 default poms
|
||||
return new StringBuffer("/usr/share/maven2/repository/" +
|
||||
System.getProperty("maven.local.default.repo", "JPP/maven2/default_poms") +
|
||||
"/" + fName);
|
||||
return new StringBuffer("/usr/share/maven2/repository/"
|
||||
+ System.getProperty("maven.local.default.repo",
|
||||
"JPP/maven2/default_poms") + "/" + fName);
|
||||
}
|
||||
}
|
||||
|
@ -1,8 +1,10 @@
|
||||
package org.apache.maven.artifact.repository;
|
||||
|
||||
|
||||
import java.io.File;
|
||||
import java.io.FileInputStream;
|
||||
import java.io.FileNotFoundException;
|
||||
import java.io.IOException;
|
||||
import java.io.InputStream;
|
||||
import java.util.Hashtable;
|
||||
import java.util.StringTokenizer;
|
||||
|
||||
@ -10,12 +12,11 @@ import javax.xml.parsers.DocumentBuilder;
|
||||
import javax.xml.parsers.DocumentBuilderFactory;
|
||||
import javax.xml.parsers.ParserConfigurationException;
|
||||
|
||||
|
||||
import org.w3c.dom.Document;
|
||||
import org.w3c.dom.Element;
|
||||
import org.w3c.dom.NodeList;
|
||||
import org.xml.sax.SAXException;
|
||||
|
||||
import org.w3c.dom.*;
|
||||
|
||||
|
||||
public class MavenJPackageDepmap {
|
||||
|
||||
private static class ArtifactDefinition {
|
||||
@ -24,11 +25,55 @@ public class MavenJPackageDepmap {
|
||||
String version = null;
|
||||
}
|
||||
|
||||
/**
|
||||
*
|
||||
* @author Stanislav Ochotnicky <sochotnicky@redhat.com>
|
||||
*
|
||||
* This class is used to wrap around fragments that are mapping
|
||||
* artifacts to jar files in our _javadir. These used to be
|
||||
* processed in a macro after every package installation. Fragments
|
||||
* themselves are not proper xml files (they have no root element)
|
||||
* so we have to fix them by wrapping them in one root element.
|
||||
*/
|
||||
private static class WrapFragmentStream extends InputStream {
|
||||
String startTag = "<deps>";
|
||||
String endTag = "</deps>";
|
||||
byte fragmentContent[];
|
||||
int position;
|
||||
|
||||
WrapFragmentStream(String fragmentPath) throws IOException {
|
||||
FileInputStream fin = new FileInputStream(fragmentPath);
|
||||
int nBytes = fin.available();
|
||||
byte tmpContent[] = new byte[nBytes];
|
||||
fin.read(tmpContent);
|
||||
fin.close();
|
||||
byte startBytes[] = startTag.getBytes();
|
||||
byte endBytes[] = endTag.getBytes();
|
||||
fragmentContent = new byte[nBytes + startBytes.length
|
||||
+ endBytes.length];
|
||||
System.arraycopy(startBytes, 0, fragmentContent, 0,
|
||||
startBytes.length);
|
||||
System.arraycopy(tmpContent, 0, fragmentContent, startBytes.length,
|
||||
tmpContent.length);
|
||||
System.arraycopy(endBytes, 0, fragmentContent, startBytes.length
|
||||
+ tmpContent.length, endBytes.length);
|
||||
position = 0;
|
||||
}
|
||||
|
||||
public int read() throws IOException {
|
||||
if (position < fragmentContent.length) {
|
||||
return fragmentContent[position++];
|
||||
} else {
|
||||
return -1;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private static MavenJPackageDepmap instance;
|
||||
private static Hashtable<String, String> jppArtifactMap;
|
||||
|
||||
private MavenJPackageDepmap() {
|
||||
jppArtifactMap = new Hashtable<String,String>();
|
||||
jppArtifactMap = new Hashtable<String, String>();
|
||||
buildJppArtifactMap();
|
||||
}
|
||||
|
||||
@ -40,26 +85,30 @@ public class MavenJPackageDepmap {
|
||||
return instance;
|
||||
}
|
||||
|
||||
public Hashtable<String, String> getMappedInfo(Hashtable<String, String> mavenDep) {
|
||||
public Hashtable<String, String> getMappedInfo(
|
||||
Hashtable<String, String> mavenDep) {
|
||||
return getMappedInfo((String) mavenDep.get("group"),
|
||||
(String) mavenDep.get("artifact"),
|
||||
(String) mavenDep.get("version"));
|
||||
}
|
||||
|
||||
public Hashtable<String, String> getMappedInfo(String groupId, String artifactId, String version) {
|
||||
public Hashtable<String, String> getMappedInfo(String groupId,
|
||||
String artifactId, String version) {
|
||||
|
||||
Hashtable<String, String> jppDep;
|
||||
String idToCheck, jppCombination;
|
||||
|
||||
if (System.getProperty("maven.ignore.versions") == null && System.getProperty("maven.local.mode") == null) {
|
||||
idToCheck = groupId+","+artifactId+","+version;
|
||||
if (System.getProperty("maven.ignore.versions") == null
|
||||
&& System.getProperty("maven.local.mode") == null) {
|
||||
idToCheck = groupId + "," + artifactId + "," + version;
|
||||
} else {
|
||||
idToCheck = groupId+","+artifactId;
|
||||
idToCheck = groupId + "," + artifactId;
|
||||
}
|
||||
|
||||
jppCombination = (String) jppArtifactMap.get(idToCheck);
|
||||
|
||||
//System.err.println("*** " + groupId+","+artifactId+","+version + " => " + jppCombination);
|
||||
// System.err.println("*** " + groupId+","+artifactId+","+version +
|
||||
// " => " + jppCombination);
|
||||
|
||||
jppDep = new Hashtable<String, String>();
|
||||
if (jppCombination != null && jppCombination != "") {
|
||||
@ -67,8 +116,8 @@ public class MavenJPackageDepmap {
|
||||
StringTokenizer st = new StringTokenizer(jppCombination, ",");
|
||||
|
||||
jppDep.put("group", st.nextToken());
|
||||
jppDep.put("artifact",st.nextToken());
|
||||
jppDep.put("version",st.nextToken());
|
||||
jppDep.put("artifact", st.nextToken());
|
||||
jppDep.put("version", st.nextToken());
|
||||
|
||||
} else {
|
||||
jppDep.put("group", groupId);
|
||||
@ -79,38 +128,55 @@ public class MavenJPackageDepmap {
|
||||
return jppDep;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Returns whether or not the given dependency should be dropped.
|
||||
*/
|
||||
public boolean shouldEliminate(String groupId, String artifactId, String version) {
|
||||
public boolean shouldEliminate(String groupId, String artifactId,
|
||||
String version) {
|
||||
String idToCheck;
|
||||
|
||||
if (System.getProperty("maven.ignore.versions") == null && System.getProperty("maven.local.mode") == null) {
|
||||
idToCheck = groupId+","+artifactId+","+version;
|
||||
if (System.getProperty("maven.ignore.versions") == null
|
||||
&& System.getProperty("maven.local.mode") == null) {
|
||||
idToCheck = groupId + "," + artifactId + "," + version;
|
||||
} else {
|
||||
idToCheck = groupId+","+artifactId;
|
||||
idToCheck = groupId + "," + artifactId;
|
||||
}
|
||||
|
||||
return jppArtifactMap.get(idToCheck) != null && jppArtifactMap.get(idToCheck).equals("");
|
||||
return jppArtifactMap.get(idToCheck) != null
|
||||
&& jppArtifactMap.get(idToCheck).equals("");
|
||||
|
||||
}
|
||||
|
||||
private static void buildJppArtifactMap() {
|
||||
|
||||
if (System.getProperty("maven.ignore.versions") != null || System.getProperty("maven.local.mode") != null) {
|
||||
if (System.getProperty("maven.ignore.versions") != null
|
||||
|| System.getProperty("maven.local.mode") != null) {
|
||||
debug("Processing file: /usr/share/java-utils/xml/maven2-versionless-depmap.xml");
|
||||
processDepmapFile("/etc/maven/maven2-versionless-depmap.xml");
|
||||
}
|
||||
|
||||
debug("Processing file: /usr/share/java-utils/xml/maven2-depmap.xml");
|
||||
processDepmapFile("/etc/maven/maven2-depmap.xml");
|
||||
// process fragments in etc
|
||||
File fragmentDir = new File("/etc/maven/fragments");
|
||||
String flist[] = fragmentDir.list();
|
||||
if (flist != null)
|
||||
for (String fragFilename : flist)
|
||||
processDepmapFile("/etc/maven/fragments/" + fragFilename);
|
||||
|
||||
String customFileName = System.getProperty("maven.local.depmap.file", null);
|
||||
// process fragments is usr. Once packages are rebuilt, we can skip
|
||||
// fragments in /etc
|
||||
fragmentDir = new File("/usr/share/maven-fragments");
|
||||
flist = fragmentDir.list();
|
||||
if (flist != null)
|
||||
for (String fragFilename : flist)
|
||||
processDepmapFile("/usr/share/maven-fragments/" + fragFilename);
|
||||
|
||||
String customFileName = System.getProperty("maven.local.depmap.file",
|
||||
null);
|
||||
if (customFileName != null) {
|
||||
debug("Processing file: " + customFileName);
|
||||
processDepmapFile(customFileName);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
private static void processDepmapFile(String fileName) {
|
||||
@ -121,17 +187,22 @@ public class MavenJPackageDepmap {
|
||||
DocumentBuilderFactory fact = DocumentBuilderFactory.newInstance();
|
||||
fact.setNamespaceAware(true);
|
||||
DocumentBuilder builder = fact.newDocumentBuilder();
|
||||
mapDocument = builder.parse(fileName);
|
||||
// we can wrap even old depmaps, no harm done
|
||||
WrapFragmentStream wfs = new WrapFragmentStream(fileName);
|
||||
mapDocument = builder.parse(wfs);
|
||||
wfs.close();
|
||||
} catch (FileNotFoundException fnfe) {
|
||||
System.err.println("ERROR: Unable to find map file: " + fileName);
|
||||
fnfe.printStackTrace();
|
||||
return;
|
||||
} catch (IOException ioe) {
|
||||
System.err.println("ERROR: I/O exception occured when opening map file");
|
||||
System.err
|
||||
.println("ERROR: I/O exception occured when opening map file");
|
||||
ioe.printStackTrace();
|
||||
return;
|
||||
} catch (ParserConfigurationException pce) {
|
||||
System.err.println("ERROR: Parsing of depmap file failed - configuration");
|
||||
System.err
|
||||
.println("ERROR: Parsing of depmap file failed - configuration");
|
||||
pce.printStackTrace();
|
||||
return;
|
||||
} catch (SAXException se) {
|
||||
@ -140,41 +211,57 @@ public class MavenJPackageDepmap {
|
||||
return;
|
||||
}
|
||||
|
||||
NodeList depNodes = (NodeList) mapDocument.getElementsByTagName("dependency");
|
||||
NodeList depNodes = (NodeList) mapDocument
|
||||
.getElementsByTagName("dependency");
|
||||
|
||||
for (int i = 0; i < depNodes.getLength(); i++) {
|
||||
Element depNode = (Element) depNodes.item(i);
|
||||
|
||||
NodeList mavenNodeList = (NodeList) depNode.getElementsByTagName("maven");
|
||||
NodeList mavenNodeList = (NodeList) depNode
|
||||
.getElementsByTagName("maven");
|
||||
if (mavenNodeList.getLength() != 1) {
|
||||
debug("Number of maven sub-elements is not 1. Bailing from depmap generation");
|
||||
debug("Maven node: " + depNode.getTextContent());
|
||||
return;
|
||||
}
|
||||
ArtifactDefinition mavenAD = getArtifactDefinition((Element) mavenNodeList.item(0));
|
||||
ArtifactDefinition mavenAD = getArtifactDefinition((Element) mavenNodeList
|
||||
.item(0));
|
||||
|
||||
ArtifactDefinition jppAD = null;
|
||||
NodeList jppNodeList = (NodeList) depNode.getElementsByTagName("jpp");
|
||||
NodeList jppNodeList = (NodeList) depNode
|
||||
.getElementsByTagName("jpp");
|
||||
|
||||
if (jppNodeList.getLength() == 1) {
|
||||
jppAD = getArtifactDefinition((Element) jppNodeList.item(0));
|
||||
if (System.getProperty("maven.ignore.versions") == null && System.getProperty("maven.local.mode") == null) {
|
||||
debug("*** Adding: " + mavenAD.groupId + "," + mavenAD.artifactId + "," + mavenAD.version + " => "
|
||||
+ jppAD.groupId + "," + jppAD.artifactId + "," + jppAD.version + " to map...");
|
||||
if (System.getProperty("maven.ignore.versions") == null
|
||||
&& System.getProperty("maven.local.mode") == null) {
|
||||
debug("*** Adding: " + mavenAD.groupId + ","
|
||||
+ mavenAD.artifactId + "," + mavenAD.version
|
||||
+ " => " + jppAD.groupId + "," + jppAD.artifactId
|
||||
+ "," + jppAD.version + " to map...");
|
||||
|
||||
jppArtifactMap.put(mavenAD.groupId + "," + mavenAD.artifactId + "," + mavenAD.version,
|
||||
jppAD.groupId + "," + jppAD.artifactId + "," + jppAD.version);
|
||||
jppArtifactMap.put(mavenAD.groupId + ","
|
||||
+ mavenAD.artifactId + "," + mavenAD.version,
|
||||
jppAD.groupId + "," + jppAD.artifactId + ","
|
||||
+ jppAD.version);
|
||||
} else {
|
||||
debug("*** Adding: " + mavenAD.groupId+"," + mavenAD.artifactId + " => "
|
||||
+ jppAD.groupId + "," + jppAD.artifactId + "," + jppAD.version + " to map...");
|
||||
debug("*** Adding: " + mavenAD.groupId + ","
|
||||
+ mavenAD.artifactId + " => " + jppAD.groupId + ","
|
||||
+ jppAD.artifactId + "," + jppAD.version
|
||||
+ " to map...");
|
||||
|
||||
jppArtifactMap.put(mavenAD.groupId+","+mavenAD.artifactId,
|
||||
jppAD.groupId + "," + jppAD.artifactId + "," + jppAD.version);
|
||||
jppArtifactMap.put(mavenAD.groupId + ","
|
||||
+ mavenAD.artifactId, jppAD.groupId + ","
|
||||
+ jppAD.artifactId + "," + jppAD.version);
|
||||
}
|
||||
} else {
|
||||
debug("Number of jpp sub-elements is not 1. Dropping dependency");
|
||||
debug("*** Adding: " + mavenAD.groupId+","+mavenAD.artifactId+"," + " => " + "JPP/maven2,empty-dep,"+mavenAD.version + " to map...");
|
||||
jppArtifactMap.put(mavenAD.groupId+","+mavenAD.artifactId, "JPP/maven2,empty-dep,"+mavenAD.version);
|
||||
debug("*** Adding: " + mavenAD.groupId + ","
|
||||
+ mavenAD.artifactId + "," + " => "
|
||||
+ "JPP/maven2,empty-dep," + mavenAD.version
|
||||
+ " to map...");
|
||||
jppArtifactMap.put(mavenAD.groupId + "," + mavenAD.artifactId,
|
||||
"JPP/maven2,empty-dep," + mavenAD.version);
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -205,7 +292,6 @@ public class MavenJPackageDepmap {
|
||||
return ad;
|
||||
}
|
||||
|
||||
|
||||
public static void debug(String msg) {
|
||||
if (System.getProperty("maven.local.debug") != null)
|
||||
System.err.println(msg);
|
||||
|
@ -1,7 +1,7 @@
|
||||
|
||||
Name: maven
|
||||
Version: 3.0.3
|
||||
Release: 4%{?dist}
|
||||
Release: 5%{?dist}
|
||||
Summary: Java project management and project comprehension tool
|
||||
|
||||
Group: Development/Tools
|
||||
@ -308,6 +308,9 @@ cp -pr target/site/apidocs/* $RPM_BUILD_ROOT%{_javadocdir}/%{name}
|
||||
|
||||
|
||||
%changelog
|
||||
* Fri Jun 10 2011 Stanislav Ochotnicky <sochotnicky@redhat.com> - 3.0.3-5
|
||||
- Process fragments directly instead of maven2-depmap.xml
|
||||
|
||||
* Mon Jun 6 2011 Stanislav Ochotnicky <sochotnicky@redhat.com> - 3.0.3-4
|
||||
- Add help to mvn-rpmbuild and mvn-local (rhbz#710448)
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user