- Rewriting of jar mojo with Plexus Archiver.

- Added full features of m1 plugin


git-svn-id: https://svn.apache.org/repos/asf/maven/components/trunk@163421 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Emmanuel Venisse 2005-02-27 17:45:41 +00:00
parent 50759a44cf
commit f793423baf
3 changed files with 208 additions and 240 deletions

View File

@ -16,8 +16,13 @@
<dependencies> <dependencies>
<dependency> <dependency>
<groupId>plexus</groupId> <groupId>plexus</groupId>
<artifactId>plexus</artifactId> <artifactId>plexus-container-default</artifactId>
<version>0.17</version> <version>1.0-alpha-2-SNAPSHOT</version>
</dependency>
<dependency>
<groupId>plexus</groupId>
<artifactId>plexus-archiver</artifactId>
<version>1.0-alpha-1-SNAPSHOT</version>
</dependency> </dependency>
<dependency> <dependency>
<groupId>maven</groupId> <groupId>maven</groupId>

View File

@ -2,7 +2,7 @@ package org.apache.maven.plugin.jar;
/** /**
* *
* Copyright 2004 The Apache Software Foundation * Copyright 2004-2005 The Apache Software Foundation
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@ -17,254 +17,152 @@ package org.apache.maven.plugin.jar;
* limitations under the License. * limitations under the License.
*/ */
import org.apache.maven.artifact.Artifact;
import org.apache.maven.model.Dependency;
import org.apache.maven.plugin.AbstractPlugin; import org.apache.maven.plugin.AbstractPlugin;
import org.codehaus.plexus.util.DirectoryScanner; import org.apache.maven.plugin.PluginExecutionRequest;
import org.apache.maven.project.MavenProject;
import org.codehaus.plexus.archiver.jar.Manifest;
import org.codehaus.plexus.util.StringUtils; import org.codehaus.plexus.util.StringUtils;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.Iterator; import java.util.Iterator;
import java.util.Map; import java.util.List;
import java.util.jar.Attributes; import java.util.Properties;
import java.util.jar.JarEntry; import java.util.Set;
import java.util.jar.JarOutputStream;
import java.util.jar.Manifest;
/** /**
* Base class for tasks that build archives in JAR file format. * Base class for tasks that build archives in JAR file format.
* *
* @author <a href="evenisse@apache.org">Emmanuel Venisse</a>
* @version $Revision$ $Date$ * @version $Revision$ $Date$
*/ */
public abstract class AbstractJarMojo public abstract class AbstractJarMojo
extends AbstractPlugin extends AbstractPlugin
{ {
private byte[] buffer = new byte[4096];
/** /**
* Add artifacts from tagged dependencies to the archive. * Return a pre-configured manifest
* @param includes a map <String, File> of items to be include in the outpur * @todo Add user attributes list and user groups list
* @param project the project object model
* @param tag the property tag to look for; for example "jar.bundle"
* @param pathTag the property tag that specifies the target path; for example, jar.target.path
*/ */
public Manifest getManifest( PluginExecutionRequest request )
/* throws Exception
protected void addTaggedDependencies(Map includes, MavenProject project, String tag, String pathTag) {
addTaggedDependencies(includes, "", project, tag, pathTag);
}
*/
/**
* Add artifacts from tagged dependencies to the archive. For example, the definition:
* <code>
* <dependency>
* <artifactId>my-library</artifactId>
* <version>1.0.1</version>
* <property>
* <jar>my-library.jar
* <property>
* </dependency>
* </code>
* would result in the archive <code>my-library-1.0.1.jar</code> being included
* in the output jar as /my-library.jar. The entry name will default to the base
* name of the archive in the root: <code>/my-library-1.0.1.jar</code>
*
* @param includes a map <String, File> of items to be include in the outpur
* @param prefix to be added to the jar entry name of each item included
* @param project the project object model
* @param tag the property tag to look for; for example "jar.bundle"
* @param pathTag the property tag that specifies the target path; for example, jar.target.path
*/
/*
protected void addTaggedDependencies(Map includes, String prefix, MavenProject project, String tag, String pathTag) {
for (Iterator i = project.getArtifacts().iterator(); i.hasNext();) {
Artifact artifact = (Artifact) i.next();
Properties properties = artifact.getDependency().getProperties();
if (Boolean.valueOf(properties.getProperty(tag)).booleanValue()) {
File file = new File(artifact.getPath());
String targetPath = properties.getProperty(pathTag, file.getName());
includes.put(prefix + targetPath, file);
}
}
}
*/
/**
* Add all files in the specified directory to the archive.
*
* @param includes a map <String, File> of items to be include in the outpur
* @param baseDir the directory to add
*/
protected void addDirectory( Map includes, File baseDir ) throws IOException
{ {
addDirectory( includes, "", baseDir ); MavenProject project = (MavenProject)request.getParameter("project");
}
/** String mainClass = (String) request.getParameter( "mainClass" );
* Add all files in the specified directory to the archive.
*
* @param includes a map <String, File> of items to be include in the outpur
* @param prefix value to be added to the front of jar entry names
* @param baseDir the directory to add
*/
protected void addDirectory( Map includes, String prefix, File baseDir ) throws IOException
{
addDirectory( includes, null, null, prefix, baseDir );
}
/** boolean addClasspath = new Boolean( (String) request.getParameter( "addClasspath" ) ).booleanValue();
* Add all files in the specified directory to the archive.
*
* @param includes a map <String, File> of items to be include in the outpur
* @param includesPattern Sets the list of include patterns to use
* @param excludesPattern Sets the list of exclude patterns to use
* @param prefix value to be added to the front of jar entry names
* @param baseDir the directory to add
*/
protected void addDirectory( Map includes, String includesPattern, String excludesPattern, String prefix, File baseDir )
throws IOException
{
if ( !baseDir.exists() )
{
return;
}
DirectoryScanner scanner = new DirectoryScanner(); boolean addExtensions = new Boolean( (String) request.getParameter( "addExtensions" ) ).booleanValue();
scanner.setBasedir( baseDir );
if ( includesPattern != null )
{
scanner.setIncludes( StringUtils.split( includesPattern, "," ) );
}
if ( excludesPattern != null ) // Added basic entries
{ Manifest m = new Manifest();
scanner.setExcludes( StringUtils.split( excludesPattern, "," ) ); Manifest.Attribute buildAttr = new Manifest.Attribute( "Built-By", System.getProperty( "user.name" ) );
} m.addConfiguredAttribute( buildAttr );
scanner.scan(); Manifest.Attribute createdAttr = new Manifest.Attribute( "Created-By", "Apache Maven" );
String[] files = scanner.getIncludedFiles(); m.addConfiguredAttribute( createdAttr );
for ( int i = 0; i < files.length; i++ ) Manifest.Attribute packageAttr = new Manifest.Attribute( "Package", project.getPackage() );
{ m.addConfiguredAttribute( packageAttr );
String file = files[i]; Manifest.Attribute buildJdkAttr = new Manifest.Attribute( "Build-Jdk", System.getProperty( "java.version" ) );
file = file.replace( '\\', '/' ); // todo shouldn't the scanner return platform independent names? m.addConfiguredAttribute( buildJdkAttr );
includes.put( prefix + file, new File( baseDir, file ) );
}
}
/** if ( addClasspath )
* Create the jar file specified and include the listed files.
*
* @param jarFile the jar file to create
* @param includes a Map<String, File>of items to include; the key is the jar entry name
* @throws IOException if there is a problem writing the archive or reading the sources
*/
protected void createJar( File jarFile, Map includes ) throws IOException
{
File parentJarFile = jarFile.getParentFile();
if ( !parentJarFile.exists() )
{ {
parentJarFile.mkdirs(); StringBuffer classpath = new StringBuffer();
} List dependencies = project.getDependencies();
JarOutputStream jos = createJar( jarFile, createManifest() );
try
{
addEntries( jos, includes );
}
finally
{
jos.close();
}
}
/** for ( Iterator iter = dependencies.iterator(); iter.hasNext(); )
* Create a manifest for the jar file
*
* @return a default manifest; the Manifest-Version and Created-By attributes are initialized
*/
protected Manifest createManifest()
{
Manifest mf = new Manifest();
Attributes attrs = mf.getMainAttributes();
attrs.putValue( Attributes.Name.MANIFEST_VERSION.toString(), "1.0" );
attrs.putValue( "Created-By", "2.0 (Apache Maven)" );
return mf;
}
/**
* Create the specified jar file and return a JarOutputStream to it
*
* @param jarFile the jar file to create
* @param mf the manifest to use
* @return a JarOutputStream that can be used to write to that file
* @throws IOException if there was a problem opening the file
*/
protected JarOutputStream createJar( File jarFile, Manifest mf ) throws IOException
{
jarFile.getParentFile().mkdirs();
FileOutputStream fos = new FileOutputStream( jarFile );
try
{
return new JarOutputStream( fos, mf );
}
catch ( IOException e )
{
try
{ {
fos.close(); Dependency dependency = (Dependency) iter.next();
jarFile.delete(); Properties properties = dependency.getProperties();
} if ( Boolean.valueOf(properties.getProperty("jar.manifest.classpath")).booleanValue())
catch ( IOException e1 ) {
{ if (classpath.length() > 0 )
// ignore {
} classpath.append( " " );
throw e; }
}
}
/** // TODO replace dependency by artifact
* Add all entries in the supplied Map to the jar classpath.append( dependency.getArtifactId() + "-" + dependency.getVersion() + ".jar");
* }
* @param jos a JarOutputStream that can be used to write to the jar
* @param includes a Map<String, File> of entries to add
* @throws IOException if there is a problem writing the archive or reading the sources
*/
protected void addEntries( JarOutputStream jos, Map includes ) throws IOException
{
for ( Iterator i = includes.entrySet().iterator(); i.hasNext(); )
{
Map.Entry entry = (Map.Entry) i.next();
String name = (String) entry.getKey();
File file = (File) entry.getValue();
addEntry( jos, name, file );
}
}
/**
* Add a single entry to the jar
*
* @param jos a JarOutputStream that can be used to write to the jar
* @param name the entry name to use; must be '/' delimited
* @param source the file to add
* @throws IOException if there is a problem writing the archive or reading the sources
*/
protected void addEntry( JarOutputStream jos, String name, File source ) throws IOException
{
FileInputStream fis = new FileInputStream( source );
try
{
jos.putNextEntry( new JarEntry( name ) );
int count;
while ( ( count = fis.read( buffer ) ) > 0 )
{
jos.write( buffer, 0, count );
} }
jos.closeEntry();
Manifest.Attribute classpathAttr = new Manifest.Attribute( "Class-Path", classpath.toString() );
m.addConfiguredAttribute( classpathAttr );
} }
finally
// Added supplementary entries
Manifest.Attribute extensionNameAttr = new Manifest.Attribute( "Extension-Name", project.getArtifactId() );
m.addConfiguredAttribute( extensionNameAttr );
if ( project.getShortDescription() != null )
{ {
fis.close(); Manifest.Attribute specificationTitleAttr = new Manifest.Attribute( "Specification-Title", project.getShortDescription() );
m.addConfiguredAttribute( specificationTitleAttr );
} }
if ( project.getOrganization() != null )
{
Manifest.Attribute specificationVendor = new Manifest.Attribute( "Specification-Vendor", project.getOrganization().getName() );
m.addConfiguredAttribute( specificationVendor );
Manifest.Attribute implementationVendorAttr = new Manifest.Attribute( "Implementation-Vendor", project.getOrganization().getName() );
m.addConfiguredAttribute( implementationVendorAttr );
}
Manifest.Attribute implementationTitleAttr = new Manifest.Attribute( "Implementation-Title", project.getArtifactId() );
m.addConfiguredAttribute( implementationTitleAttr );
Manifest.Attribute implementationVersionAttr = new Manifest.Attribute( "Implementation-Version", project.getVersion() );
m.addConfiguredAttribute( implementationVersionAttr );
if ( mainClass != null && ! "".equals( mainClass ) )
{
Manifest.Attribute mainClassAttr = new Manifest.Attribute( "Main-Class", mainClass );
m.addConfiguredAttribute( mainClassAttr );
}
// Added extensions
if ( addExtensions )
{
StringBuffer extensionsList = new StringBuffer();
Set artifacts = project.getArtifacts();
for ( Iterator iter = artifacts.iterator(); iter.hasNext(); )
{
Artifact artifact = (Artifact) iter.next();
if ( "jar".equals( artifact.getType() ) )
{
if (extensionsList.length() > 0 )
{
extensionsList.append( " " );
}
extensionsList.append( artifact.getArtifactId() );
}
}
if (extensionsList.length() > 0 )
{
Manifest.Attribute extensionsListAttr = new Manifest.Attribute( "Extension-List", extensionsList.toString() );
m.addConfiguredAttribute( extensionsListAttr );
}
for ( Iterator iter = artifacts.iterator(); iter.hasNext(); )
{
Artifact artifact = (Artifact) iter.next();
if ( "jar".equals( artifact.getType() ) )
{
Manifest.Attribute archExtNameAttr = new Manifest.Attribute( artifact.getArtifactId()
+ "-Extension-Name", artifact.getArtifactId() );
m.addConfiguredAttribute( archExtNameAttr );
Manifest.Attribute archImplVersionAttr = new Manifest.Attribute( artifact.getArtifactId()
+ "-Implementation-Version", artifact.getVersion() );
m.addConfiguredAttribute( archImplVersionAttr );
Manifest.Attribute archImplUrlAttr = new Manifest.Attribute( artifact.getArtifactId()
+ "-Implementation-URL", "http://www.ibiblio.org/maven/" + artifact.toString() );
m.addConfiguredAttribute( archImplUrlAttr );
}
}
}
return m;
} }
} }

View File

@ -1,7 +1,7 @@
package org.apache.maven.plugin.jar; package org.apache.maven.plugin.jar;
/* /*
* Copyright 2001-2004 The Apache Software Foundation. * Copyright 2001-2005 The Apache Software Foundation.
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@ -20,24 +20,67 @@ import org.apache.maven.plugin.PluginExecutionRequest;
import org.apache.maven.plugin.PluginExecutionResponse; import org.apache.maven.plugin.PluginExecutionResponse;
import org.apache.maven.project.MavenProject; import org.apache.maven.project.MavenProject;
import org.codehaus.plexus.archiver.jar.JarArchiver;
import java.io.File; import java.io.File;
import java.util.LinkedHashMap;
import java.util.Map;
/** /**
* @goal jar * @goal jar
* *
* @description build a jar * @description build a jar
* *
* @prereq surefire:test
* @prereq resources:resources
*
* @parameter * @parameter
* name="jarName" * name="jarName"
* type="String" * type="String"
* required="true" * required="true"
* validator="" * validator=""
* expression="#maven.final.name" * expression="#project.build.finalName"
* description=""
* @parameter
* name="compress"
* type="String"
* required="false"
* validator=""
* expression="#maven.jar.compress"
* default="true"
* description=""
* @parameter
* name="index"
* type="String"
* required="false"
* validator=""
* expression="#maven.jar.index"
* default="false"
* description=""
* @parameter
* name="manifest"
* type="String"
* required="false"
* validator=""
* expression="#maven.jar.manifest"
* description=""
* @parameter
* name="mainClass"
* type="String"
* required="false"
* validator=""
* expression="#maven.jar.mainClass"
* description=""
* @parameter
* name="addClasspath"
* type="String"
* required="false"
* validator=""
* expression="#maven.jar.addClasspath"
* default="false"
* description=""
* @parameter
* name="addExtensions"
* type="String"
* required="false"
* validator=""
* expression="#maven.jar.addExtensions"
* default="false"
* description="" * description=""
* @parameter * @parameter
* name="outputDirectory" * name="outputDirectory"
@ -61,12 +104,15 @@ import java.util.Map;
* expression="#project" * expression="#project"
* description="current MavenProject instance" * description="current MavenProject instance"
* *
* @author <a href="michal@codehaus">Michal Maczka</a> * @author <a href="evenisse@apache.org">Emmanuel Venisse</a>
* @version $Id$ * @version $Id$
*/ */
public class JarMojo public class JarMojo
extends AbstractJarMojo extends AbstractJarMojo
{ {
/**
* @todo Add license files in META-INF directory.
*/
public void execute( PluginExecutionRequest request, PluginExecutionResponse response ) public void execute( PluginExecutionRequest request, PluginExecutionResponse response )
throws Exception throws Exception
{ {
@ -74,12 +120,20 @@ public class JarMojo
// //
// ---------------------------------------------------------------------- // ----------------------------------------------------------------------
MavenProject project = (MavenProject)request.getParameter("project");
String manifest = (String) request.getParameter( "manifest" );
File basedir = new File( (String) request.getParameter( "basedir" ) ); File basedir = new File( (String) request.getParameter( "basedir" ) );
String outputDirectory = (String) request.getParameter( "outputDirectory" ); String outputDirectory = (String) request.getParameter( "outputDirectory" );
String jarName = (String) request.getParameter( "jarName" ); String jarName = (String) request.getParameter( "jarName" );
boolean compress = new Boolean( (String) request.getParameter( "compress" ) ).booleanValue();
boolean index = new Boolean( (String) request.getParameter( "index" ) ).booleanValue();
// ---------------------------------------------------------------------- // ----------------------------------------------------------------------
// //
// ---------------------------------------------------------------------- // ----------------------------------------------------------------------
@ -87,13 +141,24 @@ public class JarMojo
File jarFile = new File( basedir, jarName + ".jar" ); File jarFile = new File( basedir, jarName + ".jar" );
Map includes = new LinkedHashMap(); JarArchiver archiver = new JarArchiver();
archiver.addDirectory( new File( outputDirectory ), new String[] { "**/**" }, new String[] { "**/package.html" } );
archiver.addFile( project.getFile(), "META-INF/maven/pom.xml" );
addDirectory(includes, "**/**", "**/package.html", "", new File( outputDirectory ) ); if (manifest != null && ! "".equals( manifest ) )
{
File manifestFile = new File( manifest );
archiver.setManifest( manifestFile );
}
MavenProject project = (MavenProject)request.getParameter("project"); // Configure the jar
includes.put("META-INF/maven/pom.xml", project.getFile()); archiver.addConfiguredManifest( getManifest( request ) );
createJar( jarFile, includes ); archiver.setCompress( compress );
archiver.setIndex( index );
archiver.setDestFile( jarFile );
// create archive
archiver.createArchive();
} }
} }