mirror of https://github.com/apache/maven.git
PR: MNG-458
merge components.xml files git-svn-id: https://svn.apache.org/repos/asf/maven/components/trunk@326629 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
aa51fda6a5
commit
60cfb93baf
|
@ -51,6 +51,7 @@ import java.io.IOException;
|
|||
import java.io.InputStream;
|
||||
import java.io.InputStreamReader;
|
||||
import java.io.Reader;
|
||||
import java.util.ArrayList;
|
||||
import java.util.Iterator;
|
||||
import java.util.List;
|
||||
import java.util.regex.Matcher;
|
||||
|
@ -133,6 +134,8 @@ public class AssemblyMojo
|
|||
*/
|
||||
private boolean includeSite;
|
||||
|
||||
private ComponentsXmlArchiverFileFilter componentsXmlFilter = new ComponentsXmlArchiverFileFilter();
|
||||
|
||||
/**
|
||||
* Create the binary distribution.
|
||||
*
|
||||
|
@ -145,7 +148,6 @@ public class AssemblyMojo
|
|||
|
||||
// TODO: include dependencies marked for distribution under certain formats
|
||||
// TODO: how, might we plug this into an installer, such as NSIS?
|
||||
// TODO: allow file mode specifications?
|
||||
|
||||
String fullName = getDistributionName( assembly );
|
||||
|
||||
|
@ -174,6 +176,10 @@ public class AssemblyMojo
|
|||
{
|
||||
throw new MojoExecutionException( "Error creating assembly: " + e.getMessage(), e );
|
||||
}
|
||||
catch ( XmlPullParserException e )
|
||||
{
|
||||
throw new MojoExecutionException( "Error creating assembly: " + e.getMessage(), e );
|
||||
}
|
||||
|
||||
projectHelper.attachArtifact( project, format, assembly.getId(), destFile );
|
||||
}
|
||||
|
@ -196,12 +202,14 @@ public class AssemblyMojo
|
|||
}
|
||||
|
||||
protected File createArchive( Archiver archiver, Assembly assembly, String filename )
|
||||
throws ArchiverException, IOException, MojoExecutionException, MojoFailureException
|
||||
throws ArchiverException, IOException, MojoExecutionException, MojoFailureException, XmlPullParserException
|
||||
{
|
||||
File destFile;
|
||||
processDependencySets( archiver, assembly.getDependencySets(), assembly.isIncludeBaseDirectory() );
|
||||
processFileSets( archiver, assembly.getFileSets(), assembly.isIncludeBaseDirectory() );
|
||||
|
||||
componentsXmlFilter.addToArchive( archiver );
|
||||
|
||||
destFile = new File( outputDirectory, filename );
|
||||
archiver.setDestFile( destFile );
|
||||
archiver.createArchive();
|
||||
|
@ -274,7 +282,7 @@ public class AssemblyMojo
|
|||
* @param includeBaseDirectory
|
||||
*/
|
||||
protected void processDependencySets( Archiver archiver, List dependencySets, boolean includeBaseDirectory )
|
||||
throws ArchiverException, IOException, MojoExecutionException, MojoFailureException
|
||||
throws ArchiverException, IOException, MojoExecutionException, MojoFailureException, XmlPullParserException
|
||||
{
|
||||
for ( Iterator i = dependencySets.iterator(); i.hasNext(); )
|
||||
{
|
||||
|
@ -286,10 +294,9 @@ public class AssemblyMojo
|
|||
|
||||
archiver.setDefaultFileMode( Integer.parseInt( dependencySet.getFileMode(), 8 ) );
|
||||
|
||||
getLog().debug(
|
||||
"DependencySet[" + output + "]" + " dir perms: "
|
||||
+ Integer.toString( archiver.getDefaultDirectoryMode(), 8 ) + " file perms: "
|
||||
+ Integer.toString( archiver.getDefaultFileMode(), 8 ) );
|
||||
getLog().debug( "DependencySet[" + output + "]" + " dir perms: " +
|
||||
Integer.toString( archiver.getDefaultDirectoryMode(), 8 ) + " file perms: " +
|
||||
Integer.toString( archiver.getDefaultFileMode(), 8 ) );
|
||||
|
||||
AndArtifactFilter filter = new AndArtifactFilter();
|
||||
filter.add( new ScopeArtifactFilter( dependencySet.getScope() ) );
|
||||
|
@ -338,22 +345,38 @@ public class AssemblyMojo
|
|||
}
|
||||
catch ( NoSuchArchiverException e )
|
||||
{
|
||||
throw new MojoExecutionException( "Unable to obtain unarchiver for file '"
|
||||
+ artifact.getFile() + "'" );
|
||||
throw new MojoExecutionException(
|
||||
"Unable to obtain unarchiver for file '" + artifact.getFile() + "'" );
|
||||
}
|
||||
}
|
||||
archiver.addDirectory( tempLocation, output, null, FileUtils.getDefaultExcludes() );
|
||||
|
||||
addDirectory( archiver, tempLocation, output, null, FileUtils.getDefaultExcludesAsList() );
|
||||
}
|
||||
else
|
||||
{
|
||||
archiver.addFile( artifact.getFile(), output
|
||||
+ evaluateFileNameMapping( dependencySet.getOutputFileNameMapping(), artifact ) );
|
||||
archiver.addFile( artifact.getFile(), output +
|
||||
evaluateFileNameMapping( dependencySet.getOutputFileNameMapping(), artifact ) );
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private void addDirectory( Archiver archiver, File directory, String output, String[] includes, List excludes )
|
||||
throws IOException, XmlPullParserException, ArchiverException
|
||||
{
|
||||
// TODO: more robust set of filters on added files in the archiver
|
||||
File componentsXml = new File( directory, ComponentsXmlArchiverFileFilter.COMPONENTS_XML_PATH );
|
||||
if ( componentsXml.exists() )
|
||||
{
|
||||
componentsXmlFilter.addComponentsXml( componentsXml );
|
||||
excludes = new ArrayList( excludes );
|
||||
excludes.add( ComponentsXmlArchiverFileFilter.COMPONENTS_XML_PATH );
|
||||
}
|
||||
|
||||
archiver.addDirectory( directory, output, includes, (String[]) excludes.toArray( EMPTY_STRING_ARRAY ) );
|
||||
}
|
||||
|
||||
/**
|
||||
* Process Files that will be included in the distribution.
|
||||
*
|
||||
|
@ -363,7 +386,7 @@ public class AssemblyMojo
|
|||
* @throws ArchiverException
|
||||
*/
|
||||
protected void processFileSets( Archiver archiver, List fileSets, boolean includeBaseDirecetory )
|
||||
throws ArchiverException
|
||||
throws ArchiverException, IOException, XmlPullParserException
|
||||
{
|
||||
for ( Iterator i = fileSets.iterator(); i.hasNext(); )
|
||||
{
|
||||
|
@ -386,11 +409,10 @@ public class AssemblyMojo
|
|||
archiver.setDefaultFileMode( Integer.parseInt( fileSet.getFileMode(), 8 ) );
|
||||
|
||||
getLog()
|
||||
.debug(
|
||||
"FileSet[" + output + "]" + " dir perms: "
|
||||
+ Integer.toString( archiver.getDefaultDirectoryMode(), 8 ) + " file perms: "
|
||||
+ Integer.toString( archiver.getDefaultFileMode(), 8 )
|
||||
+ ( fileSet.getLineEnding() == null ? "" : " lineEndings: " + fileSet.getLineEnding() ) );
|
||||
.debug( "FileSet[" + output + "]" + " dir perms: " +
|
||||
Integer.toString( archiver.getDefaultDirectoryMode(), 8 ) + " file perms: " +
|
||||
Integer.toString( archiver.getDefaultFileMode(), 8 ) +
|
||||
( fileSet.getLineEnding() == null ? "" : " lineEndings: " + fileSet.getLineEnding() ) );
|
||||
|
||||
if ( directory == null )
|
||||
{
|
||||
|
@ -429,7 +451,7 @@ public class AssemblyMojo
|
|||
archiveBaseDir = tmpDir;
|
||||
}
|
||||
|
||||
archiver.addDirectory( archiveBaseDir, output, includes, excludes );
|
||||
addDirectory( archiver, archiveBaseDir, output, includes, excludesList );
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -0,0 +1,116 @@
|
|||
package org.apache.maven.plugin.assembly;
|
||||
|
||||
import org.codehaus.plexus.util.xml.Xpp3Dom;
|
||||
import org.codehaus.plexus.util.xml.Xpp3DomBuilder;
|
||||
import org.codehaus.plexus.util.xml.Xpp3DomWriter;
|
||||
import org.codehaus.plexus.util.xml.pull.XmlPullParserException;
|
||||
import org.codehaus.plexus.util.IOUtil;
|
||||
import org.codehaus.plexus.archiver.Archiver;
|
||||
import org.codehaus.plexus.archiver.ArchiverException;
|
||||
|
||||
import java.io.File;
|
||||
import java.io.FileReader;
|
||||
import java.io.IOException;
|
||||
import java.io.FileWriter;
|
||||
import java.util.Map;
|
||||
import java.util.HashMap;
|
||||
import java.util.Iterator;
|
||||
import java.util.LinkedHashMap;
|
||||
|
||||
/*
|
||||
* Copyright 2001-2005 The Apache Software Foundation.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
/**
|
||||
* Components XML file filter.
|
||||
*
|
||||
* @author <a href="mailto:brett@apache.org">Brett Porter</a>
|
||||
*/
|
||||
public class ComponentsXmlArchiverFileFilter
|
||||
{
|
||||
private Map components;
|
||||
|
||||
public static final String COMPONENTS_XML_PATH = "META-INF/plexus/components.xml";
|
||||
|
||||
public void addComponentsXml( File componentsXml )
|
||||
throws IOException, XmlPullParserException
|
||||
{
|
||||
FileReader fileReader = null;
|
||||
Xpp3Dom newDom;
|
||||
try
|
||||
{
|
||||
fileReader = new FileReader( componentsXml );
|
||||
newDom = Xpp3DomBuilder.build( fileReader );
|
||||
}
|
||||
finally
|
||||
{
|
||||
IOUtil.close( fileReader );
|
||||
}
|
||||
|
||||
if ( newDom != null )
|
||||
{
|
||||
newDom = newDom.getChild( "components" );
|
||||
}
|
||||
if ( newDom != null )
|
||||
{
|
||||
Xpp3Dom[] children = newDom.getChildren();
|
||||
for ( int i = 0; i < children.length; i++ )
|
||||
{
|
||||
Xpp3Dom component = children[i];
|
||||
|
||||
if ( components == null )
|
||||
{
|
||||
components = new LinkedHashMap();
|
||||
}
|
||||
|
||||
String role = component.getChild( "role" ).getValue();
|
||||
Xpp3Dom child = component.getChild( "role-hint" );
|
||||
String roleHint = child != null ? child.getValue() : "";
|
||||
components.put( role + roleHint, component );
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public void addToArchive( Archiver archiver )
|
||||
throws IOException, ArchiverException
|
||||
{
|
||||
if ( components != null )
|
||||
{
|
||||
File f = File.createTempFile( "maven-assembly-plugin", "tmp" );
|
||||
f.deleteOnExit();
|
||||
|
||||
FileWriter fileWriter = new FileWriter( f );
|
||||
try
|
||||
{
|
||||
Xpp3Dom dom = new Xpp3Dom( "component-set" );
|
||||
Xpp3Dom componentDom = new Xpp3Dom( "components" );
|
||||
dom.addChild( componentDom );
|
||||
|
||||
for ( Iterator i = components.values().iterator(); i.hasNext(); )
|
||||
{
|
||||
Xpp3Dom component = (Xpp3Dom) i.next();
|
||||
componentDom.addChild( component );
|
||||
}
|
||||
|
||||
Xpp3DomWriter.write( fileWriter, dom );
|
||||
}
|
||||
finally
|
||||
{
|
||||
IOUtil.close( fileWriter );
|
||||
}
|
||||
archiver.addFile( f, COMPONENTS_XML_PATH );
|
||||
}
|
||||
}
|
||||
}
|
|
@ -22,6 +22,7 @@ import org.apache.maven.plugin.assembly.archiver.DirectoryArchiver;
|
|||
import org.apache.maven.plugins.assembly.model.Assembly;
|
||||
import org.codehaus.plexus.archiver.Archiver;
|
||||
import org.codehaus.plexus.archiver.ArchiverException;
|
||||
import org.codehaus.plexus.util.xml.pull.XmlPullParserException;
|
||||
|
||||
import java.io.IOException;
|
||||
|
||||
|
@ -56,6 +57,10 @@ public class DirectoryMojo
|
|||
{
|
||||
throw new MojoExecutionException( "Error creating assembly", e );
|
||||
}
|
||||
catch ( XmlPullParserException e )
|
||||
{
|
||||
throw new MojoExecutionException( "Error creating assembly", e );
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -41,10 +41,9 @@ import org.codehaus.plexus.util.xml.Xpp3Dom;
|
|||
/**
|
||||
* Generates the Download report.
|
||||
*
|
||||
* @goal download
|
||||
*
|
||||
* @author <a href="mailto:vincent.siveton@gmail.com">Vincent Siveton</a>
|
||||
* @version $Id $
|
||||
* @goal download
|
||||
*/
|
||||
public class DownloadReport
|
||||
extends AbstractMavenReport
|
||||
|
@ -56,9 +55,7 @@ public class DownloadReport
|
|||
private String outputDirectory;
|
||||
|
||||
/**
|
||||
* @parameter expression="${component.org.codehaus.doxia.site.renderer.SiteRenderer}"
|
||||
* @required
|
||||
* @readonly
|
||||
* @component
|
||||
*/
|
||||
private SiteRenderer siteRenderer;
|
||||
|
||||
|
@ -220,13 +217,12 @@ public class DownloadReport
|
|||
throw new IllegalArgumentException(
|
||||
"The 'finalName' parameter is required for the configuration of the maven-assembly-plugin." );
|
||||
}
|
||||
String finalName = o.getChild( "finalName" ).getValue();
|
||||
assemblyMojo.finalName = finalName;
|
||||
assemblyMojo.finalName = o.getChild( "finalName" ).getValue();
|
||||
|
||||
if ( ( o.getChild( "descriptor" ) == null ) && ( o.getChild( "descriptorId" ) == null ) )
|
||||
{
|
||||
throw new IllegalArgumentException( "The 'descriptor' or the 'descriptorId' parameter is "
|
||||
+ "required for the configuration of the maven-assembly-plugin." );
|
||||
throw new IllegalArgumentException( "The 'descriptor' or the 'descriptorId' parameter is " +
|
||||
"required for the configuration of the maven-assembly-plugin." );
|
||||
}
|
||||
if ( o.getChild( "descriptor" ) != null )
|
||||
{
|
||||
|
@ -239,11 +235,10 @@ public class DownloadReport
|
|||
}
|
||||
if ( o.getChild( "descriptorId" ) != null )
|
||||
{
|
||||
String descriptorId = o.getChild( "descriptorId" ).getValue();
|
||||
assemblyMojo.descriptorId = descriptorId;
|
||||
assemblyMojo.descriptorId = o.getChild( "descriptorId" ).getValue();
|
||||
}
|
||||
|
||||
Assembly assembly = null;
|
||||
Assembly assembly;
|
||||
try
|
||||
{
|
||||
assembly = assemblyMojo.readAssembly();
|
||||
|
@ -291,9 +286,8 @@ public class DownloadReport
|
|||
|
||||
StringBuffer sb = null;
|
||||
|
||||
getLog().info(
|
||||
"The property distributionManagement.downloadUrl is not set in the pom.xml. "
|
||||
+ "Copying distribution files in a relative directory ('" + downloadDirectory + "')." );
|
||||
getLog().info( "The property distributionManagement.downloadUrl is not set in the pom.xml. " +
|
||||
"Copying distribution files in a relative directory ('" + downloadDirectory + "')." );
|
||||
|
||||
for ( Iterator it2 = distributionFileNames.iterator(); it2.hasNext(); )
|
||||
{
|
||||
|
@ -316,10 +310,8 @@ public class DownloadReport
|
|||
|
||||
if ( sb != null )
|
||||
{
|
||||
getLog().warn(
|
||||
"The " + ( distributionFileNames.size() > 1 ? "files" : "file" ) + " "
|
||||
+ sb.substring( 0, sb.length() - 2 )
|
||||
+ " did not exist. - Please run assembly:assembly before." );
|
||||
getLog().warn( "The " + ( distributionFileNames.size() > 1 ? "files" : "file" ) + " " +
|
||||
sb.substring( 0, sb.length() - 2 ) + " did not exist. - Please run assembly:assembly before." );
|
||||
distributionFileNames = null;
|
||||
}
|
||||
}
|
||||
|
@ -336,7 +328,6 @@ public class DownloadReport
|
|||
private List distributionFileNames = null;
|
||||
|
||||
/**
|
||||
*
|
||||
* @param sink
|
||||
* @param project
|
||||
* @param locale
|
||||
|
@ -362,11 +353,10 @@ public class DownloadReport
|
|||
*/
|
||||
public String getTitle()
|
||||
{
|
||||
return getBundle( locale ).getString( "report.download.title" )
|
||||
+ " "
|
||||
+ ( StringUtils.isEmpty( project.getName() ) ? project.getGroupId() + ":" + project.getArtifactId()
|
||||
: project.getName() ) + " "
|
||||
+ ( StringUtils.isEmpty( project.getVersion() ) ? "" : project.getVersion() );
|
||||
return getBundle( locale ).getString( "report.download.title" ) + " " + (
|
||||
StringUtils.isEmpty( project.getName() ) ? project.getGroupId() + ":" + project.getArtifactId()
|
||||
: project.getName() ) + " " +
|
||||
( StringUtils.isEmpty( project.getVersion() ) ? "" : project.getVersion() );
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
Loading…
Reference in New Issue