utilise the container for populating all mojo configuration, including expressions

git-svn-id: https://svn.apache.org/repos/asf/maven/components/trunk@163947 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Brett Leslie Porter 2005-04-15 04:52:31 +00:00
parent e282435cb9
commit b2e4433615
12 changed files with 296 additions and 159 deletions

View File

@ -62,7 +62,7 @@
<dependency>
<groupId>plexus</groupId>
<artifactId>plexus-container-default</artifactId>
<version>1.0-alpha-2</version>
<version>1.0-alpha-3-SNAPSHOT</version>
</dependency>
<dependency>
<groupId>org.apache.maven.wagon</groupId>

View File

@ -42,12 +42,13 @@ import org.codehaus.plexus.PlexusConstants;
import org.codehaus.plexus.PlexusContainer;
import org.codehaus.plexus.component.configurator.ComponentConfigurationException;
import org.codehaus.plexus.component.configurator.ComponentConfigurator;
import org.codehaus.plexus.component.configurator.expression.ExpressionEvaluationException;
import org.codehaus.plexus.component.configurator.expression.ExpressionEvaluator;
import org.codehaus.plexus.component.discovery.ComponentDiscoveryEvent;
import org.codehaus.plexus.component.discovery.ComponentDiscoveryListener;
import org.codehaus.plexus.component.repository.ComponentSetDescriptor;
import org.codehaus.plexus.component.repository.exception.ComponentLookupException;
import org.codehaus.plexus.configuration.PlexusConfiguration;
import org.codehaus.plexus.configuration.PlexusConfigurationException;
import org.codehaus.plexus.configuration.xml.XmlPlexusConfiguration;
import org.codehaus.plexus.context.Context;
import org.codehaus.plexus.context.ContextException;
@ -392,20 +393,32 @@ public class DefaultPluginManager
configuration = new XmlPlexusConfiguration( dom );
}
configuration = mergeConfiguration( configuration, mojoDescriptor.getConfiguration() );
PluginParameterExpressionEvaluator expressionEvaluator = new PluginParameterExpressionEvaluator( session );
try
{
if ( newMojoTechnique )
{
Map map = getPluginConfigurationFromExpressions( mojoDescriptor, configuration, session );
Map map = getPluginConfigurationFromExpressions( mojoDescriptor, configuration, session,
expressionEvaluator );
populatePluginFields( plugin, configuration, map );
populatePluginFields( plugin, configuration, map, expressionEvaluator );
}
else
{
getLogger().warn( "WARNING: The mojo " + mojoDescriptor.getId() + " is using the OLD API" );
Map map = getPluginConfigurationFromExpressions( mojoDescriptor, configuration, session );
Map map = getPluginConfigurationFromExpressions( mojoDescriptor, configuration, session,
expressionEvaluator );
request = createPluginRequest( configuration, map );
}
}
catch ( ExpressionEvaluationException e )
{
throw new PluginExecutionException( "Unable to configure plugin", e );
}
// !! This is ripe for refactoring to an aspect.
// Event monitoring.
@ -436,7 +449,8 @@ public class DefaultPluginManager
}
catch ( PluginConfigurationException e )
{
throw new PluginExecutionException( "Error configuring plugin for execution.", e );
String msg = "Error configuring plugin for execution of .";
throw new PluginExecutionException( msg, e );
}
catch ( ComponentLookupException e )
{
@ -446,8 +460,6 @@ public class DefaultPluginManager
{
try
{
releaseComponents( mojoDescriptor, request );
container.release( plugin );
}
catch ( Exception e )
@ -458,6 +470,48 @@ public class DefaultPluginManager
}
}
private PlexusConfiguration mergeConfiguration( PlexusConfiguration dominant, PlexusConfiguration configuration )
{
// TODO: share with mergeXpp3Dom
PlexusConfiguration[] children = configuration.getChildren();
for ( int i = 0; i < children.length; i++ )
{
PlexusConfiguration child = children[i];
PlexusConfiguration childDom = (XmlPlexusConfiguration) dominant.getChild( child.getName(), false );
if ( childDom != null )
{
mergeConfiguration( childDom, child );
}
else
{
dominant.addChild( copyConfiguration( child ) );
}
}
return dominant;
}
public static PlexusConfiguration copyConfiguration( PlexusConfiguration src )
{
// TODO: shouldn't be necessary
XmlPlexusConfiguration dom = new XmlPlexusConfiguration( src.getName() );
dom.setValue( src.getValue( null ) );
String[] attributeNames = src.getAttributeNames();
for ( int i = 0; i < attributeNames.length; i++ )
{
String attributeName = attributeNames[i];
dom.setAttribute( attributeName, src.getAttribute( attributeName, null ) );
}
PlexusConfiguration[] children = src.getChildren();
for ( int i = 0; i < children.length; i++ )
{
dom.addChild( copyConfiguration( children[i] ) );
}
return dom;
}
/**
* @deprecated
*/
@ -482,61 +536,36 @@ public class DefaultPluginManager
return newMojoTechnique;
}
// TODO: don't throw Exception
private void releaseComponents( MojoDescriptor goal, PluginExecutionRequest request )
throws Exception
{
if ( request != null && request.getParameters() != null )
{
for ( Iterator iterator = goal.getParameters().iterator(); iterator.hasNext(); )
{
Parameter parameter = (Parameter) iterator.next();
String key = parameter.getName();
String expression = parameter.getExpression();
if ( expression != null && expression.startsWith( "#component" ) )
{
Object component = request.getParameter( key );
container.release( component );
}
}
}
}
// ----------------------------------------------------------------------
// Mojo Parameter Handling
// ----------------------------------------------------------------------
/**
* @param configuration
* @param map
* @return
* @deprecated
*/
private static PluginExecutionRequest createPluginRequest( PlexusConfiguration configuration, Map map )
throws PluginConfigurationException
{
try
{
Map parameters = new HashMap();
PlexusConfiguration[] children = configuration.getChildren();
for ( int i = 0; i < children.length; i++ )
{
PlexusConfiguration child = children[i];
parameters.put( child.getName(), child.getValue() );
parameters.put( child.getName(), child.getValue( null ) );
}
map = CollectionUtils.mergeMaps( map, parameters );
}
catch ( PlexusConfigurationException e )
{
throw new PluginConfigurationException( "Unable to construct map from plugin configuration", e );
}
return new PluginExecutionRequest( map );
}
private void populatePluginFields( Plugin plugin, PlexusConfiguration configuration, Map map )
private void populatePluginFields( Plugin plugin, PlexusConfiguration configuration, Map map,
ExpressionEvaluator expressionEvaluator )
throws PluginConfigurationException
{
try
{
configurator.configureComponent( plugin, configuration );
configurator.configureComponent( plugin, configuration, expressionEvaluator );
}
catch ( ComponentConfigurationException e )
{
@ -544,7 +573,7 @@ public class DefaultPluginManager
}
// Configuration does not store objects, so the non-String fields are configured here
// TODO: we don't have converters, so "primitives" that -are- strings are not configured properly (eg String -> File from an expression)
// TODO: remove - this is for plugins built with alpha-1
for ( Iterator i = map.keySet().iterator(); i.hasNext(); )
{
String key = (String) i.next();
@ -602,9 +631,12 @@ public class DefaultPluginManager
}
}
/**
* @deprecated
*/
private Map getPluginConfigurationFromExpressions( MojoDescriptor goal, PlexusConfiguration configuration,
MavenSession session )
throws PluginConfigurationException
MavenSession session, ExpressionEvaluator expressionEvaluator )
throws ExpressionEvaluationException, PluginConfigurationException
{
List parameters = goal.getParameters();
@ -616,11 +648,17 @@ public class DefaultPluginManager
String key = parameter.getName();
String expression;
if ( configuration.getChild( key, false ) == null )
{
String expression = parameter.getExpression();
expression = parameter.getExpression();
}
else
{
expression = configuration.getChild( key, false ).getValue( null );
}
Object value = PluginParameterExpressionEvaluator.evaluate( expression, session );
Object value = expressionEvaluator.evaluate( expression );
getLogger().debug( "Evaluated mojo parameter expression: \'" + expression + "\' to: " + value );
@ -628,7 +666,7 @@ public class DefaultPluginManager
{
if ( parameter.getDefaultValue() != null )
{
value = PluginParameterExpressionEvaluator.evaluate( parameter.getDefaultValue(), session );
value = expressionEvaluator.evaluate( parameter.getDefaultValue() );
}
}
@ -648,9 +686,7 @@ public class DefaultPluginManager
String type = parameter.getType();
// TODO: Not sure how we might find files that are nested in other objects... perhaps
// we add a "needs translation" to the mojo so such types can be translated (implementing some interface) and
// address their own file objects
// TODO: remove - done via plexus configuration, but need to inject the base directory into it
if ( type != null && ( type.equals( "File" ) || type.equals( "java.io.File" ) ) )
{
value = pathTranslator.alignToBaseDirectory( (String) value,
@ -659,7 +695,6 @@ public class DefaultPluginManager
map.put( key, value );
}
}
return map;
}

View File

@ -1,7 +1,7 @@
package org.apache.maven.plugin;
/* ====================================================================
* Copyright 2001-2004 The Apache Software Foundation.
/*
* 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.
@ -14,22 +14,31 @@ package org.apache.maven.plugin;
* 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.
* ====================================================================
*/
import org.apache.maven.execution.MavenSession;
import org.apache.maven.project.MavenProject;
import org.apache.maven.util.introspection.ReflectionValueExtractor;
import org.codehaus.plexus.component.configurator.expression.ExpressionEvaluationException;
import org.codehaus.plexus.component.configurator.expression.ExpressionEvaluator;
import org.codehaus.plexus.component.repository.exception.ComponentLookupException;
/**
* @author <a href="mailto:jason@maven.org">Jason van Zyl</a>
* @version $Id$
* @todo belong in MavenSession, so it only gets created once?
*/
public class PluginParameterExpressionEvaluator
implements ExpressionEvaluator
{
public static Object evaluate( String expression, MavenSession context )
throws PluginConfigurationException
private final MavenSession context;
public PluginParameterExpressionEvaluator( MavenSession context )
{
this.context = context;
}
public Object evaluate( String expression )
throws ExpressionEvaluationException
{
Object value = null;
@ -51,7 +60,7 @@ public class PluginParameterExpressionEvaluator
}
catch ( ComponentLookupException e )
{
throw new PluginConfigurationException( "Cannot lookup component: " + role + ".", e );
throw new ExpressionEvaluationException( "Cannot lookup component: " + role + ".", e );
}
}
else if ( expression.equals( "#localRepository" ) )
@ -61,7 +70,7 @@ public class PluginParameterExpressionEvaluator
else if ( expression.equals( "#maven.final.name" ) )
{
// TODO: remove this alias
value = context.getProject().getModel().getBuild().getFinalName();
value = context.getProject().getBuild().getFinalName();
}
else if ( expression.equals( "#project" ) )
{
@ -75,17 +84,19 @@ public class PluginParameterExpressionEvaluator
if ( pathSeparator > 0 )
{
value = getValue( expression.substring( 1, pathSeparator ), context.getProject() ) +
expression.substring( pathSeparator );
String pathExpression = expression.substring( 1, pathSeparator );
value = ReflectionValueExtractor.evaluate( pathExpression, context.getProject() );
value = value + expression.substring( pathSeparator );
}
else
{
value = getValue( expression.substring( 1 ), context.getProject() );
value = ReflectionValueExtractor.evaluate( expression.substring( 1 ), context.getProject() );
}
}
catch ( Exception e )
{
throw new PluginConfigurationException( "Error evaluating plugin parameter expression: " + expression,
// TODO: don't catch exception
throw new ExpressionEvaluationException( "Error evaluating plugin parameter expression: " + expression,
e );
}
}
@ -128,12 +139,12 @@ public class PluginParameterExpressionEvaluator
if ( sharpSeparator > 0 )
{
val = val.substring( 0, sharpSeparator ) + evaluate( val.substring( sharpSeparator ), context );
val = val.substring( 0, sharpSeparator ) + evaluate( val.substring( sharpSeparator ) );
value = val;
}
else if ( sharpSeparator > 0 )
{
value = evaluate( val.substring( sharpSeparator ), context );
value = evaluate( val.substring( sharpSeparator ) );
}
}
@ -154,10 +165,5 @@ public class PluginParameterExpressionEvaluator
return value;
}
private static Object getValue( String expression, MavenProject project )
throws Exception
{
return ReflectionValueExtractor.evaluate( expression, project );
}
}

View File

@ -232,6 +232,12 @@
<!-- END SNIPPET: lifecycle -->
</configuration>
</component>
<component>
<role>org.codehaus.plexus.component.configurator.expression.ExpressionEvaluator</role>
<implementation>org.apache.maven.</implementation>
</component>
<!-- ********************* FIXME *******************************************
| I realize this is duplicated but allows the project builder to work by itself
-->

View File

@ -11,6 +11,7 @@ import org.apache.maven.monitor.logging.DefaultLog;
import org.apache.maven.project.MavenProject;
import org.apache.maven.settings.MavenSettings;
import org.codehaus.plexus.PlexusContainer;
import org.codehaus.plexus.component.configurator.expression.ExpressionEvaluator;
import java.io.File;
import java.util.Collections;
@ -25,7 +26,8 @@ public class PluginParameterExpressionEvaluatorTest
{
private MavenProject project;
protected void setUp() throws Exception
protected void setUp()
throws Exception
{
super.setUp();
@ -34,7 +36,8 @@ public class PluginParameterExpressionEvaluatorTest
project = getProject( f );
}
public void testValueExtractionWithAPomValueContainingAPath() throws Exception
public void testValueExtractionWithAPomValueContainingAPath()
throws Exception
{
String expected = getTestFile( "target/test-classes/target/classes" ).getCanonicalPath();
@ -59,7 +62,8 @@ public class PluginParameterExpressionEvaluatorTest
new DefaultEventDispatcher(), new DefaultLog( container.getLogger() ),
Collections.EMPTY_LIST );
Object value = PluginParameterExpressionEvaluator.evaluate( "#project.build.directory/classes", session );
ExpressionEvaluator expressionEvaluator = new PluginParameterExpressionEvaluator( session );
Object value = expressionEvaluator.evaluate( "#project.build.directory/classes" );
String actual = new File( value.toString() ).getCanonicalPath();
@ -69,7 +73,8 @@ public class PluginParameterExpressionEvaluatorTest
assertEquals( expected, actual );
}
public void testParameterThatIsAComponent() throws Exception
public void testParameterThatIsAComponent()
throws Exception
{
String role = "#component.org.apache.maven.project.MavenProjectBuilder";
@ -85,12 +90,14 @@ public class PluginParameterExpressionEvaluatorTest
new DefaultEventDispatcher(), new DefaultLog( container.getLogger() ),
Collections.EMPTY_LIST );
Object value = PluginParameterExpressionEvaluator.evaluate( role, session );
ExpressionEvaluator expressionEvaluator = new PluginParameterExpressionEvaluator( session );
Object value = expressionEvaluator.evaluate( role );
assertNotNull( value );
}
public void testLocalRepositoryExtraction() throws Exception
public void testLocalRepositoryExtraction()
throws Exception
{
ArtifactRepositoryLayout repoLayout = (ArtifactRepositoryLayout) lookup( ArtifactRepositoryLayout.ROLE,
"legacy" );
@ -104,7 +111,8 @@ public class PluginParameterExpressionEvaluatorTest
new DefaultEventDispatcher(), new DefaultLog( container.getLogger() ),
Collections.EMPTY_LIST );
Object value = PluginParameterExpressionEvaluator.evaluate( "#localRepository", session );
ExpressionEvaluator expressionEvaluator = new PluginParameterExpressionEvaluator( session );
Object value = expressionEvaluator.evaluate( "#localRepository" );
assertEquals( "local", ( (ArtifactRepository) value ).getId() );
}

View File

@ -17,6 +17,7 @@ package org.apache.maven.plugin.descriptor;
*/
import org.codehaus.plexus.component.repository.ComponentRequirement;
import org.codehaus.plexus.configuration.PlexusConfiguration;
import java.util.ArrayList;
import java.util.HashMap;
@ -68,6 +69,8 @@ public class MojoDescriptor
private String language = DEFAULT_LANGUAGE;
private PlexusConfiguration configuration;
// ----------------------------------------------------------------------
//
// ----------------------------------------------------------------------
@ -230,4 +233,14 @@ public class MojoDescriptor
{
getRequirements().add( cr );
}
public void setConfiguration( PlexusConfiguration configuration )
{
this.configuration = configuration;
}
public PlexusConfiguration getConfiguration()
{
return configuration;
}
}

View File

@ -147,8 +147,10 @@ public class PluginDescriptorBuilder
parameter.setDescription( d.getChild( "description" ).getValue() );
// TODO: remove
parameter.setExpression( d.getChild( "expression" ).getValue() );
// TODO: remove
parameter.setDefaultValue( d.getChild( "default" ).getValue() );
parameters.add( parameter );
@ -158,6 +160,12 @@ public class PluginDescriptorBuilder
// TODO: this should not need to be handed off...
// ----------------------------------------------------------------------
// Configuration
// ----------------------------------------------------------------------
mojo.setConfiguration( c.getChild( "configuration" ) );
// ----------------------------------------------------------------------
// Requirements
// ----------------------------------------------------------------------

View File

@ -27,8 +27,10 @@ import java.io.File;
import java.io.FileWriter;
import java.util.ArrayList;
import java.util.Collection;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.Set;
/**
@ -162,6 +164,7 @@ public class PluginDescriptorGenerator
w.startElement( "parameters" );
Collection requirements = new ArrayList();
Map configuration = new HashMap( parameters.size() );
for ( int j = 0; j < parameters.size(); j++ )
{
Parameter parameter = (Parameter) parameters.get( j );
@ -174,6 +177,7 @@ public class PluginDescriptorGenerator
element( w, "validator", parameter.getValidator() );
String value = null;
if ( parameter.getExpression().startsWith( "#component" ) )
{
requirements.add( parameter );
@ -182,18 +186,54 @@ public class PluginDescriptorGenerator
{
element( w, "required", Boolean.toString( parameter.isRequired() ) );
element( w, "expression", parameter.getExpression() );
value = parameter.getExpression();
}
element( w, "description", parameter.getDescription() );
element( w, "default", parameter.getDefaultValue() );
if ( value == null || value.length() == 0 )
{
value = parameter.getDefaultValue();
}
if ( value != null && value.length() > 0 )
{
configuration.put( parameter, value );
}
w.endElement();
}
w.endElement();
// ----------------------------------------------------------------------
// Coinfiguration
// ----------------------------------------------------------------------
if ( !configuration.isEmpty() )
{
w.startElement( "configuration" );
for ( Iterator i = configuration.keySet().iterator(); i.hasNext(); )
{
Parameter parameter = (Parameter) i.next();
w.startElement( parameter.getName() );
String type = convertType( parameter.getType() );
if ( type != null )
{
w.addAttribute( "implementation", type );
}
w.writeText( (String) configuration.get( parameter ) );
w.endElement();
}
w.endElement();
}
// ----------------------------------------------------------------------
// Requirements
// ----------------------------------------------------------------------
@ -225,6 +265,35 @@ public class PluginDescriptorGenerator
w.endElement();
}
/**
* @param type
* @return
* @deprecated - should force proper class specification
*/
private static String convertType( String type )
{
if ( "String".equals( type ) )
{
return "java.lang.String";
}
else if ( "File".equals( type ) )
{
return "java.io.File";
}
else if ( "List".equals( type ) )
{
return "java.util.List";
}
else if ( "".equals( type ) )
{
return null;
}
else
{
return type;
}
}
public void element( XMLWriter w, String name, String value )
{
w.startElement( name );

View File

@ -106,8 +106,6 @@ public class PluginDescriptorGeneratorTest
private void checkParameter( Parameter parameter )
{
assertEquals( "value", parameter.getDefaultValue() );
assertEquals( "#project.build.directory", parameter.getExpression() );
assertEquals( "dir", parameter.getName() );
assertEquals( "String", parameter.getType() );
assertTrue( parameter.isRequired() );

View File

@ -46,7 +46,7 @@ import java.io.File;
* type="String"
* required="false"
* validator=""
* expression="#maven.ejb.generateclient"
* expression=""
* default="false"
* description=""
* @parameter name="outputDirectory"

View File

@ -53,19 +53,19 @@ import java.util.StringTokenizer;
* expression="#project.build.testOutputDirectory"
* description=""
* @parameter name="includes"
* type="String"
* type="java.util.List"
* required="false"
* validator=""
* description=""
* expression=""
* @parameter name="excludes"
* type="String"
* type="java.util.List"
* required="false"
* validator=""
* description=""
* expression=""
* @parameter name="classpathElements"
* type="String[]"
* type="java.util.List"
* required="true"
* validator=""
* expression="#project.testClasspathElements"
@ -82,7 +82,12 @@ import java.util.StringTokenizer;
* validator=""
* expression="#test"
* description="Specify this parameter if you want to use the test regex notation to select tests to run."
* @parameter name="localRepository" type="ArtifactRepository" required="true" validator="" expression="#localRepository" description=""
* @parameter name="localRepository"
* type="org.apache.maven.artifact.repository.ArtifactRepository"
* required="true"
* validator=""
* expression="#localRepository"
* description=""
* @todo make version of junit and surefire configurable
* @todo make report to be produced configurable
*/

View File

@ -54,21 +54,20 @@ import java.util.Set;
* type="String"
* required="true"
* validator=""
* expression="#maven.war.src"
* default="#basedir/src/main/webapp"
* expression="#basedir/src/main/webapp"
* description=""
* @parameter name="warSourceIncludes"
* type="String"
* required="false"
* validator=""
* expression="#maven.war.src.includes"
* expression=""
* default="**"
* description=""
* @parameter name="warSourceExcludes"
* type="String"
* required="false"
* validator=""
* expression="#maven.war.src.excludes"
* expression=""
* description=""
* @parameter name="webXml"
* type="String"
@ -80,14 +79,13 @@ import java.util.Set;
* type="String"
* required="true"
* validator=""
* expression="#maven.war.webapp.dir"
* default="#project.build.directory/#project.build.finalName"
* expression="#project.build.directory/#project.build.finalName"
* description=""
* @parameter name="mode"
* type="String"
* required="true"
* validator=""
* expression="#maven.war.mode"
* expression=""
* default="war"
* description=""
* @parameter name="classesDirectory"
@ -100,13 +98,6 @@ import java.util.Set;
* type="String"
* required="true"
* validator=""
* expression="#maven.war.build.dir"
* default="#project.build.directory"
* description=""
* @parameter name="basedir"
* type="String"
* required="true"
* validator=""
* expression="#project.build.directory"
* description=""
* @parameter name="project"
@ -129,8 +120,6 @@ public class WarMojo
private MavenProject project;
private String basedir;
/**
* @todo File
*/