o using mojo executions as the placeholders in the lifecycle instead of string representations

git-svn-id: https://svn.apache.org/repos/asf/maven/components/branches/MNG-2766@777120 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Jason van Zyl 2009-05-21 14:00:34 +00:00
parent a7cbcb7b39
commit 9aae6eaa67
4 changed files with 96 additions and 37 deletions

View File

@ -227,7 +227,7 @@ public class DefaultLifecycleExecutor
{
MavenProject project = session.getCurrentProject();
List<String> phasesWithMojosToExecute = new ArrayList<String>();
List<MojoExecution> phasesWithMojosToExecute = new ArrayList<MojoExecution>();
List<MojoExecution> lifecyclePlan = new ArrayList<MojoExecution>();
@ -238,7 +238,9 @@ public class DefaultLifecycleExecutor
{
MojoDescriptor mojoDescriptor = getMojoDescriptor( task, session );
MojoExecution mojoExecution = getMojoExecution( project, mojoDescriptor );
MojoExecution mojoExecution = new MojoExecution( mojoDescriptor );
populateMojoExecutionConfiguration( project, mojoExecution );
lifecyclePlan.add( mojoExecution );
}
@ -265,7 +267,7 @@ public class DefaultLifecycleExecutor
//
// Create an ordered Map of the phases in the lifecycle to a list of mojos to execute.
Map<String, List<String>> phaseToMojoMapping = new LinkedHashMap<String, List<String>>();
Map<String, List<MojoExecution>> phaseToMojoMapping = new LinkedHashMap<String, List<MojoExecution>>();
// 4.
@ -273,11 +275,12 @@ public class DefaultLifecycleExecutor
for ( String phase : lifecycle.getPhases() )
{
List<String> mojos = new ArrayList<String>();
List<MojoExecution> mojos = new ArrayList<MojoExecution>();
//TODO: remove hard coding
if ( phase.equals( "clean" ) )
{
mojos.add( "org.apache.maven.plugins:maven-clean-plugin:clean" );
mojos.add( new MojoExecution( "org.apache.maven.plugins", "maven-clean-plugin", "2.3", "clean", null ) );
}
// This is just just laying out the initial structure of the mojos to run in each phase of the
@ -310,10 +313,11 @@ public class DefaultLifecycleExecutor
// So for the lifecycle mapping we need a map with the phases as keys so we can easily check
// if this phase belongs to the given lifecycle. this shows the system is messed up. this
// shouldn't happen.
phaseToMojoMapping.put( execution.getPhase(), new ArrayList<String>() );
phaseToMojoMapping.put( execution.getPhase(), new ArrayList<MojoExecution>() );
}
phaseToMojoMapping.get( execution.getPhase() ).add( s );
MojoExecution mojoExecution = new MojoExecution( plugin.getGroupId(), plugin.getArtifactId(), plugin.getVersion(), goal, execution.getId() );
phaseToMojoMapping.get( execution.getPhase() ).add( mojoExecution );
}
}
// if not then i need to grab the mojo descriptor and look at the phase that is specified
@ -326,7 +330,8 @@ public class DefaultLifecycleExecutor
if ( mojoDescriptor.getPhase() != null && phaseToMojoMapping.get( mojoDescriptor.getPhase() ) != null )
{
phaseToMojoMapping.get( mojoDescriptor.getPhase() ).add( s );
MojoExecution mojoExecution = new MojoExecution( plugin.getGroupId(), plugin.getArtifactId(), plugin.getVersion(), goal, execution.getId() );
phaseToMojoMapping.get( mojoDescriptor.getPhase() ).add( mojoExecution );
}
}
}
@ -338,7 +343,6 @@ public class DefaultLifecycleExecutor
// We are only interested in the phases that correspond to the lifecycle we are trying to run. If we are running the "clean"
// lifecycle we are not interested in goals -- like "generate-sources -- that belong to the default lifecycle.
//
for ( String phase : phaseToMojoMapping.keySet() )
{
phasesWithMojosToExecute.addAll( phaseToMojoMapping.get( phase ) );
@ -354,17 +358,19 @@ public class DefaultLifecycleExecutor
// 7. Now we create the correct configuration for the mojo to execute.
//TODO: this needs to go to the model builder.
for ( String mojo : phasesWithMojosToExecute )
//TODO: just used a hollowed out MojoExecution
for ( MojoExecution mojoExecution : phasesWithMojosToExecute )
{
// These are bits that look like this:
//
// org.apache.maven.plugins:maven-remote-resources-plugin:1.0:process
//
MojoDescriptor mojoDescriptor = pluginManager.getMojoDescriptor(
mojoExecution.getGroupId(), mojoExecution.getArtifactId(), mojoExecution.getVersion(), mojoExecution.getGoal(), session.getLocalRepository(), project.getRemoteArtifactRepositories() );
MojoDescriptor mojoDescriptor = getMojoDescriptor( mojo, session );
mojoExecution.setMojoDescriptor( mojoDescriptor );
MojoExecution mojoExecution = getMojoExecution( project, mojoDescriptor );
populateMojoExecutionConfiguration( project, mojoExecution );
lifecyclePlan.add( mojoExecution );
}
@ -380,13 +386,13 @@ public class DefaultLifecycleExecutor
return sb.toString();
}
private MojoExecution getMojoExecution( MavenProject project, MojoDescriptor mojoDescriptor )
//this will get the wrong configuration because it's only matching the goal not the execution id
private void populateMojoExecutionConfiguration( MavenProject project, MojoExecution mojoExecution )
{
MojoExecution mojoExecution = new MojoExecution( mojoDescriptor );
String g = mojoExecution.getGroupId();
String g = mojoDescriptor.getPluginDescriptor().getGroupId();
String a = mojoDescriptor.getPluginDescriptor().getArtifactId();
String a = mojoExecution.getArtifactId();
Plugin p = project.getPlugin( g + ":" + a );
@ -394,18 +400,16 @@ public class DefaultLifecycleExecutor
{
for ( String goal : e.getGoals() )
{
if ( mojoDescriptor.getGoal().equals( goal ) )
if ( mojoExecution.getGoal().equals( goal ) )
{
Xpp3Dom executionConfiguration = (Xpp3Dom) e.getConfiguration();
Xpp3Dom mojoConfiguration = extractMojoConfiguration( executionConfiguration, mojoDescriptor );
Xpp3Dom mojoConfiguration = extractMojoConfiguration( executionConfiguration, mojoExecution.getMojoDescriptor() );
mojoExecution.setConfiguration( mojoConfiguration );
}
}
}
return mojoExecution;
}

View File

@ -22,17 +22,19 @@ package org.apache.maven.plugin;
import org.apache.maven.plugin.descriptor.MojoDescriptor;
import org.codehaus.plexus.util.xml.Xpp3Dom;
/**
* Describes a single mojo invocation.
*
* @author <a href="mailto:brett@apache.org">Brett Porter</a>
* @version $Id$
*/
public class MojoExecution
{
private final String executionId;
private String groupId;
private final MojoDescriptor mojoDescriptor;
private String artifactId;
private String version;
private String goal;
private String executionId;
private MojoDescriptor mojoDescriptor;
private Xpp3Dom configuration;
@ -42,6 +44,15 @@ public class MojoExecution
*/
private String lifecyclePhase;
public MojoExecution( String groupId, String artifactId, String version, String goal, String executionId )
{
this.groupId = groupId;
this.artifactId = artifactId;
this.version = version;
this.goal = goal;
this.executionId = executionId;
}
public MojoExecution( MojoDescriptor mojoDescriptor )
{
this.mojoDescriptor = mojoDescriptor;
@ -115,4 +126,48 @@ public class MojoExecution
return buffer.toString();
}
public String getGroupId()
{
if ( mojoDescriptor != null )
{
return mojoDescriptor.getPluginDescriptor().getGroupId();
}
return groupId;
}
public String getArtifactId()
{
if ( mojoDescriptor != null )
{
return mojoDescriptor.getPluginDescriptor().getArtifactId();
}
return artifactId;
}
public String getVersion()
{
if ( mojoDescriptor != null )
{
return mojoDescriptor.getPluginDescriptor().getVersion();
}
return version;
}
public String getGoal()
{
if ( mojoDescriptor != null )
{
return mojoDescriptor.getGoal();
}
return goal;
}
public void setMojoDescriptor( MojoDescriptor mojoDescriptor )
{
this.mojoDescriptor = mojoDescriptor;
}
}

View File

@ -87,7 +87,7 @@ public class LifecycleExecutorTest
assertNotNull( mojoExecution );
assertEquals( "org.apache.maven.plugins", mojoExecution.getMojoDescriptor().getPluginDescriptor().getGroupId() );
assertEquals( "maven-clean-plugin", mojoExecution.getMojoDescriptor().getPluginDescriptor().getArtifactId() );
assertEquals( "2.2", mojoExecution.getMojoDescriptor().getPluginDescriptor().getVersion() );
assertEquals( "2.3", mojoExecution.getMojoDescriptor().getPluginDescriptor().getVersion() );
}
// We need to take in multiple lifecycles

View File

@ -117,7 +117,7 @@ under the License.
</plugin>
<plugin>
<artifactId>maven-plugin-plugin</artifactId>
<version>2.4.2</version>
<version>2.5</version>
</plugin>
<plugin>
<artifactId>maven-rar-plugin</artifactId>